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>
28 lines
687 B
Bash
28 lines
687 B
Bash
#!/bin/bash
|
|
|
|
backupAllApps()
|
|
{
|
|
isHeader "Backing up all installed 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
|
|
app_names+=("$name")
|
|
done < <(runInstallOp sqlite3 "$docker_dir/$db_file" "SELECT name FROM apps WHERE status = 1;")
|
|
|
|
if [[ ${#app_names[@]} -eq 0 ]]; then
|
|
isNotice "No installed applications found — nothing to back up"
|
|
return 0
|
|
fi
|
|
|
|
for name in "${app_names[@]}"; do
|
|
backupAppStart "$name"
|
|
done
|
|
|
|
isSuccessful "Backup pass complete — ${#app_names[@]} apps"
|
|
}
|