From dbd1d60d011ac8c7136ee8bd14427846a2187d51 Mon Sep 17 00:00:00 2001 From: Nischal Shrestha <39024181+nischalstha9@users.noreply.github.com> Date: Thu, 27 Jun 2024 17:42:54 +0545 Subject: [PATCH] Add CICD for Frontend to push static to S3 (#12) * feat: add CI for frontend * fix: add env stage --- ...y.yml => build_and_deploy_DTM_backend.yml} | 4 +- .../build_and_deploy_DTM_frontend.yml | 78 +++++++++++++++++++ 2 files changed, 81 insertions(+), 1 deletion(-) rename .github/workflows/{build_and_deploy.yml => build_and_deploy_DTM_backend.yml} (96%) create mode 100644 .github/workflows/build_and_deploy_DTM_frontend.yml diff --git a/.github/workflows/build_and_deploy.yml b/.github/workflows/build_and_deploy_DTM_backend.yml similarity index 96% rename from .github/workflows/build_and_deploy.yml rename to .github/workflows/build_and_deploy_DTM_backend.yml index 6201146a..d9df0a7a 100644 --- a/.github/workflows/build_and_deploy.yml +++ b/.github/workflows/build_and_deploy_DTM_backend.yml @@ -1,9 +1,11 @@ -name: Build and Deploy Drone Tasking Manager +name: Build and Deploy Drone Tasking Manager Backend on: push: branches: - main + paths: + - src/backend/** workflow_dispatch: permissions: diff --git a/.github/workflows/build_and_deploy_DTM_frontend.yml b/.github/workflows/build_and_deploy_DTM_frontend.yml new file mode 100644 index 00000000..2da9a804 --- /dev/null +++ b/.github/workflows/build_and_deploy_DTM_frontend.yml @@ -0,0 +1,78 @@ +name: Build and Deploy Drone Tasking Manager Frontend + +on: + push: + branches: + - main + paths: + - src/frontend/** + workflow_dispatch: + +permissions: + id-token: write + contents: read + +env: + AWS_REGION: ap-south-1 + S3_BUCKET: dronetm + +jobs: + build: + name: Build JavaScript assets + runs-on: ubuntu-latest + environment: + name: ${{ github.ref_name }} + steps: + - name: Clone repository + uses: actions/checkout@v3 + with: + ref: ${{ github.ref_name }} + + - name: Use Node.js 19.x + uses: actions/setup-node@v1 + with: + node-version: 19.x + + - name: Install yarn + working-directory: ./src/frontend/ + run: npm install -g yarn + + - name: Cache node_modules + uses: actions/cache@v2 + with: + path: ./src/frontend/node_modules + key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }} + restore-keys: | + ${{ runner.os }}-build-${{ env.cache-name }}- + ${{ runner.os }}-build- + ${{ runner.os }}- + + - name: Write Environment Variables + id: write_env + working-directory: ./src/frontend/ + run: | + echo ${{ vars.FRONTEND_ENV_VARS }} > .env + + - name: Install dependencies + working-directory: ./src/frontend/ + run: yarn + + - name: Generate build + working-directory: ./src/frontend/ + run: | + yarn build + + - name: Setup AWS Credentials + uses: aws-actions/configure-aws-credentials@v4 + with: + audience: sts.amazonaws.com + aws-region: ${{ env.AWS_REGION }} + role-session-name: GH-Actions-${{ github.run_id }}-${{ github.run_attempt }} + role-to-assume: ${{ secrets.AWS_OIDC_ROLE_ARN }} + + - name: Copy Static Files to S3 + working-directory: ./src/frontend/ + run: | + pwd + ls -alh + aws s3 cp --recursive ./dist/* s3://dronetm/