Files
template-code-location/.gitea/workflows/docker-publish.yml
Richard Mrasek 58600a3767
Some checks failed
Build and Push Docker Image / build-and-push (push) Failing after 0s
fixed runner again
2026-06-11 15:27:10 +02:00

74 lines
2.3 KiB
YAML

name: Build and Push Docker Image
on:
push:
branches:
- main
workflow_dispatch:
jobs:
build-and-push:
runs-on: orchestration-platform
env:
REGISTRY: gitea.dataprovider01.sandbox-cat-dat.simpl-europe.eu
IMAGE_REPO: gitea.dataprovider01.sandbox-cat-dat.simpl-europe.eu/j.r/template-code-location
steps:
- name: Checkout repository (shell)
run: |
REPO_DIR="repo"
SERVER_URL="${GITHUB_SERVER_URL:-$GITEA_SERVER_URL}"
TOKEN="${GITHUB_TOKEN:-$GITEA_TOKEN}"
REF_NAME="${GITHUB_REF_NAME}"
if [ -z "${REF_NAME}" ]; then
REF_NAME="${GITHUB_REF#refs/heads/}"
fi
if [ -z "${SERVER_URL}" ]; then
echo "Missing GITHUB_SERVER_URL/GITEA_SERVER_URL"
exit 1
fi
if [ -z "${TOKEN}" ]; then
echo "Missing GITHUB_TOKEN/GITEA_TOKEN; cannot clone private repository"
exit 1
fi
rm -rf "${REPO_DIR}"
git clone --depth 1 --branch "${REF_NAME}" \
"https://oauth2:${TOKEN}@${SERVER_URL#https://}/${GITHUB_REPOSITORY}.git" \
"${REPO_DIR}"
if [ ! -f "${REPO_DIR}/Dockerfile" ]; then
echo "Dockerfile not found after clone"
exit 1
fi
- name: Validate registry secrets
run: |
if [ -z "${{ secrets.REGISTRY_USERNAME }}" ] || [ -z "${{ secrets.REGISTRY_PASSWORD }}" ]; then
echo "Missing REGISTRY_USERNAME or REGISTRY_PASSWORD secret"
exit 1
fi
- name: Login to registry
run: |
echo "${{ secrets.REGISTRY_PASSWORD }}" | docker login "${REGISTRY}" \
-u "${{ secrets.REGISTRY_USERNAME }}" --password-stdin
- name: Build image
run: |
COMMIT_SHA="${GITHUB_SHA:-$GITEA_SHA}"
SHORT_SHA="$(echo "${COMMIT_SHA}" | cut -c1-12)"
cd repo
docker build \
-t "${IMAGE_REPO}:latest" \
-t "${IMAGE_REPO}:${SHORT_SHA}" \
.
- name: Push image tags
run: |
COMMIT_SHA="${GITHUB_SHA:-$GITEA_SHA}"
SHORT_SHA="$(echo "${COMMIT_SHA}" | cut -c1-12)"
docker push "${IMAGE_REPO}:latest"
docker push "${IMAGE_REPO}:${SHORT_SHA}"