feat: amplify deployment #9
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: Deploy Next.js to AWS Amplify | |
on: | |
pull_request: | |
branches: [ "main" ] | |
paths: | |
- .github/workflows/aws-amplify.yml | |
- client/** | |
- assistant/** | |
env: | |
AWS_REGION: ${{ vars.AWS_REGION }} | |
NEXT_PUBLIC_API_DOMAIN: ${{ vars.NEXT_PUBLIC_API_DOMAIN }} | |
AMPLIFY_APP_ID: ${{ vars.AMPLIFY_APP_ID }} | |
permissions: | |
id-token: write | |
contents: read | |
jobs: | |
deploy: | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
node-version: [18.x] | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Cache node modules | |
uses: actions/cache@v2 | |
with: | |
path: client/node_modules | |
key: ${{ runner.os }}-node-${{ hashFiles('client/**/package-lock.json') }} | |
restore-keys: | | |
${{ runner.os }}-node- | |
- name: Node ${{ matrix.node-version }} | |
uses: actions/setup-node@v3 | |
with: | |
node-version: ${{ matrix.node-version }} | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
role-to-assume: arn:aws:iam::654654285942:role/Github-OIDC | |
audience: sts.amazonaws.com | |
aws-region: ${{ env.AWS_REGION }} | |
- name: Configure Amplify CLI | |
run: npm install -g @aws-amplify/cli | |
- name: Install Dependencies | |
run: npm install | |
working-directory: ./client # 仅在 ./client 目录下安装 Next.js 项目的依赖项 | |
- name: Build Amplify App | |
run: npm run build | |
working-directory: ./client # 仅在 ./client 目录下构建 Next.js 应用程序 | |
- name: Initialize Amplify | |
run: | | |
amplify pull --appId ${{ secrets.AMPLIFY_APP_ID }} --envName dev --yes | |
amplify env checkout dev | |
- name: Deploy to Amplify | |
env: | |
AMPLIFY_APP_ID: ${{ env.AMPLIFY_APP_ID }} | |
AMPLIFY_BRANCH: dev | |
run: amplify push --y |