forked from novuhq/novu
-
Notifications
You must be signed in to change notification settings - Fork 0
119 lines (112 loc) · 4.13 KB
/
reusable-dashboard-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
name: Deploy Dashboard to Netlify
env:
NX_CLOUD_ACCESS_TOKEN: ${{ secrets.NX_CLOUD_ACCESS_TOKEN }}
# Controls when the action will run. Triggers the workflow on push or pull request
on:
workflow_call:
inputs:
environment:
required: true
type: string
react_app_api_url:
required: false
type: string
react_app_ws_url:
required: true
type: string
react_app_webhook_url:
required: true
type: string
react_app_widget_embed_path:
required: true
type: string
react_app_sentry_dsn:
required: true
type: string
react_app_environment:
required: true
type: string
react_app_mail_server_domain:
required: true
type: string
react_app_hubspot_embed:
required: false
type: string
# Netlify inputs
netlify_deploy_message:
required: true
type: string
netlify_alias:
required: true
type: string
netlify_gh_env:
required: true
type: string
netlify_site_id:
required: true
type: string
clerk_publishable_key:
required: true
type: string
clerk_is_ee_auth_enabled:
required: true
type: string
# A workflow run is made up of one or more jobs that can run sequentially or in parallel
jobs:
reusable_web_deploy:
runs-on: ubuntu-latest
timeout-minutes: 80
environment: ${{ inputs.environment }}
permissions:
contents: read
packages: write
deployments: write
id-token: write
steps:
- uses: actions/checkout@v4
name: Checkout with submodules
with:
submodules: true
token: ${{ secrets.SUBMODULES_TOKEN }}
- uses: ./.github/actions/setup-project
with:
slim: 'true'
submodules: true
- name: Create env file in the legacy Web app
working-directory: apps/web
run: |
touch .env
echo REACT_APP_SEGMENT_KEY=${{ secrets.WEB_SEGMENT_KEY }} >> .env
echo REACT_APP_INTERCOM_APP_ID=${{ secrets.INTERCOM_APP_ID }} >> .env
echo REACT_APP_API_URL=${{ inputs.react_app_api_url }} >> .env
echo REACT_APP_WS_URL=${{ inputs.react_app_ws_url }} >> .env
echo REACT_APP_WEBHOOK_URL=${{ inputs.react_app_webhook_url }} >> .env
echo REACT_APP_WIDGET_EMBED_PATH=${{ inputs.react_app_widget_embed_path }} >> .env
echo REACT_APP_NOVU_APP_ID=${{ secrets.NOVU_APP_ID }} >> .env
echo REACT_APP_SENTRY_DSN=${{ inputs.react_app_sentry_dsn }} >> .env
echo REACT_APP_ENVIRONMENT=${{ inputs.react_app_environment }} >> .env
echo REACT_APP_MAIL_SERVER_DOMAIN=${{ inputs.react_app_mail_server_domain }} >> .env
echo REACT_APP_LAUNCH_DARKLY_CLIENT_SIDE_ID=${{ secrets.LAUNCH_DARKLY_CLIENT_SIDE_ID }} >> .env
echo REACT_APP_HUBSPOT_EMBED=${{ inputs.react_app_hubspot_embed }} >> .env
echo REACT_APP_STRIPE_CLIENT_KEY=${{ secrets.STRIPE_CLIENT_KEY }} >> .env
echo REACT_APP_NOVU_GTM_ID=${{ secrets.REACT_APP_NOVU_GTM_ID }} >> .env
echo REACT_APP_MIXPANEL_KEY=${{ secrets.MIXPANEL_TOKEN }} >> .env
echo REACT_APP_CLERK_PUBLISHABLE_KEY=${{ inputs.clerk_publishable_key }} >> .env
echo REACT_APP_IS_EE_AUTH_ENABLED=${{ inputs.clerk_is_ee_auth_enabled }} >> .env
- name: Build
run: CI='' pnpm build:dashboard --skip-nx-cache
- name: Deploy Dashboard to Netlify
uses: nwtgck/[email protected]
with:
publish-dir: apps/dashboard/dist
github-token: ${{ secrets.GITHUB_TOKEN }}
deploy-message: ${{ inputs.netlify_deploy_message }}
production-deploy: true
alias: ${{ inputs.netlify_alias }}
github-deployment-environment: ${{ inputs.netlify_gh_env }}
github-deployment-description: Dashboard Deployment
netlify-config-path: apps/dashboard/netlify.toml
env:
NETLIFY_AUTH_TOKEN: ${{ secrets.NETLIFY_AUTH_TOKEN }}
NETLIFY_SITE_ID: ${{ inputs.netlify_site_id }}
timeout-minutes: 1