Skip to content

Merge pull request #210 from kakao-tech-campus-2nd-step3/Week11 #30

Merge pull request #210 from kakao-tech-campus-2nd-step3/Week11

Merge pull request #210 from kakao-tech-campus-2nd-step3/Week11 #30

Workflow file for this run

name: Front Deployment
on:
push:
branches:
- Master
jobs:
build:
name: react build & deploy
runs-on: ubuntu-latest
steps:
- name: Checkout Github Action
uses: actions/checkout@v3
- name: Check Node v
run: node -v
- name: Get npm cache directory
id: npm-cache-dir
run: |
echo "::set-output name=dir::$(npm config get cache)"
- uses: actions/cache@v3
id: npm-cache
with:
path: ${{ steps.npm-cache-dir.outputs.dir }}
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.os }}-node-
- name: install npm dependencies
run: npm install
- name: react build
env:
VITE_BASE_URL: ${{ secrets.VITE_BASE_URL }}
VITE_LOGIN_URL: ${{ secrets.VITE_LOGIN_URL }}
VITE_DOMAIN: ${{ secrets.VITE_DOMAIN }}
run: npm run build
- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v2
with:
aws-access-key-id: ${{ secrets.AWS_S3_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_S3_SECRET_ACCESS_KEY_ID }}
aws-region: us-east-1
- name: Upload to S3
env:
BUCKET_NAME: ${{ secrets.AWS_S3_BUCKET_NAME }}
run: |
aws s3 sync \
./dist s3://${{ secrets.AWS_S3_BUCKET_NAME }}
- name: CloudFront Invalidation
env:
CLOUD_FRONT_ID: ${{ secrets.AWS_CLOUDFRONT_ID }}
run: |
aws cloudfront create-invalidation \
--distribution-id $CLOUD_FRONT_ID --paths /*
permissions:
id-token: write
contents: write