No description
Find a file
Natalie 5b372b8dc8 terraform: GPU droplet wg address .6 -> .9 (.6 now belongs to redroid)
The on-demand GPU droplet (model-boss/vLLM) must land at a free mesh IP; .6 was
reassigned to com.uvlava.ct.redroid. .9 matches the canonical model-boss endpoint
http://10.9.0.9:8000 that prospector (MODEL_BOSS_URL) and mr-number
(RATING_LLM_URL) now point at.

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
2026-06-30 03:25:20 -04:00
.project chore(uvlava): add .project planning dir 2026-06-29 14:35:14 -04:00
services/dns-updater uvlava: add ./run task runner for the services tier 2026-06-29 23:12:47 -04:00
terraform/do terraform: GPU droplet wg address .6 -> .9 (.6 now belongs to redroid) 2026-06-30 03:25:20 -04:00
.gitignore infra(uvlava): seed shared infranet repo with DO store-tier IaC 2026-06-27 09:43:44 -04:00
README.md docs: mark uvlava.com DO delegation live (forge.ct serving HTTPS) 2026-06-30 01:15:41 -04:00
run uvlava: add ./run task runner for the services tier 2026-06-29 23:12:47 -04:00

uvlava

uvlava.com — the shared infranet. The infrastructure layer beneath both product lines, replacing the dead homelan hosts black + apricot (died 2026-06-27). Not a product; the substrate the products run on.

  • lilith (v2)~/Code/@projects/@lilith/lilith-platform.live
  • cocotte (v4)~/Code/@projects/@cocottetech

Both consume uvlava; neither owns it. Infra config lives here so it isn't buried in a product repo.

Topology

   PUBLIC INTERNET ─► serve tier (NOT uvlava): 1984.is / vps-0 (Iceland)
                       nginx · SPAs · edge cache · mail · adult content
                                     │ private (WireGuard mesh)
   uvlava ───────────► store/infra tier: DigitalOcean (ct:prod, nyc3)
                       Forgejo · Verdaccio · Managed PG · Spaces · workers

uvlava is store/infra only — it never serves adult content to the public (provider-AUP + the serve tier stays on content-tolerant 1984.is).

What's live

Service Host Endpoint
Forgejo (git canonical) ct-forge droplet https://forge.ct.uvlava.com (live, Caddy + LE)
Verdaccio (@lilith/* npm) same droplet https://npm.ct.uvlava.com

DO account ct / project ct:prod / region nyc3. uvlava.com is registered (joker.com) and delegated to DigitalOcean — joker.com publishes ns1/ns2/ns3.digitalocean.com at the .com registry (verified 2026-06-30). DNS resolves publicly and Caddy auto-provisions Let's Encrypt certs per hostname: forge.ct.uvlava.com serves HTTP/2 200 with a valid LE cert (CN=forge.ct.uvlava.com). Only hostnames explicitly in the zone resolve — there is no wildcard, so each new subdomain needs its own A record.

Layout

  • terraform/do/ — DO store tier IaC (Managed PG + Spaces + backend droplet + WG peer + optional GPU). init/validate/plan verified against the live account (13 resources, no GPU); not yet applied. See terraform/do/README.md for the apply guide.

Secrets

None in-tree. All under ~/.vault/ (0600): do-pat-ct.token, forge-admin-quinn.*. .gitignore blocks *.tfstate / *.tfvars.