-
-
Notifications
You must be signed in to change notification settings - Fork 150
86 lines (81 loc) · 2.35 KB
/
build-ccache.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
name: Update ccache
on:
push:
branches:
- develop
paths:
- ".github/workflows/build-ccache.yml"
- "ansible/vars.yml"
- "Dockerfile"
workflow_dispatch:
env:
image_tag: public.ecr.aws/supabase/postgres:ccache
permissions:
contents: read
packages: write
id-token: write
jobs:
settings:
runs-on: ubuntu-latest
outputs:
build_args: ${{ steps.args.outputs.result }}
steps:
- uses: actions/checkout@v3
- id: args
uses: mikefarah/yq@master
with:
cmd: yq 'to_entries | map(select(.value|type == "!!str")) | map(.key + "=" + .value) | join("\n")' 'ansible/vars.yml'
build_image:
needs: settings
strategy:
matrix:
include:
- runner: [self-hosted, X64]
arch: amd64
- runner: arm-runner
arch: arm64
runs-on: ${{ matrix.runner }}
timeout-minutes: 180
outputs:
image_digest: ${{ steps.build.outputs.digest }}
steps:
- run: docker context create builders
- uses: docker/setup-buildx-action@v3
with:
endpoint: builders
- name: Configure AWS credentials - prod
uses: aws-actions/configure-aws-credentials@v1
with:
role-to-assume: ${{ secrets.PROD_AWS_ROLE }}
aws-region: "us-east-1"
- uses: docker/login-action@v2
with:
registry: public.ecr.aws
- id: build
uses: docker/build-push-action@v5
with:
push: true
target: buildcache
build-args: |
CACHE_EPOCH=${{ github.event.repository.updated_at }}
${{ needs.settings.outputs.build_args }}
tags: ${{ env.image_tag }}_${{ matrix.arch }}
platforms: linux/${{ matrix.arch }}
merge_manifest:
needs: build_image
runs-on: ubuntu-latest
steps:
- uses: docker/setup-buildx-action@v3
- name: Configure AWS credentials - prod
uses: aws-actions/configure-aws-credentials@v1
with:
role-to-assume: ${{ secrets.PROD_AWS_ROLE }}
aws-region: "us-east-1"
- uses: docker/login-action@v2
with:
registry: public.ecr.aws
- name: Merge multi-arch manifests
run: |
docker buildx imagetools create -t ${{ env.image_tag }} \
${{ env.image_tag }}_amd64 \
${{ env.image_tag }}_arm64