Release Extension (v2) #94
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Release Extension (v2) | |
on: | |
repository_dispatch: | |
types: [liquibase-release] | |
workflow_dispatch: | |
inputs: | |
liquibaseVersion: | |
description: "Liquibase Version" | |
required: true | |
extensionVersion: | |
description: "Container Version (Defaults to Liquibase Version)" | |
required: false | |
jobs: | |
update-dockerfiles: | |
name: "Update Dockerfiles" | |
runs-on: ubuntu-latest | |
outputs: | |
liquibaseVersion: ${{ steps.collect-data.outputs.liquibaseVersion }} | |
extensionVersion: ${{ steps.collect-data.outputs.extensionVersion }} | |
minorVersion: ${{ steps.collect-data.outputs.minorVersion }} | |
steps: | |
- name: Collect Data | |
id: collect-data | |
uses: actions/github-script@v6 | |
with: | |
script: | | |
const getMinorVersion = (liquibaseVersion) => { | |
const arr = liquibaseVersion.split(".") | |
return `${arr[0]}.${arr[1]}` | |
} | |
if (context.payload.client_payload) { | |
const liquibaseVersion = context.payload.client_payload.liquibaseVersion | |
const minorVersion = getMinorVersion(liquibaseVersion) | |
core.setOutput("liquibaseVersion", liquibaseVersion); | |
core.setOutput("extensionVersion", liquibaseVersion); | |
core.setOutput("minorVersion", minorVersion); | |
} else if (context.payload.inputs) { | |
const liquibaseVersion = context.payload.inputs.liquibaseVersion | |
const minorVersion = getMinorVersion(liquibaseVersion) | |
core.setOutput("liquibaseVersion", liquibaseVersion); | |
core.setOutput("extensionVersion", context.payload.inputs.extensionVersion || liquibaseVersion); | |
core.setOutput("minorVersion", minorVersion); | |
} else { | |
core.setFailed('Unknown event type') | |
} | |
- run: | | |
echo "Saw Liquibase version ${{ steps.collect-data.outputs.liquibaseVersion }}" | |
echo "Saw Extension version ${{ steps.collect-data.outputs.extensionVersion }}" | |
- uses: actions/checkout@v3 | |
with: | |
persist-credentials: false # otherwise, the token used is the GITHUB_TOKEN, instead of your personal token | |
ref: ${{ github.ref }} | |
- name: Set up JDK | |
uses: actions/setup-java@v3 | |
with: | |
java-version: "8" | |
distribution: "adopt" | |
- name: Configure git user | |
run: | | |
git config user.name "liquibot" | |
git config user.email "[email protected]" | |
- name: Update Dockerfile and commit changes | |
run: | | |
file_list=("Dockerfile" "Dockerfile.alpine") | |
LIQUIBASE_SHA=`curl -LsS https://github.com/liquibase/liquibase/releases/download/v${{ steps.collect-data.outputs.liquibaseVersion }}/liquibase-${{ steps.collect-data.outputs.liquibaseVersion }}.tar.gz | sha256sum | awk '{ print $1 }'` | |
for file in "${file_list[@]}"; do | |
sed -i 's/^ARG LIQUIBASE_VERSION=.*/ARG LIQUIBASE_VERSION='"${{ steps.collect-data.outputs.liquibaseVersion }}"'/' "${{ github.workspace }}/${file}" | |
sed -i 's/^ARG LB_SHA256=.*/ARG LB_SHA256='"$LIQUIBASE_SHA"'/' "${{ github.workspace }}/${file}" | |
git add "${file}" | |
done | |
if git diff-index --cached --quiet HEAD -- | |
then | |
echo "Nothing new to commit" | |
else | |
git commit -m "Liquibase Version Bumped to ${{ steps.collect-data.outputs.extensionVersion }}" | |
git tag -fa -m "Version Bumped to ${{ steps.collect-data.outputs.extensionVersion }}" v${{ steps.collect-data.outputs.extensionVersion }} | |
git push -f "https://liquibot:[email protected]/$GITHUB_REPOSITORY.git" HEAD:${{ github.ref }} --follow-tags --tags | |
fi | |
env: | |
GITHUB_TOKEN: ${{ secrets.BOT_TOKEN }} | |
setup-update-draft-build: | |
name: "${{ matrix.image.name }}:${{ inputs.liquibaseVersion}}${{ matrix.image.suffix }}" | |
needs: update-dockerfiles | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
image: [ | |
{dockerfile: Dockerfile, name: liquibase/liquibase, suffix: ""}, | |
{dockerfile: Dockerfile.alpine, name: liquibase/liquibase, suffix: "-alpine"}, | |
] | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
persist-credentials: false # otherwise, the token used is the GITHUB_TOKEN, instead of your personal token | |
fetch-depth: 0 # otherwise, you will fail to push refs to dest repo | |
- name: Set up JDK | |
uses: actions/setup-java@v3 | |
with: | |
java-version: "8" | |
distribution: "adopt" | |
- name: Release Notes | |
uses: softprops/action-gh-release@v1 | |
with: | |
name: v${{ needs.update-dockerfiles.outputs.extensionVersion}} | |
tag_name: v${{ needs.update-dockerfiles.outputs.extensionVersion }} | |
draft: true | |
body: Support for Liquibase ${{ needs.update-dockerfiles.outputs.liquibaseVersion }}. | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
- uses: docker/setup-qemu-action@v2 | |
- uses: docker/setup-buildx-action@v2 | |
- uses: docker/login-action@v2 | |
with: | |
username: ${{ secrets.DOCKERHUB_USERNAME }} | |
password: ${{ secrets.DOCKERHUB_TOKEN }} | |
- name: Login to ECR Registry | |
uses: docker/login-action@v2 | |
env: | |
AWS_REGION: us-east-1 | |
with: | |
registry: public.ecr.aws | |
username: ${{ secrets.PUBLIC_ECR_ACCESS_KEY_ID }} | |
password: ${{ secrets.PUBLIC_ECR_SECRET_ACCESS_KEY }} | |
- name: Build and Push Docker Image | |
env: | |
ECR_REGISTRY: public.ecr.aws/liquibase/liquibase | |
uses: docker/build-push-action@v4 | |
with: | |
context: . | |
file: ${{ matrix.image.dockerfile }} | |
no-cache: true | |
push: true | |
platforms: linux/amd64,linux/arm64 | |
tags: ${{ matrix.image.name }}:latest${{ matrix.image.suffix }},${{ matrix.image.name }}:${{ needs.update-dockerfiles.outputs.extensionVersion }}${{ matrix.image.suffix }},${{ matrix.image.name }}:${{ needs.update-dockerfiles.outputs.minorVersion }}${{ matrix.image.suffix }},${{ env.ECR_REGISTRY }}:latest${{ matrix.image.suffix }},${{ env.ECR_REGISTRY }}:${{ needs.update-dockerfiles.outputs.extensionVersion }}${{ matrix.image.suffix }},${{ env.ECR_REGISTRY }}:${{ needs.update-dockerfiles.outputs.minorVersion }}${{ matrix.image.suffix }} |