Deploy (Staging) #137
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Deploy (Staging) | |
on: | |
workflow_run: | |
workflows: ["Release Docker Image (Staging)"] | |
types: | |
- completed | |
workflow_dispatch: | |
env: | |
IMAGE_NAME: ghcr.io/basedosdados/website:staging | |
jobs: | |
deploy-staging: | |
if: ${{ github.event.workflow_run.conclusion == 'success' }} || ${{ github.event_name == 'workflow_dispatch' }} | |
name: Deploy (Staging) | |
runs-on: ubuntu-latest | |
environment: | |
name: staging | |
url: https://staging.basedosdados.org | |
steps: | |
- name: Checkout | |
uses: actions/[email protected] | |
with: | |
ref: staging | |
- name: Import Secrets | |
id: import_secrets | |
uses: hashicorp/[email protected] | |
with: | |
url: https://vault.basedosdados.org | |
token: ${{ secrets.VAULT_TOKEN }} | |
secrets: | | |
secret/data/gcp_credentials/basedosdados-dev GCP_SA_KEY_BASE64 | GCP_SA_KEY_BASE64 ; | |
secret/data/gcp_credentials/basedosdados-dev GCP_PROJECT_ID | GCP_PROJECT_ID ; | |
secret/data/gcp_credentials/basedosdados-dev GKE_CLUSTER_NAME | GKE_CLUSTER_NAME ; | |
secret/data/gcp_credentials/basedosdados-dev GKE_CLUSTER_ZONE | GKE_CLUSTER_ZONE ; | |
- name: Setup Google Cloud CLI | |
uses: google-github-actions/[email protected] | |
with: | |
service_account_key: ${{ steps.import_secrets.outputs.GCP_SA_KEY_BASE64 }} | |
project_id: ${{ steps.import_secrets.outputs.GCP_PROJECT_ID }} | |
export_default_credentials: true | |
- name: Get GKE credentials | |
uses: google-github-actions/[email protected] | |
with: | |
cluster_name: ${{ steps.import_secrets.outputs.GKE_CLUSTER_NAME }} | |
location: ${{ steps.import_secrets.outputs.GKE_CLUSTER_ZONE }} | |
credentials: ${{ steps.import_secrets.outputs.GCP_SA_KEY_BASE64 }} | |
- name: Write values.yaml file | |
run: | | |
cat << EOF > values.yaml | |
website: | |
name: "basedosdados-website-staging" | |
image: | |
name: "ghcr.io/${{ github.repository_owner }}/${{ github.event.repository.name }}" | |
tag: "staging" | |
pullPolicy: "Always" | |
replicas: 1 | |
resources: | |
requests: | |
cpu: 100m | |
memory: 500Mi | |
limits: | |
cpu: 500m | |
memory: 1Gi | |
env: [] | |
envFrom: | |
- secretRef: | |
name: basedosdados-website-staging | |
ingress: | |
enabled: true | |
host: "staging.basedosdados.org" | |
annotations: | |
cert-manager.io/issuer: "letsencrypt-production" | |
kubernetes.io/ingress.class: nginx | |
nginx.ingress.kubernetes.io/rewrite-target: / | |
nginx.ingress.kubernetes.io/ssl-redirect: "true" | |
tls: | |
- hosts: | |
- "staging.basedosdados.org" | |
secretName: "staging-basedosdados-org-tls" | |
EOF | |
- name: Deploy using Helm | |
run: | | |
helm upgrade --install basedosdados-website-staging charts/basedosdados-website/. -n website -f values.yaml --wait |