Merge pull request #275 from jeremy4040/main #102
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: Docker Image CI | |
on: | |
push: | |
paths: | |
- 'images/**' | |
branches: [ main ] | |
env: | |
REGISTRY: ghcr.io | |
IMAGE_NAME: ${{ github.repository }} | |
GHCR_TOKEN: ${{ secrets.GHCR_TOKEN }} | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v2 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v1 | |
- name: Log in to GitHub Container Registry | |
run: echo "$GHCR_TOKEN" | base64 --decode | docker login "${{ env.REGISTRY }}" -u "${{ github.actor }}" --password-stdin | |
- name: Ensure jq is installed | |
run: | | |
if ! command -v jq &> /dev/null; then | |
sudo apt-get update | |
sudo apt-get install -y jq | |
fi | |
- name: Process and push Docker images | |
run: | | |
# Read images from capten-images.txt and process them | |
while IFS= read -r image; do | |
# Extract image name and tag | |
imagename=$(echo "$image" | awk -F '/' '{print $NF}') | |
image_name=$(echo "$image" | awk -F '/' '{print $NF}' | awk -F ':' '{print $1}') | |
image_tag=$(echo "$image" | awk -F ':' '{print $2}') | |
# Handle cases where image_tag might be empty | |
if [ -z "$image_tag" ]; then | |
image_tag="latest" | |
fi | |
github_image="${{ env.REGISTRY }}/${{ github.repository }}/$image_name" | |
# Check if the image exists in GHCR | |
response=$(curl -s -H "Authorization: Bearer $GHCR_TOKEN" https://ghcr.io/v2/${{ github.repository }}/$image_name/tags/list) | |
# If response is empty, skip to the next image | |
if [ -z "$response" ]; then | |
continue | |
fi | |
# Check for errors in the response | |
if echo "$response" | jq -e '.errors' > /dev/null; then | |
error_code=$(echo "$response" | jq -r '.errors[0].code') | |
error_message=$(echo "$response" | jq -r '.errors[0].message') | |
if [ "$error_code" = "NAME_UNKNOWN" ]; then | |
existing_tags="" | |
else | |
continue | |
fi | |
else | |
# Parse the response using jq to extract the tags | |
existing_tags=$(echo "$response" | jq -r '.tags[]? // empty') | |
# If existing_tags is null or empty, handle it | |
if [ -z "$existing_tags" ]; then | |
continue | |
fi | |
echo "Existing tags for $image_name: $existing_tags" | |
fi | |
# Check if the image tag exists in the list of existing tags | |
tag_exists=false | |
for tag in $existing_tags; do | |
if [[ "$tag" == "$image_tag" ]]; then | |
tag_exists=true | |
break | |
fi | |
done | |
if [ "$tag_exists" = true ]; then | |
echo "Image $github_image already exists in GHCR with tag $image_tag. Skipping push." | |
else | |
echo "Image $github_image not found in GHCR with tag $image_tag. Proceeding with push." | |
# Pull the image from the original registry | |
docker pull "$image" | |
# Tag the image with the GitHub repository URL and specific tag | |
docker tag "$image" "$github_image:$image_tag" | |
# Push the image to GitHub Container Registry | |
docker push "$github_image:$image_tag" | |
if [ $? -eq 0 ]; then | |
echo "Image pushed successfully" | |
else | |
echo "Retrying push" | |
docker push "$github_image:$image_tag" | |
fi | |
fi | |
done < images/capten-images.txt |