Merge pull request #58 from berkingurcan/implement-active-passive-and… #11
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: Build - publish - deploy | |
on: | |
push: | |
branches: | |
- main | |
workflow_dispatch: | |
inputs: | |
docker_tag_prefix: | |
description: "Enter the Docker Tag Prefix (e.g adhoc-test)" | |
required: true | |
type: string | |
env: | |
ECR_REPOSITORY_URL: 673156464838.dkr.ecr.us-west-2.amazonaws.com | |
ECR_REPOSITORY_NAME: gpt-survey-summarizer | |
APPLICATION_NAME: gpt-survey-summarizer | |
DOCKER_TAG_PREFIX: ${{ github.event.inputs.docker_tag_prefix }} | |
PLATFORM: staging | |
NAMESPACE: governance | |
jobs: | |
build-publish-deploy: | |
name: Build Publish and Deploy Docker Image | |
runs-on: minafoundation-default-runners | |
steps: | |
- name: ⚙️ Set environment variables | |
run: | | |
echo "AWS_REGION=$AWS_REGION" >> $GITHUB_ENV | |
echo "DEPLOYMENT_ROLE_NAME=$DEPLOYMENT_ROLE_NAME" >> $GITHUB_ENV | |
echo "AWS_ROLE_DURATION_SECONDS=$AWS_ROLE_DURATION_SECONDS" >> $GITHUB_ENV | |
- name: 📥 Checkout | |
uses: actions/checkout@v4 | |
- name: 🦀 Get application version from package.json | |
id: application-version | |
uses: martinbeentjes/[email protected] | |
- name: 🏷️ Generate Tag | |
run: | | |
SHORT_SHA=$(echo $GITHUB_SHA | cut -c1-7) | |
if [ "${{ github.event_name }}" == "workflow_dispatch" ]; then | |
echo "TAG=${{ env.DOCKER_TAG_PREFIX }}-${{ steps.application-version.outputs.current-version }}-$SHORT_SHA" >> $GITHUB_ENV | |
elif [ "${{ github.event_name }}" == "push" ] && [ -n "${{ github.event.ref }}" ]; then | |
echo "TAG=${{ steps.application-version.outputs.current-version }}-$SHORT_SHA" >> $GITHUB_ENV | |
else | |
echo "Invalid event. Exiting..." | |
exit 1 | |
fi | |
- name: 🔑 ECR Login | |
id: login-ecr | |
uses: aws-actions/amazon-ecr-login@v2 | |
- name: 🔍 Check if Tag already exists | |
id: checktag | |
uses: tyriis/docker-image-tag-exists@main | |
with: | |
registry: ${{ env.ECR_REPOSITORY_URL}} | |
repository: ${{ env.ECR_REPOSITORY_NAME }} | |
tag: ${{ env.TAG }} | |
- name: 🛠️ Build and Push Docker | |
uses: mr-smithers-excellent/docker-build-push@v6 | |
if: steps.checktag.outputs.tag == 'not found' | |
with: | |
image: ${{ env.ECR_REPOSITORY_NAME }} | |
registry: ${{ env.ECR_REPOSITORY_URL }} | |
tags: ${{ env.TAG }} | |
- name: 🔑 Assume role | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
aws-region: ${{ env.AWS_REGION }} | |
role-to-assume: ${{ env.DEPLOYMENT_ROLE_NAME }} | |
role-session-name: ${{ env.DEPLOYMENT_ROLE_NAME }} | |
role-duration-seconds: ${{ env.AWS_ROLE_DURATION_SECONDS }} | |
- name: ⬇️ Get kubeconfig | |
run: aws eks update-kubeconfig --name $PLATFORM --region $AWS_REGION 1>/dev/null | |
# "*=" means we set the image for every container in the selected deployments | |
- name: 💿 Set deployment image | |
run: kubectl set image deployment "*=$ECR_REPOSITORY_URL/$ECR_REPOSITORY_NAME:$TAG" -l app.kubernetes.io/name=$APPLICATION_NAME -n $NAMESPACE | |
- name: ⏱️ Wait for deployment to be ready | |
run: kubectl rollout status deployment --timeout=10m -l app.kubernetes.io/name=$APPLICATION_NAME -n $NAMESPACE |