-
Notifications
You must be signed in to change notification settings - Fork 220
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: support restoring local db from backup
- Loading branch information
1 parent
2cca98c
commit 69a1306
Showing
7 changed files
with
328 additions
and
247 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
#!/bin/sh | ||
set -eu | ||
|
||
#!/usr/bin/env bash | ||
# set -euo pipefail | ||
|
||
####################################### | ||
# Used by both ami and docker builds to initialise database schema. | ||
# Env vars: | ||
# POSTGRES_DB defaults to postgres | ||
# POSTGRES_HOST defaults to localhost | ||
# POSTGRES_PORT defaults to 5432 | ||
# POSTGRES_PASSWORD defaults to "" | ||
# USE_DBMATE defaults to "" | ||
# Exit code: | ||
# 0 if migration succeeds, non-zero on error. | ||
####################################### | ||
|
||
export PGDATABASE="${POSTGRES_DB:-postgres}" | ||
export PGHOST="${POSTGRES_HOST:-localhost}" | ||
export PGPORT="${POSTGRES_PORT:-5432}" | ||
export PGPASSWORD="${POSTGRES_PASSWORD:-}" | ||
|
||
echo "$0: restoring roles" | ||
cat "/etc/backup.sql" \ | ||
| grep 'CREATE ROLE' \ | ||
| grep -v 'supabase_admin' \ | ||
| psql -v ON_ERROR_STOP=1 --no-password --no-psqlrc -U supabase_admin | ||
|
||
echo "$0: restoring schema" | ||
cat "/etc/backup.sql" \ | ||
| sed -E 's/^CREATE VIEW /CREATE OR REPLACE VIEW /' \ | ||
| sed -E 's/^CREATE FUNCTION /CREATE OR REPLACE FUNCTION /' \ | ||
| sed -E 's/^CREATE TRIGGER /CREATE OR REPLACE TRIGGER /' \ | ||
| sed -E 's/^GRANT ALL ON FUNCTION graphql_public\./-- &/' \ | ||
| sed -E 's/^CREATE ROLE /-- &/' \ | ||
| psql -v ON_ERROR_STOP=1 --no-password --no-psqlrc -U supabase_admin | ||
|
||
# run any post migration script to update role passwords | ||
postinit="/etc/postgresql.schema.sql" | ||
if [ -e "$postinit" ]; then | ||
echo "$0: running $postinit" | ||
psql -v ON_ERROR_STOP=1 --no-password --no-psqlrc -U supabase_admin -f "$postinit" | ||
fi |
Oops, something went wrong.