Skip to main content

Web dashboard for getbased-agents — manage knowledge libraries, generate MCP client configs, inspect agent activity

Project description

getbased-dashboard

Web dashboard for getbased-agents — one page that covers knowledge library management, MCP client setup, and agent-activity inspection. Matches the getbased PWA's browser-local lens UX for users running the external-server backend.


What it looks like

Three tabs, single auth gate, one pill for ingest progress that lives outside the tab DOM so it survives navigation.

Knowledge tab

  • Engine badge strip at the top: ONNX · CPU · MiniLM-L6-v2 · 384d · floor 0.55 · ready
  • Library list with per-row model chip, live chunk count (12,758 chunks), relative last-ingested (indexed 2h ago), activate/rename/delete
  • Create-library form with a model dropdown (MiniLM-L6-v2 · BGE-small/base/large-en · BGE-M3) — dimension + download size shown per option
  • Drag-drop ingest with a bottom-right pill: HTML5 <progress>, 12,500 / 16,000 · 3.2/s chunks/sec rate, Cancel (partial commit) + Dismiss (×). 3s auto-dismiss on completion.
  • Search preview with score per result
  • Sources panel sorted by chunk count desc, Delete-all + per-source delete

MCP tab

  • Env viewer showing what a spawned MCP would see (LENS_URL, LENS_API_KEY_FILE + present/missing, GETBASED_TOKEN set/not set, module path). Tooltips explain the difference between "dashboard's env" and "client's MCP env block"
  • Config generator — emits paste-ready blocks for Claude Desktop, Claude Code, Cursor, Cline, Hermes, OpenClaw. JSON mcpServers.<name> for the Anthropic-shape clients, YAML with enabled_tools allowlist for Hermes, JSON mcp.servers.<name> for OpenClaw. Copy-to-clipboard button.
  • "Test MCP" — spawns the real getbased-mcp binary via stdio, runs initialize + tools/list, returns elapsed ms + tool names

Activity tab

  • Top-line stat cards (total calls, errors, error rate, tools in use)
  • Per-tool table with P50/P95 latency
  • Newest-first feed of recent calls, polls every 10s
  • Clear log button

Install and run

pipx install getbased-dashboard
getbased-dashboard serve          # http://127.0.0.1:8323

The dashboard expects a getbased-rag server at http://127.0.0.1:8322 and reuses rag's API key. On first visit the UI prompts for the bearer key; it's stored in localStorage on your machine.

Or as part of the full stack:

pipx install "getbased-agent-stack[full]"
lens serve                       # in one terminal — the RAG backend
getbased-dashboard serve         # in another — the UI

Architecture

  Browser                 Dashboard               Rag server            MCP subprocess
  localhost        ↔      localhost         ↔     localhost             on-demand stdio
                          /api/* proxy            /query, /ingest,      tools/list
                          + MCP test spawn        /libraries, /info,    (for Test button)
                          + activity tail         /models, /stats

The dashboard holds no data. Delete it and your knowledge base is untouched.

  • All /api/* routes bearer-auth'd with the same key rag + MCP use (secrets.compare_digest, constant-time)
  • Error envelope normalised to {"error": "<string>"} for both HTTPException and Pydantic validation errors — frontend has one shape to parse
  • Upload path streams chunk-by-chunk to a temp file with a byte cap enforced before buffering (no OOM-via-multi-GB-upload)
  • Client disconnect propagates: browser aborts fetch → dashboard drops upstream → rag sees disconnect → ingest stops at next batch boundary

Config

Variable Default Description
DASHBOARD_HOST 127.0.0.1 Bind host. Loopback-only by default — expose to LAN at your own risk
DASHBOARD_PORT 8323 Bind port
LENS_URL http://127.0.0.1:8322 Where the rag server lives
LENS_API_KEY_FILE $XDG_DATA_HOME/getbased/lens/api_key (with legacy fallback to ~/.hermes/rag/lens_api_key) Shared bearer token — same one MCP reads
DASHBOARD_ACTIVITY_LOG $XDG_STATE_HOME/getbased/mcp/activity.jsonl JSONL path the MCP writes to; dashboard tails it
DASHBOARD_MAX_INGEST_BYTES 268435456 (256 MB) Cap on a single upload's total size
GETBASED_TOKEN (from env) Optional. When set, the MCP tab's env viewer reads "set" and the config generator bakes it into the env blocks. Typically you leave it unset locally and set it in your AI client's MCP config

CLI

getbased-dashboard serve       Start the web server. Prints a one-click
                               `?key=…` login URL tagged [LOGIN-URL] so
                               users don't need to copy-paste the bearer
                               out of the terminal.

getbased-dashboard login-url   Re-print the magic login URL on demand.
                               Use this after closing the original
                               `serve` terminal or when running as a
                               systemd / launchd service. Exits non-zero
                               if no key is on disk.

getbased-dashboard info        Show resolved config + whether the rag
                               key is on disk. Never echoes the key
                               itself — safe to paste into a bug report.

When running under systemd, the login URL is also grep-able in the service logs:

journalctl --user -u getbased-dashboard | grep LOGIN-URL

Security notes

  • Dashboard binds loopback by default. Exposing via DASHBOARD_HOST=0.0.0.0 means anyone on the LAN can drive your rag with the bearer key
  • The bearer key is read fresh from disk on every authed request — rotating the key (rewrite the file) takes effect without a dashboard restart
  • Multipart upload filenames are basename-sanitised before forwarding to rag (defence in depth; rag also sanitises)
  • Subprocess spawn for the MCP test button reaps the child on timeout, exception, or cancellation — no orphaned processes

License

GPL-3.0-only, matching the rest of the monorepo.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

getbased_dashboard-0.6.0.tar.gz (61.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

getbased_dashboard-0.6.0-py3-none-any.whl (54.3 kB view details)

Uploaded Python 3

File details

Details for the file getbased_dashboard-0.6.0.tar.gz.

File metadata

  • Download URL: getbased_dashboard-0.6.0.tar.gz
  • Upload date:
  • Size: 61.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for getbased_dashboard-0.6.0.tar.gz
Algorithm Hash digest
SHA256 dce259e91adaed9c8e00621b764f63fa862ed84afa4d8e174c8597a9e4999718
MD5 2743957297ec7b93b5ee4bd4f4518cfa
BLAKE2b-256 f3da9e093d18978f7c2c8fe4d74ff43a2970da498417ac85613f07ab240c6692

See more details on using hashes here.

Provenance

The following attestation bundles were made for getbased_dashboard-0.6.0.tar.gz:

Publisher: publish.yml on elkimek/getbased-agents

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file getbased_dashboard-0.6.0-py3-none-any.whl.

File metadata

  • Download URL: getbased_dashboard-0.6.0-py3-none-any.whl
  • Upload date:
  • Size: 54.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.3 {"installer":{"name":"uv","version":"0.11.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Pop!_OS","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for getbased_dashboard-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 685ac1b540440bc744ea61cc9a3d53ddd01d1963acf7e2b4cdccbe5bb0115ac5
MD5 f21bcc28511843b930638c3f6484297d
BLAKE2b-256 3c5969be057813c0d35243ff7dc4ad26105029894adcda4153e2f856276fbbe5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page