The apps SQLite DB ($docker_dir/$db_file) is owned by the manager user, so read/write it AS the manager via runInstallOp instead of sudo (root). 48 call sites across 28 scripts. In rooted this drops root->manager (correct owner); in rootless it's the manager too (using runFileOp/dockerinstall here was the 'unable to open database' bug). The broken 'command -v sudo sqlite3' check lines are left untouched (separate pre-existing issue). Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com> Signed-off-by: librelad <librelad@digitalangels.vip>
33 lines
1.0 KiB
Bash
33 lines
1.0 KiB
Bash
#!/bin/bash
|
|
|
|
# Enqueue a backup for every installed app that has backups enabled. Invoked
|
|
# once daily by the backup scheduler crontab entry. Each app is handed to
|
|
# backupAppSchedule, which queues a task for the processor (WebUI installs) or
|
|
# runs the backup inline (terminal-only installs).
|
|
backupScheduleEnabledApps()
|
|
{
|
|
isHeader "Scheduling backups for enabled applications"
|
|
|
|
if [ ! -f "$docker_dir/$db_file" ]; then
|
|
isError "Database not found: $docker_dir/$db_file"
|
|
return 1
|
|
fi
|
|
|
|
local app_names=()
|
|
while IFS= read -r name; do
|
|
[[ -z "$name" ]] && continue
|
|
app_names+=("$name")
|
|
done < <(runInstallOp sqlite3 "$docker_dir/$db_file" "SELECT name FROM apps WHERE status = 1;")
|
|
|
|
local queued=0
|
|
for name in "${app_names[@]}"; do
|
|
local backup_flag="CFG_${name^^}_BACKUP"
|
|
if [[ "${!backup_flag}" == "true" ]]; then
|
|
backupAppSchedule "$name"
|
|
((queued++))
|
|
fi
|
|
done
|
|
|
|
isSuccessful "Backup scheduling complete — $queued app(s) queued"
|
|
}
|