Deploy Website #1706
This file contains hidden or 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 Website | |
on: | |
workflow_dispatch: | |
inputs: | |
environment: | |
description: 'The environment used as target' | |
type: choice | |
required: true | |
default: dev | |
options: | |
- dev | |
- uat | |
- prod | |
# Allows external webhook trigger | |
repository_dispatch: | |
types: | |
- webhook | |
# Runs at 11 p.m. UTC every day | |
schedule: | |
- cron: '0 23 * * *' | |
# These permissions are needed to interact with GitHub's OIDC Token endpoint. | |
permissions: | |
id-token: write | |
contents: write | |
env: | |
LATEST_DEPLOYED_IN_PRODUCTION_TAG: latest-deployed-in-production | |
jobs: | |
manual_deploy: | |
name: Deploy to S3 (manual on ${{ inputs.environment }}) | |
if: github.event_name == 'workflow_dispatch' | |
runs-on: codebuild-${{ inputs.environment }}-github-runner-${{ github.run_id }}-${{ github.run_attempt }} | |
environment: ${{ inputs.environment }} | |
env: | |
SKIP_HUSKY_PRE_PUSH: true | |
concurrency: | |
group: ${{ github.workflow }}-${{ inputs.environment }} | |
cancel-in-progress: false | |
steps: | |
- name: Checkout | |
uses: actions/checkout@8e5e7e5ab8b370d6c329ec480221332ada57f0ab | |
with: | |
ref: ${{ github.ref_name }} | |
- name: Increase action disk space | |
uses: ./.github/actions/increase-disk-space | |
- name: Deploy website | |
uses: ./.github/actions/deploy | |
with: | |
environment: ${{ inputs.environment }} | |
path_to_gitbook_docs: ${{ github.workspace }}/apps/nextjs-website/docs | |
cookie_domain_script: ${{ secrets.COOKIE_DOMAIN_SCRIPT }} | |
cookie_script_url: ${{ vars.NEXT_PUBLIC_COOKIE_SCRIPT_URL }} | |
cookie_category: ${{ vars.NEXT_PUBLIC_COOKIE_CATEGORY }} | |
use_new_cookie: ${{ vars.NEXT_PUBLIC_USE_NEW_COOKIE }} | |
allow_crawler: ${{ vars.ALLOW_CRAWLER }} | |
iam_role: ${{ secrets.DEPLOY_IAM_ROLE }} | |
bucket: ${{ vars.S3_BUCKET_NAME }} | |
static_contents_url: ${{ vars.STATIC_CONTENTS_URL }} | |
cloudfront_distribution_id: ${{ vars.CLOUDFRONT_DISTRIBUTION_ID }} | |
cognito_user_pool_id: ${{ secrets.NEXT_PUBLIC_COGNITO_USER_POOL_ID }} | |
cognito_identity_pool_id: ${{ secrets.NEXT_PUBLIC_COGNITO_IDENTITY_POOL_ID }} | |
cognito_app_client_id: ${{ secrets.NEXT_PUBLIC_COGNITO_USER_POOL_WEB_CLIENT_ID }} | |
chatbot_host: ${{ vars.NEXT_PUBLIC_CHATBOT_HOST }} | |
chat_max_history_messages: ${{ vars.NEXT_PUBLIC_CHAT_MAX_HISTORY_MESSAGES }} | |
website_name: ${{ vars.NEXT_PUBLIC_WEBSITE_NAME }} | |
organization_name: ${{ vars.NEXT_PUBLIC_ORGANIZATION_NAME }} | |
organization_logo: ${{ vars.NEXT_PUBLIC_ORGANIZATION_LOGO }} | |
organization_social_links: ${{ vars.NEXT_PUBLIC_ORGANIZATION_SOCIAL_LINKS }} | |
chatbot_active: ${{ vars.NEXT_PUBLIC_CHATBOT_ACTIVE }} | |
strapi_endpoint: ${{ vars.STRAPI_ENDPOINT }} | |
strapi_api_token: ${{ secrets.STRAPI_API_TOKEN }} | |
s3_access_key_id: ${{ secrets.S3_ACCESS_KEY_ID }} | |
s3_secret_access_key: ${{ secrets.S3_SECRET_ACCESS_KEY }} | |
fetch_from_strapi: ${{ vars.FETCH_FROM_STRAPI }} | |
matomo_script_src: ${{ vars.NEXT_PUBLIC_MATOMO_SCRIPT_SRC }} | |
webinar_question_lifetime_in_seconds: ${{ vars.NEXT_PUBLIC_WEBINAR_QUESTION_LIFETIME_IN_SECONDS }} | |
- name: Move nextjs-website@latest-deployed-in-production tag to the commit just deployed | |
shell: bash | |
run: | | |
# Extract tag from GitHub ref | |
TAG=${{ github.ref_name }} | |
# Ensure we are dealing with a valid front-end tag | |
if [[ ! $TAG =~ ^nextjs-website@[0-9]+(\.[0-9]+)*$ ]]; then | |
echo "Error: '$TAG' is not a valid version tag. Skipping tag update." | |
exit 0 | |
fi | |
# Check if the environment is "prod" | |
if [[ "${{ inputs.environment }}" != "prod" ]]; then | |
echo "Error: ${{ inputs.environment }} environment is not 'prod'. Skipping tag update." | |
exit 0 | |
fi | |
# Get commit hash associated with the tag | |
COMMIT_HASH=$(git rev-list -n 1 $TAG || echo "") | |
# Exit if the commit hash is empty | |
if [ -z "$COMMIT_HASH" ]; then | |
echo "Error: No commit found for tag '$TAG'. Skipping tag update." | |
exit 0 | |
fi | |
# Set up Git | |
git config user.name "github-actions[bot]" | |
git config user.email "github-actions[bot]@users.noreply.github.com" | |
# Move the LATEST_DEPLOYED_IN_PRODUCTION_TAG to the commit just deployed | |
git tag -f nextjs-website@$LATEST_DEPLOYED_IN_PRODUCTION_TAG $COMMIT_HASH | |
# Some remote repositories (e.g., GitHub) may not update tags automatically. | |
# Ensure old tag is deleted remotely before pushing the new one | |
git push --delete origin nextjs-website@$LATEST_DEPLOYED_IN_PRODUCTION_TAG || true | |
git push origin nextjs-website@$LATEST_DEPLOYED_IN_PRODUCTION_TAG --force | |
scheduled_deploy: | |
name: Scheduled Deploy to S3 | |
if: github.event_name == 'schedule' | |
runs-on: codebuild-prod-github-runner-${{ github.run_id }}-${{ github.run_attempt }} | |
environment: prod | |
concurrency: | |
group: ${{ github.workflow }}-scheduled | |
cancel-in-progress: false | |
steps: | |
- name: Checkout specific tag | |
uses: actions/checkout@8e5e7e5ab8b370d6c329ec480221332ada57f0ab | |
with: | |
ref: nextjs-website@${{ env.LATEST_DEPLOYED_IN_PRODUCTION_TAG }} | |
- name: Increase action disk space | |
uses: ./.github/actions/increase-disk-space | |
- name: Deploy website | |
uses: ./.github/actions/deploy | |
with: | |
environment: prod | |
ref: nextjs-website@${{ env.LATEST_DEPLOYED_IN_PRODUCTION_TAG }} | |
path_to_gitbook_docs: ${{ github.workspace }}/apps/nextjs-website/docs | |
cookie_domain_script: ${{ secrets.COOKIE_DOMAIN_SCRIPT }} | |
cookie_script_url: ${{ vars.NEXT_PUBLIC_COOKIE_SCRIPT_URL }} | |
cookie_category: ${{ vars.NEXT_PUBLIC_COOKIE_CATEGORY }} | |
use_new_cookie: ${{ vars.NEXT_PUBLIC_USE_NEW_COOKIE }} | |
allow_crawler: ${{ vars.ALLOW_CRAWLER }} | |
iam_role: ${{ secrets.DEPLOY_IAM_ROLE }} | |
bucket: ${{ vars.S3_BUCKET_NAME }} | |
static_contents_url: ${{ vars.STATIC_CONTENTS_URL }} | |
cloudfront_distribution_id: ${{ vars.CLOUDFRONT_DISTRIBUTION_ID }} | |
cognito_user_pool_id: ${{ secrets.NEXT_PUBLIC_COGNITO_USER_POOL_ID }} | |
cognito_identity_pool_id: ${{ secrets.NEXT_PUBLIC_COGNITO_IDENTITY_POOL_ID }} | |
cognito_app_client_id: ${{ secrets.NEXT_PUBLIC_COGNITO_USER_POOL_WEB_CLIENT_ID }} | |
chatbot_host: ${{ vars.NEXT_PUBLIC_CHATBOT_HOST }} | |
chat_max_history_messages: ${{ vars.NEXT_PUBLIC_CHAT_MAX_HISTORY_MESSAGES }} | |
website_name: ${{ vars.NEXT_PUBLIC_WEBSITE_NAME }} | |
organization_name: ${{ vars.NEXT_PUBLIC_ORGANIZATION_NAME }} | |
organization_logo: ${{ vars.NEXT_PUBLIC_ORGANIZATION_LOGO }} | |
organization_social_links: ${{ vars.NEXT_PUBLIC_ORGANIZATION_SOCIAL_LINKS }} | |
chatbot_active: ${{ vars.NEXT_PUBLIC_CHATBOT_ACTIVE }} | |
strapi_endpoint: ${{ vars.STRAPI_ENDPOINT }} | |
strapi_api_token: ${{ secrets.STRAPI_API_TOKEN }} | |
s3_access_key_id: ${{ secrets.S3_ACCESS_KEY_ID }} | |
s3_secret_access_key: ${{ secrets.S3_SECRET_ACCESS_KEY }} | |
fetch_from_strapi: ${{ vars.FETCH_FROM_STRAPI }} | |
matomo_script_src: ${{ vars.NEXT_PUBLIC_MATOMO_SCRIPT_SRC }} | |
webinar_question_lifetime_in_seconds: ${{ vars.NEXT_PUBLIC_WEBINAR_QUESTION_LIFETIME_IN_SECONDS }} |