Poker Venue Manager
Find a file
Mikkel Georgsen f5df3e1182 Add display system design doc (Orange Pi 5 + ROCK 4D signage)
Documents the architecture for PVM's managed digital signage system:
Orange Pi 5 as leaf node (local backend, screen management API, video
pipeline), Radxa ROCK 4D as thin-client display nodes (kiosk Chromium,
CEC control, mDNS auto-discovery). API-first design for web and tablet
management clients. libsql on leaf, PostgreSQL on core.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-09 14:50:04 +01:00
apps/dashboard Add custom login UI replacing Zitadel built-in login pages 2026-02-08 13:54:01 +01:00
crates Address security/tech debt: token refresh, JWKS thundering herd, config safety, jq migration 2026-02-08 13:17:42 +01:00
docker Add custom login UI replacing Zitadel built-in login pages 2026-02-08 13:54:01 +01:00
docs Add display system design doc (Orange Pi 5 + ROCK 4D signage) 2026-02-09 14:50:04 +01:00
.gitignore Add Zitadel OIDC setup, SMTP config, and security fixes 2026-02-08 12:34:44 +01:00
Cargo.toml Scaffold base webapp: Rust/Axum API + SvelteKit dashboard + Docker dev env 2026-02-08 03:37:07 +01:00
package.json Scaffold base webapp: Rust/Axum API + SvelteKit dashboard + Docker dev env 2026-02-08 03:37:07 +01:00
pnpm-lock.yaml Scaffold base webapp: Rust/Axum API + SvelteKit dashboard + Docker dev env 2026-02-08 03:37:07 +01:00
pnpm-workspace.yaml Scaffold base webapp: Rust/Axum API + SvelteKit dashboard + Docker dev env 2026-02-08 03:37:07 +01:00
README.md Fix misaligned right border in ASCII art hero 2026-02-08 05:52:01 +01:00

 ░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░
 ░░                                                               ░░
 ░░   ██████╗ ██╗   ██╗███╗   ███╗   ♠ ♥ ♣ ♦                      ░░
 ░░   ██╔══██╗██║   ██║████╗ ████║                                ░░
 ░░   ██████╔╝╚██╗ ██╔╝██╔████╔██║   poker venue manager          ░░
 ░░   ██╔═══╝  ╚████╔╝ ██║╚██╔╝██║   -- since 2026 --             ░░
 ░░   ██║       ╚██╔╝  ██║ ╚═╝ ██║   seat open, table 3!          ░░
 ░░   ╚═╝        ╚═╝   ╚═╝     ╚═╝                                ░░
 ░░                                                               ░░
 ░░   tournaments · cash games · dealers · players · displays     ░░
 ░░   all managed · always on · no rake required                  ░░
 ░░                                                               ░░
 ░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░

What is PVM?

PVM is a comprehensive management system for poker venues of any size. It handles the full lifecycle of venue operations:

  • Tournament Management — Planning, live clocks, seating, registration, results, and recurring series
  • Cash Game Operations — Table tracking, waiting lists, game types, and session history
  • Player Accounts — One account across all venues, memberships, and game history. Players sign up for PVM first, then join venues.
  • Dealer Coordination — Scheduling, availability, shift swaps, and cross-venue mobility
  • Venue Display System — Push live clocks, seatings, waitlists, and info to any TV via Android display clients with mDNS auto-discovery
  • Local Node Support — Optional on-premise Raspberry Pi 5 proxy (Docker-based) for zero-downtime operation during internet outages (up to 72h offline)

Architecture

Hetzner PVE (LXC + Docker)
├── Rust API (Axum) + WebSocket Gateway
├── PostgreSQL 16 + DragonflyDB
├── NATS + JetStream
└── SvelteKit Web Apps
       │
       ├── near-realtime event sync (NATS)      ──►  Venue RPi5 Nodes (Docker)
       ├── Web App / PWA (managers, staff, players, dealers)
       └── Venue TVs (Android display client, cloud fallback)

Tech Stack

Layer Technology
Backend Rust + Axum
Frontend SvelteKit (Svelte 5) + shadcn-svelte + Tailwind v4
Cloud DB PostgreSQL 16+
Local DB libSQL (embedded)
Cache DragonflyDB
Messaging NATS + JetStream
Auth Custom JWT + RBAC
API REST + OpenAPI 3.1
Infra Hetzner PVE, Docker, Forgejo Actions

Documentation


Built for the poker community.