Skip to content

Commit

Permalink
feat: pg-restore utility (#1243)
Browse files Browse the repository at this point in the history
Co-authored-by: Sam Rose <[email protected]>
  • Loading branch information
samrose and samrose authored Oct 9, 2024
1 parent f7bb3fe commit 4ab3640
Show file tree
Hide file tree
Showing 2 changed files with 129 additions and 0 deletions.
8 changes: 8 additions & 0 deletions flake.nix
Original file line number Diff line number Diff line change
Expand Up @@ -459,6 +459,13 @@
--subst-var-by 'PSQL15_BINDIR' '${basePackages.psql_15.bin}'
chmod +x $out/bin/start-postgres-replica
'';
pg-restore =
pkgs.runCommand "run-pg-restore" { } ''
mkdir -p $out/bin
substitute ${./nix/tools/run-restore.sh.in} $out/bin/pg-restore \
--subst-var-by PSQL15_BINDIR '${basePackages.psql_15.bin}'
chmod +x $out/bin/pg-restore
'';
sync-exts-versions = pkgs.runCommand "sync-exts-versions" { } ''
mkdir -p $out/bin
substitute ${./nix/tools/sync-exts-versions.sh.in} $out/bin/sync-exts-versions \
Expand Down Expand Up @@ -589,6 +596,7 @@
start-replica = mkApp "start-replica" "start-postgres-replica";
migration-test = mkApp "migrate-tool" "migrate-postgres";
sync-exts-versions = mkApp "sync-exts-versions" "sync-exts-versions";
pg-restore = mkApp "pg-restore" "pg-restore";
};

# 'devShells.default' lists the set of packages that are included in the
Expand Down
121 changes: 121 additions & 0 deletions nix/tools/run-restore.sh.in
Original file line number Diff line number Diff line change
@@ -0,0 +1,121 @@
#!/usr/bin/env bash
# shellcheck shell=bash

set -euo pipefail

# Function to display help message
show_help() {
echo "Usage: nix run .#pg-restore -- [OPTIONS]"
echo
echo "Run pg_restore with the specified parameters."
echo
echo "Options:"
echo " --version PostgreSQL version (currently only 15 is supported)"
echo " --dbname Name of the database to restore to"
echo " --host Host of the database server"
echo " --user Database user to connect as"
echo " --file Path to the file to restore from (absolute or relative to current directory)"
echo " --port Port number (default: 5432)"
echo " -h, --help Show this help message and exit"
echo "Example:"
echo "nix run .#pg-restore -- --version 15 --dbname postgres --host localhost --user postgres --port 5435 --file my.dump"
}

# Initialize variables
PG_VERSION=""
DBNAME=""
DBHOST=""
DBUSER=""
RESTORE_FILE=""
PORT="5432"

# Parse command line arguments
while [[ $# -gt 0 ]]; do
case $1 in
--version)
PG_VERSION="$2"
shift 2
;;
--dbname)
DBNAME="$2"
shift 2
;;
--host)
DBHOST="$2"
shift 2
;;
--user)
DBUSER="$2"
shift 2
;;
--file)
RESTORE_FILE="$2"
shift 2
;;
--port)
PORT="$2"
shift 2
;;
-h|--help)
show_help
exit 0
;;
*)
echo "Unknown option: $1"
show_help
exit 1
;;
esac
done

# Check if all required arguments are provided
if [ -z "$PG_VERSION" ] || [ -z "$DBNAME" ] || [ -z "$DBHOST" ] || [ -z "$DBUSER" ] || [ -z "$RESTORE_FILE" ]; then
echo "Error: Missing required arguments."
show_help
exit 1
fi

if [ "$PG_VERSION" == "15" ]; then
echo "Starting restore for PSQL 15"
PSQL15=@PSQL15_BINDIR@
PSQL_BINDIR="$PSQL15"
else
echo "Error: Please provide a valid Postgres version (currently only 15 is supported)"
show_help
exit 1
fi

# Convert RESTORE_FILE to an absolute path if it's relative
if [[ "$RESTORE_FILE" != /* ]]; then
RESTORE_FILE="$(pwd)/$RESTORE_FILE"
fi

# Check if the file exists
if [ ! -f "$RESTORE_FILE" ]; then
echo "Error: Restore file '$RESTORE_FILE' does not exist."
exit 1
fi

echo "Using restore file: $RESTORE_FILE"

# Run pg_restore and capture its exit status
"$PSQL_BINDIR/bin/pg_restore" \
-h "$DBHOST" \
-p "$PORT" \
-U "$DBUSER" \
-d "$DBNAME" \
-v \
--no-owner \
--no-acl \
"$RESTORE_FILE"

RESTORE_STATUS=$?

# Check the exit status of pg_restore
if [ $RESTORE_STATUS -eq 0 ]; then
echo "Restore completed successfully."
exit 0
else
echo "Restore failed with exit code $RESTORE_STATUS."
exit $RESTORE_STATUS
fi

0 comments on commit 4ab3640

Please sign in to comment.