Skip to content

Deploy-V2

Deploy-V2 #3

Workflow file for this run

name: Deploy-V2
on:
workflow_dispatch:
inputs:
environment:
description: "Choose environment"
required: true
default: "acceptance"
type: choice
options:
- "acceptance"
- "production"
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Node.js version
uses: actions/setup-node@v4
with:
node-version: "20.x"
cache: "npm"
- name: "πŸ“© npm install"
run: npm ci
- name: "πŸ— npm build"
run: |
npm ci
cp .env.example .env # an env file is needed for `build`
npm run db:generate
npm run build
npm ci --prod
rm .env
- name: "πŸ“¦ Package artifact"
# `./*`: the current directory
# `.next`: explicitly also zip this hidden directory.
# `-r`: recursive
# `-y`: preserve symlinks
run: zip -y release.zip ./* .next -r
- name: "πŸ“€ Upload artifact"
uses: actions/upload-artifact@v4
with:
name: node-app
path: release.zip
deploy:
runs-on: ubuntu-latest
needs: build
environment:
name: ${{ github.event.inputs.environment }}
url: ${{ steps.deploy-to-webapp.outputs.webapp-url }}
permissions:
id-token: write #This is required for requesting the JWT
steps:
- name: "πŸ“© Download artifact"
uses: actions/download-artifact@v4
with:
name: node-app
- name: "πŸ’€ Unzip artifact"
run: unzip release.zip
- name: "πŸ™Œ Prepare"
run: az storage file download --share-name import --path survey.csv --account-name $AZURE_STORAGE_ACCOUNT --account-key $AZURE_STORAGE_KEY --dest import/survey.csv
env:
AZURE_STORAGE_ACCOUNT: ${{ secrets.AZURE_STORAGE_ACCOUNT }}
AZURE_STORAGE_KEY: ${{ secrets.AZURE_STORAGE_KEY }}
- name: "πŸš€ Deploy"
id: deploy-to-webapp
uses: azure/webapps-deploy@v2
with:
app-name: ${{ secrets.APP_SERVICE_NAME_V2 }}
slot-name: "production"
package: .
publish-profile: ${{ secrets.AZURE_APP_SERVICE_PUBLISH_PROFILE_V2 }}