-
Notifications
You must be signed in to change notification settings - Fork 77
73 lines (57 loc) · 1.88 KB
/
release-public-ami.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
name: build-public-ami
on:
schedule:
- cron: '10 10 * * 1'
push:
tags:
- "*"
permissions:
id-token: write # This is required for requesting the JWT
contents: read # This is required for actions/checkout
env:
PACKER_VERSION: "1.11.2"
jobs:
build-public-ami-and-upload:
name: Build Public AMIs for AWS and GCP
runs-on: ubuntu-22.04
timeout-minutes: 45
steps:
- name: Check out repository
uses: actions/checkout@v4
- name: Set up Go
uses: actions/setup-go@v5
with:
go-version-file: 'go.mod'
- name: Install NodeJS
uses: actions/setup-node@v3
with:
node-version: '16'
- name: Install npx aws-amicleaner
run: npm install -g aws-amicleaner
- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v4
with:
role-to-assume: ${{ secrets.AWS_ROLE_TO_ASSUME }}
aws-region: us-east-1
- name: Clean up old AMIs
run: npx aws-amicleaner --include-name 'public-avalanchecli-ubuntu-*' --exclude-newest 1 --region="*" --exclude-days 0 --force
env:
AWS_REGION: us-east-1
- name: Configure GCP credentials
uses: google-github-actions/auth@v2
with:
credentials_json: ${{ secrets.EXPERIMENTAL_GCP_SA_KEY_PACKER }}
- name: Setup `packer`
uses: hashicorp/setup-packer@main
id: setup
with:
version: ${{ env.PACKER_VERSION }}
- name: Run `packer init`
id: init
run: "packer init ./.github/packer/aws-ubuntu-docker.pkr.hcl"
- name: Run `packer validate`
id: validate
run: "packer validate ./.github/packer/aws-ubuntu-docker.pkr.hcl"
- name: Run `packer build`
id: build
run: "packer build -color=false -force ./.github/packer/aws-ubuntu-docker.pkr.hcl"