This commit is contained in:
2026-03-05 01:53:13 +01:00
parent 8d72ff526f
commit 6ba6bcb6ee
2 changed files with 12 additions and 49 deletions

View File

@@ -204,9 +204,9 @@ cd /opt/dockge
docker compose up -d docker compose up -d
# call replacements for nginx db # call replacements for nginx db
replace_in_sqlite_db "/opt/stacks/npm/data/database.sqlite" "?domain?" $domain replace_in_sqlite_db "/opt/stacks/npm/data/database.sqlite" "<domain>" $domain
replace_in_sqlite_db "/opt/stacks/npm/data/database.sqlite" "?localip?" $localip replace_in_sqlite_db "/opt/stacks/npm/data/database.sqlite" "<localip>" $localip
replace_in_sqlite_db "/opt/stacks/npm/data/database.sqlite" "?adminpass?" $adminpass replace_in_sqlite_db "/opt/stacks/npm/data/database.sqlite" "<adminpass>" $adminpass
echo "" echo ""

View File

@@ -20,22 +20,9 @@ replace_in_sqlite_db() {
local OLD_STRING_ESC=$(printf '%s\n' "$OLD_STRING" | sed "s/'/''/g") local OLD_STRING_ESC=$(printf '%s\n' "$OLD_STRING" | sed "s/'/''/g")
local NEW_STRING_ESC=$(printf '%s\n' "$NEW_STRING" | sed "s/'/''/g") local NEW_STRING_ESC=$(printf '%s\n' "$NEW_STRING" | sed "s/'/''/g")
# Start a transaction with immediate mode for better locking
if ! sqlite3 "$DB_PATH" "BEGIN IMMEDIATE TRANSACTION;"; then
echo "Error: Failed to begin transaction"
exit 1
fi
# Get a list of all tables in the database # Get a list of all tables in the database
local TABLES local TABLES
TABLES=$(sqlite3 "$DB_PATH" ".tables") || { TABLES=$(sqlite3 "$DB_PATH" ".tables")
echo "Error: Failed to get list of tables"
sqlite3 "$DB_PATH" "ROLLBACK;"
exit 1
}
# Track if we made any changes
local CHANGES_MADE=false
# Loop through each table # Loop through each table
for TABLE in $TABLES; do for TABLE in $TABLES; do
@@ -68,41 +55,17 @@ replace_in_sqlite_db() {
fi fi
# Update only rows where the column contains OLD_STRING # Update only rows where the column contains OLD_STRING
if sqlite3 "$DB_PATH" " # Run each update in its own connection to avoid locking issues
sqlite3 "$DB_PATH" "
UPDATE $ESCAPED_TABLE UPDATE $ESCAPED_TABLE
SET $ESCAPED_COLUMN = replace(CAST($ESCAPED_COLUMN AS TEXT), '$OLD_STRING_ESC', '$NEW_STRING_ESC') SET $ESCAPED_COLUMN = replace(CAST($ESCAPED_COLUMN AS TEXT), '$OLD_STRING_ESC', '$NEW_STRING_ESC')
WHERE CAST($ESCAPED_COLUMN AS TEXT) LIKE '%$OLD_STRING_ESC%'; WHERE CAST($ESCAPED_COLUMN AS TEXT) LIKE '%$OLD_STRING_ESC%';
" 2>/dev/null; then "
CHANGES_MADE=true
else
echo " Warning: Failed to update table $TABLE, column $COLUMN"
fi
fi fi
done done
done done
# Try to commit the transaction with retries
local RETRIES=3
local COMMIT_SUCCESS=false
while [ $RETRIES -gt 0 ]; do
if sqlite3 "$DB_PATH" "COMMIT;" 2>/dev/null; then
COMMIT_SUCCESS=true
break
else
echo "Warning: Failed to commit transaction, retrying ($RETRIES attempts left)..."
sleep 1
((RETRIES--))
fi
done
if [ "$COMMIT_SUCCESS" = false ]; then
echo "Error: Failed to commit transaction after multiple attempts"
sqlite3 "$DB_PATH" "ROLLBACK;" 2>/dev/null
exit 1
else
echo "Replacement completed in '$DB_PATH'. Original database backed up to '$BACKUP_PATH'." echo "Replacement completed in '$DB_PATH'. Original database backed up to '$BACKUP_PATH'."
fi
} }
#set script directory #set script directory
@@ -110,7 +73,7 @@ scriptdir="$(dirname "$(realpath "$0")")"
#example usage: replace_in_sqlite_db "database.sqlite" "Europe/Amsterdam" "UTC" #example usage: replace_in_sqlite_db "database.sqlite" "Europe/Amsterdam" "UTC"
cp $scriptdir/stacks/npm/data/database-pre.sqlite $scriptdir/stacks/npm/data/database.sqlite cp $scriptdir/stacks/npm/data/database-pre.sqlite $scriptdir/stacks/npm/data/database.sqlite
replace_in_sqlite_db "$scriptdir/stacks/npm/data/database.sqlite" "sdgserver.online" "?domain?" replace_in_sqlite_db "$scriptdir/stacks/npm/data/database.sqlite" "sdgserver.online" "<domain>"
replace_in_sqlite_db "$scriptdir/stacks/npm/data/database.sqlite" "192.168.2.132" "?localip?" replace_in_sqlite_db "$scriptdir/stacks/npm/data/database.sqlite" "192.168.2.132" "<localip>"
replace_in_sqlite_db "$scriptdir/stacks/npm/data/database.sqlite" "z5fGWz2i0q" "?adminpass?" replace_in_sqlite_db "$scriptdir/stacks/npm/data/database.sqlite" "z5fGWz2i0q" "<adminpass>"
replace_in_sqlite_db "$scriptdir/stacks/npm/data/database.sqlite" "0.0.0.0/0" "?localip?" replace_in_sqlite_db "$scriptdir/stacks/npm/data/database.sqlite" "0.0.0.0/0" "<localip>"