Private
Public Access
1
0

Compare commits

...

8 Commits

Author SHA1 Message Date
a3b299b116 Merge pull request #7 from Draco-Lunaris/fix/ci-build-errors
Some checks failed
CI/CD Pipeline / Code Format (push) Successful in 2s
CI/CD Pipeline / Clippy Lints (push) Successful in 1m21s
CI/CD Pipeline / All Unit Tests (push) Successful in 1m30s
CI/CD Pipeline / Security Audit (push) Successful in 5s
CI/CD Pipeline / Enrollment Tests (push) Successful in 1m33s
CI/CD Pipeline / Build Debian Package (Ubuntu 22.04) (push) Failing after 4s
CI/CD Pipeline / Verify Enrollment CLI Flag (push) Successful in 1m5s
CI/CD Pipeline / Build Debian Package (push) Failing after 4s
CI/CD Pipeline / Build RPM Package (push) Successful in 2m19s
CI/CD Pipeline / Build Arch Package (push) Successful in 2m22s
CI/CD Pipeline / Build Alpine Package (push) Successful in 3m5s
Co-authored-by: git-echo <git-echo@moon-dragon.us>
2026-05-31 15:51:49 -05:00
2d33973b5f Merge pull request #6 from Draco-Lunaris/fix/ci-deps
Some checks failed
CI/CD Pipeline / Code Format (push) Successful in 1s
CI/CD Pipeline / Clippy Lints (push) Successful in 46s
CI/CD Pipeline / All Unit Tests (push) Successful in 2m55s
CI/CD Pipeline / Security Audit (push) Successful in 5s
CI/CD Pipeline / Enrollment Tests (push) Successful in 1m30s
CI/CD Pipeline / Build Debian Package (Ubuntu 22.04) (push) Failing after 5s
CI/CD Pipeline / Verify Enrollment CLI Flag (push) Successful in 1m9s
CI/CD Pipeline / Build Debian Package (push) Failing after 4s
CI/CD Pipeline / Build RPM Package (push) Successful in 2m18s
CI/CD Pipeline / Build Arch Package (push) Successful in 2m21s
CI/CD Pipeline / Build Alpine Package (push) Successful in 3m5s
Co-authored-by: Echo Dev <echo@moon-dragon.us>
2026-05-31 15:11:31 -05:00
6ddb511cb0 Merge pull request #5 from Draco-Lunaris/feature/multi-distro-ci
Some checks failed
CI/CD Pipeline / Code Format (push) Successful in 2s
CI/CD Pipeline / Clippy Lints (push) Successful in 53s
CI/CD Pipeline / All Unit Tests (push) Successful in 1m15s
CI/CD Pipeline / Security Audit (push) Successful in 5s
CI/CD Pipeline / Enrollment Tests (push) Successful in 1m34s
CI/CD Pipeline / Build Debian Package (Ubuntu 22.04) (push) Failing after 4s
CI/CD Pipeline / Verify Enrollment CLI Flag (push) Successful in 1m3s
CI/CD Pipeline / Build Debian Package (push) Failing after 3s
CI/CD Pipeline / Build RPM Package (push) Successful in 2m21s
CI/CD Pipeline / Build Arch Package (push) Successful in 2m27s
CI/CD Pipeline / Build Alpine Package (push) Successful in 3m8s
feat: multi-distro CI with self-hosted runners
2026-05-31 12:58:15 -05:00
cc21868b6c feat: multi-distro CI with self-hosted runners and config naming fix 2026-05-31 12:31:13 -05:00
32803ff27c fix: switch to build-package.sh for .deb builds
Some checks failed
CI/CD Pipeline / Code Format (push) Successful in 2s
CI/CD Pipeline / Clippy Lints (push) Successful in 46s
CI/CD Pipeline / All Unit Tests (push) Successful in 1m11s
CI/CD Pipeline / Security Audit (push) Successful in 5s
CI/CD Pipeline / Enrollment Tests (push) Successful in 1m27s
CI/CD Pipeline / Build Debian Package (Ubuntu 22.04) (push) Failing after 5s
CI/CD Pipeline / Verify Enrollment CLI Flag (push) Successful in 1m5s
CI/CD Pipeline / Build Debian Package (push) Failing after 4s
CI/CD Pipeline / Build Arch Package (push) Successful in 2m22s
CI/CD Pipeline / Build RPM Package (push) Successful in 2m17s
CI/CD Pipeline / Build Alpine Package (push) Successful in 3m7s
* fix: switch to build-package.sh for .deb builds

Replace dpkg-buildpackage with scripts/build-package.sh using
dpkg-deb --build approach. This bypasses the dpkg-buildpackage
subprocess chain (dh → make → debian/rules → cargo) which
does not inherit the rustup environment (RUSTUP_HOME, CARGO_HOME,
default toolchain) from GitHub Actions.

Same approach as Linux-Patch-Manager which passes CI.

- Add scripts/build-package.sh (modeled after Manager)
- Add Version and Installed-Size to debian/control
- Update CI workflow to use build-package.sh
- Fix release files path (project root, not ../)

* fix: extract only binary package paragraph from debian/control

dpkg-deb --build expects a single control paragraph starting
with Package: field. The debian/control file has two paragraphs
(source + binary). The awk command extracts only the binary
package paragraph to avoid dpkg-deb parse errors.

* fix: generate DEBIAN/control from scratch in build-package.sh

dpkg-deb --build is fundamentally incompatible with debian/control
which uses dpkg-buildpackage substitution variables like
${shlibs:Depends} and ${misc:Depends}. Generate a clean control
file from scratch in the script to eliminate all incompatibilities.

- No substitution variables
- No source paragraph
- No Build-Depends
- Homepage points to GitHub
- Installed-Size calculated before control file generation

---------

Co-authored-by: git-echo <git-echo@moon-dragon.us>
2026-05-31 11:19:47 -05:00
0bca0c7784 fix: remove cargo env sourcing from debian/rules
Some checks failed
CI/CD Pipeline / Code Format (push) Successful in 2s
CI/CD Pipeline / Clippy Lints (push) Successful in 44s
CI/CD Pipeline / All Unit Tests (push) Successful in 1m13s
CI/CD Pipeline / Security Audit (push) Successful in 5s
CI/CD Pipeline / Enrollment Tests (push) Successful in 1m29s
CI/CD Pipeline / Build Debian Package (Ubuntu 22.04) (push) Failing after 5s
CI/CD Pipeline / Verify Enrollment CLI Flag (push) Successful in 1m6s
CI/CD Pipeline / Build Debian Package (push) Failing after 4s
CI/CD Pipeline / Build Arch Package (push) Successful in 2m20s
CI/CD Pipeline / Build RPM Package (push) Successful in 2m13s
CI/CD Pipeline / Build Alpine Package (push) Successful in 3m5s
The debian/rules override_dh_auto_build was sourcing $HOME/.cargo/env
which fails under sudo where HOME=/root while cargo is at
/home/runner/.cargo/. The CI workflow already passes PATH via
"sudo env PATH=$PATH", so cargo is in PATH without sourcing.

Co-authored-by: git-echo <git-echo@moon-dragon.us>
2026-05-31 09:22:16 -05:00
2ac40076f5 ci: add debhelper dependency and contents:write permission
All checks were successful
CI/CD Pipeline / Code Format (push) Successful in 1s
CI/CD Pipeline / Clippy Lints (push) Successful in 46s
CI/CD Pipeline / All Unit Tests (push) Successful in 1m18s
CI/CD Pipeline / Security Audit (push) Successful in 4s
CI/CD Pipeline / Enrollment Tests (push) Successful in 1m38s
CI/CD Pipeline / Verify Enrollment CLI Flag (push) Successful in 1m11s
CI/CD Pipeline / Build Debian Package (Ubuntu 22.04) (push) Successful in 2m28s
CI/CD Pipeline / Build RPM Package (push) Successful in 2m35s
CI/CD Pipeline / Build Arch Package (push) Successful in 2m37s
CI/CD Pipeline / Build Alpine Package (push) Successful in 3m32s
CI/CD Pipeline / Build Debian Package (push) Successful in 2m2s
- Add debhelper to system dependencies for dpkg-buildpackage
- Add permissions: contents: write for GitHub Release creation
- Fixes Build & Release job failures on tag push

Co-authored-by: git-echo <git-echo@moon-dragon.us>
2026-05-31 02:08:36 -05:00
4375f915ca Merge pull request #1 from Draco-Lunaris/fix/ci-build-path
Some checks failed
CI/CD Pipeline / Code Format (push) Successful in 1s
CI/CD Pipeline / Clippy Lints (push) Successful in 46s
CI/CD Pipeline / All Unit Tests (push) Successful in 1m17s
CI/CD Pipeline / Security Audit (push) Successful in 5s
CI/CD Pipeline / Verify Enrollment CLI Flag (push) Has been cancelled
CI/CD Pipeline / Build Debian Package (push) Has been cancelled
CI/CD Pipeline / Build Debian Package (Ubuntu 22.04) (push) Has been cancelled
CI/CD Pipeline / Build RPM Package (push) Has been cancelled
CI/CD Pipeline / Build Alpine Package (push) Has been cancelled
CI/CD Pipeline / Build Arch Package (push) Has been cancelled
CI/CD Pipeline / Enrollment Tests (push) Has been cancelled
ci: fix dpkg-buildpackage PATH for cargo
2026-05-31 01:52:46 -05:00
4 changed files with 330 additions and 16 deletions

View File

@ -9,8 +9,15 @@ on:
env: env:
CARGO_TERM_COLOR: always CARGO_TERM_COLOR: always
RUST_BACKTRACE: 1
FORCE_JAVASCRIPT_ACTIONS_TO_NODE24: true
permissions:
contents: write
jobs: jobs:
# ── Quality Gates (GitHub-hosted, all triggers) ──────────────────────────
fmt: fmt:
name: Rust Format name: Rust Format
runs-on: ubuntu-latest runs-on: ubuntu-latest
@ -68,24 +75,18 @@ jobs:
- run: cargo test --test enrollment_test - run: cargo test --test enrollment_test
- run: cargo test --test enrollment_e2e - run: cargo test --test enrollment_e2e
build-deb: # ── Release Preparation (tag push only) ───────────────────────────────────
name: Build & Release
needs: [fmt, clippy, test, enrollment-tests] prepare-release:
name: Prepare Release
if: startsWith(github.ref, 'refs/tags/v')
needs: [fmt, clippy, test, enrollment-tests, audit]
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@v4
with: with:
fetch-depth: 0 fetch-depth: 0
- uses: dtolnay/rust-toolchain@stable
- uses: Swatinem/rust-cache@v2
- name: Install system dependencies
run: sudo apt-get update && sudo apt-get install -y build-essential libsystemd-dev pkg-config libssl-dev dpkg-dev
- name: Build .deb package
run: |
. "$HOME/.cargo/env"
sudo env "PATH=$PATH" dpkg-buildpackage -us -uc -b -d
- name: Generate release notes - name: Generate release notes
if: startsWith(github.ref, 'refs/tags/v')
id: release_notes id: release_notes
run: | run: |
PREV_TAG=$(git describe --tags --abbrev=0 HEAD^ 2>/dev/null || echo "") PREV_TAG=$(git describe --tags --abbrev=0 HEAD^ 2>/dev/null || echo "")
@ -97,9 +98,173 @@ jobs:
echo "notes<<EOF" >> $GITHUB_OUTPUT echo "notes<<EOF" >> $GITHUB_OUTPUT
echo "$NOTES" >> $GITHUB_OUTPUT echo "$NOTES" >> $GITHUB_OUTPUT
echo "EOF" >> $GITHUB_OUTPUT echo "EOF" >> $GITHUB_OUTPUT
- name: Upload to GitHub Release - name: Create GitHub Release
if: startsWith(github.ref, 'refs/tags/v')
uses: softprops/action-gh-release@v2 uses: softprops/action-gh-release@v2
with: with:
body: ${{ steps.release_notes.outputs.notes }} body: ${{ steps.release_notes.outputs.notes }}
files: ../linux-patch-api_*.deb
# ── Build Jobs (tag push only, self-hosted runners) ───────────────────────
build-deb-u2404:
name: Build .deb (Ubuntu 24.04)
if: startsWith(github.ref, 'refs/tags/v')
needs: [fmt, clippy, test, enrollment-tests, audit, prepare-release]
runs-on: [self-hosted, linux, ubuntu-24.04]
steps:
- uses: actions/checkout@v4
- name: Install system dependencies
run: sudo apt-get update && sudo apt-get install -y build-essential libsystemd-dev pkg-config libssl-dev
- name: Add Rust to PATH
run: echo "$HOME/.cargo/bin" >> "$GITHUB_PATH"
- name: Build .deb package
run: chmod +x scripts/build-package.sh && scripts/build-package.sh
- name: Rename package with distro suffix
run: |
FILE=$(ls linux-patch-api_*_amd64.deb 2>/dev/null | head -1)
if [ -n "$FILE" ]; then
mv "$FILE" "$(echo "$FILE" | sed 's/_amd64/_u2404_amd64/')"
fi
- name: Upload to GitHub Release
uses: softprops/action-gh-release@v2
with:
files: linux-patch-api_*_u2404_amd64.deb
build-deb-u2204:
name: Build .deb (Ubuntu 22.04)
if: startsWith(github.ref, 'refs/tags/v')
needs: [fmt, clippy, test, enrollment-tests, audit, prepare-release]
runs-on: [self-hosted, linux, ubuntu-22.04]
steps:
- uses: actions/checkout@v4
- name: Install system dependencies
run: sudo apt-get update && sudo apt-get install -y build-essential libsystemd-dev pkg-config libssl-dev
- name: Add Rust to PATH
run: echo "$HOME/.cargo/bin" >> "$GITHUB_PATH"
- name: Build .deb package
run: chmod +x scripts/build-package.sh && scripts/build-package.sh
- name: Rename package with distro suffix
run: |
FILE=$(ls linux-patch-api_*_amd64.deb 2>/dev/null | head -1)
if [ -n "$FILE" ]; then
mv "$FILE" "$(echo "$FILE" | sed 's/_amd64/_u2204_amd64/')"
fi
- name: Upload to GitHub Release
uses: softprops/action-gh-release@v2
with:
files: linux-patch-api_*_u2204_amd64.deb
build-deb-debian13:
name: Build .deb (Debian 13)
if: startsWith(github.ref, 'refs/tags/v')
needs: [fmt, clippy, test, enrollment-tests, audit, prepare-release]
runs-on: [self-hosted, linux, debian-13]
steps:
- uses: actions/checkout@v4
- name: Install system dependencies
run: sudo apt-get update && sudo apt-get install -y build-essential libsystemd-dev pkg-config libssl-dev
- name: Add Rust to PATH
run: echo "$HOME/.cargo/bin" >> "$GITHUB_PATH"
- name: Build .deb package
run: chmod +x scripts/build-package.sh && scripts/build-package.sh
- name: Rename package with distro suffix
run: |
FILE=$(ls linux-patch-api_*_amd64.deb 2>/dev/null | head -1)
if [ -n "$FILE" ]; then
mv "$FILE" "$(echo "$FILE" | sed 's/_amd64/_debian13_amd64/')"
fi
- name: Upload to GitHub Release
uses: softprops/action-gh-release@v2
with:
files: linux-patch-api_*_debian13_amd64.deb
build-rpm-fedora:
name: Build .rpm (Fedora)
if: startsWith(github.ref, 'refs/tags/v')
needs: [fmt, clippy, test, enrollment-tests, audit, prepare-release]
runs-on: [self-hosted, linux, fedora]
steps:
- uses: actions/checkout@v4
- name: Install system dependencies
run: sudo dnf install -y systemd-devel openssl-devel pkg-config gcc make
- name: Add Rust to PATH
run: echo "$HOME/.cargo/bin" >> "$GITHUB_PATH"
- name: Build release binary
run: cargo build --release
- name: Build RPM package
run: chmod +x build-rpm.sh && SKIP_CARGO_BUILD=1 sudo -E ./build-rpm.sh
- name: Upload to GitHub Release
uses: softprops/action-gh-release@v2
with:
files: releases/linux-patch-api-*.rpm
build-rpm-almalinux:
name: Build .rpm (AlmaLinux 10)
if: startsWith(github.ref, 'refs/tags/v')
needs: [fmt, clippy, test, enrollment-tests, audit, prepare-release]
runs-on: [self-hosted, linux, almalinux-10]
steps:
- uses: actions/checkout@v4
- name: Install system dependencies
run: sudo dnf install -y systemd-devel openssl-devel pkg-config gcc make
- name: Add Rust to PATH
run: echo "$HOME/.cargo/bin" >> "$GITHUB_PATH"
- name: Build release binary
run: cargo build --release
- name: Build RPM package
run: chmod +x build-rpm.sh && SKIP_CARGO_BUILD=1 sudo -E ./build-rpm.sh
- name: Upload to GitHub Release
uses: softprops/action-gh-release@v2
with:
files: releases/linux-patch-api-*.rpm
build-arch:
name: Build .pkg.tar.zst (Arch Linux)
if: startsWith(github.ref, 'refs/tags/v')
needs: [fmt, clippy, test, enrollment-tests, audit, prepare-release]
runs-on: [self-hosted, linux, arch]
steps:
- uses: actions/checkout@v4
- name: Install system dependencies
run: sudo pacman -Syu --noconfirm systemd openssl pkg-config gcc
- name: Add Rust to PATH
run: echo "$HOME/.cargo/bin" >> "$GITHUB_PATH"
- name: Build release binary
run: cargo build --release
- name: Build Arch package
run: chmod +x build-arch.sh && SKIP_CARGO_BUILD=1 ./build-arch.sh
- name: Upload to GitHub Release
uses: softprops/action-gh-release@v2
with:
files: releases/*.pkg.tar.zst
build-alpine:
name: Build .apk (Alpine)
if: startsWith(github.ref, 'refs/tags/v')
needs: [fmt, clippy, test, enrollment-tests, audit, prepare-release]
runs-on: ubuntu-latest
container:
image: alpine:latest
steps:
- name: Install prerequisites for actions/checkout
run: apk add --no-cache bash git curl tar
- uses: actions/checkout@v4
- name: Install Alpine build dependencies
run: apk add --no-cache gcc musl-dev openssl-dev openssl elogind-dev alpine-sdk abuild
- name: Install Rust via rustup
run: curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y
- name: Add Rust to PATH
run: echo "$HOME/.cargo/bin" >> "$GITHUB_PATH"
- name: Add musl target
run: rustup target add x86_64-unknown-linux-musl
- name: Build release binary (musl target)
run: cargo build --release --target x86_64-unknown-linux-musl
- name: Generate abuild signing keys
run: abuild-keygen -a -n
- name: Build Alpine package
run: |
chmod +x build-alpine.sh
SKIP_CARGO_BUILD=1 ./build-alpine.sh
- name: Upload to GitHub Release
uses: softprops/action-gh-release@v2
with:
files: releases/linux-patch-api-*.apk

2
debian/control vendored
View File

@ -14,6 +14,8 @@ Vcs-Browser: https://gitea.moon-dragon.us/echo/linux_patch_api
Package: linux-patch-api Package: linux-patch-api
Architecture: amd64 Architecture: amd64
Version: 1.2.0-1
Installed-Size: 0
Depends: systemd, Depends: systemd,
libsystemd0, libsystemd0,
${shlibs:Depends}, ${shlibs:Depends},

2
debian/rules vendored Executable file → Normal file
View File

@ -8,7 +8,7 @@ export DEB_CARGO_BUILD_FLAGS=--release
dh $@ dh $@
override_dh_auto_build: override_dh_auto_build:
. "$$HOME/.cargo/env" && cargo build --release --target x86_64-unknown-linux-gnu cargo build --release --target x86_64-unknown-linux-gnu
override_dh_auto_install: override_dh_auto_install:
dh_auto_install dh_auto_install

147
scripts/build-package.sh Normal file
View File

@ -0,0 +1,147 @@
#!/usr/bin/env bash
# =============================================================================
# Linux Patch API — Build .deb Package for Ubuntu 24.04
# =============================================================================
# Produces: linux-patch-api_<version>-1_amd64.deb
# Prerequisites:
# - Rust toolchain (cargo, rustc >= 1.75)
# - dpkg-deb
# =============================================================================
set -euo pipefail
RED='\033[0;31m'
GREEN='\033[0;32m'
YELLOW='\033[1;33m'
CYAN='\033[0;36m'
NC='\033[0m'
info() { echo -e "${GREEN}[INFO]${NC} $*"; }
warn() { echo -e "${YELLOW}[WARN]${NC} $*"; }
error() { echo -e "${RED}[ERROR]${NC} $*" >&2; exit 1; }
PROJECT_ROOT="$(cd "$(dirname "${BASH_SOURCE[0]}")/.." && pwd)"
VERSION="1.2.0"
RELEASE="1"
PKG_NAME="linux-patch-api"
DEB_NAME="${PKG_NAME}_${VERSION}-${RELEASE}_amd64.deb"
BUILD_DIR="${PROJECT_ROOT}/package-build"
info "=== Linux Patch API — Package Build ==="
info "Version: ${VERSION}-${RELEASE}"
info "Target: Ubuntu 24.04 (noble) amd64"
echo
# ---------------------------------------------------------------------------
# 1. Build Rust binary (release mode)
# ---------------------------------------------------------------------------
info "Step 1/4: Building Rust binary (release mode)..."
cd "${PROJECT_ROOT}"
cargo build --release 2>&1 | tail -5
# Verify binary exists
[[ -f "${PROJECT_ROOT}/target/release/linux-patch-api" ]] || error "linux-patch-api not found in target/release/"
info "Rust binary built successfully."
# Strip debug symbols for smaller package
strip "${PROJECT_ROOT}/target/release/linux-patch-api" 2>/dev/null || warn "strip failed (may already be stripped)"
info "Binary stripped."
# ---------------------------------------------------------------------------
# 2. Assemble package directory structure
# ---------------------------------------------------------------------------
info "Step 2/4: Assembling package structure..."
rm -rf "${BUILD_DIR}"
mkdir -p "${BUILD_DIR}/DEBIAN"
mkdir -p "${BUILD_DIR}/usr/bin"
mkdir -p "${BUILD_DIR}/etc/linux_patch_api"
mkdir -p "${BUILD_DIR}/etc/linux_patch_api/certs"
mkdir -p "${BUILD_DIR}/lib/systemd/system"
mkdir -p "${BUILD_DIR}/var/log/linux_patch_api"
mkdir -p "${BUILD_DIR}/var/lib/linux_patch_api"
# Binary
cp "${PROJECT_ROOT}/target/release/linux-patch-api" "${BUILD_DIR}/usr/bin/linux-patch-api"
chmod 755 "${BUILD_DIR}/usr/bin/linux-patch-api"
# Systemd service
cp "${PROJECT_ROOT}/configs/linux-patch-api.service" "${BUILD_DIR}/lib/systemd/system/"
# Configuration files (live configs for admin editing)
cp "${PROJECT_ROOT}/configs/config.yaml.example" "${BUILD_DIR}/etc/linux_patch_api/config.yaml"
cp "${PROJECT_ROOT}/configs/whitelist.yaml.example" "${BUILD_DIR}/etc/linux_patch_api/whitelist.yaml"
# Example config files (referenced by postinst for first-run setup)
cp "${PROJECT_ROOT}/configs/config.yaml.example" "${BUILD_DIR}/etc/linux_patch_api/config.yaml.example"
cp "${PROJECT_ROOT}/configs/whitelist.yaml.example" "${BUILD_DIR}/etc/linux_patch_api/whitelist.yaml.example"
# Calculate installed size BEFORE generating control file
INSTALLED_SIZE=$(du -sk "${BUILD_DIR}" | cut -f1)
# Generate DEBIAN/control from scratch for dpkg-deb --build
# (debian/control uses dpkg-buildpackage substitution variables like
# ${shlibs:Depends} that dpkg-deb cannot resolve)
cat > "${BUILD_DIR}/DEBIAN/control" <<EOF
Package: linux-patch-api
Version: ${VERSION}-${RELEASE}
Architecture: amd64
Maintainer: Echo <echo@moon-dragon.us>
Installed-Size: ${INSTALLED_SIZE}
Depends: systemd, libsystemd0
Section: admin
Priority: optional
Homepage: https://github.com/Draco-Lunaris/Linux-Patch-Api
Description: Secure remote package management API for Linux systems
Linux Patch API provides a secure, mTLS-authenticated REST API for
remote package management operations including package installation
and removal, security patch application, system health monitoring,
and job queue management with WebSocket status streaming.
EOF
# Conffiles
cat > "${BUILD_DIR}/DEBIAN/conffiles" << 'EOF'
/etc/linux_patch_api/config.yaml
/etc/linux_patch_api/whitelist.yaml
EOF
# Maintainer scripts
cp "${PROJECT_ROOT}/debian/postinst" "${BUILD_DIR}/DEBIAN/postinst"
cp "${PROJECT_ROOT}/debian/prerm" "${BUILD_DIR}/DEBIAN/prerm"
cp "${PROJECT_ROOT}/debian/postrm" "${BUILD_DIR}/DEBIAN/postrm"
chmod 755 "${BUILD_DIR}/DEBIAN/postinst" "${BUILD_DIR}/DEBIAN/prerm" "${BUILD_DIR}/DEBIAN/postrm"
info "Package structure assembled (${INSTALLED_SIZE} KB)."
# ---------------------------------------------------------------------------
# 3. Build .deb package
# ---------------------------------------------------------------------------
info "Step 3/4: Building .deb package..."
dpkg-deb --build "${BUILD_DIR}" "${PROJECT_ROOT}/${DEB_NAME}"
info ".deb package created: ${DEB_NAME}"
# ---------------------------------------------------------------------------
# 4. Verify and summarize
# ---------------------------------------------------------------------------
info "Step 4/4: Verifying package..."
dpkg-deb --info "${PROJECT_ROOT}/${DEB_NAME}"
echo
dpkg-deb --contents "${PROJECT_ROOT}/${DEB_NAME}" | head -20 || true
echo
PKG_SIZE=$(du -h "${PROJECT_ROOT}/${DEB_NAME}" | cut -f1)
info "=== Package Build Complete ==="
info "Package: ${DEB_NAME}"
info "Size: ${PKG_SIZE}"
echo
echo -e "${CYAN}Installation instructions:${NC}"
echo " 1. Copy ${DEB_NAME} to the target Ubuntu 24.04 host"
echo " 2. Install: sudo dpkg -i ${DEB_NAME}"
echo " 3. Or with auto-deps: sudo apt install ./${DEB_NAME}"
echo " 4. Configure: /etc/linux_patch_api/config.yaml"
echo " 5. Start: systemctl enable --now linux-patch-api.service"
echo
# Cleanup build directory
rm -rf "${BUILD_DIR}"
info "Build directory cleaned up."