liquibase-release #171
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 | |
dryRun: | |
description: "Dry Run release" | |
required: true | |
type: boolean | |
default: false | |
jobs: | |
update-dockerfiles: | |
env: | |
LPM_VERSION: "0.2.7" | |
name: "Update Dockerfiles" | |
runs-on: ubuntu-latest | |
outputs: | |
liquibaseVersion: ${{ steps.collect-data.outputs.liquibaseVersion }} | |
extensionVersion: ${{ steps.collect-data.outputs.extensionVersion }} | |
dryRun: ${{ steps.collect-data.outputs.dryRun }} | |
minorVersion: ${{ steps.collect-data.outputs.minorVersion }} | |
latestCommitSha: ${{ steps.get-latest-sha.outputs.latestCommitSha }} | |
steps: | |
- name: Collect Data | |
id: collect-data | |
uses: actions/github-script@v7 | |
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 dryRun = context.payload.client_payload.dryRun | |
const minorVersion = getMinorVersion(liquibaseVersion) | |
core.setOutput("liquibaseVersion", liquibaseVersion); | |
core.setOutput("extensionVersion", liquibaseVersion); | |
core.setOutput("minorVersion", minorVersion); | |
core.setOutput("dryRun", dryRun); | |
} else if (context.payload.inputs) { | |
const liquibaseVersion = context.payload.inputs.liquibaseVersion | |
const dryRun = context.payload.inputs.dryRun | |
const minorVersion = getMinorVersion(liquibaseVersion) | |
core.setOutput("liquibaseVersion", liquibaseVersion); | |
core.setOutput("extensionVersion", context.payload.inputs.extensionVersion || liquibaseVersion); | |
core.setOutput("minorVersion", minorVersion); | |
core.setOutput("dryRun", dryRun); | |
} 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 }}" | |
echo "Saw dryRun ${{ steps.collect-data.outputs.dryRun }}" | |
- uses: actions/checkout@v4 | |
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@v4 | |
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 }'` | |
LPM_SHA=`curl -LsS https://github.com/liquibase/liquibase-package-manager/releases/download/v${{ env.LPM_VERSION }}/lpm-${{ env.LPM_VERSION }}-linux.zip | sha256sum | awk '{ print $1 }'` | |
LPM_SHA_ARM=`curl -LsS https://github.com/liquibase/liquibase-package-manager/releases/download/v${{ env.LPM_VERSION }}/lpm-${{ env.LPM_VERSION }}-linux-arm64.zip | 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}" | |
sed -i 's/^ARG LPM_SHA256=.*/ARG LPM_SHA256='"$LPM_SHA"'/' "${{ github.workspace }}/${file}" | |
#sed -i 's/^ARG LPM_SHA256_ARM=.*/ARG LPM_SHA256_ARM='"$LPM_SHA_ARM"'/' "${{ 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 }}" | |
if [[ "${{ steps.collect-data.outputs.dryRun }}" == false ]]; then | |
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 | |
else | |
echo "Dry run mode: changes have not been pushed." | |
fi | |
fi | |
env: | |
GITHUB_TOKEN: ${{ secrets.BOT_TOKEN }} | |
- name: Get latest commit SHA | |
id: get-latest-sha | |
run: echo "latestCommitSha=$(git rev-parse HEAD)" >> "$GITHUB_OUTPUT" | |
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: "", latest_tag: "latest"}, | |
{dockerfile: Dockerfile.alpine, name: liquibase/liquibase, suffix: "-alpine", latest_tag: "alpine"}, | |
] | |
steps: | |
- uses: actions/checkout@v4 | |
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@v4 | |
with: | |
java-version: "8" | |
distribution: "adopt" | |
- name: Release Notes | |
if: ${{ needs.update-dockerfiles.outputs.dryRun == 'false' }} | |
uses: softprops/action-gh-release@v2 | |
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@v3 | |
- uses: docker/setup-buildx-action@v3 | |
- uses: docker/login-action@v3 | |
if: ${{ needs.update-dockerfiles.outputs.dryRun == 'false' }} | |
with: | |
username: ${{ secrets.DOCKERHUB_USERNAME }} | |
password: ${{ secrets.DOCKERHUB_TOKEN }} | |
- name: Login to ECR Registry | |
if: ${{ needs.update-dockerfiles.outputs.dryRun == 'false' }} | |
uses: docker/login-action@v3 | |
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: Login to ECR Private Registry (dry-run) | |
if: ${{ needs.update-dockerfiles.outputs.dryRun == 'true' }} | |
uses: docker/login-action@v3 | |
env: | |
AWS_REGION: us-east-1 | |
with: | |
registry: ${{ secrets.PRIVATE_ECR_DRY_RUN_REPO }} | |
username: ${{ secrets.PUBLIC_ECR_ACCESS_KEY_ID }} | |
password: ${{ secrets.PUBLIC_ECR_SECRET_ACCESS_KEY }} | |
- name: Build and Push Docker Image | |
if: ${{ needs.update-dockerfiles.outputs.dryRun == 'false' }} | |
env: | |
ECR_REGISTRY: public.ecr.aws/liquibase/liquibase | |
uses: docker/build-push-action@v6 | |
with: | |
context: . | |
file: ${{ matrix.image.dockerfile }} | |
no-cache: true | |
push: true | |
platforms: linux/amd64,linux/arm64 | |
tags: ${{ matrix.image.name }}:${{ matrix.image.latest_tag }},${{ 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 }}:${{ matrix.image.latest_tag }},${{ env.ECR_REGISTRY }}:${{ needs.update-dockerfiles.outputs.extensionVersion }}${{ matrix.image.suffix }},${{ env.ECR_REGISTRY }}:${{ needs.update-dockerfiles.outputs.minorVersion }}${{ matrix.image.suffix }} | |
- name: Build and Push Docker Image (dry-run) | |
if: ${{ needs.update-dockerfiles.outputs.dryRun == 'true' }} | |
env: | |
ECR_REGISTRY: ${{ secrets.PRIVATE_ECR_DRY_RUN_REPO }} | |
uses: docker/build-push-action@v6 | |
with: | |
context: . | |
file: ${{ matrix.image.dockerfile }} | |
no-cache: true | |
push: true | |
platforms: linux/amd64,linux/arm64 | |
tags: ${{ env.ECR_REGISTRY }}:${{ matrix.image.latest_tag }},${{ env.ECR_REGISTRY }}:${{ needs.update-dockerfiles.outputs.extensionVersion }}${{ matrix.image.suffix }},${{ env.ECR_REGISTRY }}:${{ needs.update-dockerfiles.outputs.minorVersion }}${{ matrix.image.suffix }} | |
update-official-repo: | |
name: "Update Official Docker Repo" | |
needs: update-dockerfiles | |
runs-on: ubuntu-latest | |
env: | |
GITHUB_TOKEN: ${{ secrets.BOT_TOKEN }} | |
steps: | |
- name: Extract major.minor version | |
id: extract_version | |
run: | | |
VERSION="${{ needs.update-dockerfiles.outputs.liquibaseVersion }}" | |
echo "MAJOR_MINOR=${VERSION%.*}" >> $GITHUB_ENV | |
echo "VERSION: $VERSION" | |
echo "MAJOR_MINOR: ${VERSION%.*}" | |
- name: Check out liquibase/official-images | |
uses: actions/checkout@v4 | |
with: | |
repository: liquibase/official-images | |
ref: master | |
token: ${{ env.GITHUB_TOKEN }} | |
- name: Update library/liquibase in liquibase/official-images | |
run: | | |
echo "Maintainers: Jake Newton <[email protected]> (@jnewton03)" > library/liquibase | |
echo "Architectures: arm64v8, amd64" >> library/liquibase | |
echo "GitRepo: https://github.com/liquibase/docker.git" >> library/liquibase | |
echo "" >> library/liquibase | |
echo "Tags: ${{ env.MAJOR_MINOR }}, ${{ needs.update-dockerfiles.outputs.liquibaseVersion }}, latest" >> library/liquibase | |
echo "GitFetch: refs/heads/main" >> library/liquibase | |
echo "GitCommit: ${{ needs.update-dockerfiles.outputs.latestCommitSha }}" >> library/liquibase | |
echo "File: Dockerfile" >> library/liquibase | |
echo "" >> library/liquibase | |
echo "Tags: ${{ env.MAJOR_MINOR }}-alpine, ${{ needs.update-dockerfiles.outputs.liquibaseVersion }}-alpine, alpine" >> library/liquibase | |
echo "GitFetch: refs/heads/main" >> library/liquibase | |
echo "GitCommit: ${{ needs.update-dockerfiles.outputs.latestCommitSha }}" >> library/liquibase | |
echo "File: Dockerfile.alpine" >> library/liquibase | |
git add library/liquibase | |
if git diff-index --cached --quiet HEAD -- | |
then | |
echo "Nothing new to commit" | |
else | |
git config user.name "liquibot" | |
git config user.email "[email protected]" | |
git commit -m "Update library/liquibase to ${{ needs.update-dockerfiles.outputs.liquibaseVersion }}" | |
if [[ "${{ needs.update-dockerfiles.outputs.dryRun }}" == false ]]; then | |
git push https://liquibot:[email protected]/liquibase/official-images.git | |
else | |
echo "Dry run mode: changes have not been pushed." | |
fi | |
fi | |
- name: Create Official Docker Pull Request | |
if: ${{ needs.update-dockerfiles.outputs.dryRun == 'false' }} | |
id: create_pr | |
run: | | |
response=$(curl \ | |
-X POST \ | |
-H "Authorization: token ${{ env.GITHUB_TOKEN }}" \ | |
-H "Accept: application/vnd.github.v3+json" \ | |
https://api.github.com/repos/docker-library/official-images/pulls \ | |
-d '{ | |
"title": "Update library/liquibase to ${{ needs.update-dockerfiles.outputs.liquibaseVersion }}", | |
"body": "Update library/liquibase with latest commit and version", | |
"head": "liquibase:master", | |
"base": "master" | |
}') | |
pr_url=$(echo $response | jq -r '.html_url') | |
echo "PR_URL=$pr_url" >> $GITHUB_ENV | |
- name: Adding Official Docker PR to job summary | |
if: ${{ needs.update-dockerfiles.outputs.dryRun == 'false' }} | |
run: echo '### 🚀 Official Docker PR -> ${{ env.PR_URL }}' >> $GITHUB_STEP_SUMMARY | |