.github/workflows/docker-image.yml #40
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
# This github workflow will automatically update docker image tags of auditing-server-depl in the datakaveri/iudx-deployment repository files, whenever docker image is pushed to ghcr.io/datakaveri/auditing-server-depl .Based on tag it will update the master/latest branch (if its 5.5.1-alpha-) or 5.5.0 stable branch (if its 5.5.0-) | |
name: Update Auditing server docker image tags | |
# This trigger will run the workflow whenever a new package is published to the registry | |
on: | |
registry_package: | |
types: [published] | |
# This is needed to read the registry packages | |
permissions: | |
packages: read | |
jobs: | |
build: | |
runs-on: ubuntu-20.04 | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
repository: datakaveri/iudx-deployment | |
# Jenkins token to perform git operations | |
token: "${{ secrets.JENKINS_UPDATE }}" | |
fetch-depth: 0 | |
# This step updates the Auditing Server docker image tags | |
- name: Update Auditing server docker image tags | |
env: | |
GH_TOKEN: ${{ secrets.JENKINS_UPDATE}} | |
run: | | |
# Get the latest version of 5.5.0 and 5.5.1-alpha tags from the container registry using GitHub API | |
export newtag5_5_0=`(head -n 1 <(curl -H "Accept: application/vnd.github+json" -H "Authorization: Bearer ${{ secrets.GITHUB_TOKEN }}" https://api.github.com/orgs/datakaveri/packages/container/auditing-server-depl/versions | jq ' .[].metadata.container.tags[0]' | grep 5.5.0 | grep -v alpha | sed -e 's/^"//' -e 's/"$//'))` | |
export newtag5_5_1=`(head -n 1 <(curl -H "Accept: application/vnd.github+json" -H "Authorization: Bearer ${{ secrets.GITHUB_TOKEN }}" https://api.github.com/orgs/datakaveri/packages/container/auditing-server-depl/versions | jq ' .[].metadata.container.tags[0]' | grep 5.5.1-alpha | sed -e 's/^"//' -e 's/"$//'))` | |
# Get the old tags from the YAML files | |
export oldtag5_5_1=`yq -r .services.auditing.image Docker-Swarm-deployment/single-node/auditing-server/auditing-stack.yaml | cut -d : -f 2` | |
git checkout 5.5.0 | |
export oldtag5_5_0=$(yq -r .services.auditing.image Docker-Swarm-deployment/single-node/auditing-server/auditing-stack.yaml | cut -d : -f 2) | |
# Set Git user | |
git config --global user.name 'jenkins-datakaveri' | |
git config --global user.email "96175780+jenkins-datakaveri@users.noreply.github.com" | |
# Update the YAML files and create a new branch for each tag update | |
if [ "$newtag5_5_0" != "$oldtag5_5_0" ] | |
then | |
git checkout -b auditing-server-5.5.0-automatic-updates/$newtag5_5_0 | |
# Uses sed to find and replace $oldtag5_5_0 with $newtag5_5_0 in Docker-Swarm-deployment/single-node/auditing-server/auditing-stack.yaml file | |
sed -i s/$oldtag5_5_0/$newtag5_5_0/g Docker-Swarm-deployment/single-node/auditing-server/auditing-stack.yaml | |
# Exports the current version of the application from K8s-deployment/Charts/auditing-server/Chart.yaml file | |
export oldappversion=`yq -r .version K8s-deployment/Charts/auditing-server/Chart.yaml` | |
# Uses awk to increment the version number in K8s-deployment/Charts/auditing-server/Chart.yaml file | |
export newappversion=`yq -r .version K8s-deployment/Charts/auditing-server/Chart.yaml | awk -F. -v OFS=. 'NF==1{print ++$NF}; NF>1{if(length($NF+1)>length($NF))$(NF-1)++; $NF=sprintf("%0*d", length($NF), ($NF+1)%(10^length($NF))); print}' ` | |
# Uses sed to find and replace $oldappversion with $newappversion in K8s-deployment/Charts/auditing-server/Chart.yaml and K8s-deployment/Charts/auditing-server/values.yaml files | |
sed -i s/$oldappversion/$newappversion/g K8s-deployment/Charts/auditing-server/Chart.yaml | |
sed -i s/$oldtag5_5_0/$newtag5_5_0/g K8s-deployment/Charts/auditing-server/values.yaml | |
git add Docker-Swarm-deployment/single-node/auditing-server/auditing-stack.yaml K8s-deployment/Charts/auditing-server/values.yaml K8s-deployment/Charts/auditing-server/Chart.yaml | |
git commit --allow-empty -m "updated Auditing server docker image tag to $newtag5_5_0" | |
git push --set-upstream origin auditing-server-5.5.0-automatic-updates/$newtag5_5_0 | |
# Creates a new pull request on the datakaveri/iudx-deployment repository with the base branch 5.5.0 | |
gh pr create -R datakaveri/iudx-deployment --base 5.5.0 --fill | |
fi | |
if [ "$newtag5_5_1" != "$oldtag5_5_1" ] | |
then | |
git checkout master | |
git checkout -b auditing-server-automatic-updates/$newtag5_5_1 | |
# Uses sed to find and replace $oldtag5_5_1 with $newtag5_5_1 in Docker-Swarm-deployment/single-node/auditing-server/auditing-stack.yaml file | |
sed -i s/$oldtag5_5_1/$newtag5_5_1/g Docker-Swarm-deployment/single-node/auditing-server/auditing-stack.yaml | |
# Exports the current version of the application from K8s-deployment/Charts/auditing-server/Chart.yaml file | |
export oldappversion=`yq -r .version K8s-deployment/Charts/auditing-server/Chart.yaml` | |
# Uses awk to increment the version number in K8s-deployment/Charts/auditing-server/Chart.yaml file | |
export newappversion=`yq -r .version K8s-deployment/Charts/auditing-server/Chart.yaml | awk -F. -v OFS=. 'NF==1{print ++$NF}; NF>1{if(length($NF+1)>length($NF))$(NF-1)++; $NF=sprintf("%0*d", length($NF), ($NF+1)%(10^length($NF))); print}' ` | |
# Uses sed to find and replace $oldappversion with $newappversion in K8s-deployment/Charts/auditing-server/Chart.yaml and K8s-deployment/Charts/auditing-server/values.yaml files | |
sed -i s/$oldappversion/$newappversion/g K8s-deployment/Charts/auditing-server/Chart.yaml | |
sed -i s/$oldtag5_5_1/$newtag5_5_1/g K8s-deployment/Charts/auditing-server/values.yaml | |
git add Docker-Swarm-deployment/single-node/auditing-server/auditing-stack.yaml K8s-deployment/Charts/auditing-server/values.yaml K8s-deployment/Charts/auditing-server/Chart.yaml | |
git commit --allow-empty -m "updated Auditing server docker image tag to $newtag5_5_1" | |
git push --set-upstream origin auditing-server-automatic-updates/$newtag5_5_1 | |
# Creates a new pull request on the datakaveri/iudx-deployment repository with the base branch master | |
gh pr create -R datakaveri/iudx-deployment --base master --fill | |
fi |