Skip to content
This repository has been archived by the owner on May 3, 2024. It is now read-only.

release-step-4_automatic_docker-prod-build-and-publish #118

release-step-4_automatic_docker-prod-build-and-publish

release-step-4_automatic_docker-prod-build-and-publish #118

name: '[Release step 4 | automatic] Docker Prod build and Publish'
on:
workflow_dispatch:
inputs:
docker_tag_version:
description: 'Semantic Version'
required: true
docker_meta_tag:
type: choice
options:
- do_not_tag
- latest
- next
description: When manually triggering a deployment, specify which meta tag such as `latest` should be used. `do_not_tag` will result in no meta tag being applied.
required: true
repository_dispatch:
types: [release-step-4_automatic_docker-prod-build-and-publish]
jobs:
release-step-4_automatic_docker-prod-build-and-publish:
name: One App Production Image Build and Push
runs-on: ubuntu-latest
steps:
- name: Extract sem versions
id: get_sem_version
run: |
MAJOR="$(echo ${{ github.event.client_payload.docker_tag_version}} | cut -d'.' -f1)"
MINOR="$(echo ${{ github.event.client_payload.docker_tag_version}} | cut -d'.' -f2)"
PATCH="$(echo ${{ github.event.client_payload.docker_tag_version}} | cut -d'.' -f3)"
echo "major_version=${MAJOR}" >> $GITHUB_OUTPUT
echo "minor_version=${MINOR}" >> $GITHUB_OUTPUT
- name: Docker Image Versions
id: set_docker_version
run: |
#Runs when the action is triggered by the dispatch function
if [[ "${{ github.event.inputs.docker_tag_version }}" == "" ]]; then
echo "docker_version=${{ github.event.client_payload.docker_tag_version }}" >> $GITHUB_OUTPUT
echo "major_version=${{ steps.get_sem_version.outputs.major_version }}" >> $GITHUB_OUTPUT
echo "minor_version=${{ steps.get_sem_version.outputs.minor_version }}" >> $GITHUB_OUTPUT
else
#Runs when a tag is triggered manually
echo "docker_version=${{ github.event.inputs.docker_tag_version }}" >> $GITHUB_OUTPUT
MAJOR="$(echo ${{ github.event.inputs.docker_tag_version}} | cut -d'.' -f1)"
MINOR="$(echo ${{ github.event.inputs.docker_tag_version}} | cut -d'.' -f2)"
echo "major_version=${MAJOR}" >> $GITHUB_OUTPUT
echo "minor_version=${MINOR}" >> $GITHUB_OUTPUT
fi
- name: Normalize meta tag
id: set_docker_meta_tag
run: |
# Always use the value from the last step if it is present
if [[ "${{ github.event.client_payload.docker_meta_tag }}" != "" ]]
then
echo "metatag=${{ github.event.client_payload.docker_meta_tag }}" >> $GITHUB_OUTPUT
echo From previous step: ${{ github.event.client_payload.docker_meta_tag }}
# if a meta tag was specified this was a manual build
elif [[ "${{ github.event.inputs.docker_meta_tag }}" != "" ]]
then
echo "metatag=${{ github.event.inputs.docker_meta_tag }}" >> $GITHUB_OUTPUT
echo From manual run: ${{ github.event.inputs.docker_meta_tag }}
# if we are on the main branch, default to `latest`
elif [[ "$GITHUB_REF" == "refs/heads/main" ]]
then
echo "metatag=latest" >> $GITHUB_OUTPUT
echo For main branch: latest
# if we are not on the main branch, default to `do_not_tag`
else
echo "metatag=do_not_tag" >> $GITHUB_OUTPUT
echo For other branch: do_not_tag
fi
- uses: actions/checkout@v4
with:
ref: "v${{ steps.set_docker_version.outputs.docker_version }}"
- name: Docker login
run: echo "${{ secrets.DOCKER_PASSWORD }}" | docker login --username ${{ secrets.DOCKER_USER }} --password-stdin
- name: Build production docker image
run: docker build -t prod . --build-arg VERSION=$(cat .nvmrc)
- name: Tag Docker Images
run: |
# Always tag the exact version
docker tag prod ${{ secrets.DOCKER_USER }}/one-app:${{ steps.set_docker_version.outputs.docker_version}}
# Only tag with `<major>` and `<major>.<minor>` if we are tagging `latest`
if [[ "${{ steps.set_docker_meta_tag.outputs.metatag }}" == "latest" ]]
then
docker tag prod ${{ secrets.DOCKER_USER }}/one-app:${{ steps.set_docker_version.outputs.major_version}}
docker tag prod ${{ secrets.DOCKER_USER }}/one-app:${{ steps.set_docker_version.outputs.major_version}}.${{steps.set_docker_version.outputs.minor_version}}
fi
# Finally tag with the requested meta tag
if [[ "${{ steps.set_docker_meta_tag.outputs.metatag }}" != "do_not_tag" ]]
then
docker tag prod ${{ secrets.DOCKER_USER }}/one-app:${{ steps.set_docker_meta_tag.outputs.metatag }}
fi
- name: Push Docker Images
run: |
docker push ${{ secrets.DOCKER_USER }}/one-app:${{ steps.set_docker_version.outputs.docker_version}}
# Only tag with `<major>` and `<major>.<minor>` if we are tagging `latest`
if [[ "${{ steps.set_docker_meta_tag.outputs.metatag }}" == "latest" ]]
then
docker push ${{ secrets.DOCKER_USER }}/one-app:${{ steps.set_docker_version.outputs.major_version}}
docker push ${{ secrets.DOCKER_USER }}/one-app:${{ steps.set_docker_version.outputs.major_version}}.${{ steps.set_docker_version.outputs.minor_version}}
fi
if [[ "${{ steps.set_docker_meta_tag.outputs.metatag }}" != "do_not_tag" ]]
then
docker push ${{ secrets.DOCKER_USER }}/one-app:${{ steps.set_docker_meta_tag.outputs.metatag }}
fi
- name: Trigger Development Image Publishing
uses: octokit/[email protected]
id: dispatch_one_app_docker_dev_build
with:
route: POST /repos/:repository/dispatches
repository: ${{ github.repository }}
mediaType: '{"previews": ["everest"]}'
event_type: "release-step-5_automatic_docker-dev-build-and-publish"
client_payload: '{"docker_tag_version": "${{ steps.set_docker_version.outputs.docker_version }}","major_version":"${{ steps.set_docker_version.outputs.major_version}}","minor_version":"${{ steps.set_docker_version.outputs.minor_version}}","docker_meta_tag": "${{ steps.set_docker_meta_tag.outputs.metatag }}"}'
env:
GITHUB_TOKEN: ${{ secrets.PA_TOKEN }}