-
Notifications
You must be signed in to change notification settings - Fork 214
141 lines (122 loc) · 5.33 KB
/
build-and-deploy.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
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
- dev2
- 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: vercel pull --yes --environment=preview --token=${{ secrets.VERCEL_TOKEN }} --scope=ottehr --cwd=${{ env.PACKAGE_LOCATION }}
- name: Copy vercel env config file to vercel.json
run: cp ${{ env.PACKAGE_LOCATION }}/vercel/vercel-${{ github.event.inputs.environment }}.json ${{ env.PACKAGE_LOCATION }}/vercel.json
- name: Build Project Artifacts
run: vercel build --token=${{ secrets.VERCEL_TOKEN }} --scope=ottehr --cwd=packages/app
- 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/${{ github.event.inputs.environment }}.json
- name: Copy env file to local.env to support serverless package command
run: cp ${{ env.ZAMBDAS_LOCATION }}/.env/${{ github.event.inputs.environment }}.json ${{ env.ZAMBDAS_LOCATION }}/.env/local.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="$(vercel deploy --prebuilt --token=${{ secrets.VERCEL_TOKEN }} --scope=ottehr --cwd=${{ env.PACKAGE_LOCATION }})"
vercel alias --token=${{ secrets.VERCEL_TOKEN }} --scope=ottehr --cwd=${{ env.PACKAGE_LOCATION }} set "$url" ${{ github.event.inputs.environment }}.ottehr.com
- name: Setup zapehr secrets
run: cd ${{ env.ZAMBDAS_LOCATION }} && pnpm setup-zapehr-secrets:${{ github.event.inputs.environment }}
- name: Deploy zambdas
run: cd ${{ env.ZAMBDAS_LOCATION }} && pnpm 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": "${vars.ENVIRONMENT}", "short": true },
{ "title": "Version", "value": "${env.PACKAGE_VERSION}", "short": true }]