104 lines
2.8 KiB
Text
104 lines
2.8 KiB
Text
# syntax=docker/dockerfile:1
|
|
ARG BASE_IMAGE=fedora:42
|
|
FROM ${BASE_IMAGE}
|
|
|
|
RUN set -eux; \
|
|
dnf -y update; \
|
|
dnf -y install \
|
|
rpm-build \
|
|
rpmdevtools \
|
|
redhat-rpm-config \
|
|
gcc \
|
|
make \
|
|
findutils \
|
|
tar \
|
|
gzip \
|
|
rsync \
|
|
python3 \
|
|
python3-devel \
|
|
python3-setuptools \
|
|
python3-wheel \
|
|
pyproject-rpm-macros \
|
|
python3-rpm-macros \
|
|
python3-yaml \
|
|
python3-paramiko \
|
|
openssl-devel \
|
|
python3-poetry-core ; \
|
|
dnf -y clean all
|
|
|
|
# Build runner script (copies repo, tars, runs rpmbuild)
|
|
RUN set -eux; cat > /usr/local/bin/build-rpm <<'EOF'
|
|
#!/usr/bin/env bash
|
|
set -euo pipefail
|
|
|
|
SRC="${SRC:-/src}"
|
|
WORKROOT="${WORKROOT:-/work}"
|
|
OUT="${OUT:-/out}"
|
|
DEPS_DIR="${DEPS_DIR:-/deps}"
|
|
VERSION_ID="$(grep VERSION_ID /etc/os-release | cut -d= -f2)"
|
|
echo "Version ID is ${VERSION_ID}"
|
|
# Install jinjaturtle from local rpm
|
|
# Filter out .src.rpm and debug* subpackages if present.
|
|
if [ -d "${DEPS_DIR}" ] && compgen -G "${DEPS_DIR}/*.rpm" > /dev/null; then
|
|
mapfile -t rpms < <(ls -1 "${DEPS_DIR}"/*.rpm | grep -vE '(\.src\.rpm$|-(debuginfo|debugsource)-)' | grep "${VERSION_ID}")
|
|
if [ "${#rpms[@]}" -gt 0 ]; then
|
|
echo "Installing dependency RPMs from ${DEPS_DIR}:"
|
|
printf ' - %s\n' "${rpms[@]}"
|
|
dnf -y install "${rpms[@]}"
|
|
dnf -y clean all
|
|
else
|
|
echo "NOTE: Only src/debug RPMs found in ${DEPS_DIR}; nothing installed." >&2
|
|
fi
|
|
else
|
|
echo "NOTE: No RPMs found in ${DEPS_DIR}. If the build fails with missing python3dist(jinjaturtle)," >&2
|
|
echo " mount your jinjaturtle RPM directory as -v <dir>:/deps" >&2
|
|
fi
|
|
|
|
mkdir -p "${WORKROOT}" "${OUT}"
|
|
WORK="${WORKROOT}/src"
|
|
rm -rf "${WORK}"
|
|
mkdir -p "${WORK}"
|
|
|
|
rsync -a --delete \
|
|
--exclude '.git' \
|
|
--exclude '.venv' \
|
|
--exclude 'dist' \
|
|
--exclude 'build' \
|
|
--exclude '__pycache__' \
|
|
--exclude '.pytest_cache' \
|
|
--exclude '.mypy_cache' \
|
|
"${SRC}/" "${WORK}/"
|
|
|
|
cd "${WORK}"
|
|
|
|
# Determine version from pyproject.toml unless provided
|
|
if [ -n "${VERSION:-}" ]; then
|
|
ver="${VERSION}"
|
|
else
|
|
ver="$(grep -m1 '^version = ' pyproject.toml | sed -E 's/version = "([^"]+)".*/\1/')"
|
|
fi
|
|
|
|
TOPDIR="${WORKROOT}/rpmbuild"
|
|
mkdir -p "${TOPDIR}"/{BUILD,BUILDROOT,RPMS,SOURCES,SPECS,SRPMS}
|
|
|
|
tarball="${TOPDIR}/SOURCES/enroll-${ver}.tar.gz"
|
|
tar -czf "${tarball}" --transform "s#^#enroll/#" .
|
|
|
|
spec_src="rpm/enroll.spec"
|
|
|
|
cp -v "${spec_src}" "${TOPDIR}/SPECS/enroll.spec"
|
|
|
|
rpmbuild -ba "${TOPDIR}/SPECS/enroll.spec" \
|
|
--define "_topdir ${TOPDIR}" \
|
|
--define "upstream_version ${ver}"
|
|
|
|
shopt -s nullglob
|
|
cp -v "${TOPDIR}"/RPMS/*/*.rpm "${OUT}/" || true
|
|
cp -v "${TOPDIR}"/SRPMS/*.src.rpm "${OUT}/" || true
|
|
echo "Artifacts copied to ${OUT}"
|
|
EOF
|
|
|
|
RUN chmod +x /usr/local/bin/build-rpm
|
|
|
|
WORKDIR /work
|
|
ENTRYPOINT ["/usr/local/bin/build-rpm"]
|