Skip to content

Commit

Permalink
added docker publish 22.0.1 and latest
Browse files Browse the repository at this point in the history
  • Loading branch information
Allan-Nava authored Dec 17, 2024
1 parent 8fdb537 commit 6858a2b
Show file tree
Hide file tree
Showing 5 changed files with 212 additions and 0 deletions.
79 changes: 79 additions & 0 deletions .github/workflows/docker-publish.22.0.1.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,79 @@
name: Docker apple idendity provider & DRUID keycloak 22.0.1
'on':
push:
tags:
- '*'
jobs:
docker:
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Repo metadata
id: repo
uses: actions/github-script@v4
with:
script: |
const repo = await github.repos.get(context.repo)
return repo.data
- name: Prepare
id: prep
run: |
REG=ghcr.io
IMAGE=$(echo ${{ github.repository }} | tr '[:upper:]' '[:lower:]')
DOCKER_IMAGE=${REG}/${IMAGE}-22.0.1
VERSION=nool
if [ "${{ github.event_name }}" = "schedule" ]; then
VERSION=nightly
elif [[ $GITHUB_REF == refs/tags/* ]]; then
VERSION=${GITHUB_REF#refs/tags/}-
elif [[ $GITHUB_REF == refs/heads/* ]]; then
VERSION=$(echo ${GITHUB_REF#refs/heads/} | sed -r 's#/+#-#g')
if [ "${{ github.event.repository.default_branch }}" = "$VERSION" ]; then
VERSION=latest
fi
elif [[ $GITHUB_REF == refs/pull/* ]]; then
VERSION=pr-${{ github.event.number }}
fi
TAGS="${DOCKER_IMAGE}:${VERSION}"
if [[ $VERSION =~ ^v[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$ ]]; then
MINOR=${VERSION%.*}
MAJOR=${MINOR%.*}
TAGS="$TAGS,${DOCKER_IMAGE}:${MINOR},${DOCKER_IMAGE}:${MAJOR},${DOCKER_IMAGE}:latest"
fi
echo ::set-output name=version::${VERSION}
echo ::set-output name=tags::${TAGS}
echo ::set-output name=created::$(date -u +'%Y-%m-%dT%H:%M:%SZ')
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Login to GitHub Container Registry
uses: docker/login-action@v2
with:
registry: ghcr.io
username: '${{ github.actor }}'
password: '${{ secrets.GITHUB_TOKEN }}'
- name: Build and push
uses: docker/build-push-action@v4
with:
context: .
file: ./Dockerfile.22.0.1
platforms: linux/amd64
push: true
tags: '${{ steps.prep.outputs.tags }}'
labels: >
org.opencontainers.image.title=${{
fromJson(steps.repo.outputs.result).name }}
org.opencontainers.image.description=${{
fromJson(steps.repo.outputs.result).description }}
org.opencontainers.image.url=${{
fromJson(steps.repo.outputs.result).html_url }}
org.opencontainers.image.source=${{
fromJson(steps.repo.outputs.result).html_url }}
org.opencontainers.image.version=${{ steps.prep.outputs.version }}
org.opencontainers.image.created=${{ steps.prep.outputs.created }}
org.opencontainers.image.revision=${{ github.sha }}
org.opencontainers.image.licenses=${{
fromJson(steps.repo.outputs.result).license.spdx_id }}
79 changes: 79 additions & 0 deletions .github/workflows/docker-publish.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,79 @@
name: Docker apple idendity provider & druid keycloak
'on':
push:
tags:
- '*'
jobs:
docker:
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Repo metadata
id: repo
uses: actions/github-script@v4
with:
script: |
const repo = await github.repos.get(context.repo)
return repo.data
- name: Prepare
id: prep
run: |
REG=ghcr.io
IMAGE=$(echo ${{ github.repository }} | tr '[:upper:]' '[:lower:]')
DOCKER_IMAGE=${REG}/${IMAGE}
VERSION=nool
if [ "${{ github.event_name }}" = "schedule" ]; then
VERSION=nightly
elif [[ $GITHUB_REF == refs/tags/* ]]; then
VERSION=${GITHUB_REF#refs/tags/}
elif [[ $GITHUB_REF == refs/heads/* ]]; then
VERSION=$(echo ${GITHUB_REF#refs/heads/} | sed -r 's#/+#-#g')
if [ "${{ github.event.repository.default_branch }}" = "$VERSION" ]; then
VERSION=latest
fi
elif [[ $GITHUB_REF == refs/pull/* ]]; then
VERSION=pr-${{ github.event.number }}
fi
TAGS="${DOCKER_IMAGE}:${VERSION}"
if [[ $VERSION =~ ^v[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$ ]]; then
MINOR=${VERSION%.*}
MAJOR=${MINOR%.*}
TAGS="$TAGS,${DOCKER_IMAGE}:${MINOR},${DOCKER_IMAGE}:${MAJOR},${DOCKER_IMAGE}:latest"
fi
echo ::set-output name=version::${VERSION}
echo ::set-output name=tags::${TAGS}
echo ::set-output name=created::$(date -u +'%Y-%m-%dT%H:%M:%SZ')
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Login to GitHub Container Registry
uses: docker/login-action@v2
with:
registry: ghcr.io
username: '${{ github.actor }}'
password: '${{ secrets.GITHUB_TOKEN }}'
- name: Build and push
uses: docker/build-push-action@v4
with:
context: .
file: ./Dockerfile.latest
platforms: linux/amd64
push: true
tags: '${{ steps.prep.outputs.tags }}'
labels: >
org.opencontainers.image.title=${{
fromJson(steps.repo.outputs.result).name }}
org.opencontainers.image.description=${{
fromJson(steps.repo.outputs.result).description }}
org.opencontainers.image.url=${{
fromJson(steps.repo.outputs.result).html_url }}
org.opencontainers.image.source=${{
fromJson(steps.repo.outputs.result).html_url }}
org.opencontainers.image.version=${{ steps.prep.outputs.version }}
org.opencontainers.image.created=${{ steps.prep.outputs.created }}
org.opencontainers.image.revision=${{ github.sha }}
org.opencontainers.image.licenses=${{
fromJson(steps.repo.outputs.result).license.spdx_id }}
27 changes: 27 additions & 0 deletions Dockerfile.22.0.1
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
FROM quay.io/keycloak/keycloak:22.0.1 as builder
#ENV KC_HEALTH_ENABLED=true
ENV KC_FEATURES=token-exchange
ENV KC_METRICS_ENABLED=true
#ENV KC_HTTP_RELATIVE_PATH="/auth"
# Install custom providers
# Apple Social Identity Provider - https://github.com/klausbetz/apple-identity-provider-keycloak
ADD --chown=keycloak:keycloak https://github.com/klausbetz/apple-identity-provider-keycloak/releases/download/1.10.0/apple-identity-provider-1.10.0.jar /opt/keycloak/providers/apple-identity-provider-1.10.0.jar
# build optimized image
RUN /opt/keycloak/bin/kc.sh build
#
FROM quay.io/keycloak/keycloak:22.0.1 as druid-builder
#ENV KC_HEALTH_ENABLED=true
ENV KC_FEATURES=token-exchange
ENV KC_METRICS_ENABLED=true
# Install custom providers
COPY druid-social-identity-provider-1.0.2.jar /opt/keycloak/providersdruid-social-identity-provider-1.0.2.jar
# build optimized image
RUN /opt/keycloak/bin/kc.sh build
#
#
FROM quay.io/keycloak/keycloak:22.0.1
WORKDIR /opt/keycloak
COPY --from=builder /opt/keycloak/ /opt/keycloak/
COPY --from=druid-builder /opt/keycloak/ /opt/keycloak/
ENTRYPOINT ["/opt/keycloak/bin/kc.sh"]
#
27 changes: 27 additions & 0 deletions Dockerfile.latest
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
FROM quay.io/keycloak/keycloak:latest as builder
#ENV KC_HEALTH_ENABLED=true
ENV KC_FEATURES=token-exchange
ENV KC_METRICS_ENABLED=true
#ENV KC_HTTP_RELATIVE_PATH="/auth"
# Install custom providers
# Apple Social Identity Provider - https://github.com/klausbetz/apple-identity-provider-keycloak
ADD --chown=keycloak:keycloak https://github.com/klausbetz/apple-identity-provider-keycloak/releases/download/1.10.0/apple-identity-provider-1.10.0.jar /opt/keycloak/providers/apple-identity-provider-1.10.0.jar
# build optimized image
RUN /opt/keycloak/bin/kc.sh build
#
FROM quay.io/keycloak/keycloak:latest as druid-builder
#ENV KC_HEALTH_ENABLED=true
ENV KC_FEATURES=token-exchange
ENV KC_METRICS_ENABLED=true
# Install custom providers
COPY druid-social-identity-provider-1.0.2.jar /opt/keycloak/providersdruid-social-identity-provider-1.0.2.jar
# build optimized image
RUN /opt/keycloak/bin/kc.sh build
#
#
FROM quay.io/keycloak/keycloak:latest
WORKDIR /opt/keycloak
COPY --from=builder /opt/keycloak/ /opt/keycloak/
COPY --from=druid-builder /opt/keycloak/ /opt/keycloak/
ENTRYPOINT ["/opt/keycloak/bin/kc.sh"]
#
Binary file added druid-social-identity-provider-1.0.2.jar
Binary file not shown.

0 comments on commit 6858a2b

Please sign in to comment.