Skip to content

Deploy on aiscatcher changes #34243

Deploy on aiscatcher changes

Deploy on aiscatcher changes #34243

---
name: Deploy on aiscatcher changes
on:
schedule:
- cron: "0,15,30,45 * * * *"
workflow_dispatch:
env:
# GHCR_IMAGE: <USER>/<REPO> for the local imagesdr-enthusiasts/shipxplorer
# GHCR_REGISTRY: Container registry URL, e.g.: ghcr.io . Leave empty for dockerhub
# CHECK_CONTAINER: GHRC.IO container to be checked for updates <USER>/<IMAGE>
# CHECK_TAG: tag of the CHECK_CONTAINER to be checked. For example: latest
GHCR_IMAGE: sdr-enthusiasts/shipxplorer
GHCR_REGISTRY: ghcr.io
CHECK_CONTAINER: jvde-github/ais-catcher
CHECK_TAG: edge
jobs:
check_upstream_image:
name: Check upstream image
runs-on: ubuntu-latest
steps:
# Check out our code
- name: Checkout
uses: actions/[email protected]
with:
fetch-depth: 0
- name: check container SHAs
env:
CHECK_CONTAINER: ${{ env.CHECK_CONTAINER }}
CHECK_TAG: ${{ env.CHECK_TAG }}
run: |
SHA_FILE="aiscatcher.sha"
TOKEN="$(curl -sSL "https://ghcr.io/token?scope=repository:$CHECK_CONTAINER:pull" | awk -F'"' '$0=$4')"
manifest="$(curl -sSL -H "Accept: application/vnd.oci.image.index.v1+json" -H "Authorization: Bearer ${TOKEN}" "https://ghcr.io/v2/$CHECK_CONTAINER/manifests/$CHECK_TAG")"
SHAs_remote="$(echo "$manifest"|jq '.manifests[].digest')"
SHAs_remote="${SHAs_remote//$'\n'/}"
if grep "error" <<< "$TOKEN $manifest" >/dev/null 2>&1
then
echo "Error retrieving Token or Manifest."
echo "TOKEN=$TOKEN"
echo "MANIFEST=$manifest"
exit 2
fi
if [ ! -f "$SHA_FILE" ]; then
touch "$SHA_FILE"
fi
read -r SHAs_local < "$SHA_FILE"
# now compare:
if [ "$SHAs_local" != "$SHAs_remote" ]; then
# we need to rebuild
echo "$SHAs_remote" > "$SHA_FILE"
git config --local user.name actions-user
git config --local user.email "[email protected]"
git add "$SHA_FILE"
git commit -am "GH Action SHA updated $(date)"
git push -f origin main
echo "Success - container needs rebuilding"
else
echo "Remote container has not changed, no need to run deploy. Exiting."
exit 1
fi
call-workflow-in-local-repo:
# Make sure this in the downstream build action:
# on:
# workflow_call:
# repository_dispatch:
# types: build_on_aiscatcher_update
needs: check_upstream_image
uses: ./.github/workflows/deploy.yml