Skip to content

Set env

Set env #13

Workflow file for this run

# Deploy the site to AWS S3 on a push to specific branches
name: Deploy Production - MCP (S3)
permissions:
id-token: write
pages: write
contents: read
on:
push:
branches:
- 'main'
- 'develop'
- 'deploy-ghpages'
env:
NODE: 16
DOMAIN_PROD: https://d3az0w890ohf9k.cloudfront.net
DEPLOY_BUCKET_PROD: ogc-ospd-veda-frontend
DEPLOY_BUCKET_PROD_REGION: us-east-1
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Cancel Previous Runs
uses: styfle/[email protected]
with:
access_token: ${{ github.token }}
- name: Checkout
uses: actions/checkout@v3
with:
submodules: recursive
- name: Use Node.js ${{ env.NODE }}
uses: actions/setup-node@v1
with:
node-version: ${{ env.NODE }}
- name: Cache node_modules
uses: actions/cache@v2
id: cache-node-modules
with:
path: |
node_modules
.veda/ui/node_modules
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package.json') }}
- name: Cache dist
uses: actions/cache@v2
id: cache-dist
with:
path: dist
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ github.workflow }}-${{ github.sha }}
- name: Install
run: ./.veda/setup
- name: Build production
env:
MAPBOX_TOKEN: ${{secrets.MAPBOX_TOKEN}}
GOOGLE_TAG_MANAGER_ID: ${{secrets.GOOGLE_TAG_MANAGER_ID}}
GOOGLE_TAG_AUTH: ${{secrets.GOOGLE_TAG_AUTH}}
GOOGLE_TAG_PREVIEW: ${{secrets.GOOGLE_TAG_PREVIEW}}
run: PUBLIC_URL="${{ env.DOMAIN_PROD }}" yarn build
deploy:
runs-on: ubuntu-latest
needs: build
environment:
name: github-pages
steps:
- name: Checkout
uses: actions/checkout@v3
with:
submodules: recursive
- name: Restore node_modules
uses: actions/cache@v2
id: cache-node-modules
with:
path: |
node_modules
.veda/ui/node_modules
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package.json') }}
- name: Restore dist cache
uses: actions/cache@v2
id: cache-dist
with:
path: dist
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ github.workflow }}-${{ github.sha }}
- name: Use Node.js ${{ env.NODE }}
uses: actions/setup-node@v1
with:
node-version: ${{ env.NODE }}
# - name: Configure AWS Credentials
# uses: aws-actions/configure-aws-credentials@v2
# with:
# role-to-assume: ${{ secrets.DEPLOYMENT_ROLE_ARN }}
# role-session-name: "veda-dashboard-prod-deployment"
# aws-region: ${{ env.DEPLOY_BUCKET_PROD_REGION }}
# - name: Deploy to S3 Production
# run: |
# aws s3 sync ./dist s3://${{ env.DEPLOY_BUCKET_PROD }} --cache-control max-age=604800 --delete
# - name: Invalidate CloudFront cache
# uses: oneyedev/aws-cloudfront-invalidation@v1
# with:
# distribution-id: ${{ secrets.CLOUDFRONT_DISTRIBUTION_PROD }}
- name: Upload artifact
uses: actions/upload-pages-artifact@v3
with:
path: ./dist
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v4