promiscuity/.gitea/workflows/deploy-mail.yml
Zeeshaun a8db66b93e
All checks were successful
Deploy Promiscuity Auth API / deploy (push) Successful in 48s
Deploy Promiscuity Character API / deploy (push) Successful in 59s
Deploy Promiscuity Inventory API / deploy (push) Successful in 46s
Deploy Promiscuity Locations API / deploy (push) Successful in 1m0s
Deploy Promiscuity Mail API / deploy (push) Successful in 1m9s
k8s smoke test / test (push) Successful in 9s
Mail support
2026-03-23 20:18:23 -05:00

79 lines
2.2 KiB
YAML

name: Deploy Promiscuity Mail API
on:
push:
branches:
- main
workflow_dispatch: {}
jobs:
deploy:
runs-on: self-hosted
env:
IMAGE_NAME: promiscuity-mail:latest
IMAGE_TAR: /tmp/promiscuity-mail.tar
NODES: "192.168.86.72 192.168.86.73 192.168.86.74"
steps:
- name: Checkout repo
uses: actions/checkout@v4
- name: Build Docker image
run: |
cd microservices/MailApi
docker build -t "${IMAGE_NAME}" .
- name: Save Docker image to TAR
run: |
docker save "${IMAGE_NAME}" -o "${IMAGE_TAR}"
- name: Copy TAR to nodes
run: |
for node in ${NODES}; do
scp -o StrictHostKeyChecking=no "${IMAGE_TAR}" hz@"$node":/tmp/promiscuity-mail.tar
done
- name: Import image on nodes
run: |
for node in ${NODES}; do
ssh -o StrictHostKeyChecking=no hz@"$node" "sudo ctr -n k8s.io images import /tmp/promiscuity-mail.tar"
done
- name: Clean TAR from nodes
run: |
for node in ${NODES}; do
ssh -o StrictHostKeyChecking=no hz@"$node" "rm -f /tmp/promiscuity-mail.tar"
done
- name: Clean TAR on runner
run: |
rm -f "${IMAGE_TAR}"
- name: Write kubeconfig from secret
env:
KUBECONFIG_CONTENT: ${{ secrets.KUBECONFIG }}
run: |
mkdir -p /tmp/kube
printf '%s\n' "$KUBECONFIG_CONTENT" > /tmp/kube/config
- name: Create namespace if missing
env:
KUBECONFIG: /tmp/kube/config
run: |
kubectl create namespace promiscuity-mail --dry-run=client -o yaml | kubectl apply -f -
- name: Apply Mail deployment & service
env:
KUBECONFIG: /tmp/kube/config
run: |
kubectl apply -f microservices/MailApi/k8s/deployment.yaml -n promiscuity-mail
kubectl apply -f microservices/MailApi/k8s/service.yaml -n promiscuity-mail
- name: Restart Mail deployment
env:
KUBECONFIG: /tmp/kube/config
run: |
kubectl rollout restart deployment/promiscuity-mail -n promiscuity-mail
kubectl rollout status deployment/promiscuity-mail -n promiscuity-mail