Files
ScadaBridge/docker/rename-databases.sh
Joseph Doherty 1aa5da4eca refactor: add docker/rename-databases.sh for in-place MS SQL cutover
Renames ScadaLink* databases + scadalink_app login on an existing
running scadabridge-mssql container. For users preserving seeded
test data through the rename. Fresh deployments use the already-
updated infra/mssql/setup.sql directly.
2026-05-28 09:39:33 -04:00

104 lines
3.8 KiB
Bash
Executable File

#!/usr/bin/env bash
# docker/rename-databases.sh
#
# In-place rename of the MS SQL databases from ScadaLink* → ScadaBridge*.
# Use this when you have an existing ScadaLink dev stack and want to preserve
# the seeded test data through the product rename. If you're starting fresh,
# just run `bash docker/deploy.sh` instead — infra/mssql/setup.sql now creates
# the databases with their new names directly.
#
# The MS SQL container itself (renamed scadalink-mssql → scadabridge-mssql in
# infra/docker-compose.yml) must already be running. If you also renamed the
# container, do the container rename + volume remount before this script.
#
# Usage:
# bash docker/rename-databases.sh # primary databases only
# bash docker/rename-databases.sh --include-env2 # primary + env2 databases
#
# After running, restart the application containers so EF picks up the new
# database names from the migrated connection strings:
# bash docker/teardown.sh && bash docker/deploy.sh
# bash docker-env2/teardown.sh && bash docker-env2/deploy.sh # if env2
set -euo pipefail
INCLUDE_ENV2=0
if [[ "${1:-}" == "--include-env2" ]]; then
INCLUDE_ENV2=1
fi
CONTAINER="scadabridge-mssql"
SA_PASSWORD="ScadaBridge_Dev1#"
if ! docker ps --format '{{.Names}}' | grep -q "^${CONTAINER}$"; then
echo "Error: container '${CONTAINER}' is not running."
echo "Start the infra stack first: cd infra && docker compose up -d"
exit 1
fi
run_sql() {
docker exec "$CONTAINER" /opt/mssql-tools18/bin/sqlcmd \
-S localhost -U sa -P "$SA_PASSWORD" -C -Q "$1"
}
rename_db() {
local old="$1"
local new="$2"
if ! run_sql "SELECT name FROM sys.databases WHERE name = '$old'" | grep -q "$old"; then
echo " $old: not present — skipping"
return
fi
if run_sql "SELECT name FROM sys.databases WHERE name = '$new'" | grep -q "$new"; then
echo " $old$new: target already exists — skipping"
return
fi
echo " $old$new"
run_sql "ALTER DATABASE [$old] SET SINGLE_USER WITH ROLLBACK IMMEDIATE;
ALTER DATABASE [$old] MODIFY NAME = [$new];
ALTER DATABASE [$new] SET MULTI_USER;"
}
echo "=== Renaming primary databases ==="
rename_db "ScadaLinkConfig" "ScadaBridgeConfig"
rename_db "ScadaLinkMachineData" "ScadaBridgeMachineData"
if [[ "$INCLUDE_ENV2" -eq 1 ]]; then
echo
echo "=== Renaming env2 databases ==="
rename_db "ScadaLinkConfig2" "ScadaBridgeConfig2"
rename_db "ScadaLinkMachineData2" "ScadaBridgeMachineData2"
fi
echo
echo "=== Renaming SQL login ==="
if run_sql "SELECT name FROM sys.server_principals WHERE name = 'scadalink_app'" | grep -q "scadalink_app"; then
echo " scadalink_app → scadabridge_app"
run_sql "ALTER LOGIN [scadalink_app] WITH NAME = [scadabridge_app];"
# Database-scoped user names follow the login but the rename above doesn't
# cascade — fix them up per database.
for db in ScadaBridgeConfig ScadaBridgeMachineData; do
if run_sql "SELECT name FROM sys.databases WHERE name = '$db'" | grep -q "$db"; then
run_sql "USE [$db]; IF EXISTS (SELECT 1 FROM sys.database_principals WHERE name = 'scadalink_app') ALTER USER [scadalink_app] WITH NAME = [scadabridge_app];"
fi
done
if [[ "$INCLUDE_ENV2" -eq 1 ]]; then
for db in ScadaBridgeConfig2 ScadaBridgeMachineData2; do
if run_sql "SELECT name FROM sys.databases WHERE name = '$db'" | grep -q "$db"; then
run_sql "USE [$db]; IF EXISTS (SELECT 1 FROM sys.database_principals WHERE name = 'scadalink_app') ALTER USER [scadalink_app] WITH NAME = [scadabridge_app];"
fi
done
fi
else
echo " scadalink_app: not present — skipping"
fi
echo
echo "=== Done ==="
echo
echo "Next steps:"
echo " bash docker/teardown.sh && bash docker/deploy.sh"
[[ "$INCLUDE_ENV2" -eq 1 ]] && echo " bash docker-env2/teardown.sh && bash docker-env2/deploy.sh"