ba39b08e09
apple / swift (push) Successful in 1m6s
ci / rust (push) Successful in 5m51s
android / android (push) Successful in 6m21s
ci / web (push) Successful in 49s
ci / docs-site (push) Successful in 58s
windows-host / package (push) Successful in 8m6s
release / apple (push) Successful in 8m17s
deb / build-publish (push) Successful in 3m26s
decky / build-publish (push) Successful in 25s
docker / build-push (--build-arg FEDORA_VERSION=44, ci, ci/fedora-rpm.Dockerfile, punktfunk-fedora44-rpm) (push) Successful in 5s
ci / bench (push) Successful in 4m42s
docker / build-push (., web/Dockerfile, punktfunk-web) (push) Successful in 30s
docker / build-push (ci, ci/fedora-rpm.Dockerfile, punktfunk-fedora-rpm) (push) Successful in 2m36s
docker / build-push (ci, ci/rust-ci.Dockerfile, punktfunk-rust-ci) (push) Successful in 2m17s
rpm / build-publish (fedora-44, punktfunk-fedora44-rpm) (push) Failing after 19s
docker / build-push (docs-site, docs-site/Dockerfile, punktfunk-docs) (push) Successful in 51s
apple / screenshots (push) Successful in 5m45s
docker / deploy-docs (push) Successful in 22s
rpm / build-publish (bazzite, punktfunk-fedora-rpm) (push) Failing after 22s
Web console - Pairing/Library/Stats refactored into self-contained subsections that each own their own queries + mutations; a shared slot-based layout (view.tsx) is filled by the live page (containers) and Storybook (pure cards + fixtures) so the layout can't drift. - All paired devices in one list on Pairing with a protocol column (punktfunk/1 + Moonlight), routing each unpair to the right endpoint; the redundant Clients page is removed. - Library: overview grid split from the add/edit form into separate files. - Login screen links out to the docs. Docs - "Console login password" section on every host page (apt/RPM/Bazzite/SteamOS/Windows) plus a new "Forgot your Password?" troubleshooting page, linked from the login screen. - Console served as HTTP/1.1 over TLS (drop the unusable HTTP/3 advertising) across the Bun entry, launchers, systemd units, and packaging. Tooling - Biome now respects .gitignore (stops linting generated code), config migrated to 2.5.1; all lint issues fixed cleanly. Also includes this branch's in-progress host, Apple client, packaging, and CI changes. Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
144 lines
6.4 KiB
Bash
Executable File
144 lines
6.4 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
# Build the punktfunk-web .deb — the management web console (Nitro SSR on bun + React).
|
|
#
|
|
# Runtime is BUN: the console is built with Nitro's `bun` preset + a custom Bun.serve entry that
|
|
# serves HTTPS (HTTP/1.1 over TLS) with the host's identity cert (web/nitro-entry/bun-https.mjs). Bun
|
|
# isn't in apt, so we VENDOR a bun binary into the package — which makes the
|
|
# package per-arch (amd64/arm64), NOT `all`. The host's punktfunk-host .deb Recommends this, so a
|
|
# default `apt install punktfunk-host` pulls the console too; it is auto-wired to the host's mgmt
|
|
# token + identity cert via the systemd --user units (no env editing on a packaged install).
|
|
#
|
|
# Usage: VERSION=0.0.1~ci42.gdeadbee [DEB_ARCH=amd64] [BUN_BIN=/path/to/bun] bash packaging/debian/build-web-deb.sh
|
|
# Output: dist/punktfunk-web_<version>_<arch>.deb
|
|
set -euo pipefail
|
|
|
|
VERSION="${VERSION:?set VERSION (e.g. 0.0.1 or 0.0.1~ci42.gdeadbee)}"
|
|
PKG="punktfunk-web"
|
|
ROOTDIR="$(cd "$(dirname "$0")/../.." && pwd)"
|
|
cd "$ROOTDIR"
|
|
|
|
# Per-arch: vendor bun for the target Debian arch. Map deb arch → bun's release arch tag.
|
|
DEB_ARCH="${DEB_ARCH:-$(dpkg --print-architecture)}"
|
|
BUN_VERSION="${BUN_VERSION:-1.3.14}" # pinned bun build vendored into the package
|
|
case "$DEB_ARCH" in
|
|
amd64) BUN_ARCH=x64 ;;
|
|
arm64) BUN_ARCH=aarch64 ;;
|
|
*) echo "ERROR: unsupported DEB_ARCH=$DEB_ARCH (want amd64 or arm64)" >&2; exit 1 ;;
|
|
esac
|
|
|
|
# Build the console if not already built (.output is gitignored — CI builds it each run).
|
|
if [ ! -f web/.output/server/index.mjs ]; then
|
|
echo "==> building web console"
|
|
(cd web && bun install --frozen-lockfile && bun run build)
|
|
fi
|
|
# The build MUST be the bun preset (our Bun.serve TLS entry) — node can't run Bun.serve.
|
|
if ! grep -rq 'Bun\.serve' web/.output/server/index.mjs 2>/dev/null; then
|
|
echo "ERROR: web/.output has no Bun.serve — wrong nitro preset (need 'bun' + the custom entry)" >&2
|
|
exit 1
|
|
fi
|
|
|
|
STAGE="$(mktemp -d)"
|
|
trap 'rm -rf "$STAGE"' EXIT
|
|
SHAREDIR="$STAGE/usr/share/$PKG"
|
|
DOCDIR="$STAGE/usr/share/doc/$PKG"
|
|
LIBDIR="$STAGE/usr/lib/$PKG"
|
|
|
|
# --- vendor the bun runtime --------------------------------------------------
|
|
# Honor a pre-fetched bun (CI may cache it) via BUN_BIN; else download the pinned release.
|
|
mkdir -p "$LIBDIR"
|
|
if [ -n "${BUN_BIN:-}" ]; then
|
|
echo "==> vendoring bun from BUN_BIN=$BUN_BIN"
|
|
install -m0755 "$BUN_BIN" "$LIBDIR/bun"
|
|
else
|
|
url="https://github.com/oven-sh/bun/releases/download/bun-v${BUN_VERSION}/bun-linux-${BUN_ARCH}.zip"
|
|
echo "==> downloading bun $BUN_VERSION ($BUN_ARCH) from $url"
|
|
tmp="$(mktemp -d)"
|
|
curl -fsSL "$url" -o "$tmp/bun.zip"
|
|
unzip -q "$tmp/bun.zip" -d "$tmp"
|
|
install -m0755 "$tmp/bun-linux-${BUN_ARCH}/bun" "$LIBDIR/bun"
|
|
rm -rf "$tmp"
|
|
fi
|
|
"$LIBDIR/bun" --version
|
|
|
|
# --- file layout -------------------------------------------------------------
|
|
mkdir -p "$SHAREDIR/.output"
|
|
cp -r web/.output/server "$SHAREDIR/.output/server"
|
|
cp -r web/.output/public "$SHAREDIR/.output/public"
|
|
# Stable PATH-independent ExecStart wrapper.
|
|
install -d "$STAGE/usr/bin"
|
|
cat > "$STAGE/usr/bin/punktfunk-web-server" <<'WRAP'
|
|
#!/bin/sh
|
|
# The console runs on the vendored bun (Bun.serve TLS); bun lives privately under
|
|
# /usr/lib/punktfunk-web so it never collides with a system-wide bun on PATH.
|
|
exec /usr/lib/punktfunk-web/bun /usr/share/punktfunk-web/.output/server/index.mjs "$@"
|
|
WRAP
|
|
chmod 0755 "$STAGE/usr/bin/punktfunk-web-server"
|
|
install -Dm0644 scripts/punktfunk-web.service "$STAGE/usr/lib/systemd/user/punktfunk-web.service"
|
|
install -Dm0644 scripts/punktfunk-web-init.service "$STAGE/usr/lib/systemd/user/punktfunk-web-init.service"
|
|
install -Dm0755 scripts/web-init.sh "$SHAREDIR/web-init.sh"
|
|
install -Dm0644 web/web.env.example "$SHAREDIR/web.env.example"
|
|
install -Dm0644 LICENSE-MIT "$DOCDIR/LICENSE-MIT"
|
|
install -Dm0644 LICENSE-APACHE "$DOCDIR/LICENSE-APACHE"
|
|
install -Dm0644 web/README.md "$DOCDIR/README.md"
|
|
|
|
cat > "$DOCDIR/copyright" <<EOF
|
|
Format: https://www.debian.org/doc/packaging-manuals/copyright-format/1.0/
|
|
Upstream-Name: punktfunk
|
|
Source: https://git.unom.io/unom/punktfunk
|
|
|
|
Files: *
|
|
Copyright: punktfunk contributors
|
|
License: MIT or Apache-2.0
|
|
Dual-licensed. Full texts in /usr/share/doc/$PKG/LICENSE-MIT and
|
|
/usr/share/doc/$PKG/LICENSE-APACHE.
|
|
EOF
|
|
printf '%s (%s) stable; urgency=medium\n\n * Automated build %s.\n\n -- unom <noreply@anthropic.com> %s\n' \
|
|
"$PKG" "$VERSION" "$VERSION" "$(date -uR 2>/dev/null || echo 'Thu, 01 Jan 1970 00:00:00 +0000')" \
|
|
| gzip -9n > "$DOCDIR/changelog.Debian.gz"
|
|
|
|
INSTALLED_KB="$(du -k -s "$STAGE" | cut -f1)"
|
|
|
|
install -d "$STAGE/DEBIAN"
|
|
cat > "$STAGE/DEBIAN/control" <<EOF
|
|
Package: $PKG
|
|
Version: $VERSION
|
|
Architecture: $DEB_ARCH
|
|
Maintainer: unom <noreply@anthropic.com>
|
|
Installed-Size: $INSTALLED_KB
|
|
Section: net
|
|
Priority: optional
|
|
Homepage: https://git.unom.io/unom/punktfunk
|
|
Description: punktfunk management web console (Nitro SSR on bun + React)
|
|
The browser console for a punktfunk streaming host: status, paired devices, and the
|
|
SPAKE2 PIN pairing flow every client needs. Runs as a systemd --user service on port
|
|
3000 over HTTPS (HTTP/1.1 over TLS, with the host's own identity cert), login-gated (a
|
|
password generated on first start), proxying the host's loopback HTTPS management API
|
|
with a bearer token injected server-side (never sent to the browser). Bundles its own
|
|
bun runtime (no system nodejs/bun dependency).
|
|
.
|
|
Auto-wired to the host on a packaged install: it sources the host's
|
|
~/.config/punktfunk/mgmt-token and a generated login password — no env editing. Enable
|
|
the systemd user service punktfunk-web; read the login password from the --user journal.
|
|
EOF
|
|
|
|
cat > "$STAGE/DEBIAN/postinst" <<'EOF'
|
|
#!/bin/sh
|
|
set -e
|
|
if [ "$1" = "configure" ]; then
|
|
echo "punktfunk-web installed. Enable it for your user:"
|
|
echo " systemctl --user enable --now punktfunk-web"
|
|
echo "A login password is generated on first start — read it with:"
|
|
echo " journalctl --user -u punktfunk-web-init | sed -n 's/.*password generated: //p'"
|
|
echo " (or: sed -n 's/^PUNKTFUNK_UI_PASSWORD=//p' ~/.config/punktfunk/web-password)"
|
|
echo "Then open https://<host-ip>:3000 (self-signed host cert — trust it once)"
|
|
fi
|
|
exit 0
|
|
EOF
|
|
chmod 0755 "$STAGE/DEBIAN/postinst"
|
|
|
|
mkdir -p dist
|
|
OUT="dist/${PKG}_${VERSION}_${DEB_ARCH}.deb"
|
|
dpkg-deb --root-owner-group --build "$STAGE" "$OUT" >/dev/null
|
|
echo "built $OUT"
|
|
dpkg-deb -I "$OUT" | sed -n 's/^/ /p' | grep -E 'Version|Installed-Size|Depends' || true
|