pipeline build v32 - GCP secret and syntax
This commit is contained in:
parent
8a84621b5a
commit
d165e2b4d3
158
.woodpecker.yml
158
.woodpecker.yml
@ -1,68 +1,114 @@
|
|||||||
|
---
|
||||||
|
kind: pipeline
|
||||||
|
type: docker
|
||||||
|
name: build-and-deploy
|
||||||
|
|
||||||
|
workspace:
|
||||||
|
base: /woodpecker
|
||||||
|
path: src
|
||||||
|
|
||||||
|
clone:
|
||||||
|
depth: 50
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
- name: docker-sock
|
||||||
|
host:
|
||||||
|
path: /var/run/docker.sock
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: ssh-test
|
- name: build-and-push
|
||||||
image: google/cloud-sdk:latest
|
image: docker:24.0-cli
|
||||||
entrypoint:
|
privileged: true
|
||||||
- bash
|
volumes:
|
||||||
- -c
|
- name: docker-sock
|
||||||
|
path: /var/run/docker.sock
|
||||||
|
commands:
|
||||||
|
- |
|
||||||
|
set -eu
|
||||||
|
REG=us-central1-docker.pkg.dev/aptivaai-dev/aptiva-repo
|
||||||
|
TAG=$(echo "$CI_COMMIT_SHA" | head -c 8)
|
||||||
|
|
||||||
|
docker buildx create --use --name woodpecker || true
|
||||||
|
|
||||||
|
for svc in server1 server2 server3 nginx; do
|
||||||
|
docker buildx build \
|
||||||
|
-f Dockerfile.${svc} \
|
||||||
|
-t ${REG}/${svc}:${TAG} \
|
||||||
|
--push .
|
||||||
|
done
|
||||||
|
when:
|
||||||
|
event: [push, manual]
|
||||||
|
branch: [master]
|
||||||
|
|
||||||
|
- name: deploy-staging
|
||||||
|
image: appleboy/drone-ssh
|
||||||
|
settings:
|
||||||
|
host: 10.128.0.12
|
||||||
|
port: 22
|
||||||
|
username: jcoakley
|
||||||
|
key:
|
||||||
|
from_secret: STAGING_SSH_KEY
|
||||||
|
known_hosts:
|
||||||
|
from_secret: STAGING_KNOWN_HOSTS
|
||||||
|
script:
|
||||||
- |
|
- |
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
mkdir -p ~/.ssh
|
ENV=dev
|
||||||
|
PROJECT=aptivaai-dev
|
||||||
|
ROOT=/opt/aptiva-staging-app
|
||||||
|
REG=us-central1-docker.pkg.dev/${PROJECT}/aptiva-repo
|
||||||
|
TAG=$(echo "$CI_COMMIT_SHA" | head -c 8)
|
||||||
|
|
||||||
# ── Inject known-hosts and SSH key ───────────────────────────────
|
cd "$ROOT"
|
||||||
gcloud secrets versions access latest \
|
export IMG_TAG="$TAG"
|
||||||
--secret=STAGING_KNOWN_HOSTS --project=aptivaai-dev \
|
|
||||||
| base64 -d > ~/.ssh/known_hosts
|
|
||||||
chmod 644 ~/.ssh/known_hosts
|
|
||||||
|
|
||||||
gcloud secrets versions access latest \
|
read -r -a SECRETS <<'EOF'
|
||||||
--secret=STAGING_SSH_KEY --project=aptivaai-dev \
|
JWT_SECRET
|
||||||
| base64 -d > ~/.ssh/id_ed25519
|
OPENAI_API_KEY
|
||||||
chmod 600 ~/.ssh/id_ed25519
|
ONET_USERNAME
|
||||||
|
ONET_PASSWORD
|
||||||
|
STRIPE_SECRET_KEY
|
||||||
|
STRIPE_PUBLISHABLE_KEY
|
||||||
|
STRIPE_WH_SECRET
|
||||||
|
STRIPE_PRICE_PREMIUM_MONTH
|
||||||
|
STRIPE_PRICE_PREMIUM_YEAR
|
||||||
|
STRIPE_PRICE_PRO_MONTH
|
||||||
|
STRIPE_PRICE_PRO_YEAR
|
||||||
|
DB_HOST
|
||||||
|
DB_PORT
|
||||||
|
DB_USER
|
||||||
|
DB_PASSWORD
|
||||||
|
TWILIO_ACCOUNT_SID
|
||||||
|
TWILIO_AUTH_TOKEN
|
||||||
|
TWILIO_MESSAGING_SERVICE_SID
|
||||||
|
EOF
|
||||||
|
|
||||||
echo "🔑 SSH prerequisites installed"
|
echo "🔐 Pulling secrets from Secret Manager"
|
||||||
|
for S in "${SECRETS[@]}"; do
|
||||||
# ── SSH into staging and deploy ──────────────────────────────────
|
|
||||||
ssh -o StrictHostKeyChecking=yes \
|
|
||||||
-i ~/.ssh/id_ed25519 \
|
|
||||||
jcoakley@10.128.0.12 \
|
|
||||||
'set -euo pipefail; \
|
|
||||||
cd /home/jcoakley/aptiva-staging-app; \
|
|
||||||
|
|
||||||
# ── Pull canonical IMG_TAG ────────────────────────────────
|
|
||||||
IMG_TAG=$(gcloud secrets versions access latest \
|
|
||||||
--secret=IMG_TAG --project=aptivaai-dev); \
|
|
||||||
export IMG_TAG; \
|
|
||||||
echo "📦 IMG_TAG=$IMG_TAG"; \
|
|
||||||
|
|
||||||
# ── Inject sensitive secrets runtime-only ─────────────────
|
|
||||||
ENV=staging; \
|
|
||||||
PROJECT=aptivaai-dev; \
|
|
||||||
SECRETS=( \
|
|
||||||
JWT_SECRET OPENAI_API_KEY ONET_USERNAME ONET_PASSWORD \
|
|
||||||
STRIPE_SECRET_KEY STRIPE_PUBLISHABLE_KEY STRIPE_WH_SECRET \
|
|
||||||
STRIPE_PRICE_PREMIUM_MONTH STRIPE_PRICE_PREMIUM_YEAR \
|
|
||||||
STRIPE_PRICE_PRO_MONTH STRIPE_PRICE_PRO_YEAR \
|
|
||||||
DB_HOST DB_PORT DB_USER DB_PASSWORD \
|
|
||||||
TWILIO_ACCOUNT_SID TWILIO_AUTH_TOKEN TWILIO_MESSAGING_SERVICE_SID \
|
|
||||||
); \
|
|
||||||
for S in "${SECRETS[@]}"; do \
|
|
||||||
export "$S"="$(gcloud secrets versions access latest \
|
export "$S"="$(gcloud secrets versions access latest \
|
||||||
--secret="${S}_${ENV}" --project="$PROJECT")"; \
|
--secret="${S}_${ENV}" \
|
||||||
done; \
|
--project="${PROJECT}")"
|
||||||
export FROM_SECRETS_MANAGER=true; \
|
done
|
||||||
|
|
||||||
# ── Compose with env preserved ────────────────────────────
|
export FROM_SECRETS_MANAGER=true
|
||||||
preserve=IMG_TAG,FROM_SECRETS_MANAGER,$(IFS=,; echo "${SECRETS[*]}"); \
|
|
||||||
echo "🚀 docker compose up with envs: $preserve"; \
|
|
||||||
sudo --preserve-env="$preserve" docker compose pull; \
|
|
||||||
sudo --preserve-env="$preserve" docker compose up -d --force-recreate --remove-orphans; \
|
|
||||||
echo "✅ Staging stack refreshed with tag $IMG_TAG"'
|
|
||||||
|
|
||||||
secrets:
|
preserve_vars=(
|
||||||
- STAGING_SSH_KEY
|
IMG_TAG
|
||||||
- STAGING_KNOWN_HOSTS
|
FROM_SECRETS_MANAGER
|
||||||
|
$(IFS=,; echo "${SECRETS[*]}")
|
||||||
|
)
|
||||||
|
preserve=$(IFS=,; echo "${preserve_vars[*]}")
|
||||||
|
|
||||||
|
echo "🚀 Deploying with preserved env: $preserve"
|
||||||
|
|
||||||
|
sudo --preserve-env="$preserve" \
|
||||||
|
docker compose pull
|
||||||
|
|
||||||
|
sudo --preserve-env="$preserve" \
|
||||||
|
docker compose up -d \
|
||||||
|
--force-recreate \
|
||||||
|
--remove-orphans
|
||||||
when:
|
when:
|
||||||
event:
|
event: [push, manual]
|
||||||
- push
|
branch: [master]
|
||||||
|
Loading…
Reference in New Issue
Block a user