summaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/deploy.sh52
-rwxr-xr-xscripts/post-receive.sample32
2 files changed, 51 insertions, 33 deletions
diff --git a/scripts/deploy.sh b/scripts/deploy.sh
index f192e72..5eae840 100755
--- a/scripts/deploy.sh
+++ b/scripts/deploy.sh
@@ -2,12 +2,12 @@
#
# Production deploy script for Prism v2.
#
-# Runs on the production server (in /var/www/prism-v2). Idempotent — handles
-# both first-time install and redeploys.
+# Runs on the production server, AFTER the working tree has been updated
+# (typically by a git post-receive hook that does `git checkout -f` into
+# /var/www/prism-v2). This script does NOT pull — it only builds + restarts.
#
# Usage:
-# sudo ./scripts/deploy.sh # full deploy (pull + build + restart)
-# sudo ./scripts/deploy.sh --no-pull # build + restart only (skip git pull)
+# sudo ./scripts/deploy.sh # build + restart + smoke-check
# sudo ./scripts/deploy.sh --install # also install systemd units + nginx site
# sudo ./scripts/deploy.sh --help
@@ -20,17 +20,15 @@ DOMAIN="${DOMAIN:-prism.tylerhoang.xyz}"
BACKEND_SVC="prismv2-backend.service"
FRONTEND_SVC="prismv2-frontend.service"
-DO_PULL=1
DO_INSTALL=0
usage() {
- sed -n '2,12p' "$0" | sed 's/^# \{0,1\}//'
+ sed -n '2,14p' "$0" | sed 's/^# \{0,1\}//'
exit 0
}
for arg in "$@"; do
case "$arg" in
- --no-pull) DO_PULL=0 ;;
--install) DO_INSTALL=1 ;;
-h|--help) usage ;;
*) echo "Unknown arg: $arg" >&2; exit 2 ;;
@@ -39,26 +37,13 @@ done
log() { printf '\n=== %s ===\n' "$*"; }
-require_root() {
- if [[ $EUID -ne 0 ]]; then
- echo "deploy.sh must be run as root (use sudo)" >&2
- exit 1
- fi
-}
-
-run_as_app() {
- # Run a command as APP_USER with HOME + NPM_CONFIG_CACHE set so npm/git work.
- sudo -u "$APP_USER" \
- env HOME="$APP_DIR/frontend" \
- NPM_CONFIG_CACHE="$APP_DIR/frontend/.npm" \
- "$@"
-}
-
-require_root
+if [[ $EUID -ne 0 ]]; then
+ echo "deploy.sh must be run as root (use sudo)" >&2
+ exit 1
+fi
-if [[ ! -d "$APP_DIR/.git" ]]; then
- echo "Not a checkout: $APP_DIR (expected $APP_DIR/.git)" >&2
- echo "Clone the repo to $APP_DIR first." >&2
+if [[ ! -d "$APP_DIR/backend" || ! -d "$APP_DIR/frontend" ]]; then
+ echo "Expected working tree at $APP_DIR (backend/ + frontend/ not found)" >&2
exit 1
fi
@@ -66,13 +51,15 @@ cd "$APP_DIR"
log "Ensuring ownership of $APP_DIR"
chown -R "$APP_USER:$APP_GROUP" "$APP_DIR"
-mkdir -p "$APP_DIR/frontend/.npm"
-chown -R "$APP_USER:$APP_GROUP" "$APP_DIR/frontend/.npm"
+install -d -o "$APP_USER" -g "$APP_GROUP" "$APP_DIR/frontend/.npm"
+install -d -o "$APP_USER" -g "$APP_GROUP" "$APP_DIR/backend/data"
-if [[ $DO_PULL -eq 1 ]]; then
- log "git pull origin master"
- sudo -u "$APP_USER" git -C "$APP_DIR" pull --ff-only origin master
-fi
+run_as_app() {
+ sudo -u "$APP_USER" \
+ env HOME="$APP_DIR/frontend" \
+ NPM_CONFIG_CACHE="$APP_DIR/frontend/.npm" \
+ "$@"
+}
log "Backend: venv + dependencies"
if [[ ! -x "$APP_DIR/backend/.venv/bin/pip" ]]; then
@@ -108,7 +95,6 @@ if curl -fsS http://127.0.0.1:8001/health >/dev/null; then
echo " backend /health OK"
else
echo " backend /health FAILED" >&2
- echo " journalctl -u $BACKEND_SVC -n 50 --no-pager:" >&2
journalctl -u "$BACKEND_SVC" -n 50 --no-pager >&2 || true
exit 1
fi
diff --git a/scripts/post-receive.sample b/scripts/post-receive.sample
new file mode 100755
index 0000000..3ee898d
--- /dev/null
+++ b/scripts/post-receive.sample
@@ -0,0 +1,32 @@
+#!/bin/bash
+#
+# Sample git post-receive hook for /srv/git/prism-v2.git on the VPS.
+#
+# Install:
+# sudo cp /var/www/prism-v2/scripts/post-receive.sample /srv/git/prism-v2.git/hooks/post-receive
+# sudo chmod +x /srv/git/prism-v2.git/hooks/post-receive
+#
+# Required sudoers entry so the git user can restart services without a password.
+# Adjust GIT_USER if your git is owned by a different account.
+# GIT_USER ALL=(root) NOPASSWD: /var/www/prism-v2/scripts/deploy.sh
+
+set -euo pipefail
+
+BRANCH="master"
+WEB_DIR="/var/www/prism-v2"
+GIT_DIR="/srv/git/prism-v2.git"
+LOG="/var/log/git-deploy.log"
+
+exec >> "$LOG" 2>&1
+
+while read -r oldrev newrev refname; do
+ if [ "$refname" = "refs/heads/$BRANCH" ]; then
+ echo "$(date -Is): Checking out $BRANCH to $WEB_DIR"
+ sudo -u www-data git --work-tree="$WEB_DIR" --git-dir="$GIT_DIR" checkout -f "$BRANCH"
+
+ echo "$(date -Is): Running deploy.sh"
+ sudo "$WEB_DIR/scripts/deploy.sh"
+
+ echo "$(date -Is): Done."
+ fi
+done