Merge pull request #2 from conganhhcmus/feature/support-analytics-page #15
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: Check, Build & Deployment | |
on: | |
push: | |
branches: [master] | |
pull_request: | |
branches: [master] | |
types: [opened, synchronize, reopened, edited] | |
jobs: | |
check: | |
name: Check | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js 20.x | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 20.x | |
cache: yarn | |
- name: Cache node_modules | |
uses: actions/cache@v4 | |
id: yarn-cache | |
with: | |
path: ./node_modules | |
key: ${{ runner.os }}-node_modules-${{ hashFiles('yarn.lock') }} | |
restore-keys: | | |
${{ runner.os }}-node_modules- | |
- name: Install packages | |
run: yarn install | |
- name: Check coding conventions | |
run: | | |
yarn ts-check | |
yarn prettier-check | |
yarn cspell-check | |
- if: github.event_name == 'push' | |
run: echo "${{ github.event.head_commit.message }}" | yarn commitlint | |
- if: github.event_name == 'pull_request' | |
run: echo "${{ github.event.pull_request.title }}" | yarn commitlint | |
deploy-on-aws: | |
name: Deploy AWS | |
env: | |
PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }} | |
HOSTNAME: ${{secrets.SSH_HOST}} | |
USER_NAME: ${{secrets.USER_NAME}} | |
environment: Production | |
if: github.ref == 'refs/heads/master' | |
needs: [check] | |
runs-on: ubuntu-latest | |
steps: | |
- name: Deploy to AWS | |
run: | | |
echo "$PRIVATE_KEY" > private_key && chmod 600 private_key | |
ssh -o StrictHostKeyChecking=no -i private_key ${USER_NAME}@${HOSTNAME} ' | |
# Now we have got the access of EC2 and we will start the deploy . | |
cd /home/ec2-user/youth-book-api && | |
git checkout master && | |
git fetch --all && | |
git reset --hard origin/master && | |
git pull origin master && | |
yarn && | |
yarn build && | |
pm2 stop ./dist/app.js && | |
pm2 start ./dist/app.js | |
' | |
build: | |
name: Build | |
needs: [check] | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js 20.x | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 20.x | |
cache: yarn | |
- name: Cache node_modules | |
uses: actions/cache@v4 | |
id: yarn-cache | |
with: | |
path: ./node_modules | |
key: ${{ runner.os }}-node_modules-${{ hashFiles('yarn.lock') }} | |
restore-keys: | | |
${{ runner.os }}-node_modules- | |
- name: Install packages | |
run: yarn install | |
- name: Build code | |
run: yarn build | |
- name: Upload build folder | |
uses: actions/upload-artifact@v4 | |
with: | |
name: build-folder | |
path: ./dist | |
overwrite: true | |
retention-days: 7 | |
deploy-on-vercel: | |
name: Deploy Vercel | |
env: | |
VERCEL_ORG_ID: ${{ secrets.VERCEL_ORG_ID }} | |
VERCEL_PROJECT_ID: ${{ secrets.VERCEL_PROJECT_ID }} | |
VERCEL_TOKEN: ${{ secrets.VERCEL_TOKEN }} | |
environment: Production-BK | |
if: github.ref == 'refs/heads/master' | |
needs: [build] | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js 20.x | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 20.x | |
cache: yarn | |
- name: Download build folder | |
uses: actions/download-artifact@v4 | |
with: | |
name: build-folder | |
path: ./dist | |
- name: Install Vercel CLI | |
run: yarn global add vercel@latest | |
- name: Pull Vercel Environment Information | |
run: vercel pull --yes --environment=production --token=$VERCEL_TOKEN | |
- name: Build Project Artifacts | |
run: vercel build --prod --token=$VERCEL_TOKEN | |
- name: Deploy Project Artifacts to Vercel | |
run: vercel deploy --prebuilt --prod --token=$VERCEL_TOKEN |