Skip to content

HDDS-11632. Publish images to GitHub container registry (#9) #1

HDDS-11632. Publish images to GitHub container registry (#9)

HDDS-11632. Publish images to GitHub container registry (#9) #1

# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with
# the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
name: build-and-tag
# This workflow builds (if necessary) and tags the Docker image.
on:
push:
permissions:
contents: read
packages: write
jobs:
build:
uses: ./.github/workflows/build.yaml
tag:
needs: build
if: ${{ github.ref_type == 'tag' }}
runs-on: ubuntu-latest
env:
IMAGE_ID: ${{ needs.build.outputs.image-id }}
steps:
- name: Generate tags
uses: docker/metadata-action@8e5442c4ef9f78752691e2d8f8d19755c6f78e81
with:
images: |
ghcr.io/${{ github.repository_owner }}/ozone-testkrb5
tags: |
type=ref,event=tag
flavor: |
latest=false
- name: Pull image
run: |
docker pull "$IMAGE_ID"
- name: Login to GitHub Container Registry
uses: docker/login-action@9780b0c442fbb1117ed29e0efdff1e18412f7567
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Apply tags to existing image
run: |
opts="$(echo "$DOCKER_METADATA_OUTPUT_TAGS" | sed "s@^@--tag @g" | xargs echo)"
if [[ -n "$opts" ]]; then
docker buildx imagetools create $opts "$IMAGE_ID"
fi