-
Notifications
You must be signed in to change notification settings - Fork 1
78 lines (67 loc) · 2.68 KB
/
build_docker_image.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
name: Build docker image
on:
workflow_dispatch:
push:
branches:
- production
- staging
env:
PROJECT_ID: ${{ secrets.GCP_PROJECT }}
DOCKER_IMAGE: eu.gcr.io/${{ secrets.GCP_PROJECT }}/koyeb-console
GCP_CREDENTIALS: ${{ secrets.GCP_CREDENTIALS }}
jobs:
build-push:
name: Build and push docker image
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Configure docker registry
run: |
echo "$GCP_CREDENTIALS" | base64 -d > "$HOME/gcp-key.json"
gcloud auth activate-service-account --key-file "$HOME/gcp-key.json"
gcloud --quiet config set project "$PROJECT_ID"
gcloud auth configure-docker
- name: Build docker image
run: |
docker build --rm=false \
--build-arg ENVIRONMENT \
--build-arg APP_VERSION \
--build-arg API_URL \
--build-arg AI_ASSISTANT_API_URL \
--build-arg WEBSITE_URL \
--build-arg PAGE_CONTEXT_BASE_URL \
--build-arg IDENFY_SERVICE_BASE_URL \
--build-arg RECAPTCHA_CLIENT_KEY \
--build-arg POSTHOG_API_HOST \
--build-arg POSTHOG_KEY \
--build-arg STRIPE_PUBLIC_KEY \
--build-arg MAPBOX_TOKEN \
--build-arg INTERCOM_APP_ID \
--build-arg SENTRY_AUTH_TOKEN \
-t "$DOCKER_IMAGE:$GITHUB_SHA" .
env:
ENVIRONMENT: ${{ github.ref_name }}
APP_VERSION: ${{ github.sha }}
API_URL:
AI_ASSISTANT_API_URL: ${{ secrets.AI_ASSISTANT_API_URL }}
WEBSITE_URL: ${{ secrets.WEBSITE_URL }}
PAGE_CONTEXT_BASE_URL: ${{ secrets.PAGE_CONTEXT_BASE_URL }}
IDENFY_SERVICE_BASE_URL: ${{ secrets.IDENFY_SERVICE_BASE_URL }}
RECAPTCHA_CLIENT_KEY: ${{ secrets.RECAPTCHA_CLIENT_KEY }}
POSTHOG_API_HOST: ${{ secrets.POSTHOG_API_HOST }}
POSTHOG_KEY: ${{ secrets.POSTHOG_KEY }}
STRIPE_PUBLIC_KEY: ${{ secrets.STRIPE_PUBLIC_KEY }}
MAPBOX_TOKEN: ${{ secrets.MAPBOX_TOKEN }}
INTERCOM_APP_ID: ${{ secrets.INTERCOM_APP_ID }}
SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }}
- name: Push docker image
run: |
REF_NAME=${{ github.ref_name }}
SHORT_SHA1="${GITHUB_SHA:0:7}"
DATE=$(date +%s)
docker tag "$DOCKER_IMAGE:$GITHUB_SHA" "$DOCKER_IMAGE:$REF_NAME-$SHORT_SHA1-$DATE"
docker tag "$DOCKER_IMAGE:$GITHUB_SHA" "$DOCKER_IMAGE:$REF_NAME-latest"
docker push "$DOCKER_IMAGE:$GITHUB_SHA"
docker push "$DOCKER_IMAGE:$REF_NAME-$SHORT_SHA1-$DATE"
docker push "$DOCKER_IMAGE:$REF_NAME-latest"