name: CD on: push: branches: [master, main] pull_request: env: IMG: ${{ secrets.AR_LOCATION }}-docker.pkg.dev/${{ secrets.GCP_PROJECT }}/${{ secrets.AR_REPO }}/${{ gitea.event.repository.name }}:lab-${{ gitea.run_number }} jobs: # Build + push da imagem usando Kaniko (sem Docker daemon, sem Cloud Build). # Roda dentro da imagem oficial do Kaniko que tem busybox + binary executor. build: runs-on: ubuntu-latest container: image: gcr.io/kaniko-project/executor:v1.23.2-debug steps: - uses: actions/checkout@v4 - name: Auth Artifact Registry + Build & Push (kaniko) run: | set -e mkdir -p /kaniko/.docker # Grava a chave da SA em arquivo via heredoc (preserva quebras/aspas) cat > /tmp/sa.json <<'__SA_EOF__' ${{ secrets.GCP_SA_KEY }} __SA_EOF__ # Docker config: Basic Auth com user `_json_key` + JSON da SA AUTH_B64=$(printf '_json_key:%s' "$(cat /tmp/sa.json)" | base64 -w0) cat > /kaniko/.docker/config.json < /etc/apt/sources.list.d/google-cloud-sdk.list apt-get update -qq apt-get install -y -qq kubectl google-cloud-cli-gke-gcloud-auth-plugin kubectl version --client=true - name: Auth GCP uses: google-github-actions/auth@v2 with: credentials_json: ${{ secrets.GCP_SA_KEY }} - name: Setup gcloud uses: google-github-actions/setup-gcloud@v2 with: project_id: ${{ secrets.GCP_PROJECT }} - name: Deploy hml2 env: USE_GKE_GCLOUD_AUTH_PLUGIN: "True" run: | gcloud container clusters get-credentials ${{ secrets.GKE_CLUSTER }} --region ${{ secrets.GKE_REGION }} --project ${{ secrets.GCP_PROJECT }} NS=${{ secrets.K8S_NAMESPACE }} # 1) Aplica manifests (idempotente) if [ -d k8s ]; then kubectl apply -n "$NS" -f k8s/ fi # 2) Atualiza imagem DEPLOYMENT="${{ gitea.event.repository.name }}-deployment" if kubectl get deployment "$DEPLOYMENT" -n "$NS" >/dev/null 2>&1; then CONTAINER=$(kubectl get deployment "$DEPLOYMENT" -n "$NS" -o jsonpath='{.spec.template.spec.containers[0].name}') kubectl set image deployment/"$DEPLOYMENT" -n "$NS" "$CONTAINER=${IMG}" kubectl rollout status deployment/"$DEPLOYMENT" -n "$NS" --timeout=600s else echo "Deployment $DEPLOYMENT não existe — kubectl apply acabou de criar (1º deploy)" fi