-
Notifications
You must be signed in to change notification settings - Fork 22
78 lines (67 loc) · 3.16 KB
/
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
name: CI
on:
push:
branches: [ master, testnet, toronet ]
env:
INGRESS_DOMAIN_master: "console.minter.network"
INGRESS_DOMAIN_testnet: "console.testnet.minter.network"
INGRESS_DOMAIN_toronet: "console.toronet.minter.network"
KUBE_NAMESPACE_master: "mainnet"
KUBE_NAMESPACE_testnet: "testnet"
KUBE_NAMESPACE_toronet: "toronet"
jobs:
deploy:
runs-on: ubuntu-latest
if: "!contains(github.event.head_commit.message, 'skip deploy')"
steps:
- name: set env BUILD_BRANCH
run: echo "BUILD_BRANCH=$(echo $GITHUB_REF | sed 's:refs/heads/::')" >> $GITHUB_ENV
- name: set branch prefix env to be used during docker build, .e.g. "refs/heads/testnet" => ".testnet"
run: echo "BUILD_BRANCH_ENV_PREFIX=$(echo .$BUILD_BRANCH)" >> $GITHUB_ENV
- name: set env PROJECT_NAME
run: echo "PROJECT_NAME=$(echo $GITHUB_REPOSITORY | sed "s:MinterTeam/::")" >> $GITHUB_ENV
- name: set env INGRESS_DOMAIN
env:
INGRESS_DOMAIN_KEY: INGRESS_DOMAIN_${{ env.BUILD_BRANCH }}
run: echo "INGRESS_DOMAIN=$(echo ${!INGRESS_DOMAIN_KEY})" >> $GITHUB_ENV
- name: set env KUBE_NAMESPACE
env:
KUBE_NAMESPACE_KEY: KUBE_NAMESPACE_${{ env.BUILD_BRANCH }}
run: echo "KUBE_NAMESPACE=$(echo ${!KUBE_NAMESPACE_KEY})" >> $GITHUB_ENV
- uses: actions/checkout@v3
- name: build and push docker image
uses: opspresso/[email protected]
env:
USERNAME: ${{ secrets.DOCKER_HUB_USER }}
PASSWORD: ${{ secrets.DOCKER_HUB_PASSWORD }}
IMAGE_NAME: "minterteam/console-web"
LATEST: "true"
TAG_NAME: ${{ github.sha }}
DOCKERFILE: ".docker/Dockerfile"
DOCKER_BUILD_ARGS: --build-arg BUILD_BRANCH_ENV_PREFIX
- name: DigitalOcean Kubernetes
uses: matootie/[email protected]
with:
personalAccessToken: ${{ secrets.DIGITALOCEAN_TOKEN }}
clusterName: k8s-prod-do
- name: Install helm to DO
run: wget https://get.helm.sh/helm-v3.3.4-linux-amd64.tar.gz &> /dev/null && tar xvzf helm-v3.3.4-linux-amd64.tar.gz && chmod 777 linux-amd64/helm && ./linux-amd64/helm ls -n $KUBE_NAMESPACE
- name: Deploy to DO
env:
TAG_NAME: ${{ github.sha }}
run: ./linux-amd64/helm upgrade -n $KUBE_NAMESPACE -i $PROJECT_NAME chart/ --atomic --timeout 100s --set image.tag=$TAG_NAME --set ingress.domain=$INGRESS_DOMAIN --set ingress.tlsname=$INGRESS_DOMAIN
- name: deploy to production cluster
uses: wahyd4/[email protected]
env:
KUBE_CONFIG_DATA: ${{ secrets.KUBE_PROD_CONFIG_DATA }}
TAG_NAME: ${{ github.sha }}
with:
args: helm upgrade -n $KUBE_NAMESPACE -i $PROJECT_NAME chart/ --atomic --timeout 100s --set image.tag=$TAG_NAME --set ingress.domain=$INGRESS_DOMAIN --set ingress.tlsname=$INGRESS_DOMAIN
- name: notification
if: cancelled() == false
uses: xinthink/[email protected]
with:
botToken: ${{ secrets.TELEGRAM_CI_TOKEN }}
chatId: ${{ secrets.TELEGRAM_CI_TO }}
jobStatus: ${{ job.status }}
skipSuccess: false