-
Notifications
You must be signed in to change notification settings - Fork 4
44 lines (40 loc) · 1.48 KB
/
gcp_deploy_prod.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
name: gcp_deploy_frontend_dev
on:
push:
branches:
- master
jobs:
deploy:
name: deploy
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: G-Cloud Authenticate
env:
SERVICE_CREDENTIALS: ${{ secrets.GCP_SERVICE_CREDENTIALS_PROD }}
SERVICE_ACCOUNT: ${{ secrets.GCP_SERVICE_ACCOUNT_PROD }}
PROJECT_ID: ${{ secrets.GCP_PROJECT_ID_PROD }}
run: |-
echo "$SERVICE_CREDENTIALS" > ./credentials.json
gcloud auth activate-service-account "$SERVICE_ACCOUNT" --key-file=./credentials.json --project="$PROJECT_ID"
gcloud auth configure-docker us-central1-docker.pkg.dev --quiet
- name: Create Env File
env:
SECRETS: $${{ secrets.VUE_APP_VARIABLES_PROD }}
run: echo "$SECRETS" > ./.env
- name: Docker Build
env:
IMAGE_NAME: ${{ secrets.GCP_IMAGE_NAME_PROD }}
run: docker build -t "$IMAGE_NAME" .
- name: Push to Container Registry
env:
IMAGE_NAME: ${{ secrets.GCP_IMAGE_NAME_PROD }}
run: sudo -u $USER docker push "$IMAGE_NAME"
- name: Deploy to Cloud Run
env:
IMAGE_NAME: ${{ secrets.GCP_IMAGE_NAME_PROD }}
PROJECT_ID: ${{ secrets.GCP_PROJECT_ID_PROD }}
run: gcloud run deploy uwpath-frontend-prod --image="$IMAGE_NAME" --project="$PROJECT_ID" --region=us-central1
- name: Clean Env
if: always()
run: docker system prune --volumes -af