felt/.planning/STATE.md
Mikkel Georgsen 9bfd959eaf docs(01-02): complete database schema + migrations plan
- SUMMARY.md with full execution record and deviations
- STATE.md updated: plan 2/14, decisions, session info
- ROADMAP.md updated: Phase 1 progress 2/14
- REQUIREMENTS.md: ARCH-03, ARCH-08, PLYR-01, PLYR-07, SEAT-01, SEAT-02 complete

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-01 03:39:59 +01:00

71 lines
2.8 KiB
Markdown

# Project State
## Project Reference
See: .planning/PROJECT.md (updated 2026-02-28)
**Core value:** A venue can run a complete tournament offline on a €100 device with wireless displays and player mobile access — and it just works, on any network, with zero IT involvement.
**Current focus:** Phase 1 — Foundation
## Current Position
Phase: 1 of 7 (Tournament Engine)
Plan: 2 of 14 in current phase
Status: Executing Phase 1
Last activity: 2026-03-01 — Completed Plan B (Database Schema + Migrations)
Progress: [█░░░░░░░░░] 14%
## Performance Metrics
**Velocity:**
- Total plans completed: 1
- Average duration: 10min
- Total execution time: 0.17 hours
**By Phase:**
| Phase | Plans | Total | Avg/Plan |
|-------|-------|-------|----------|
| 01-tournament-engine | 1 | 10min | 10min |
**Recent Trend:**
- Last 5 plans: 01-02 (10min)
- Trend: starting
*Updated after each plan completion*
## Accumulated Context
### Decisions
Decisions are logged in PROJECT.md Key Decisions table.
Recent decisions affecting current work:
- [Init]: Go monorepo, shared `internal/`, `cmd/leaf` and `cmd/core` are the only divergence points
- [Init]: NATS sync_interval: always required before first deploy (December 2025 Jepsen finding)
- [Init]: All monetary values int64 cents — never float64 (CI gate test required)
- [Init]: go-libsql has no tagged releases — pin to commit hash in go.mod
- [Init]: Netbird reverse proxy is beta — validate player PWA access in Phase 1 before depending on it in Phase 8
- [01-02]: go-libsql requires single-statement Exec — migration runner splits SQL files into individual statements
- [01-02]: go-libsql PRAGMA handling is inconsistent — use QueryRow for journal_mode, execPragma helper for others
- [01-02]: Force single DB connection during migrations (SetMaxOpenConns(1)) for table visibility
### Pending Todos
None yet.
### Blockers/Concerns
- [Phase 1]: go-libsql CGO ARM64 cross-compilation must be validated in CI before any downstream features depend on it
- [Phase 1]: Netbird reverse proxy beta status — test the full QR code → HTTPS → WireGuard → Leaf flow early
- [Phase 3]: NATS JetStream cross-domain stream mirroring (Leaf → Core) needs integration test before Phase 2 depends on it
- [Phase 4]: Events engine security — run_command sandboxing, webhook URL allowlist, WYSIWYG HTML sanitization (deferred from Phase 1 security review)
- [Phase 7]: JWT HttpOnly cookies + signing key rotation (deferred from Phase 1 security review — localStorage is acceptable while Leaf is local-network only)
- [Phase 7]: Pi Zero 2W memory must be profiled on actual hardware with all display views before scaling signage
## Session Continuity
Last session: 2026-03-01
Stopped at: Completed 01-02-PLAN.md (Database Schema + Migrations)
Resume file: None