feat: add GFM markdown support including tables via remark-gfm
fix: store full opencode tool output and display it in session view
- Collector sender now supports Remote-User header for forward-auth
- OpenCode parser: store full tool output (was truncated to 120 chars + first line)
- OpenCode parser: generate fallback content for tool-only turns instead of empty content
- OpenCode parser: increase parse timeout to 5min for large DBs
- Frontend: show collapsible tool output in session detail below turn body
- Frontend: extract toolOutput from both opencode ({output}) and claude-code ({content}) formats
fix: add tool column to search table; remove conversation bleed from comments
feat: add search UI layer — SearchTable, SearchFilters, SaveSearchForm, route, and styles
feat: add search data layer — adapter, highlight helper, hook, and tests
collector: add Claude Code parser
web: map tool-call setting to boolean attribute
web: align tool-call hide selector
web: wire display settings UI
web: add display preference modules
web: prune lethe_auth_failures log to the 5-min window on insert
web: AuthGate consolidates three "not authenticated" cards
Create AuthGate component as the single source of truth for the
unauthenticated UI. Cold renders show a manual sign-in button (IV7);
mid-session expiry auto-redirects via useEffect (IV7); auth_error shows
the distinct error card with a "Try again" button and never auto-retries
(IV6). Swap the inline AuthError cards at index, projects, and
SavedSearchesSection call sites.
web: /login + /auth/callback routes + auth context + config reader
- web/src/lib/config.ts: readConfig() reads window.__LETHE_CONFIG__ (IF1),
converts client_id -> clientId, throws on absent config (GPC6)
- web/src/lib/authContext.tsx: AuthProvider subscribes to tokenStore, parses
ID token name claim, exposes signIn/signOut/reportAuthError via context;
hasBeenAuthenticated flag supports IV7 cold-vs-session distinction
- web/src/routes/login.tsx: /login route calls signIn(return_to) on mount
- web/src/routes/auth.callback.tsx: validates state+TTL, exchanges code via
raw fetch to OP /token (allowed exception), stores access_token via
tokenStore.set, anti-loop guard using countCallbackFailures (IV6)
- web/src/routes/__root.tsx: wraps tree in AuthProvider above
KeyboardCursorContext
- web/src/routeTree.gen.ts: regenerated by Vite with /login and /auth/callback
- internal/server/web/dist/index.html: rebuilt artifact with new asset hashes
web: PKCE machinery + Authorization-header attachment in apiFetch
web: palette — gate prefetch with enabled+staleTime per plan 4.2
web: palette items — projects, sessions, saved searches
Extend the command palette with three new item kinds (project, session,
saved) backed by unconditional TanStack Query hooks. Items are grouped in
fixed order (jump → projects → sessions → saved) with section headers;
fire() dispatches kind-aware navigation; .palette-group-head CSS added.
web: sectioned /settings with saved-searches CRUD
Add four TanStack Query hooks (useSavedSearches, useCreateSavedSearch,
useUpdateSavedSearch, useDeleteSavedSearch) backed by IF3 contract.
Introduce apiFetchVoid in client.ts for the 204 No Content DELETE path.
Replace the placeholder /settings route with a two-column sectioned shell
(SectionRail + SavedSearchesSection); Display section is disabled pending #8.
web: adapter — add Session.sessionId, SavedSearch DTO; fix composite-id call sites
web: review fixes for projects/stats SPA routes
- ProjectsTable: drop the inner navigate call from handleOpen;
the parent route already navigates via the onOpen callback,
so the second push was creating a duplicate history entry
on every row click. Matches the SessionsTable pattern.
- HorizontalBars: replace href:string with onActivate(row)
callback. The earlier shape passed a pre-encoded path
string straight into TanStack <Link to={...}>; routing the
navigation through the typed (to, params) form via the
caller avoids any double-encoding ambiguity around splat
params and decouples the primitive from a specific route.
- stats.css: drop duplicated .card / .card-head / .card-body
blocks. The same rules already live in shell.css (loaded
globally), so any future divergence between the two copies
would silently desync.
web: stats route with backend-driven chart primitives