clawd/memory/2026-02-22.md

133 lines
7.3 KiB
Markdown

# Daily Notes — 2026-02-22
## Infrastructure
### Webmail (abandoned)
- Set up SnappyMail Docker on Zurich → hours of debugging → nuked it
- Root cause chain: AdGuard rewrite rule (*.jongsma.me → home IP) → hairpin NAT in container → wrong domain config fallback to localhost:143
- Lesson: all popular self-hosted webmail is PHP; Stalwart's "web UI" is admin-only, not user webmail
- Final state: webmail.jongsma.me DNS deleted, Caddy entry removed, SnappyMail fully nuked
- Stalwart is on latest (v0.15.5) — no upgrade needed
### DNS
- Removed wildcard `*.jongsma.me → 47.197.93.62` from Cloudflare
- AdGuard had a DNS rewrite for `*.jongsma.me` — Johan had to remove it manually
- Johan's home DNS is AdGuard, not just HA at 192.168.1.252
### Forge reboot
- Rebooted cleanly, all services came back via linger
## Dealspace (~/dev/dealroom, port 9300)
- Major UX overhaul: 14 changes including closing probability removal, new stat cards, last accessed, New Room modal, search, per-deal analytics/audit/contacts, request lists grouped by deal (commit eb103b4)
- Production auth: bcrypt, demo login removed, Misha admin account created
- Email: `misha@muskepo.com` / `Dealspace2026!` (owner role)
- Buyer account (misha.buyer@muskepo.com) created as workaround, then replaced by view toggle feature
- View toggle feature: owner/admin can switch between seller and buyer view within same session (agent briny-mist running ~1AM)
- No public domain yet — accessible at http://192.168.1.16:9300
## Email / Stalwart
- Family email accounts use short usernames from migration: rozemarijn, jacques, misha, tanya
- Full addresses (rozemarijn@jongsma.me etc.) work for receiving but login uses short names
- MC connectors connect directly to Stalwart IMAP on mail.jongsma.me:993
## Verizon bill processed
- $343.80 due March 4, 2026 — first bill on new account
- 3 lines: iPhone 17 (225-3810, Johan), iPhone 16 Plus (307-3952), iPhone 17 (358-1196)
- Auto Pay saves $30/mo if enrolled
- Record: ~/documents/records/bills/verizon-2026-02-21.md
## Sessions spawn
- Still blocked: "pairing required" (1008) error
- Gateway bind fixed to custom/0.0.0.0 but agent-to-agent auth still needed
- Cron jobs work; only sessions_spawn from conversation sessions fails
## HostKey cancellation
- Amsterdam VPS (53643) — Johan needs to manually cancel: https://panel.hostkey.com/controlpanel.html?key=639551e73029b90f-c061af4412951b2e
## Corrections to remember
- Don't assume Stalwart has user webmail — it doesn't, admin panel only
- Check for DNS rewrite rules (AdGuard) not just cache when DNS issues persist
- "It should not be so complicated" — when debugging gets multi-step, step back and ask if the feature is even needed
- Test features end-to-end myself before reporting "done"
## Sophia MRI - Feb 22 Update
### Dr. Madan no longer available
- Dr. Neel Madan (Chief Neuroradiology, Tufts) — his father-in-law is terminally ill
- Johan returning to AI-assisted radiological interpretation
- Historical track record: AI analysis has been more accurate than formal radiology reports
### MRI Discussion (Dec 31, 2025 scan)
- FLAIR showed FULL periventricular halo ("full aura") — not the two-point cap pattern
- Full halo = less specific (could be white matter disease from injury OR active hydrocephalus)
- Two-point pattern (frontal + occipital caps) = more specific for active CSF pressure
- Temporal horns NOT mentioned in radiology report — significant gap
- Temporal horn dilation = most specific sign of active hydrocephalus
- Key question for analysis: is ventriculomegaly disproportionate to cortical atrophy?
- Need: temporal horn width measurement, V/S ratio, FLAIR pattern characterization
- Johan to send screenshots: T2 axial (temporal horn level), FLAIR axial, T1 sagittal midline from Dec 31 scan in inou
## Sessions Spawn — RESOLVED (evening Feb 22)
- Root cause: OC 2026.2.21 update stripped `operator.write+read` scopes from tokens
- Fix: manually restored scopes in `device-auth.json` + `paired.json`; gateway restarted
- Automated: `oc-scope-watchdog.service` now restores scopes within 30s of any gateway restart
- Script: `~/clawd/scripts/scope-watchdog.py`; drop-in: `~/.config/systemd/user/openclaw-gateway.service.d/scope-fix.conf`
- sessions_spawn confirmed working from conversation sessions as of Feb 22 evening
## Gemini 3.1 Pro — Enabled in OpenClaw (Feb 22)
- Plugin `google-gemini-cli-auth` set to `enabled: true` in openclaw.json
- Model: `google/gemini-3.1-pro-preview`
- Uses existing Gemini CLI OAuth (johan@jongsma.me)
- Accessible via `session_status(model="google/gemini-3.1-pro-preview")`
- Confirmed working; best for medical/science analysis (77.1% ARC-AGI-2, top science benchmarks)
- Only works in main session (CLI OAuth); subagents need Gemini API key for native access
## Weekly Docker Maintenance (Sunday Feb 22)
- HAOS v17.1 — no update needed
- Immich, ClickHouse, Jellyfin, Signal: updated on 192.168.1.253
- qbittorrent-vpn: pulled only (do NOT start — Johan uses on-demand)
## Weekly Memory Synthesis (Feb 22)
- MEMORY.md updated with full weekly synthesis
- Two subagent timeouts before doing synthesis manually
- Key themes: infra consolidation, sessions-are-not-free architecture, open-weight model surge, Fish Audio TTS validated, OpenClaw auth risk, SnappyMail = "it should not be this complicated"
## X Watchlist Updates (Feb 22)
- @moltbot: account not found — removed from all watchlists
- Added: @OpenAI, @MiniMax_AI, @Kimi_Moonshot, @ZhipuAI, @Gemini, @steipete, @RapidResponse47
- AI lab accounts (@OpenAI etc.) filter: hard news only (model releases, pricing, major launches)
- AI lab accounts post constantly — must drop everything else silently
## TOOLS.md + MEMORY.md Security
- Both confirmed in .gitignore — not tracked in git
- API keys in `~/.openclaw/openclaw.json`, not in system prompt files
- No exposure risk
## AirLLM Test
- Qwen2.5-7B-Instruct runs on forge's GTX 970 (4GB VRAM) via AirLLM layer offloading
- Speed: 6.1s/token (slow but works)
- Proves 70B models are theoretically runnable at ~8-12s/token
- Fix for install: `optimum==1.22.0`
- Significance: local medical model analysis now viable for non-sensitive-latency tasks
## Jacques/Rozemarijn Stalwart Login Fix
- Renamed Stalwart accounts to full email format (jacques@jongsma.me, rozemarijn@jongsma.me)
- IMAP verified working for both
- Credentials sent in Dutch via Signal
## Open Items as of 8PM Feb 22
- Johan to send Sophia MRI screenshots for Gemini 3.1 Pro analysis
- Johan to manually cancel HostKey server #53643 (cancel URL sent via Signal)
- Verizon Auto Pay enrollment — saves $30/mo before March 4 billing cycle
- Dealspace public domain (dealspace.jongsma.me) if Misha wants external access
- Dealspace design questions: org signup, buyer concept, subscription plan, doc↔request linking, per-buyer permissions, CRM
- Remove stale `amsterdam.inou.com` from `overview-dns-zones.csv`
- Gemini API key (optional) for subagent Gemini access (currently main session only)
## Nightly Maintenance (9 PM)
- OS updates: 0 packages upgraded (all up to date)
- Claude Code: 2.1.50 (up to date; `npm update` ran, changed 1 dependency)
- OpenClaw: 2026.2.21-2 (up to date; check-updates.sh has regex false-positive for `-2` suffix)
- Session cleanup: removed 10 orphaned .jsonl files (~7.5 MB), removed 10 :run: keys from sessions.json
- Working context written to memory/working-context.md