Nystart basert på arkitektonisk innsikt fra Sidelinja v1. Koden er ny, visjon og primitiver er validert gjennom tidligere arbeid. Inneholder: - Komplett arkitekturdokumentasjon (docs/arkitektur.md) - 6 vedtatte retninger (docs/retninger/) - Alle concepts, features, proposals og erfaringer fra v1 - Server-oppsett og drift (docs/setup/) - LiteLLM-konfigurasjon (API-nøkler via env) - Editor.svelte referanse fra v1 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
73 lines
2.9 KiB
Markdown
73 lines
2.9 KiB
Markdown
# Server-tilstand ved v1→v2 overgang (mars 2025)
|
|
|
|
Denne filen dokumenterer hva som kjører på serveren ved overgangen.
|
|
Slettes når v2 er oppe og stabilt.
|
|
|
|
## Kjørende containere (docker-compose)
|
|
|
|
| Container | Image | Rolle | Beholdes? |
|
|
|---|---|---|---|
|
|
| postgres | postgres:16 | Database (sidelinja, authentik, forgejo) | JA |
|
|
| caddy | caddy:2 | Reverse proxy, HTTPS | JA |
|
|
| authentik-server | goauthentik/server:latest | SSO | JA |
|
|
| authentik-worker | goauthentik/server:latest | SSO bakgrunn | JA |
|
|
| redis | redis:7-alpine | Cache for Authentik | JA |
|
|
| forgejo | forgejo:10 | Git | JA |
|
|
| spacetimedb | clockworklabs/spacetime:latest | Sanntid | FJERNES (tom v1-modul) |
|
|
| web | sidelinja-web (bygget) | SvelteKit v1 | FJERNES |
|
|
| worker | sidelinja-worker (bygget) | Rust worker v1 | FJERNES |
|
|
| ai-gateway | litellm:main-stable | AI-ruter | BEHOLDES (uavhengig av app) |
|
|
|
|
## Caddyfile (fungerende)
|
|
- auth.sidelinja.org → authentik-server:9000
|
|
- git.sidelinja.org → forgejo:3000
|
|
- sidelinja.org → web:3000 + /media/* (filservering) + JSON access log
|
|
- vegard.info → placeholder
|
|
- rt.sidelinja.org → spacetimedb:3000
|
|
|
|
## PG init-script
|
|
`/srv/sidelinja/config/postgres/init/01-create-databases.sql`
|
|
Oppretter authentik og forgejo DB-brukere med hardkodede passord.
|
|
Disse passordene matcher .env-variablene og er allerede kjørt — scriptet
|
|
kjøres kun ved *første* PG-oppstart.
|
|
|
|
## Dockerfiles (referanse)
|
|
### web/Dockerfile
|
|
- node:20-alpine, to-stegs bygg
|
|
- VITE_SPACETIMEDB_URL som build-arg
|
|
- `npm run build` → `node build` på port 3000
|
|
|
|
### worker/Dockerfile
|
|
- rust:1-bookworm, to-stegs bygg med dependency-caching
|
|
- debian:bookworm-slim runtime med ca-certificates
|
|
- Binary: sidelinja-worker
|
|
|
|
## .env-variabler på server
|
|
AUTHENTIK_CLIENT_ID, AUTHENTIK_CLIENT_SECRET, AUTHENTIK_ISSUER,
|
|
AUTHENTIK_POSTGRESQL_HOST, AUTHENTIK_POSTGRESQL_NAME, AUTHENTIK_POSTGRESQL_PASSWORD,
|
|
AUTHENTIK_POSTGRESQL_USER, AUTHENTIK_SECRET_KEY, AUTH_SECRET,
|
|
COMPOSE_PROJECT_NAME, DATABASE_URL, DOMAIN_AUTH, DOMAIN_SIDELINJA, DOMAIN_VEGARD,
|
|
FORGEJO_DB_PASSWD, LITELLM_MASTER_KEY, LIVEKIT_API_KEY, LIVEKIT_API_SECRET,
|
|
OPENROUTER_API_KEY, POSTGRES_DB, POSTGRES_PASSWORD, POSTGRES_USER
|
|
|
|
## Migrasjoner (v1, 15 stk)
|
|
0001-0015: initial_schema, kanban, calendar, notes, meldingsboks,
|
|
warmup_config, ai_config, ai_prompts, provider_extra_params, openrouter_only,
|
|
api_keys_toggle, api_keys_values, drop_priority_unique, workspace_ai_prompts,
|
|
usage_action_column. Pluss seed_dev.sql.
|
|
|
|
v2 starter med nytt skjema (noder+edges). Disse migreringene er irrelevante.
|
|
|
|
## Crontab
|
|
Ingen crontab konfigurert (backup-strategi er dokumentert men ikke implementert).
|
|
|
|
## Mappestruktur /srv/sidelinja/
|
|
```
|
|
config/authentik/ config/caddy/ config/postgres/init/
|
|
data/authentik/ data/caddy/ data/forgejo/ data/postgres/ data/redis/ data/spacetimedb/
|
|
logs/caddy/
|
|
media/ (podcast-filer)
|
|
server/ (git-klon av v1-repoet)
|
|
docker-compose.yml
|
|
.env
|
|
```
|