9.9 KiB
Agent Handoff
Last updated: 2026-05-17
Repository State
Project: Crucix fork / Intelligence Terminal
Local workspace:
C:\Users\MrSphay\Documents\Codex\Crucix\intelligence-terminal
Remotes:
origin https://git.wilkensxl.de/MrSphay/intelligence-terminal.git
upstream https://github.com/calesthio/Crucix.git
Final pushed commit:
e933586b220656a2858d2215b934b22d1f08a908
Both pushed branches currently point to this commit:
origin/codex/production-intelligence-terminal
origin/main
Gitea repository:
https://git.wilkensxl.de/MrSphay/intelligence-terminal
Default branch observed through the Gitea API:
codex/production-intelligence-terminal
Agent Kit Requirements Applied
The mandatory kit was cloned and reviewed first:
C:\Users\MrSphay\Documents\Codex\Crucix\agent-kit
Rules applied from the kit:
- Keep agent context in source control:
AGENTS.md,.codex/project.md, and this handoff file. - Use Gitea Ubuntu runners for heavy verification and package publishing.
- Keep Docker/Dockge operation first-class.
- Do not commit secrets,
.env, private logs, tokens, or generatedruns/data. - Add report-only maintenance workflows for security, dependency checks, repo cleanup, release dry runs, and template compliance.
- Poll pushed Gitea Actions until terminal state when a token is available.
What Was Implemented
Docker And Runtime
- Docker image is Docker-first and Dockge/Pangolin suitable.
- Browser auto-open is disabled by default through
AUTO_OPEN_BROWSER=false. - Runtime health checks now work in the container without
wgetor host browser tools. runsis persisted through a volume.- A later fix added
docker-entrypoint.shto prepare/app/runsbefore dropping privileges, so mounted volumes work with the non-root Node runtime. docker-compose.ymluses the Gitea Registry image by default:
git.wilkensxl.de/mrsphay/intelligence-terminal:latest
API And Health
Added or hardened:
GET /api/healthGET /api/dataGET /api/metricsPOST /api/sweep
Health now reports:
startinghealthydegradedstaleerror
It also reports:
- last sweep timestamps
- stale/bootstrap state
- data age
- source health
- source errors
- LLM configuration state
- Telegram/Discord enabled state
- memory store state
Live Data And Source Degradation
- Existing
runs/latest.jsonis only treated as bootstrap/stale data until a real sweep completes. - Sweeps update
sourceHealth, SSE/API data, and memory state. - RSS/news feed failures no longer silently look like fresh valid data.
safeFetchnow tracks request counts, failures, bytes, source labels, hosts, and recent fetch events.safeFetchhas better timeout/retry/backoff/error behavior and reports HTML-as-API-error cases.- Yahoo Finance fetches are more explicit about source errors and HTML/API failures.
- ACLED missing credentials now degrade transparently.
- Telegram polling has quieter network-error backoff logs.
LLM Integration
Added unified OpenAI-compatible provider layer:
lib/llm/openai-compatible.mjs
Supported provider paths include:
openrouteropenaiopenai-compatiblelocal-openailmstudiolm-studioollama
Relevant environment keys:
LLM_PROVIDER
LLM_BASE_URL
LLM_API_KEY
LLM_MODEL
LLM_TEMPERATURE
LLM_MAX_TOKENS
LLM_TIMEOUT_MS
OPENROUTER_SITE_URL
OPENROUTER_APP_NAME
OpenRouter Free and local OpenAI-compatible endpoints are documented in README.md and .env.example.
Memory
Added Phase-1 SQLite memory:
lib/intelligence-store.mjs
runs/intelligence.db
It uses node:sqlite when available and gracefully falls back when unavailable.
Dashboard
Implemented:
- interactive Sensor Grid layer modes
- focus/hide/normal states persisted in
localStorage - Space Watch icon/orbit toggle
- map/globe filtering consistency
- flat map label redraw handling
Important UI markers in the final code:
layerModes
spaceDisplayMode
toggleSpaceDisplay()
shouldShowType()
Briefings
Brief output now includes:
- Source Integrity
- evidence links
- event IDs
- configurable verbosity through
BRIEF_VERBOSITY
Documentation
Updated:
README.md.env.exampledocs/sources/README.mddocs/sources/opensky.mddocs/sources/acled.mddocs/sources/telegram.mddocs/sources/firms.mddocs/sources/maritime.mddocs/security-review.mddocs/release-checklist.md
README includes:
- Gitea Registry pull example
- Dockge-compatible compose example
- full
.envexamples - OpenRouter Free setup
- LM Studio setup
- Ollama setup
- local OpenAI-compatible setup
- Pangolin/reverse proxy notes
Registry And Images
Registry image:
git.wilkensxl.de/mrsphay/intelligence-terminal
Verified package tags through Gitea API:
latest
20260517
e933586b220656a2858d2215b934b22d1f08a908
Successful pull test:
docker pull git.wilkensxl.de/mrsphay/intelligence-terminal:latest
Observed digest:
sha256:780a41413921bd9a676461eca1cd1372591f523be4b7c9513d9bc085cbe7922d
Gitea Actions
Workflows present:
.gitea/workflows/build.yml
.gitea/workflows/security-scan.yml
.gitea/workflows/repo-cleanup.yml
.gitea/workflows/dependency-check.yml
.gitea/workflows/release-dry-run.yml
.gitea/workflows/template-compliance.yml
Final runs for commit e933586b220656a2858d2215b934b22d1f08a908 were polled through the Gitea API and succeeded:
build.yml on main: success
build.yml on codex/production-intelligence-terminal: success
release-dry-run.yml on main: success
release-dry-run.yml on codex/production-intelligence-terminal: success
template-compliance.yml on main: success
template-compliance.yml on codex/production-intelligence-terminal: success
Relevant run URLs:
https://git.wilkensxl.de/MrSphay/intelligence-terminal/actions/runs/23
https://git.wilkensxl.de/MrSphay/intelligence-terminal/actions/runs/24
https://git.wilkensxl.de/MrSphay/intelligence-terminal/actions/runs/25
https://git.wilkensxl.de/MrSphay/intelligence-terminal/actions/runs/26
https://git.wilkensxl.de/MrSphay/intelligence-terminal/actions/runs/27
https://git.wilkensxl.de/MrSphay/intelligence-terminal/actions/runs/28
Repository secret expected by the registry publish workflow:
REGISTRY_TOKEN
Local token note:
GITEA_TOKENwas visible in the final Codex process.- It was used only for Gitea API checks and not printed.
Verification Already Performed
Local lightweight checks:
npm run test:unit
npm audit --omit=dev --audit-level=high
docker compose --env-file .env.example config
node --check server.mjs
node --check dashboard/inject.mjs
node --check lib/llm/openai-compatible.mjs
git diff --check
Unit test result:
21 tests passing
0 failing
Audit result:
0 high vulnerabilities
Docker build and smoke test were performed locally earlier:
docker build -t git.wilkensxl.de/mrsphay/intelligence-terminal:latest .
docker run --rm -d --name intelligence-terminal-smoke -p 127.0.0.1::3117 -e AUTO_OPEN_BROWSER=false git.wilkensxl.de/mrsphay/intelligence-terminal:latest
Smoke test observations:
- Server booted.
- No
xdg-openerror. - Initial sweep completed.
/api/healthmoved fromstartingtodegradedwith transparent source errors.- Degraded state was expected without all optional API keys.
Important Commits
7e85a54 chore: apply agent kit project structure
85f97bb feat: harden intelligence runtime and llm providers
42b7fc2 docs: add registry dockge and dashboard operations
d072390 ci: align gitea workflows with agent kit
0559481 ci: fix gitea registry publish login
f3c9331 ci: fix agent kit compliance checks
c2d572e fix: prepare runs volume before dropping privileges
8e096b2 ci: harden gitea workflow reruns
e933586 merge: reconcile main with production branch
The large implementation commit 85f97bb is contained in both:
origin/codex/production-intelligence-terminal
origin/main
How To Continue In A Fresh Codex Environment
- Clone the Gitea repository:
git clone https://git.wilkensxl.de/MrSphay/intelligence-terminal.git
cd intelligence-terminal
git checkout codex/production-intelligence-terminal
- Confirm the expected commit:
git rev-parse HEAD
Expected:
e933586b220656a2858d2215b934b22d1f08a908
- Read these files first:
AGENTS.md
.codex/project.md
docs/agent-handoff.md
README.md
.env.example
- If checking Actions, use
GITEA_TOKENfrom the environment. Do not print it.
PowerShell check:
if ($env:GITEA_TOKEN) { "GITEA_TOKEN=set" } else { "GITEA_TOKEN=missing" }
- Useful commands:
npm run test:unit
docker compose --env-file .env.example config
docker pull git.wilkensxl.de/mrsphay/intelligence-terminal:latest
- Start with Dockge/Pangolin using the README compose example and a
.envbased on.env.example.
Remaining Risks And Follow-Ups
- Some sources will report
degradeduntil optional keys are set, especially ACLED, FRED, EIA, and Cloudflare Radar. - OpenSky can rate-limit with HTTP 429; this is now visible in health instead of hidden.
- GDELT/OFAC can time out under runner/network conditions; health reports this explicitly.
- Browser-level visual verification of the full dashboard should be repeated after any future UI change.
- The project still inherits the original Crucix broad source surface. Future work should prefer focused source-by-source tests over broad refactors.
- If a new Codex environment sees non-fast-forward branch pushes, fetch first and preserve remote commits. Do not force-push without explicit approval.
Operator Pull Command
For deployment:
docker pull git.wilkensxl.de/mrsphay/intelligence-terminal:latest
For a pinned deployment:
docker pull git.wilkensxl.de/mrsphay/intelligence-terminal:20260517