Skip to content

production-deployment #8

production-deployment

production-deployment #8

Workflow file for this run

name: Deploy to production environment
# Controls when the action will run
on:
# Triggers the workflow on repository-dispatch event
repository_dispatch:
types: [production-deployment]
# This workflow is made up of one job that calls the reusable workflow in graasp-deploy
jobs:
graasp-deploy-ecs-workflow:
# Replace with repository name
name: CD caller template
# Replace 'main' with the hash of a commit, so it points to an specific version of the reusable workflow that is used
uses: graasp/graasp-deploy/.github/workflows/library-deploy-prod.yml@v1
# abort previous deployment if a newer one is in progress
concurrency:
group: deploy-production
cancel-in-progress: true
# Replace input ecs-task-definition with template file. Format: '.aws/<name>-prod.json'
with:
app-name: graasp-library
app-version: ${{ github.event.client_payload.tag }}
next-public-graasp-account-host: ${{ vars.NEXT_PUBLIC_GRAASP_ACCOUNT_HOST_PROD }}
ecs-task-definition: '.aws/graasp-library-prod.json'
tag: ${{ github.event.client_payload.tag }}
# Insert required secrets based on repository with the following format: ${{ secrets.SECRET_NAME }}
secrets:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID_PROD }}
aws-region: ${{ secrets.AWS_REGION_PROD }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY_PROD }}
container-name-library: ${{ secrets.CONTAINER_NAME_GRAASP_EXPLORE_PROD }}
ecr-repository: ${{ secrets.ECR_REPOSITORY_GRAASP_EXPLORE_PROD }}
ecs-cluster: ${{ secrets.ECS_CLUSTER_GRAASP_EXPLORE_PROD }}
ecs-service: ${{ secrets.ECS_SERVICE_GRAASP_EXPLORE_PROD }}
next-public-api-host: ${{ secrets.NEXT_PUBLIC_API_HOST_PROD }}
next-public-domain: ${{ secrets.REACT_APP_DOMAIN_PROD }}
next-public-ga-measurement-id: ${{ secrets.REACT_APP_GA_MEASUREMENT_ID_PROD }}
next-public-graasp-analytics-host: ${{ secrets.ANALYZER_CLIENT_HOST_PROD }}
next-public-graasp-auth-host: ${{ secrets.NEXT_PUBLIC_GRAASP_AUTH_HOST_PROD }}
next-public-graasp-builder-host: ${{ secrets.BUILDER_CLIENT_HOST_PROD }}
next-public-graasp-perform-host: ${{ secrets.PLAYER_CLIENT_HOST_PROD }}
next-public-graasper-id: ${{ secrets.NEXT_PUBLIC_GRAASPER_ID }}
next-public-show-notifications: ${{ secrets.NEXT_PUBLIC_SHOW_NOTIFICATIONS }}
# to be removed ! we do not use it anymore
next-public-published-tag-id: ${{ secrets.NEXT_PUBLIC_PUBLISHED_TAG_ID }}
next-public-sentry-dsn: ${{ secrets.SENTRY_DSN }}
next-public-sentry-env: production
port: ${{ secrets.PORT }}