-
Notifications
You must be signed in to change notification settings - Fork 0
124 lines (108 loc) · 3.58 KB
/
publish-new-build.yml
File metadata and controls
124 lines (108 loc) · 3.58 KB
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
name: Publish new build
run-name: "Publish new images for ${{ github.ref_name }} triggered by ${{ github.actor }}; version: ${{ inputs.version || 'N/A'}}"
on:
pull_request:
types: [opened, synchronize]
push:
branches:
- main
workflow_dispatch:
inputs:
version:
description: "Enter the version number"
required: true
deploy-to-production:
description: "Deploy the new version on production?"
required: false
type: boolean
default: false
permissions:
contents: write
jobs:
code-check:
uses: ./.github/workflows/code-check.yml
bump-version:
runs-on: ubuntu-latest
if: ${{ github.ref_name == 'main' && inputs.version != '' }}
needs:
- code-check
outputs:
commit_sha: ${{ steps.commit-version.outputs.commit_sha }}
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Install semver
run: npm install semver
- name: Get current version
run: echo "current_version=$(jq -r '.version' package.json)" >> $GITHUB_ENV
- name: Validate and set new version
run: |
new_version="${{ inputs.version }}"
current_version="${{ env.current_version }}"
if npx semver $new_version -r "<=$current_version"; then
echo "Error: New version ($new_version) is lowest or the same as current ($current_version)"
exit 1
fi
- name: Bump version
run: |
npm version ${{ inputs.version }} --no-git-tag-version
- name: Git config
run: |
git config user.name "${GITHUB_ACTOR}"
git config user.email "${GITHUB_ACTOR}@users.noreply.github.com"
- name: Commit version change
id: commit-version
run: |
git commit -am "Update version to ${{ inputs.version }}"
git push origin main
echo "commit_sha=$(git rev-parse HEAD)" >> $GITHUB_OUTPUT
build-and-publish:
needs:
- code-check
- bump-version
if: |
always() &&
!contains(needs.*.result, 'failure') &&
!contains(needs.*.result, 'cancelled')
uses: ./.github/workflows/build-docker-image.yml
with:
version: ${{ inputs.version }}
commit_sha: ${{ github.ref_name == 'main' && inputs.version != '' && needs.bump-version.outputs.commit_sha || '' }}
secrets: inherit
git-tag:
runs-on: ubuntu-latest
needs:
- bump-version
- build-and-publish
if: |
${{ github.ref_name == 'main' && inputs.version != '' }} &&
always() &&
!contains(needs.*.result, 'failure') &&
!contains(needs.*.result, 'cancelled')
steps:
- name: Checkout code
uses: actions/checkout@v4
with:
ref: ${{ needs.bump-version.outputs.commit_sha }}
- name: Create and push tag
run: |
TAG_NAME="v${{ inputs.version }}"
git tag $TAG_NAME
git push origin $TAG_NAME
trigger-production-deploy:
runs-on: ubuntu-latest
needs:
- code-check
- build-and-publish
if: ${{ inputs.version != '' && inputs.deploy-to-production == true }}
environment: production-fidl
steps:
- name: Trigger production deploy
uses: neti-filplus-infra/filplus-deploy-action@main
with:
version: ${{ inputs.version }}
environment: production
ecr-repository: filecoin-oracle-service
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID_IMAGE_DEPLOYER }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY_IMAGE_DEPLOYER }}
aws-region: us-east-1