Deploy #13
Workflow file for this run
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 | |
# Do we even need these? | |
env: | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_KEY }} | |
on: | |
workflow_dispatch: | |
inputs: | |
environment: | |
description: 'Environment name' | |
required: true | |
type: choice | |
default: 'dev' | |
options: | |
- dev | |
- testing | |
- staging | |
incrementVersion: | |
description: 'Bump Version?' | |
type: boolean | |
required: false | |
versionType: | |
description: 'Version to bump (major.minor.patch)' | |
type: choice | |
default: 'patch' | |
options: | |
- patch | |
- minor | |
- major | |
jobs: | |
deploy: | |
env: | |
PACKAGE_LOCATION: packages/app | |
ZAMBDAS_LOCATION: packages/zambdas | |
SLACK_NOTIFICATION_SERVICE_NAME: zapehr-telehealth | |
runs-on: ubuntu-latest | |
environment: ${{ github.event.inputs.environment }} | |
strategy: | |
matrix: | |
node-version: [18.18.0] | |
steps: | |
- name: Install SSH Client | |
uses: webfactory/[email protected] | |
with: | |
ssh-private-key: | | |
${{ secrets.OTTEHR_PRIVATE_SSH_KEY }} | |
${{ secrets.BUMP_VERSION }} | |
- uses: actions/checkout@v3 | |
with: | |
ssh-key: ${{ secrets.BUMP_VERSION }} | |
- name: Use Node.js ${{ matrix.node-version }} | |
uses: actions/setup-node@v2 | |
with: | |
node-version: ${{ matrix.node-version }} | |
- uses: pnpm/action-setup@v2 | |
with: | |
version: 8 | |
- name: Install Vercel CLI | |
run: pnpm install --global vercel@latest | |
- name: Pull Vercel Environment Information | |
run: cd ${{ env.PACKAGE_LOCATION }} && vercel pull --yes --environment=preview --token=${{ secrets.VERCEL_TOKEN }} --scope ottehr | |
- name: Build Project Artifacts | |
run: cd ${{ env.PACKAGE_LOCATION }} && vercel build --token=${{ secrets.VERCEL_TOKEN }} --scope ottehr | |
- name: Create secrets file from github secrets | |
id: create-json | |
uses: jsdaniell/[email protected] | |
with: | |
name: 'secrets.json' | |
json: ${{ secrets.OTTEHR_SECRETS_JSON }} | |
- name: Move env file into .env folder | |
run: mkdir -p ${{ env.ZAMBDAS_LOCATION }}/.env/ && mv secrets.json ${{ env.ZAMBDAS_LOCATION }}/.env/${{ secrets.ENVIRONMENT }}.json | |
- name: Increase version if input dictates. | |
if: ${{ github.event.inputs.incrementVersion == 'true' }} | |
run: > | |
git config --local user.email "[email protected]" | |
git config --local user.name "GitHub Action Bump Version" | |
pnpm version ${{ github.event.inputs.versionType }} | |
- name: Push increased version if input dictates. | |
if: ${{ github.event.inputs.incrementVersion == 'true' }} | |
uses: ad-m/github-push-action@master | |
with: | |
ssh: true | |
branch: ${{ github.ref }} | |
- name: Get Version Number from package.json for build notifications. | |
id: package-version | |
uses: martinbeentjes/[email protected] | |
with: | |
path: ${{ env.PACKAGE_LOCATION }} | |
- name: Install dependencies | |
run: pnpm install | |
- name: Deploy app | |
run: | | |
url="$(cd ${{ env.PACKAGE_LOCATION }} && vercel deploy --prebuilt --token=${{ secrets.VERCEL_TOKEN }})" --scope ottehr | |
cd ${{ env.PACKAGE_LOCATION }} && vercel alias --token=${{ secrets.VERCEL_TOKEN }} --scope ottehr set "$url" ${{ github.event.inputs.environment }}.ottehr.com | |
- name: Setup zapehr secrets | |
run: cd ${{ env.ZAMBDAS_LOCATION }} && pnpm run setup-zapehr-secrets ${{ github.event.inputs.environment }} | |
- name: Deploy zambdas | |
run: cd ${{ env.ZAMBDAS_LOCATION }} && pnpm run deploy-zambdas ${{ github.event.inputs.environment }} | |
- name: Notify Slack | |
if: always() | |
uses: edge/[email protected] | |
env: | |
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }} | |
BRANCH: ${{ github.ref }} | |
PACKAGE_VERSION: ${{ steps.package-version.outputs.current-version }} | |
with: | |
channel: '#zapehr-notifications' | |
status: ${{ job.status }} | |
success_text: '${env.GITHUB_WORKFLOW} (${env.GITHUB_RUN_NUMBER}) deploy completed successfully' | |
failure_text: '${env.GITHUB_WORKFLOW} (${env.GITHUB_RUN_NUMBER}) deploy failed' | |
cancelled_text: '${env.GITHUB_WORKFLOW} (${env.GITHUB_RUN_NUMBER}) deploy was cancelled' | |
fields: | | |
[{ "title": "Service", "value": "${env.SLACK_NOTIFICATION_SERVICE_NAME}", "short": true }, | |
{ "title": "Action URL", "value": "${env.GITHUB_SERVER_URL}/${env.GITHUB_REPOSITORY}/actions/runs/${env.GITHUB_RUN_ID}"}, | |
{ "title": "Branch", "value": "${env.BRANCH}", "short": true }, | |
{ "title": "Environment", "value": "${env.ENVIRONMENT}", "short": true }, | |
{ "title": "Version", "value": "${env.PACKAGE_VERSION}", "short": true }] | |