Dev: - Add tailwind install + build to docker-compose startup so CSS is built inside the container — not dependent on local filesystem Production (docker-compose.prod.yml): - Gunicorn on 127.0.0.1:8001, bind-mounted static/media to host paths so Caddy can serve them directly - Runs migrate, tailwind build, collectstatic on startup Settings (production.py): - Disable SECURE_SSL_REDIRECT (Caddy handles redirects; Django would loop) - Add CSRF_TRUSTED_ORIGINS for nohypeai.net CI (.gitea/workflows/ci.yml): - Add push-to-main trigger - Add deploy job: SSHes to lintel-prod-01 as deploy, runs deploy/deploy.sh Server config (deploy/): - deploy/caddy/nohype.caddy — Caddy site config for nohypeai.net - deploy/sum-nohype.service — systemd unit for the compose stack - deploy/deploy.sh — deploy script (pull, build, restart) One-time manual steps required on lintel-prod-01 (need root): sudo cp deploy/sum-nohype.service /etc/systemd/system/ sudo cp deploy/caddy/nohype.caddy /etc/caddy/sites-enabled/ sudo systemctl daemon-reload && sudo systemctl enable sum-nohype sudo systemctl reload caddy Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
35 lines
940 B
Bash
Executable File
35 lines
940 B
Bash
Executable File
#!/usr/bin/env bash
|
|
# Deploy script for No Hype AI — runs on lintel-prod-01 as deploy user.
|
|
# Called by CI after a successful push to main.
|
|
set -euo pipefail
|
|
|
|
SITE_DIR=/srv/sum/nohype
|
|
APP_DIR=${SITE_DIR}/app
|
|
|
|
echo "==> Pulling latest code"
|
|
git -C "${APP_DIR}" pull origin main
|
|
|
|
echo "==> Updating compose file"
|
|
cp "${APP_DIR}/docker-compose.prod.yml" "${SITE_DIR}/docker-compose.prod.yml"
|
|
|
|
echo "==> Ensuring static/media directories exist"
|
|
mkdir -p "${SITE_DIR}/static" "${SITE_DIR}/media"
|
|
|
|
echo "==> Building image"
|
|
docker compose -f "${SITE_DIR}/docker-compose.prod.yml" build --no-cache
|
|
|
|
echo "==> Restarting service"
|
|
sudo systemctl restart sum-nohype
|
|
|
|
echo "==> Waiting for health check"
|
|
for i in $(seq 1 30); do
|
|
if curl -fsS http://localhost:8001/ >/dev/null 2>&1; then
|
|
echo "==> Site is up"
|
|
exit 0
|
|
fi
|
|
sleep 3
|
|
done
|
|
echo "ERROR: site did not come up after 90s" >&2
|
|
sudo journalctl -u sum-nohype --no-pager -n 50
|
|
exit 1
|