2019-11-08 08:31:16 -06:00
---
2022-09-27 16:30:54 +02:00
name : Deploy super-linter release container images
2019-11-08 08:31:16 -06:00
2019-11-08 08:39:18 -06:00
on :
2021-07-13 15:20:17 -05:00
release :
2022-03-25 10:20:52 -05:00
types : [ published]
workflow_dispatch :
inputs :
release_version :
description: 'version to release. Ex : v4.3.2'
required : true
default : 'v'
2019-11-08 08:31:16 -06:00
jobs :
2022-01-26 16:17:59 +01:00
build :
2022-09-27 16:30:54 +02:00
name : Deploy container image - Release
2019-11-08 08:31:16 -06:00
runs-on : ubuntu-latest
2022-01-26 16:17:59 +01:00
strategy :
2022-02-07 11:28:48 -05:00
fail-fast : false
2022-01-26 16:17:59 +01:00
matrix :
images :
2022-09-27 16:30:54 +02:00
- container-image-id-prefix : slim-
2022-01-26 16:17:59 +01:00
deployment-environment-identifier : Release-SLIM
2022-09-27 16:30:54 +02:00
- container-image-id-prefix : ""
2022-01-26 16:17:59 +01:00
deployment-environment-identifier : Release
2021-11-16 01:25:36 +09:00
timeout-minutes : 60
2019-11-08 08:31:16 -06:00
steps :
2022-09-27 16:30:54 +02:00
- name : Setup Docker BuildX
2022-05-09 09:46:10 -05:00
uses : docker/setup-buildx-action@v2.0.0
2020-12-04 17:32:48 -06:00
2020-12-04 17:15:51 -06:00
- name : Login to DockerHub
2022-05-09 09:45:50 -05:00
uses : docker/login-action@v2.0.0
2020-12-04 12:49:09 -06:00
with :
username : ${{ secrets.DOCKER_USERNAME }}
password : ${{ secrets.DOCKER_PASSWORD }}
2020-08-20 12:58:11 -05:00
2020-12-04 17:15:51 -06:00
- name : Login to GitHub Container Registry
2022-05-09 09:45:50 -05:00
uses : docker/login-action@v2.0.0
2020-12-04 12:49:09 -06:00
with :
2022-01-26 16:17:59 +01:00
registry : ghcr.io
2020-12-04 17:21:08 -06:00
username : ${{ secrets.GCR_USERNAME }}
2020-12-04 17:15:51 -06:00
password : ${{ secrets.GCR_TOKEN }}
2021-05-25 12:03:41 -05:00
2022-09-27 16:30:54 +02:00
- name : Get current release identifier
2021-07-19 09:28:49 -05:00
# shellcheck disable=SC2062
2021-06-03 09:45:15 -05:00
run : |
2021-07-19 09:28:49 -05:00
echo "RELEASE_VERSION=$(echo ${{ github.event.release.name }} \
2021-06-03 09:45:15 -05:00
| grep -E -o "v[[:digit:]]+\.[[:digit:]]+\.[[:digit:]]+")" \
2021-07-19 09:28:49 -05:00
>> "${GITHUB_ENV}"
2022-03-25 10:20:52 -05:00
if [ -z "${RELEASE_VERSION}" ]; then
echo "No release version found in environment, using input..."
echo "RELEASE_VERSION=${{ github.event.inputs.release_version }}" \
>> "${GITHUB_ENV}"
fi
2021-06-03 09:45:15 -05:00
2022-09-27 16:30:54 +02:00
- name : Start deployment for the ${{ matrix.images.deployment-environment-identifier }} environment
2022-07-11 12:13:52 -05:00
uses : bobheadxi/deployments@v1.3.0
2022-01-26 16:17:59 +01:00
id : deployment
2021-06-24 10:19:42 -05:00
with :
2022-01-26 16:17:59 +01:00
step : start
token : ${{ secrets.GITHUB_TOKEN }}
env : ${{ matrix.images.deployment-environment-identifier }}
2021-06-24 10:19:42 -05:00
2022-09-27 16:30:54 +02:00
# We don't rebuild the image to avoid that the latest tag and the release tags don't point to what the release tag is pointing to.
# Instead, we pull the latest image and tag it.
- name : Add release tags and push image
uses : akhilerm/tag-push-action@v2.0.0
2021-05-25 10:14:43 -05:00
with :
2022-09-27 16:30:54 +02:00
src : ghcr.io/github/super-linter:${{ matrix.images.container-image-id-prefix }}latest
dst : |
2022-01-26 16:17:59 +01:00
github/super-linter:${{ matrix.images.container-image-id-prefix }}v4
github/super-linter:${{ matrix.images.container-image-id-prefix }}${{ env.RELEASE_VERSION }}
ghcr.io/github/super-linter:${{ matrix.images.container-image-id-prefix }}v4
ghcr.io/github/super-linter:${{ matrix.images.container-image-id-prefix }}${{ env.RELEASE_VERSION }}
2021-03-10 08:36:46 -06:00
2022-09-27 16:30:54 +02:00
- name : Update the deployment status for the ${{ matrix.images.deployment-environment-identifier }} environment
2022-07-11 12:13:52 -05:00
uses : bobheadxi/deployments@v1.3.0
2021-03-10 08:36:46 -06:00
if : always()
with :
step : finish
token : ${{ secrets.GITHUB_TOKEN }}
status : ${{ job.status }}
deployment_id : ${{ steps.deployment.outputs.deployment_id }}
2022-03-15 17:54:31 +09:00
env : ${{ steps.deployment.outputs.env }}
2021-05-25 14:07:27 -05:00
env_url : https://github.com/github/super-linter/releases/tag/${{ env.RELEASE_VERSION }}
2021-07-13 15:20:17 -05:00
2022-09-27 16:30:54 +02:00
- name : Create a GitHub issue on failure
2021-07-13 15:20:17 -05:00
if : failure()
2022-02-14 15:20:29 -06:00
uses : actions/github-script@v6
2021-07-13 15:20:17 -05:00
id : create-issue
with :
# https://octokit.github.io/rest.js/v18#issues-create
github-token : ${{secrets.GITHUB_TOKEN}}
script : |
2021-11-12 23:53:39 +09:00
const create = await github.rest.issues.create({
2021-07-13 15:20:17 -05:00
owner : context.repo.owner,
repo : context.repo.repo,
title : "Failed to deploy release to production" ,
2021-11-12 11:02:28 -06:00
body : "Automation has failed us! Failed to push release ${{ env.RELEASE_VERSION }}\nMore information can be found at:\n - ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}"
2021-07-13 15:20:17 -05:00
})
console.log('create', create)
return create.data.number
2022-09-27 16:30:54 +02:00
- name : Assign admins to the issue created on failure
2022-02-14 15:20:29 -06:00
uses : actions/github-script@v6
2021-07-13 15:20:17 -05:00
if : failure()
with :
github-token : ${{secrets.GITHUB_TOKEN}}
script : |
2021-11-12 23:53:39 +09:00
github.rest.issues.addAssignees({
2021-07-13 15:20:17 -05:00
owner : context.repo.owner,
repo : context.repo.repo,
issue_number : "${{ steps.create-issue.outputs.result }}" ,
assignees : [
'admiralawkbar' ,
2022-01-06 11:00:13 -06:00
'lindluni' ,
2021-07-13 15:20:17 -05:00
'IAmHughes' ,
'nemchik' ,
'Hanse00' ,
'GaboFDC' ,
'ferrarimarco'
]
})