ci: add GHCR container publish pipeline with semantic tags
Some checks failed
Mark stable commit / test-unit (push) Has been cancelled
Mark stable commit / test-integration (push) Has been cancelled
Mark stable commit / test-env-virtual (push) Has been cancelled
Mark stable commit / test-env-nix (push) Has been cancelled
Mark stable commit / test-e2e (push) Has been cancelled
Mark stable commit / test-virgin-user (push) Has been cancelled
Mark stable commit / test-virgin-root (push) Has been cancelled
Mark stable commit / mark-stable (push) Has been cancelled
Some checks failed
Mark stable commit / test-unit (push) Has been cancelled
Mark stable commit / test-integration (push) Has been cancelled
Mark stable commit / test-env-virtual (push) Has been cancelled
Mark stable commit / test-env-nix (push) Has been cancelled
Mark stable commit / test-e2e (push) Has been cancelled
Mark stable commit / test-virgin-user (push) Has been cancelled
Mark stable commit / test-virgin-root (push) Has been cancelled
Mark stable commit / mark-stable (push) Has been cancelled
Introduce a dedicated publish-containers workflow triggered after stable releases. Unify container build and publish logic via scripts, add buildx-based multi-tag publishing, default base image resolution, and Arch alias tags for latest/version/stable. https://chatgpt.com/share/693c836b-0b00-800f-9536-9e273abd0fb5
This commit is contained in:
63
.github/workflows/publish-containers.yml
vendored
Normal file
63
.github/workflows/publish-containers.yml
vendored
Normal file
@@ -0,0 +1,63 @@
|
|||||||
|
name: Publish container images (GHCR)
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_run:
|
||||||
|
workflows: ["Mark stable commit"]
|
||||||
|
types: [completed]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
publish:
|
||||||
|
if: ${{ github.event.workflow_run.conclusion == 'success' }}
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
packages: write
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository (with tags)
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
fetch-tags: true
|
||||||
|
|
||||||
|
- name: Checkout workflow_run commit
|
||||||
|
run: |
|
||||||
|
set -euo pipefail
|
||||||
|
git checkout -f "${{ github.event.workflow_run.head_sha }}"
|
||||||
|
|
||||||
|
- name: Compute version and stable flag
|
||||||
|
id: info
|
||||||
|
run: |
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
SHA="$(git rev-parse HEAD)"
|
||||||
|
V_TAG="$(git tag --points-at "${SHA}" --list 'v*' | sort -V | tail -n1)"
|
||||||
|
[[ -n "$V_TAG" ]] || { echo "No version tag found"; exit 1; }
|
||||||
|
|
||||||
|
VERSION="${V_TAG#v}"
|
||||||
|
|
||||||
|
STABLE_SHA="$(git rev-parse -q --verify refs/tags/stable^{commit} 2>/dev/null || true)"
|
||||||
|
IS_STABLE=false
|
||||||
|
[[ "$STABLE_SHA" == "$SHA" ]] && IS_STABLE=true
|
||||||
|
|
||||||
|
echo "version=${VERSION}" >> "$GITHUB_OUTPUT"
|
||||||
|
echo "is_stable=${IS_STABLE}" >> "$GITHUB_OUTPUT"
|
||||||
|
|
||||||
|
- uses: docker/setup-buildx-action@v3
|
||||||
|
with:
|
||||||
|
use: true
|
||||||
|
|
||||||
|
- uses: docker/login-action@v3
|
||||||
|
with:
|
||||||
|
registry: ghcr.io
|
||||||
|
username: ${{ github.actor }}
|
||||||
|
password: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
|
||||||
|
- name: Publish all images
|
||||||
|
run: |
|
||||||
|
set -euo pipefail
|
||||||
|
OWNER="${{ github.repository_owner }}" \
|
||||||
|
VERSION="${{ steps.info.outputs.version }}" \
|
||||||
|
IS_STABLE="${{ steps.info.outputs.is_stable }}" \
|
||||||
|
bash scripts/build/publish.sh
|
||||||
@@ -1,18 +1,20 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
|
: "${BASE_IMAGE_ARCH:=archlinux:latest}"
|
||||||
|
: "${BASE_IMAGE_DEBIAN:=debian:stable-slim}"
|
||||||
|
: "${BASE_IMAGE_UBUNTU:=ubuntu:latest}"
|
||||||
|
: "${BASE_IMAGE_FEDORA:=fedora:latest}"
|
||||||
|
: "${BASE_IMAGE_CENTOS:=quay.io/centos/centos:stream9}"
|
||||||
|
|
||||||
resolve_base_image() {
|
resolve_base_image() {
|
||||||
local distro="$1"
|
local distro="$1"
|
||||||
|
|
||||||
case "$distro" in
|
case "$distro" in
|
||||||
arch) echo "$BASE_IMAGE_ARCH" ;;
|
arch) echo "$BASE_IMAGE_ARCH" ;;
|
||||||
debian) echo "$BASE_IMAGE_DEBIAN" ;;
|
debian) echo "$BASE_IMAGE_DEBIAN" ;;
|
||||||
ubuntu) echo "$BASE_IMAGE_UBUNTU" ;;
|
ubuntu) echo "$BASE_IMAGE_UBUNTU" ;;
|
||||||
fedora) echo "$BASE_IMAGE_FEDORA" ;;
|
fedora) echo "$BASE_IMAGE_FEDORA" ;;
|
||||||
centos) echo "$BASE_IMAGE_CENTOS" ;;
|
centos) echo "$BASE_IMAGE_CENTOS" ;;
|
||||||
*)
|
*) echo "ERROR: Unknown distro '$distro'" >&2; exit 1 ;;
|
||||||
echo "ERROR: Unknown distro '$distro'" >&2
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,28 +1,7 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
# Unified docker image builder for all distros.
|
|
||||||
#
|
|
||||||
# Supports:
|
|
||||||
# --missing Build only if image does not exist
|
|
||||||
# --no-cache Disable docker layer cache
|
|
||||||
# --target Dockerfile target (e.g. virgin|full)
|
|
||||||
# --tag Override image tag (default: pkgmgr-$distro[-$target])
|
|
||||||
#
|
|
||||||
# Requires:
|
|
||||||
# - env var: distro (arch|debian|ubuntu|fedora|centos)
|
|
||||||
# - base.sh in same dir
|
|
||||||
#
|
|
||||||
# Examples:
|
|
||||||
# distro=arch bash scripts/build/image.sh
|
|
||||||
# distro=arch bash scripts/build/image.sh --no-cache
|
|
||||||
# distro=arch bash scripts/build/image.sh --missing
|
|
||||||
# distro=arch bash scripts/build/image.sh --target virgin
|
|
||||||
# distro=arch bash scripts/build/image.sh --target virgin --missing
|
|
||||||
# distro=arch bash scripts/build/image.sh --tag myimg:arch
|
|
||||||
|
|
||||||
SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)"
|
SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)"
|
||||||
# shellcheck source=/dev/null
|
|
||||||
source "${SCRIPT_DIR}/base.sh"
|
source "${SCRIPT_DIR}/base.sh"
|
||||||
|
|
||||||
: "${distro:?Environment variable 'distro' must be set (arch|debian|ubuntu|fedora|centos)}"
|
: "${distro:?Environment variable 'distro' must be set (arch|debian|ubuntu|fedora|centos)}"
|
||||||
@@ -30,7 +9,15 @@ source "${SCRIPT_DIR}/base.sh"
|
|||||||
NO_CACHE=0
|
NO_CACHE=0
|
||||||
MISSING_ONLY=0
|
MISSING_ONLY=0
|
||||||
TARGET=""
|
TARGET=""
|
||||||
IMAGE_TAG="" # derive later unless --tag is provided
|
IMAGE_TAG="" # local image name or base tag (without registry)
|
||||||
|
PUSH=0 # if 1 -> use buildx and push (requires docker buildx)
|
||||||
|
PUBLISH=0 # if 1 -> push with semantic tags (latest/version/stable + arch aliases)
|
||||||
|
REGISTRY="" # e.g. ghcr.io
|
||||||
|
OWNER="" # e.g. github org/user
|
||||||
|
REPO_PREFIX="pkgmgr" # image base name (pkgmgr)
|
||||||
|
VERSION="" # X.Y.Z (required for --publish)
|
||||||
|
IS_STABLE="false" # "true" -> publish stable tags
|
||||||
|
DEFAULT_DISTRO="arch"
|
||||||
|
|
||||||
usage() {
|
usage() {
|
||||||
local default_tag="pkgmgr-${distro}"
|
local default_tag="pkgmgr-${distro}"
|
||||||
@@ -39,14 +26,26 @@ usage() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
cat <<EOF
|
cat <<EOF
|
||||||
Usage: distro=<distro> $0 [--missing] [--no-cache] [--target <name>] [--tag <image>]
|
Usage: distro=<distro> $0 [options]
|
||||||
|
|
||||||
Options:
|
Build options:
|
||||||
--missing Build only if the image does not already exist
|
--missing Build only if the image does not already exist (local build only)
|
||||||
--no-cache Build with --no-cache
|
--no-cache Build with --no-cache
|
||||||
--target <name> Build a specific Dockerfile target (e.g. virgin|full)
|
--target <name> Build a specific Dockerfile target (e.g. virgin)
|
||||||
--tag <image> Override the output image tag (default: ${default_tag})
|
--tag <image> Override the output image tag (default: ${default_tag})
|
||||||
-h, --help Show help
|
|
||||||
|
Publish options:
|
||||||
|
--push Push the built image (uses docker buildx build --push)
|
||||||
|
--publish Publish semantic tags (latest, <version>, optional stable) + arch aliases
|
||||||
|
--registry <reg> Registry (e.g. ghcr.io)
|
||||||
|
--owner <owner> Registry namespace (e.g. \${GITHUB_REPOSITORY_OWNER})
|
||||||
|
--repo-prefix <name> Image base name (default: pkgmgr)
|
||||||
|
--version <X.Y.Z> Version for --publish
|
||||||
|
--stable <true|false> Whether to publish :stable tags (default: false)
|
||||||
|
|
||||||
|
Notes:
|
||||||
|
- --publish implies --push and requires --registry, --owner, and --version.
|
||||||
|
- Local build (no --push) uses "docker build" and creates local images like "pkgmgr-arch" / "pkgmgr-arch-virgin".
|
||||||
EOF
|
EOF
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -56,18 +55,39 @@ while [[ $# -gt 0 ]]; do
|
|||||||
--missing) MISSING_ONLY=1; shift ;;
|
--missing) MISSING_ONLY=1; shift ;;
|
||||||
--target)
|
--target)
|
||||||
TARGET="${2:-}"
|
TARGET="${2:-}"
|
||||||
if [[ -z "${TARGET}" ]]; then
|
[[ -n "${TARGET}" ]] || { echo "ERROR: --target requires a value (e.g. virgin)"; exit 2; }
|
||||||
echo "ERROR: --target requires a value (e.g. virgin|full)" >&2
|
|
||||||
exit 2
|
|
||||||
fi
|
|
||||||
shift 2
|
shift 2
|
||||||
;;
|
;;
|
||||||
--tag)
|
--tag)
|
||||||
IMAGE_TAG="${2:-}"
|
IMAGE_TAG="${2:-}"
|
||||||
if [[ -z "${IMAGE_TAG}" ]]; then
|
[[ -n "${IMAGE_TAG}" ]] || { echo "ERROR: --tag requires a value"; exit 2; }
|
||||||
echo "ERROR: --tag requires a value" >&2
|
shift 2
|
||||||
exit 2
|
;;
|
||||||
fi
|
--push) PUSH=1; shift ;;
|
||||||
|
--publish) PUBLISH=1; PUSH=1; shift ;;
|
||||||
|
--registry)
|
||||||
|
REGISTRY="${2:-}"
|
||||||
|
[[ -n "${REGISTRY}" ]] || { echo "ERROR: --registry requires a value"; exit 2; }
|
||||||
|
shift 2
|
||||||
|
;;
|
||||||
|
--owner)
|
||||||
|
OWNER="${2:-}"
|
||||||
|
[[ -n "${OWNER}" ]] || { echo "ERROR: --owner requires a value"; exit 2; }
|
||||||
|
shift 2
|
||||||
|
;;
|
||||||
|
--repo-prefix)
|
||||||
|
REPO_PREFIX="${2:-}"
|
||||||
|
[[ -n "${REPO_PREFIX}" ]] || { echo "ERROR: --repo-prefix requires a value"; exit 2; }
|
||||||
|
shift 2
|
||||||
|
;;
|
||||||
|
--version)
|
||||||
|
VERSION="${2:-}"
|
||||||
|
[[ -n "${VERSION}" ]] || { echo "ERROR: --version requires a value"; exit 2; }
|
||||||
|
shift 2
|
||||||
|
;;
|
||||||
|
--stable)
|
||||||
|
IS_STABLE="${2:-}"
|
||||||
|
[[ -n "${IS_STABLE}" ]] || { echo "ERROR: --stable requires a value (true|false)"; exit 2; }
|
||||||
shift 2
|
shift 2
|
||||||
;;
|
;;
|
||||||
-h|--help) usage; exit 0 ;;
|
-h|--help) usage; exit 0 ;;
|
||||||
@@ -79,9 +99,9 @@ while [[ $# -gt 0 ]]; do
|
|||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
# Auto-tag: if --tag not provided, derive from distro (+ target suffix)
|
# Derive default local tag if not provided
|
||||||
if [[ -z "${IMAGE_TAG}" ]]; then
|
if [[ -z "${IMAGE_TAG}" ]]; then
|
||||||
IMAGE_TAG="pkgmgr-${distro}"
|
IMAGE_TAG="${REPO_PREFIX}-${distro}"
|
||||||
if [[ -n "${TARGET}" ]]; then
|
if [[ -n "${TARGET}" ]]; then
|
||||||
IMAGE_TAG="${IMAGE_TAG}-${TARGET}"
|
IMAGE_TAG="${IMAGE_TAG}-${TARGET}"
|
||||||
fi
|
fi
|
||||||
@@ -89,22 +109,51 @@ fi
|
|||||||
|
|
||||||
BASE_IMAGE="$(resolve_base_image "$distro")"
|
BASE_IMAGE="$(resolve_base_image "$distro")"
|
||||||
|
|
||||||
|
# Local-only "missing" shortcut
|
||||||
if [[ "${MISSING_ONLY}" == "1" ]]; then
|
if [[ "${MISSING_ONLY}" == "1" ]]; then
|
||||||
|
if [[ "${PUSH}" == "1" ]]; then
|
||||||
|
echo "ERROR: --missing is only supported for local builds (without --push/--publish)" >&2
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
if docker image inspect "${IMAGE_TAG}" >/dev/null 2>&1; then
|
if docker image inspect "${IMAGE_TAG}" >/dev/null 2>&1; then
|
||||||
echo "[build] Image already exists: ${IMAGE_TAG} (skipping due to --missing)"
|
echo "[build] Image already exists: ${IMAGE_TAG} (skipping due to --missing)"
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Validate publish parameters
|
||||||
|
if [[ "${PUBLISH}" == "1" ]]; then
|
||||||
|
[[ -n "${REGISTRY}" ]] || { echo "ERROR: --publish requires --registry"; exit 2; }
|
||||||
|
[[ -n "${OWNER}" ]] || { echo "ERROR: --publish requires --owner"; exit 2; }
|
||||||
|
[[ -n "${VERSION}" ]] || { echo "ERROR: --publish requires --version"; exit 2; }
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Guard: --push without --publish requires fully-qualified --tag
|
||||||
|
if [[ "${PUSH}" == "1" && "${PUBLISH}" != "1" ]]; then
|
||||||
|
if [[ "${IMAGE_TAG}" != */* ]]; then
|
||||||
|
echo "ERROR: --push requires --tag with a fully-qualified name (e.g. ghcr.io/<owner>/<image>:tag), or use --publish" >&2
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
echo
|
echo
|
||||||
echo "------------------------------------------------------------"
|
echo "------------------------------------------------------------"
|
||||||
echo "[build] Building image: ${IMAGE_TAG}"
|
echo "[build] Building image"
|
||||||
echo "distro = ${distro}"
|
echo "distro = ${distro}"
|
||||||
echo "BASE_IMAGE = ${BASE_IMAGE}"
|
echo "BASE_IMAGE = ${BASE_IMAGE}"
|
||||||
if [[ -n "${TARGET}" ]]; then echo "target = ${TARGET}"; fi
|
if [[ -n "${TARGET}" ]]; then echo "target = ${TARGET}"; fi
|
||||||
if [[ "${NO_CACHE}" == "1" ]]; then echo "cache = disabled"; fi
|
if [[ "${NO_CACHE}" == "1" ]]; then echo "cache = disabled"; fi
|
||||||
|
if [[ "${PUSH}" == "1" ]]; then echo "push = enabled"; fi
|
||||||
|
if [[ "${PUBLISH}" == "1" ]]; then
|
||||||
|
echo "publish = enabled"
|
||||||
|
echo "registry = ${REGISTRY}"
|
||||||
|
echo "owner = ${OWNER}"
|
||||||
|
echo "version = ${VERSION}"
|
||||||
|
echo "stable = ${IS_STABLE}"
|
||||||
|
fi
|
||||||
echo "------------------------------------------------------------"
|
echo "------------------------------------------------------------"
|
||||||
|
|
||||||
|
# Common build args
|
||||||
build_args=(--build-arg "BASE_IMAGE=${BASE_IMAGE}")
|
build_args=(--build-arg "BASE_IMAGE=${BASE_IMAGE}")
|
||||||
|
|
||||||
if [[ "${NO_CACHE}" == "1" ]]; then
|
if [[ "${NO_CACHE}" == "1" ]]; then
|
||||||
@@ -115,6 +164,62 @@ if [[ -n "${TARGET}" ]]; then
|
|||||||
build_args+=(--target "${TARGET}")
|
build_args+=(--target "${TARGET}")
|
||||||
fi
|
fi
|
||||||
|
|
||||||
build_args+=(-t "${IMAGE_TAG}" .)
|
compute_publish_tags() {
|
||||||
|
local distro_tag_base="${REGISTRY}/${OWNER}/${REPO_PREFIX}-${distro}"
|
||||||
|
local alias_tag_base=""
|
||||||
|
|
||||||
docker build "${build_args[@]}"
|
if [[ -n "${TARGET}" ]]; then
|
||||||
|
distro_tag_base="${distro_tag_base}-${TARGET}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${distro}" == "${DEFAULT_DISTRO}" ]]; then
|
||||||
|
alias_tag_base="${REGISTRY}/${OWNER}/${REPO_PREFIX}"
|
||||||
|
if [[ -n "${TARGET}" ]]; then
|
||||||
|
alias_tag_base="${alias_tag_base}-${TARGET}"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
local tags=()
|
||||||
|
tags+=("${distro_tag_base}:latest")
|
||||||
|
tags+=("${distro_tag_base}:${VERSION}")
|
||||||
|
|
||||||
|
if [[ "${IS_STABLE}" == "true" ]]; then
|
||||||
|
tags+=("${distro_tag_base}:stable")
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -n "${alias_tag_base}" ]]; then
|
||||||
|
tags+=("${alias_tag_base}:latest")
|
||||||
|
tags+=("${alias_tag_base}:${VERSION}")
|
||||||
|
if [[ "${IS_STABLE}" == "true" ]]; then
|
||||||
|
tags+=("${alias_tag_base}:stable")
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
printf '%s\n' "${tags[@]}"
|
||||||
|
}
|
||||||
|
|
||||||
|
if [[ "${PUSH}" == "1" ]]; then
|
||||||
|
bx_args=(docker buildx build --push)
|
||||||
|
|
||||||
|
if [[ "${PUBLISH}" == "1" ]]; then
|
||||||
|
while IFS= read -r t; do
|
||||||
|
bx_args+=(-t "$t")
|
||||||
|
done < <(compute_publish_tags)
|
||||||
|
else
|
||||||
|
bx_args+=(-t "${IMAGE_TAG}")
|
||||||
|
fi
|
||||||
|
|
||||||
|
bx_args+=("${build_args[@]}")
|
||||||
|
bx_args+=(.)
|
||||||
|
|
||||||
|
echo "[build] Running: ${bx_args[*]}"
|
||||||
|
"${bx_args[@]}"
|
||||||
|
else
|
||||||
|
local_args=(docker build)
|
||||||
|
local_args+=("${build_args[@]}")
|
||||||
|
local_args+=(-t "${IMAGE_TAG}")
|
||||||
|
local_args+=(.)
|
||||||
|
|
||||||
|
echo "[build] Running: ${local_args[*]}"
|
||||||
|
"${local_args[@]}"
|
||||||
|
fi
|
||||||
|
|||||||
55
scripts/build/publish.sh
Executable file
55
scripts/build/publish.sh
Executable file
@@ -0,0 +1,55 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
# Publish all distro images (full + virgin) to a registry via image.sh --publish
|
||||||
|
#
|
||||||
|
# Required env:
|
||||||
|
# OWNER (e.g. GITHUB_REPOSITORY_OWNER)
|
||||||
|
# VERSION (e.g. 1.2.3)
|
||||||
|
#
|
||||||
|
# Optional env:
|
||||||
|
# REGISTRY (default: ghcr.io)
|
||||||
|
# IS_STABLE (default: false)
|
||||||
|
# DISTROS (default: "arch debian ubuntu fedora centos")
|
||||||
|
|
||||||
|
SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)"
|
||||||
|
|
||||||
|
REGISTRY="${REGISTRY:-ghcr.io}"
|
||||||
|
IS_STABLE="${IS_STABLE:-false}"
|
||||||
|
DISTROS="${DISTROS:-arch debian ubuntu fedora centos}"
|
||||||
|
|
||||||
|
: "${OWNER:?Environment variable OWNER must be set (e.g. github.repository_owner)}"
|
||||||
|
: "${VERSION:?Environment variable VERSION must be set (e.g. 1.2.3)}"
|
||||||
|
|
||||||
|
echo "[publish] REGISTRY=${REGISTRY}"
|
||||||
|
echo "[publish] OWNER=${OWNER}"
|
||||||
|
echo "[publish] VERSION=${VERSION}"
|
||||||
|
echo "[publish] IS_STABLE=${IS_STABLE}"
|
||||||
|
echo "[publish] DISTROS=${DISTROS}"
|
||||||
|
|
||||||
|
for d in ${DISTROS}; do
|
||||||
|
echo
|
||||||
|
echo "============================================================"
|
||||||
|
echo "[publish] distro=${d}"
|
||||||
|
echo "============================================================"
|
||||||
|
|
||||||
|
# virgin
|
||||||
|
distro="${d}" bash "${SCRIPT_DIR}/image.sh" \
|
||||||
|
--publish \
|
||||||
|
--registry "${REGISTRY}" \
|
||||||
|
--owner "${OWNER}" \
|
||||||
|
--version "${VERSION}" \
|
||||||
|
--stable "${IS_STABLE}" \
|
||||||
|
--target virgin
|
||||||
|
|
||||||
|
# full (default target)
|
||||||
|
distro="${d}" bash "${SCRIPT_DIR}/image.sh" \
|
||||||
|
--publish \
|
||||||
|
--registry "${REGISTRY}" \
|
||||||
|
--owner "${OWNER}" \
|
||||||
|
--version "${VERSION}" \
|
||||||
|
--stable "${IS_STABLE}"
|
||||||
|
done
|
||||||
|
|
||||||
|
echo
|
||||||
|
echo "[publish] Done."
|
||||||
0
scripts/installation/os_resolver.sh
Normal file → Executable file
0
scripts/installation/os_resolver.sh
Normal file → Executable file
0
scripts/nix/lib/config.sh
Normal file → Executable file
0
scripts/nix/lib/config.sh
Normal file → Executable file
0
scripts/nix/lib/detect.sh
Normal file → Executable file
0
scripts/nix/lib/detect.sh
Normal file → Executable file
0
scripts/nix/lib/install.sh
Normal file → Executable file
0
scripts/nix/lib/install.sh
Normal file → Executable file
0
scripts/nix/lib/path.sh
Normal file → Executable file
0
scripts/nix/lib/path.sh
Normal file → Executable file
0
scripts/nix/lib/symlinks.sh
Normal file → Executable file
0
scripts/nix/lib/symlinks.sh
Normal file → Executable file
0
scripts/nix/lib/users.sh
Normal file → Executable file
0
scripts/nix/lib/users.sh
Normal file → Executable file
Reference in New Issue
Block a user