-
Notifications
You must be signed in to change notification settings - Fork 107
85 lines (81 loc) · 2.86 KB
/
build_push.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
---
name: Build and Push Docker
on:
release:
types:
- published
push:
env:
AWS_REGION: eu-west-1
EKS_CLUSTER_NAME: ${{ vars.CLUSTER_NAME }}
jobs:
build-and-push:
runs-on: ubuntu-latest
if: |
startsWith(github.ref_name, 'faucet@') ||
startsWith(github.ref_name, 'wardend@') ||
startsWith(github.ref_name, 'web@') ||
startsWith(github.ref_name, 'wardenkms@') ||
startsWith(github.ref_name, 'fwardenmodel@') ||
startsWith(github.ref_name, 'mpcwardenmodel@') ||
startsWith(github.ref_name, 'mpc-relayer@') ||
startsWith(github.ref_name, 'relayer-eth@')
permissions:
id-token: write
contents: read
steps:
- uses: actions/checkout@v4
- uses: aws-actions/configure-aws-credentials@v4
with:
role-to-assume: ${{ vars.AWS_ROLE }}
aws-region: ${{ env.AWS_REGION }}
- uses: aws-actions/amazon-ecr-login@v2
id: login-ecr
- name: Set tags
id: vars
run: |
echo "SHORT_SHA=$(git rev-parse --short HEAD)" >> $GITHUB_ENV
echo "COMMIT_SHA=$(git rev-parse HEAD)" >> $GITHUB_ENV
echo "BUILD_DATE=$(git show -s --format=%ci ${{ env.COMMIT_SHA }})" >> $GITHUB_ENV
echo "TAG=$(echo ${GITHUB_REF_NAME} | cut -d'@' -f2)" >> $GITHUB_ENV
echo "REF=$(echo ${GITHUB_REF_NAME} | cut -d'@' -f1)" >> $GITHUB_ENV
echo "ECR_REPO=${{ vars.ECR_REGISTRY }}.dkr.ecr.eu-west-1.amazonaws.com/wardenprotocol/production" >> $GITHUB_ENV
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Build and Push
id: image
uses: docker/build-push-action@v4
with:
context: .
file: ./docker/Dockerfile-${{ env.REF }}
build-args: |
SERVICE=${{ env.REF }}
GIT_SHA=${{ env.COMMIT_SHA }}
BUILD_DATE=${{ env.BUILD_DATE }}
push: true
tags: |
${{ env.ECR_REPO }}/${{ env.REF }}:${{ env.SHORT_SHA }}
${{ env.ECR_REPO }}/${{ env.REF }}:${{ env.TAG }}
cache-from: type=gha
cache-to: type=gha,mode=max
- name: 'Clone Helm repository'
uses: actions/checkout@v3
with:
repository: ${{ vars.HELM_REPOSITORY }}
ref: 'main'
token: ${{ secrets.PAT }}
- name: Update kube config
run: aws eks update-kubeconfig --name $EKS_CLUSTER_NAME --region $AWS_REGION
- uses: azure/setup-helm@v3
with:
version: 'v3.12.0'
- name: Deploy to EKS
run: |
helm upgrade \
-i ${{ env.REF }} \
-n devnet \
--set fullnameOverride=${{ env.REF }} \
--set image.repository=${{ env.ECR_REPO }} \
--set image.name=${{ env.REF }} \
--set image.tag=${{ env.SHORT_SHA }} \
./stable/${{ env.REF }}/