-
Notifications
You must be signed in to change notification settings - Fork 2
96 lines (91 loc) · 3.27 KB
/
all.workflows.yml
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
on:
workflow_dispatch:
inputs:
workflow:
type: choice
description: "Backend or frontend."
options:
- "backend"
- "frontend"
type:
type: choice
description: "App or proxy. Used to resolve the working directory together with name, as <type>/<name>."
options:
- "apps"
- "proxies"
cluster:
type: choice
description: "The cluster to deploy to."
options:
- "dev-gcp"
- "dev-fss"
- "prod-gcp"
name:
type: string
description: "The workflow name, e.g. dolly-backend. Used to resolve the working directory together with type, as <type>/<name>."
required: true
force-deploy:
type: boolean
description: "Deploy? Make sure the effective working directory contains a NAIS manifest as named below! Note: For dolly-frontend, this will also deploy with config.idporten.yml."
default: false
nais-manifest:
type: string
description: "Custom NAIS manifest filename."
default: "config.yml"
force-deploy-test:
type: boolean
description: "Deploy to test? Make sure the effective working directory contains a config.test.yml! Note: For dolly-frontend, this will also deploy with config.unstable.yml."
default: false
permissions:
contents: read
id-token: write
jobs:
start:
runs-on: ubuntu-latest
steps:
- name: "Log inputs"
run: |
echo "branch: ${{ github.ref_name }}"
echo "inputs: ${{ toJSON(inputs) }}"
backend:
needs: start
if: inputs.workflow == 'backend'
uses: ./.github/workflows/common.workflow.backend.yml
with:
cluster: ${{ inputs.cluster }}
working-directory: "${{ inputs.type }}/${{ inputs.name }}"
image-suffix: ${{ inputs.name }}
deploy-tag: ""
force-deploy: ${{ inputs.force-deploy }}
force-deploy-test: ${{ inputs.force-deploy-test }}
permissions:
contents: read
id-token: write
secrets:
NAIS_DOLLY_DEPLOY_API_KEY: ${{ secrets.NAIS_DOLLY_DEPLOY_API_KEY }}
NAIS_WORKLOAD_IDENTITY_PROVIDER: ${{ secrets.NAIS_WORKLOAD_IDENTITY_PROVIDER }}
NAV_TOKEN: ${{ secrets.NAV_TOKEN }}
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
frontend:
needs: start
if: inputs.workflow == 'frontend'
uses: ./.github/workflows/common.workflow.frontend.yml
with:
cluster: ${{ inputs.cluster }}
working-directory: "${{ inputs.type }}/${{ inputs.name }}"
image-suffix: ${{ inputs.name }}
deploy-tag: ""
nais-manifest: ${{ inputs.nais-manifest }}
force-deploy: ${{ inputs.force-deploy }}
force-deploy-test: ${{ inputs.force-deploy-test }}
force-deploy-idporten: ${{ inputs.name == 'dolly-frontend' && inputs.force-deploy }}
force-deploy-unstable: ${{ inputs.name == 'dolly-frontend' && inputs.force-deploy-test }}
permissions:
contents: read
id-token: write
secrets:
NAIS_DOLLY_DEPLOY_API_KEY: ${{ secrets.NAIS_DOLLY_DEPLOY_API_KEY }}
NAIS_WORKLOAD_IDENTITY_PROVIDER: ${{ secrets.NAIS_WORKLOAD_IDENTITY_PROVIDER }}
NAV_TOKEN: ${{ secrets.NAV_TOKEN }}
READER_TOKEN: ${{ secrets.READER_TOKEN }}
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}