Merge pull request #415 from lbl-srg/dependabot/npm_and_yarn/server/m… #63
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: ctrl-flow prod deployment | |
on: | |
push: | |
branches: main | |
env: | |
LBL_STAGE: production | |
DEBIAN_FRONTEND: noninteractive | |
TEMPLATES_FILE_NAME: templates.json | |
jobs: | |
build-template-json: | |
runs-on: ubuntu-22.04 | |
defaults: | |
run: | |
working-directory: server | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js ${{ matrix.node-version }} | |
uses: actions/setup-node@v4 | |
with: | |
node-version: ${{ matrix.node-version }} | |
cache: "npm" | |
cache-dependency-path: client/package-lock.json | |
- name: Build Docker Image for LBL Parser and API Server | |
run: docker build -t lbl-api-cdk . | |
- name: Create A Container and copy file | |
run: | | |
CONTAINER_ID=$(docker create lbl-api-cdk) | |
docker cp $CONTAINER_ID:/server/scripts/templates.json $GITHUB_WORKSPACE/$TEMPLATES_FILE_NAME | |
echo "CONTAINER_ID=$CONTAINER_ID" >> $GITHUB_ENV | |
- name: Copy templates.json out of the container | |
run: docker cp $CONTAINER_ID:/server/scripts/templates.json $TEMPLATES_FILE_NAME | |
- name: Upload templates.json as an artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: template | |
path: ${{github.workspace}}/${{env.TEMPLATES_FILE_NAME}} | |
retention-days: 3 | |
- name: Remove the container | |
run: docker rm -v ${{env.CONTAINER_ID}} | |
deploy: | |
needs: build-template-json | |
runs-on: ubuntu-22.04 | |
defaults: | |
run: | |
working-directory: cdk | |
strategy: | |
matrix: | |
node-version: [20.x] | |
# See supported Node.js release schedule at https://nodejs.org/en/about/releases/ | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js ${{ matrix.node-version }} | |
uses: actions/setup-node@v4 | |
with: | |
node-version: ${{ matrix.node-version }} | |
cache: "npm" | |
cache-dependency-path: client/package-lock.json | |
- name: Configure AWS CLI | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
aws-secret-access-key: ${{secrets.AWS_SECRET_ACCESS_KEY }} | |
aws-region: us-east-2 | |
- name: Update template.json | |
uses: actions/download-artifact@v4 | |
with: | |
name: template | |
path: ${{github.workspace}}/client/src/data | |
- name: Install node packages | |
run: | | |
# Updated the lib | |
npm i -D aws-cdk@latest | |
rm -fr node_modules package-lock.json cdk.out | |
npm i | |
- name: Synthesize cloud formation template | |
run: npx aws-cdk synth | |
- name: Deploy stack | |
run: npx aws-cdk deploy --require-approval never --outputs-file cdk.out/cdk-outputs.json | |
- name: Set environment variables and deploy to s3 | |
run: | | |
export API_ARN=$(jq -r .LblCdkStack${{env.LBL_STAGE}}.LbLALBArn cdk.out/cdk-outputs.json) | |
aws elbv2 modify-load-balancer-attributes --load-balancer-arn $API_ARN --attributes Key=idle_timeout.timeout_seconds,Value=300 | |
export REACT_APP_API=https://ctrl-flow.lbl.gov/api | |
cd $GITHUB_WORKSPACE/client | |
npm i | |
npm run buildForS3 | |
cd $GITHUB_WORKSPACE/client | |
aws s3 rm s3://lbl-client-${LBL_STAGE}/ --recursive | |
aws s3 sync build s3://lbl-client-${LBL_STAGE}/ | |
- name: Invalidate Cloudfront | |
uses: chetan/invalidate-cloudfront-action@v2 | |
env: | |
DISTRIBUTION: ${{ secrets.PROD_CLOUDFRONT_ID }} | |
PATHS: "/*" | |
AWS_REGION: us-east-2 | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} |