-
Notifications
You must be signed in to change notification settings - Fork 17
78 lines (73 loc) · 2.92 KB
/
Copy pathdeploy.yml
File metadata and controls
78 lines (73 loc) · 2.92 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
# -----------------------------------------------------------------------------
# Toggle de GitHub Environments
# -----------------------------------------------------------------------------
# Os jobs abaixo usam a variável de repositório `USE_ENVIRONMENTS` para decidir
# se vinculam o deploy a um GitHub Environment (`homologation` / `production`).
#
# Configuração em Settings → Secrets and variables → Actions:
#
# Variables → New repository variable
# • USE_ENVIRONMENTS = "false" → bypass: nenhum environment é exigido.
# Secrets lidos do nível repositório.
# • USE_ENVIRONMENTS = "true" → modo normal: exige que os environments
# `homologation` e `production` existam.
# Secrets do environment têm precedência.
#
# Secrets necessários (em repository secrets enquanto bypass; podem ser
# movidos para environment secrets depois):
# • PORTAINER_DEPLOY_HMG_WEBHOOK_URL
# • PORTAINER_DEPLOY_PRD_WEBHOOK_URL
#
# Quando os environments forem criados no GitHub, basta alterar
# USE_ENVIRONMENTS para "true" — não é necessário editar este arquivo.
# -----------------------------------------------------------------------------
name: 🚢 Deploy
on:
workflow_run:
workflows: ["🚀 Release and build"]
types: [completed]
branches: [main]
concurrency:
group: deploy
cancel-in-progress: false
jobs:
deploy-hmg:
if: ${{ github.event.workflow_run.conclusion == 'success' }}
runs-on: ubuntu-latest
environment:
name: ${{ vars.USE_ENVIRONMENTS == 'true' && 'homologation' || '' }}
permissions: {}
steps:
- name: 🚀 Trigger Portainer webhook (HMG)
env:
WEBHOOK_URL: ${{ secrets.PORTAINER_DEPLOY_HMG_WEBHOOK_URL }}
run: |
if [ -z "$WEBHOOK_URL" ]; then
echo "::error::PORTAINER_DEPLOY_HMG_WEBHOOK_URL secret is not set for environment 'homologation'."
exit 1
fi
curl -X POST "$WEBHOOK_URL" \
-H "Content-Type: application/json" \
-d '{"ref":"main"}' \
--fail --silent --show-error
echo "Homologation deploy triggered."
deploy-prd:
needs: deploy-hmg
runs-on: ubuntu-latest
environment:
name: ${{ vars.USE_ENVIRONMENTS == 'true' && 'production' || '' }}
permissions: {}
steps:
- name: 🚀 Trigger Portainer webhook (PRD)
env:
WEBHOOK_URL: ${{ secrets.PORTAINER_DEPLOY_PRD_WEBHOOK_URL }}
run: |
if [ -z "$WEBHOOK_URL" ]; then
echo "::error::PORTAINER_DEPLOY_PRD_WEBHOOK_URL secret is not set for environment 'production'."
exit 1
fi
curl -X POST "$WEBHOOK_URL" \
-H "Content-Type: application/json" \
-d '{"ref":"main"}' \
--fail --silent --show-error
echo "Production deploy triggered."