Releases no longer ship as bootable ISOs. Archipelago updates are distributed as the backend binary plus a frontend tarball referenced by releases/manifest.json. Nodes OTA-update via scripts/self-update.sh. Filebrowser and AIUI remain bundled inside the frontend tarball and deployed atomically, verified present in v1.7.43-alpha release artifact (189 AIUI files, filebrowser-client bundle). Archived under image-recipe/_archived/ (resurrectable if ISO distribution is reintroduced): - build-auto-installer-iso.sh - build-unbundled-iso.sh - test-iso-qemu.sh - scripts/convert-iso-to-disk.sh - BUILD-ISO-STATUS.md, ISO-BUILD-CHECKLIST.md - branding/isohdpfx.bin - .gitea/workflows/build-iso-dev.yml Updated release process docs to drop ISO references: - scripts/create-release.sh (next-steps text) - docs/BETA-RELEASE-CHECKLIST.md - docs/hotfix-process.md - README.md
270 lines
9.1 KiB
Markdown
270 lines
9.1 KiB
Markdown
# Beta Release Checklist (v0.5.0-beta)
|
|
|
|
## Pre-Build Verification
|
|
|
|
### Source Code
|
|
|
|
- [ ] All changes committed and pushed to `main`
|
|
- [ ] `cargo clippy --all-targets --all-features` passes (zero warnings)
|
|
- [ ] `cargo fmt --all` applied
|
|
- [ ] `cd neode-ui && npm run type-check` passes (zero errors)
|
|
- [ ] `cd neode-ui && npm test` passes (all tests green)
|
|
- [ ] `cargo test --all-features` passes on dev server
|
|
|
|
### Critical Files
|
|
|
|
- [ ] `core/container/src/podman_client.rs` — rootless Podman REST API socket
|
|
- [ ] `core/archipelago/src/container/docker_packages.rs` — app metadata + UI mapping
|
|
- [ ] `core/archipelago/src/api/rpc/package.rs` — app configs, capabilities, dependencies
|
|
- [ ] `core/archipelago/src/session.rs` — session security hardening
|
|
- [ ] `core/security/src/secrets_manager.rs` — encryption + rotation
|
|
- [ ] `neode-ui/src/views/Marketplace.vue` — all app entries with pinned image versions
|
|
- [ ] `neode-ui/src/api/websocket.ts` — heartbeat + reconnection
|
|
- [ ] `image-recipe/configs/nginx-archipelago.conf` — all app proxies + path traversal blocks
|
|
- [ ] All app icons present in `neode-ui/public/assets/img/app-icons/`
|
|
|
|
---
|
|
|
|
## App Integration Matrix
|
|
|
|
Every app must be tested for install, launch, and uninstall on a fresh system.
|
|
|
|
### Core Bitcoin Stack
|
|
|
|
| App | Image | Version | Install | Launch | UI Loads | Uninstall |
|
|
|-----|-------|---------|---------|--------|----------|-----------|
|
|
| Bitcoin Knots | `bitcoinknots/bitcoin` | `v28.1` | [ ] | [ ] | [ ] | [ ] |
|
|
| Electrs | `mempool/electrs` | `v0.4.1` | [ ] | [ ] | [ ] | [ ] |
|
|
| LND | `lightninglabs/lnd` | `v0.18.4` | [ ] | [ ] | [ ] | [ ] |
|
|
| BTCPay Server | `btcpayserver/btcpayserver` | `2.0.6` | [ ] | [ ] | [ ] | [ ] |
|
|
| Mempool | `mempool/frontend` | `v3.0.0` | [ ] | [ ] | [ ] | [ ] |
|
|
| Fedimint | `fedimintui/fedimint` | `0.5.0` | [ ] | [ ] | [ ] | [ ] |
|
|
| Fedimint Gateway | `fedimintui/gateway-ui` | `0.5.0` | [ ] | [ ] | [ ] | [ ] |
|
|
|
|
### Storage & Media
|
|
|
|
| App | Image | Version | Install | Launch | UI Loads | Uninstall |
|
|
|-----|-------|---------|---------|--------|----------|-----------|
|
|
| File Browser | `filebrowser/filebrowser` | `v2` | [ ] | [ ] | [ ] | [ ] |
|
|
| Immich | `ghcr.io/immich-app/immich-server` | `v1.121.0` | [ ] | [ ] | [ ] | [ ] |
|
|
| PhotoPrism | `photoprism/photoprism` | `240915` | [ ] | [ ] | [ ] | [ ] |
|
|
|
|
### Productivity & Privacy
|
|
|
|
| App | Image | Version | Install | Launch | UI Loads | Uninstall |
|
|
|-----|-------|---------|---------|--------|----------|-----------|
|
|
| Penpot | `penpotapp/frontend` | `2.4` | [ ] | [ ] | [ ] | [ ] |
|
|
| SearXNG | `searxng/searxng` | `2024.11.17-e2554de75` | [ ] | [ ] | [ ] | [ ] |
|
|
| Ollama | `ollama/ollama` | `0.5.4` | [ ] | [ ] | [ ] | [ ] |
|
|
|
|
### Network & Infrastructure
|
|
|
|
| App | Image | Version | Install | Launch | UI Loads | Uninstall |
|
|
|-----|-------|---------|---------|--------|----------|-----------|
|
|
| Nostr Relay | `scsiblade/nostr-rs-relay` | `0.9.0` | [ ] | [ ] | [ ] | [ ] |
|
|
| Nginx Proxy Manager | `jc21/nginx-proxy-manager` | `2.12.1` | [ ] | [ ] | [ ] | [ ] |
|
|
| Tailscale | `tailscale/tailscale` | pinned | [ ] | [ ] | [ ] | [ ] |
|
|
| Home Assistant | `homeassistant/home-assistant` | pinned | [ ] | [ ] | [ ] | [ ] |
|
|
|
|
### Virtual Apps (No Container)
|
|
|
|
| App | Behavior | Works |
|
|
|-----|----------|-------|
|
|
| IndeedHub | Opens external URL | [ ] |
|
|
|
|
---
|
|
|
|
## Dependency Chain Tests
|
|
|
|
These must be tested in order on a fresh install:
|
|
|
|
- [ ] Install Bitcoin Knots → starts and begins syncing
|
|
- [ ] Install Electrs while Bitcoin running → connects to Bitcoin automatically
|
|
- [ ] Install LND while Bitcoin running → connects to Bitcoin automatically
|
|
- [ ] Install BTCPay while Bitcoin running → connects; Lightning available if LND present
|
|
- [ ] Install Mempool while Bitcoin + Electrs running → shows blockchain data
|
|
- [ ] Try installing Electrs without Bitcoin → shows clear error message
|
|
- [ ] Try installing LND without Bitcoin → shows clear error message
|
|
- [ ] Try installing Mempool without Bitcoin + Electrs → shows missing deps error
|
|
- [ ] Fedimint Gateway auto-detects LND credentials when available
|
|
|
|
---
|
|
|
|
## Security Hardening Verification
|
|
|
|
### Session Security
|
|
|
|
- [ ] Sessions expire after 24 hours of inactivity
|
|
- [ ] Password change invalidates all other sessions
|
|
- [ ] Maximum 5 concurrent sessions (oldest evicted when exceeded)
|
|
- [ ] Session tokens are SHA-256 hashed in memory (never stored as plaintext)
|
|
- [ ] Login rate limiting: 5 failures per 60 seconds per IP
|
|
|
|
### Container Security
|
|
|
|
- [ ] All container images use pinned versions (no `:latest`)
|
|
- [ ] Read-only root filesystem enabled for compatible apps
|
|
- [ ] `--cap-drop=ALL` applied to all containers
|
|
- [ ] `--security-opt=no-new-privileges:true` applied to all containers
|
|
- [ ] Required capabilities added explicitly per app (e.g., CHOWN for File Browser)
|
|
|
|
### Secrets Management
|
|
|
|
- [ ] Secrets encrypted with AES-256-GCM on disk
|
|
- [ ] Secret metadata tracked (creation date, rotation count)
|
|
- [ ] Secret rotation generates new random values and re-encrypts
|
|
- [ ] `security.list-expiring` RPC returns secrets older than threshold
|
|
|
|
### Path Traversal Prevention
|
|
|
|
- [ ] Nginx blocks `..` in filebrowser API paths (403 response)
|
|
- [ ] Frontend `sanitizePath()` strips `..` and resolves paths
|
|
- [ ] File Browser token not exposed in URLs
|
|
|
|
### Authentication
|
|
|
|
- [ ] TOTP 2FA enrollment and verification works
|
|
- [ ] TOTP backup codes work for recovery
|
|
- [ ] Maximum 5 TOTP attempts before session invalidation
|
|
- [ ] Pending TOTP sessions expire after 5 minutes
|
|
- [ ] Cookie-based auth (no tokens in query strings)
|
|
|
|
---
|
|
|
|
## WebSocket & Connectivity
|
|
|
|
- [ ] WebSocket connects on login and receives initial data dump
|
|
- [ ] WebSocket reconnects after network interruption (exponential backoff, max 30s)
|
|
- [ ] Server sends ping every 30s; client responds with pong
|
|
- [ ] Client sends JSON ping every 30s; server responds with JSON pong
|
|
- [ ] Server closes inactive connections after 5 minutes
|
|
- [ ] Connection state shown in UI (connected/reconnecting/disconnected)
|
|
- [ ] Install progress updates delivered in real-time via WebSocket
|
|
|
|
---
|
|
|
|
## Fresh Install Testing Matrix
|
|
|
|
### ISO Build
|
|
|
|
- [ ] ISO builds successfully on dev server
|
|
- [ ] ISO size is reasonable (< 10 GB)
|
|
- [ ] All container images captured in ISO
|
|
|
|
### Installation
|
|
|
|
- [ ] Boot from USB on x86_64 hardware
|
|
- [ ] Auto-installer partitions disk correctly
|
|
- [ ] Debian 13 installs without errors
|
|
- [ ] Archipelago services start on first boot
|
|
- [ ] Web UI accessible at server IP within 3 minutes of first boot
|
|
|
|
### Onboarding Flow
|
|
|
|
- [ ] Welcome screen displays with intro video
|
|
- [ ] Password creation enforces minimum requirements
|
|
- [ ] Path selection shows all 6 options
|
|
- [ ] DID generation completes within 60 seconds
|
|
- [ ] Identity naming is optional and skippable
|
|
- [ ] Backup download produces valid JSON file
|
|
- [ ] Onboarding completes and reaches Dashboard
|
|
|
|
### Post-Onboarding
|
|
|
|
- [ ] Dashboard shows all overview cards
|
|
- [ ] App Store loads with all curated apps
|
|
- [ ] Settings shows server name, version, DID, Tor address
|
|
- [ ] Logout and re-login works
|
|
- [ ] Password change works and invalidates other sessions
|
|
|
|
---
|
|
|
|
## Performance Targets
|
|
|
|
- [ ] Backend startup: < 3 seconds
|
|
- [ ] Frontend initial load: < 500 KB gzipped
|
|
- [ ] WebSocket initial data: < 1 second after connection
|
|
- [ ] App install progress visible in UI within 5 seconds of starting
|
|
|
|
---
|
|
|
|
## Nginx Proxy Verification
|
|
|
|
All app proxies must work in both HTTP and HTTPS blocks:
|
|
|
|
- [ ] `/rpc/` → backend:5678
|
|
- [ ] `/ws/` → backend:5678 (WebSocket upgrade)
|
|
- [ ] `/health` → backend:5678
|
|
- [ ] `/app/filebrowser/` → filebrowser:80
|
|
- [ ] `/app/searxng/` → searxng:8080
|
|
- [ ] `/app/immich/` → immich:2283
|
|
- [ ] `/app/penpot/` → penpot-frontend:80
|
|
- [ ] `/app/ollama/` → ollama:11434
|
|
- [ ] `/app/photoprism/` → photoprism:2342
|
|
- [ ] `/app/nginx-proxy-manager/` → npm:81
|
|
- [ ] `/app/tailscale/` → tailscale:8240
|
|
- [ ] BTCPay (port 23000) opens in new tab
|
|
- [ ] Home Assistant (port 8123) opens in new tab
|
|
- [ ] Tor hidden services resolve for all configured apps
|
|
|
|
---
|
|
|
|
## Rollback Procedures
|
|
|
|
### If Backend Fails to Start
|
|
|
|
```bash
|
|
# Check logs
|
|
sudo journalctl -u archipelago -n 50 --no-pager
|
|
|
|
# Restore previous binary
|
|
sudo cp /usr/local/bin/archipelago.bak /usr/local/bin/archipelago
|
|
sudo systemctl restart archipelago
|
|
```
|
|
|
|
### If Frontend is Broken
|
|
|
|
```bash
|
|
# Restore previous frontend build
|
|
sudo cp -r /opt/archipelago/web-ui.bak/* /opt/archipelago/web-ui/
|
|
sudo systemctl reload nginx
|
|
```
|
|
|
|
### If Container Won't Start
|
|
|
|
```bash
|
|
# Check container logs
|
|
podman logs <container-name>
|
|
|
|
# Remove and recreate
|
|
podman rm -f <container-name>
|
|
# Reinstall from App Store
|
|
```
|
|
|
|
### If ISO Install Fails
|
|
|
|
1. Boot into rescue mode from USB
|
|
2. Check `/var/log/installer.log` on target disk
|
|
3. Verify disk partitioning with `lsblk`
|
|
4. Re-run installer with `INSTALLER_STARTED= /opt/installer.sh`
|
|
|
|
### Full System Rollback
|
|
|
|
If the beta is unusable:
|
|
1. Re-flash the ISO from the last known good build
|
|
2. Restore user data from `/var/lib/archipelago/` backup
|
|
3. Re-import DID from backup JSON file
|
|
|
|
---
|
|
|
|
## Sign-Off
|
|
|
|
| Reviewer | Area | Date | Pass/Fail |
|
|
|----------|------|------|-----------|
|
|
| | Backend | | |
|
|
| | Frontend | | |
|
|
| | Security | | |
|
|
| | ISO Build | | |
|
|
| | Fresh Install | | |
|
|
| | App Integrations | | |
|