|
All checks were successful
Build ISO / build-iso (push) Successful in 21m23s
CI / lint (push) Successful in 1m31s
CI / test (push) Successful in 1m20s
CI / validate-json (push) Successful in 48s
CI / markdown-links (push) Successful in 27s
Deploy site / deploy (push) Successful in 8s
Release / release (push) Successful in 24s
Rolls the apps-catalog split, the /settings CSS wrap fix, and the version bump to 26.6-alpha across pyproject + website copy. Core release tarball still carries apps/fileshare as the offline first-boot seed; the new daniel/furtka-apps catalog (tagged 26.6-alpha today) is the authoritative source on boxes that have synced at least once. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com> |
||
|---|---|---|
| .. | ||
| assets/css | ||
| content | ||
| layouts | ||
| static | ||
| deploy-ci.sh | ||
| deploy.sh | ||
| hugo.toml | ||
| README.md | ||
website/ — furtka.org
Hugo source for furtka.org. Intentionally minimal while the project is pre-alpha: a single idea page in English and German, nothing more. More pages will come back when there's something real to show.
Local build
cd website
hugo server # http://localhost:1313
Requires Hugo extended ≥ 0.140.
Deploy
Hosted on forge-runner-01 (Proxmox VM, Ubuntu 24.04). Hugo runs on the VM;
nginx serves the built output from /var/www/furtka.org. TLS is terminated by
an upstream openresty reverse proxy — the VM itself only speaks plain HTTP.
Auto-deploy on push-to-main (default)
.forgejo/workflows/deploy-site.yml fires on every push to main that touches
website/**. The self-hosted runner is forge-runner-01, so the whole deploy
collapses to a local rsync into /srv/furtka-site/ + hugo --minify into
/var/www/furtka.org/. No SSH hop, no secrets. Runs in under a minute.
The in-CI script is website/deploy-ci.sh. Don't invoke it from your dev box —
it assumes it's already on the target host.
Manual deploy (fallback)
For out-of-band pushes (feature branch, CI outage), deploy from your dev machine:
./website/deploy.sh
This rsyncs website/ to /srv/furtka-site/ on the VM over SSH and runs
hugo --minify into /var/www/furtka.org. Same end state as the CI path,
just with an SSH hop.
First-time VM setup
Only needed once, when provisioning a fresh forge-runner VM:
ssh forge-runner
sudo /srv/furtka-site/ops/nginx/setup-vm.sh # or copy the script over first
Structure
hugo.toml Hugo config (multilingual: en default, de)
content/ Markdown pages
_index.md Home (EN)
_index.de.md Home (DE)
layouts/ Custom inline theme — no external theme or framework
_default/ baseof, single, list
partials/ head, header, footer, gate SVG, lang switcher
index.html Home-only layout with editorial hero
assets/css/main.css Stylesheet (fingerprinted + minified on build)
static/favicon.svg Gate mark in crimson
deploy.sh Manual rsync + remote Hugo build (over SSH, for off-CI pushes)
deploy-ci.sh Local rsync + Hugo build — runs on forge-runner-01 from CI
Design
Modern-minimal on paper-white light / near-black dark. System-UI sans
(no webfonts — zero external requests, matches the self-hosting ethos).
Deep crimson accent, prefers-color-scheme switch.
The gate SVG is the one brand mark — a small wicket-gate glyph repeated in the header, footer, and favicon.