Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 78d9ca75f3 | |||
| 316a41d231 | |||
| b0ceee7e9b | |||
| 5ff1f840dc |
@@ -22,6 +22,26 @@ Builds and optionally pushes OCI container images to `registry.noctrl.eu` using
|
|||||||
|
|
||||||
See [podman-build-publish README](./podman-build-publish/README.md) for full documentation.
|
See [podman-build-publish README](./podman-build-publish/README.md) for full documentation.
|
||||||
|
|
||||||
|
### Podman Manifest Publish
|
||||||
|
|
||||||
|
Creates and pushes OCI multi-arch manifest tags to `registry.noctrl.eu` using
|
||||||
|
Podman with isolated storage context.
|
||||||
|
|
||||||
|
**Location:** [`./podman-manifest-publish`](./podman-manifest-publish)
|
||||||
|
|
||||||
|
**Use in workflows:**
|
||||||
|
```yaml
|
||||||
|
- uses: https://gitea.noctrl.eu/noctrl/actions/podman-manifest-publish@v1
|
||||||
|
with:
|
||||||
|
image-name: noctrl/myapp
|
||||||
|
manifest-tag: v1.2.3
|
||||||
|
source-tags: |
|
||||||
|
v1.2.3-tmp-123-amd64
|
||||||
|
v1.2.3-tmp-123-arm64
|
||||||
|
```
|
||||||
|
|
||||||
|
See [podman-manifest-publish README](./podman-manifest-publish/README.md) for full documentation.
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
Reference actions by absolute URL in your workflow:
|
Reference actions by absolute URL in your workflow:
|
||||||
|
|||||||
@@ -1,53 +0,0 @@
|
|||||||
# Podman Build And Publish Action
|
|
||||||
|
|
||||||
Composite action that builds and pushes OCI images with Podman to `registry.noctrl.eu`.
|
|
||||||
|
|
||||||
## Inputs
|
|
||||||
|
|
||||||
- `image-name` (required): repository path, for example `noctrl/gitea-runner`
|
|
||||||
- `tags` (required): newline, comma, or space separated tags
|
|
||||||
- `context` (optional, default `.`): build context
|
|
||||||
- `containerfile` (optional, default `Containerfile`): containerfile path
|
|
||||||
- `build-args` (optional): newline-separated `KEY=VALUE`
|
|
||||||
- `registry-username` (required): registry login username
|
|
||||||
- `registry-password` (required): registry login password
|
|
||||||
|
|
||||||
## Caller Secrets
|
|
||||||
|
|
||||||
Define these secrets in the calling repository and pass them to the action inputs:
|
|
||||||
- `REGISTRY_USERNAME`: registry authentication username
|
|
||||||
- `REGISTRY_PASSWORD`: registry authentication password
|
|
||||||
|
|
||||||
The action uses fixed Podman defaults matching the runner workflows:
|
|
||||||
- root: `${RUNNER_TEMP}/podman-root`
|
|
||||||
- runroot: `${RUNNER_TEMP}/podman-runroot`
|
|
||||||
- storage driver: `vfs`
|
|
||||||
- build isolation: `chroot`
|
|
||||||
- registry: `registry.noctrl.eu` (hardcoded)
|
|
||||||
|
|
||||||
## Example
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
jobs:
|
|
||||||
build-and-push:
|
|
||||||
runs-on: [linux, build]
|
|
||||||
steps:
|
|
||||||
- name: Checkout
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: Build and push image
|
|
||||||
uses: https://gitea.noctrl.eu/noctrl/actions/podman-build-publish@v1
|
|
||||||
with:
|
|
||||||
image-name: noctrl/gitea-runner
|
|
||||||
tags: |
|
|
||||||
latest
|
|
||||||
sha-${{ github.sha }}
|
|
||||||
context: .
|
|
||||||
containerfile: Containerfile
|
|
||||||
build-args: |
|
|
||||||
ACT_RUNNER_VERSION=0.2.11
|
|
||||||
registry-username: ${{ secrets.REGISTRY_USERNAME }}
|
|
||||||
registry-password: ${{ secrets.REGISTRY_PASSWORD }}
|
|
||||||
```
|
|
||||||
|
|
||||||
> **Note:** Composite actions should receive credentials through inputs. Keep secrets in the caller repo and pass them via `with:` as shown above.
|
|
||||||
@@ -12,10 +12,10 @@ inputs:
|
|||||||
required: true
|
required: true
|
||||||
registry-username:
|
registry-username:
|
||||||
description: Registry username for login.
|
description: Registry username for login.
|
||||||
required: true
|
required: false
|
||||||
registry-password:
|
registry-password:
|
||||||
description: Registry password for login.
|
description: Registry password for login.
|
||||||
required: true
|
required: false
|
||||||
context:
|
context:
|
||||||
description: Build context path.
|
description: Build context path.
|
||||||
required: false
|
required: false
|
||||||
@@ -30,6 +30,12 @@ inputs:
|
|||||||
Example: "ACT_RUNNER_VERSION=0.2.11"
|
Example: "ACT_RUNNER_VERSION=0.2.11"
|
||||||
required: false
|
required: false
|
||||||
default: ""
|
default: ""
|
||||||
|
push:
|
||||||
|
description: |
|
||||||
|
Whether to push tags to the registry after build.
|
||||||
|
Set to "false" for build-only verification workflows.
|
||||||
|
required: false
|
||||||
|
default: "true"
|
||||||
|
|
||||||
runs:
|
runs:
|
||||||
using: composite
|
using: composite
|
||||||
@@ -39,34 +45,27 @@ runs:
|
|||||||
run: |
|
run: |
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
# Fixed Podman storage paths — re-derived in each step to avoid
|
rm -rf "${RUNNER_TEMP}/podman-root" "${RUNNER_TEMP}/podman-runroot"
|
||||||
# relying on GITHUB_ENV propagation between composite action steps.
|
mkdir -p "${RUNNER_TEMP}/podman-root" "${RUNNER_TEMP}/podman-runroot"
|
||||||
podman_root="${RUNNER_TEMP}/podman-root"
|
|
||||||
podman_runroot="${RUNNER_TEMP}/podman-runroot"
|
|
||||||
|
|
||||||
rm -rf "${podman_root}" "${podman_runroot}"
|
# Validate tags early so failures are caught before build starts
|
||||||
mkdir -p "${podman_root}" "${podman_runroot}"
|
|
||||||
|
|
||||||
# Export only input-derived values that cannot be recomputed later.
|
|
||||||
{
|
|
||||||
echo "IMAGE_BASE=registry.noctrl.eu/${{ inputs.image-name }}"
|
|
||||||
} >> "${GITHUB_ENV}"
|
|
||||||
|
|
||||||
# Parse and validate tags
|
|
||||||
mapfile -t tags < <(printf '%s\n' "${{ inputs.tags }}" | tr ', ' '\n\n' | sed '/^$/d')
|
mapfile -t tags < <(printf '%s\n' "${{ inputs.tags }}" | tr ', ' '\n\n' | sed '/^$/d')
|
||||||
if [[ ${#tags[@]} -eq 0 ]]; then
|
if [[ ${#tags[@]} -eq 0 ]]; then
|
||||||
echo "ERROR: no tags resolved from inputs.tags" >&2
|
echo "ERROR: no tags resolved from inputs.tags" >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Export tags as newline-separated string for subsequent steps
|
|
||||||
(IFS=$'\n'; echo "IMAGE_TAGS=${tags[*]}") >> "${GITHUB_ENV}"
|
|
||||||
|
|
||||||
- id: login
|
- id: login
|
||||||
|
if: ${{ inputs.push != 'false' }}
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
|
if [[ -z "${{ inputs.registry-username }}" || -z "${{ inputs.registry-password }}" ]]; then
|
||||||
|
echo "ERROR: registry-username and registry-password are required when push is enabled" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
podman_args=(
|
podman_args=(
|
||||||
--root "${RUNNER_TEMP}/podman-root"
|
--root "${RUNNER_TEMP}/podman-root"
|
||||||
--runroot "${RUNNER_TEMP}/podman-runroot"
|
--runroot "${RUNNER_TEMP}/podman-runroot"
|
||||||
@@ -87,6 +86,7 @@ runs:
|
|||||||
--storage-driver vfs
|
--storage-driver vfs
|
||||||
)
|
)
|
||||||
|
|
||||||
|
image_base="registry.noctrl.eu/${{ inputs.image-name }}"
|
||||||
build_cmd=(podman "${podman_args[@]}" build --isolation chroot -f "${{ inputs.containerfile }}")
|
build_cmd=(podman "${podman_args[@]}" build --isolation chroot -f "${{ inputs.containerfile }}")
|
||||||
|
|
||||||
# Add build args
|
# Add build args
|
||||||
@@ -99,14 +99,15 @@ runs:
|
|||||||
echo "Building image with tags:"
|
echo "Building image with tags:"
|
||||||
while IFS= read -r tag; do
|
while IFS= read -r tag; do
|
||||||
[[ -z "${tag}" ]] && continue
|
[[ -z "${tag}" ]] && continue
|
||||||
echo " ${IMAGE_BASE}:${tag}"
|
echo " ${image_base}:${tag}"
|
||||||
build_cmd+=(-t "${IMAGE_BASE}:${tag}")
|
build_cmd+=(-t "${image_base}:${tag}")
|
||||||
done <<< "${IMAGE_TAGS}"
|
done < <(printf '%s\n' "${{ inputs.tags }}" | tr ', ' '\n\n' | sed '/^$/d')
|
||||||
|
|
||||||
build_cmd+=("${{ inputs.context }}")
|
build_cmd+=("${{ inputs.context }}")
|
||||||
"${build_cmd[@]}"
|
"${build_cmd[@]}"
|
||||||
|
|
||||||
- id: push
|
- if: ${{ inputs.push != 'false' }}
|
||||||
|
id: push
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
@@ -117,9 +118,11 @@ runs:
|
|||||||
--storage-driver vfs
|
--storage-driver vfs
|
||||||
)
|
)
|
||||||
|
|
||||||
|
image_base="registry.noctrl.eu/${{ inputs.image-name }}"
|
||||||
|
|
||||||
echo "Pushing image tags:"
|
echo "Pushing image tags:"
|
||||||
while IFS= read -r tag; do
|
while IFS= read -r tag; do
|
||||||
[[ -z "${tag}" ]] && continue
|
[[ -z "${tag}" ]] && continue
|
||||||
echo " ${IMAGE_BASE}:${tag}"
|
echo " ${image_base}:${tag}"
|
||||||
podman "${podman_args[@]}" push "${IMAGE_BASE}:${tag}"
|
podman "${podman_args[@]}" push "${image_base}:${tag}"
|
||||||
done <<< "${IMAGE_TAGS}"
|
done < <(printf '%s\n' "${{ inputs.tags }}" | tr ', ' '\n\n' | sed '/^$/d')
|
||||||
|
|||||||
@@ -0,0 +1,87 @@
|
|||||||
|
name: Podman Manifest Publish
|
||||||
|
description: Create and push OCI multi-arch manifests with Podman to registry.noctrl.eu.
|
||||||
|
|
||||||
|
inputs:
|
||||||
|
image-name:
|
||||||
|
description: Repository/image name path, for example noctrl/gitea-runner
|
||||||
|
required: true
|
||||||
|
manifest-tag:
|
||||||
|
description: Final manifest tag to publish, for example v1.2.3
|
||||||
|
required: true
|
||||||
|
source-tags:
|
||||||
|
description: |
|
||||||
|
Source image tags to include in the manifest.
|
||||||
|
Supports newline, comma, or space separated values.
|
||||||
|
Example: "v1.2.3-tmp-123-amd64\nv1.2.3-tmp-123-arm64"
|
||||||
|
required: true
|
||||||
|
registry-username:
|
||||||
|
description: Registry username for login.
|
||||||
|
required: true
|
||||||
|
registry-password:
|
||||||
|
description: Registry password for login.
|
||||||
|
required: true
|
||||||
|
|
||||||
|
runs:
|
||||||
|
using: composite
|
||||||
|
steps:
|
||||||
|
- id: initialize
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
rm -rf "${RUNNER_TEMP}/podman-root" "${RUNNER_TEMP}/podman-runroot"
|
||||||
|
mkdir -p "${RUNNER_TEMP}/podman-root" "${RUNNER_TEMP}/podman-runroot"
|
||||||
|
|
||||||
|
mapfile -t source_tags < <(printf '%s\n' "${{ inputs.source-tags }}" | tr ', ' '\n\n' | sed '/^$/d')
|
||||||
|
if [[ ${#source_tags[@]} -eq 0 ]]; then
|
||||||
|
echo "ERROR: no tags resolved from inputs.source-tags" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
- id: login
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
podman_args=(
|
||||||
|
--root "${RUNNER_TEMP}/podman-root"
|
||||||
|
--runroot "${RUNNER_TEMP}/podman-runroot"
|
||||||
|
--storage-driver vfs
|
||||||
|
)
|
||||||
|
|
||||||
|
echo "Logging in to registry: registry.noctrl.eu"
|
||||||
|
echo "${{ inputs.registry-password }}" | podman "${podman_args[@]}" login registry.noctrl.eu -u "${{ inputs.registry-username }}" --password-stdin
|
||||||
|
|
||||||
|
- id: publish-manifest
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
podman_args=(
|
||||||
|
--root "${RUNNER_TEMP}/podman-root"
|
||||||
|
--runroot "${RUNNER_TEMP}/podman-runroot"
|
||||||
|
--storage-driver vfs
|
||||||
|
)
|
||||||
|
|
||||||
|
image_base="registry.noctrl.eu/${{ inputs.image-name }}"
|
||||||
|
target_ref="docker://${image_base}:${{ inputs.manifest-tag }}"
|
||||||
|
manifest_name="manifest-${{ github.run_id }}-${{ github.job }}"
|
||||||
|
|
||||||
|
cleanup() {
|
||||||
|
podman "${podman_args[@]}" manifest rm "${manifest_name}" >/dev/null 2>&1 || true
|
||||||
|
}
|
||||||
|
trap cleanup EXIT
|
||||||
|
|
||||||
|
echo "Creating manifest ${target_ref} from tags:"
|
||||||
|
podman "${podman_args[@]}" manifest create "${manifest_name}"
|
||||||
|
|
||||||
|
while IFS= read -r tag; do
|
||||||
|
[[ -z "${tag}" ]] && continue
|
||||||
|
source_ref="docker://${image_base}:${tag}"
|
||||||
|
echo " ${source_ref}"
|
||||||
|
podman "${podman_args[@]}" manifest add "${manifest_name}" "${source_ref}"
|
||||||
|
done < <(printf '%s\n' "${{ inputs.source-tags }}" | tr ', ' '\n\n' | sed '/^$/d')
|
||||||
|
|
||||||
|
podman "${podman_args[@]}" manifest push --all "${manifest_name}" "${target_ref}"
|
||||||
|
podman "${podman_args[@]}" manifest rm "${manifest_name}"
|
||||||
|
trap - EXIT
|
||||||
Reference in New Issue
Block a user