NeuroDock
A local-first cognitive substrate for neurodivergent professionals. Gives Claude memory, a sense of time, a translator for corporate ambiguity, and a guardrail that refuses to amplify rumination, hyperfocus, or sycophancy. MCP-native. No telemetry. AGPL-3.0-or-later. Self-ID sufficient ā no diagnosis gating.
README
<p align="center"> <img src="./assets/icon-512.png" alt="NeuroDock" width="180"> </p>
<h1 align="center">NeuroDock</h1>
<p align="center"><em>A cognitive substrate that remembers, paces, and refuses. Built with neurodivergent professionals, not for them.</em></p>
<p align="center"> <a href="./LICENSE"><img src="https://img.shields.io/badge/license-AGPL--3.0--or--later-1f1f1f.svg" alt="License AGPL-3.0-or-later"></a> <img src="https://img.shields.io/badge/python-3.11%2B-1f1f1f.svg" alt="Python 3.11+"> <img src="https://img.shields.io/badge/node-22%2B-1f1f1f.svg" alt="Node 22+"> <a href="https://www.npmjs.com/package/@neurodock/cli"><img src="https://img.shields.io/npm/v/@neurodock/cli?label=%40neurodock%2Fcli&color=1f1f1f" alt="@neurodock/cli on npm"></a> <a href="https://pypi.org/project/neurodock-mcp-chronometric/"><img src="https://img.shields.io/pypi/v/neurodock-mcp-chronometric?label=pypi%3A%20mcp-servers&color=1f1f1f" alt="neurodock-mcp-* on PyPI"></a> </p>
<p align="center"> <img src="https://img.shields.io/badge/cross--platform-macos%20%C2%B7%20linux%20%C2%B7%20windows-1f1f1f.svg" alt="Cross-platform"> <img src="https://img.shields.io/badge/MCP-native-1f1f1f.svg" alt="MCP-native"> <img src="https://img.shields.io/badge/local--first-default-1f1f1f.svg" alt="Local-first by default"> <img src="https://img.shields.io/badge/telemetry-none-1f1f1f.svg" alt="No telemetry"> <img src="https://img.shields.io/badge/self--ID-sufficient-1f1f1f.svg" alt="Self-ID sufficient"> </p>
5-second TL;DR
- What it does: gives Claude a memory of your work, a sense of time, a refuse-rumination guardrail, and a translator for corporate ambiguity.
- Who it's for: neurodivergent people ā self-ID only, no diagnosis required, no gatekeeping.
- How to install: one command, below.
NeuroDock plugs into Claude Desktop / Claude Code / Cursor (any MCP-aware client). Local-first by default. No telemetry. AGPL-3.0-or-later.
How it fits together
You chat with Claude exactly like normal. Under the hood, Claude calls NeuroDock's local MCP servers; they read and write your local store; the result flows back into Claude's reply.
<p align="center"> <img src="./assets/branding/architecture-request-path.svg" alt="Request path: you talk to Claude; Claude calls five NeuroDock MCP servers (chronometric, cognitive-graph, task-fractionator, translation, guardrail) plus the evals harness; they read and write ~/.neurodock on your local machine; results flow back into Claude's reply. All local by default, no telemetry, your data stays your data." width="100%"> </p>
Everything runs on your laptop. Nothing leaves your machine unless you explicitly turn on a cloud option.
<p align="center"> <img src="./assets/branding/onboarding-3-steps.svg" alt="Install NeuroDock in three steps: 1) Run npx @neurodock/cli@latest install-all (under 5 minutes). 2) Full-quit Claude with Cmd+Q or Ctrl+Q so it re-reads its MCP config (30 seconds). 3) Start talking to Claude ā for example, ask 'What was I working on yesterday?'" width="100%"> </p>
Install
npx --yes @neurodock/cli@latest install-all
One command. It pip-installs the five MCP servers (plus the neurodock-evals
harness), wires Claude Desktop / Claude Code / Cursor, and drops a starter
profile at ~/.neurodock/profile.yaml.
Then, in any conversation, try one of:
What was I working on yesterday?
Plan my morning.
Decompose this goal into atomic tasks.
Claude calls the MCP tools under the hood; you just talk.
š First-time gotcha: full-quit Claude before testing
Claude only reads its MCP config at startup. Closing the window is not enough. This is the #1 silent failure people hit.
- macOS:
Cmd + Q(or Claude menu ā Quit Claude).- Windows: right-click the Claude icon in the system tray ā Quit.
- Linux: kill the process (
pkill -f Claudeor quit from the tray).Then reopen Claude and try one of the prompts above.
Requires Python 3.11+ and Node 22+. Works on macOS, Linux, Windows.
Why
@latest? If you previously rannpm install -g @neurodock/cli, npx will silently reuse that older global install instead of fetching the current version ā and old versions don't haveinstall-all. The@latesttag forces npx to resolve against the npm registry every time. Same reason we use it onupdate.
<details> <summary><strong>Want to install it step-by-step instead?</strong></summary>
NeuroDock ships across two registries: the Python MCP servers (MCP = Model Context Protocol ā the standard that lets Claude call local tools) on PyPI, and the user-facing CLI on npm. The CLI wraps everything else.
1. Install the six MCP servers
pip install neurodock-mcp-chronometric neurodock-mcp-cognitive-graph neurodock-mcp-task-fractionator neurodock-mcp-translation neurodock-mcp-guardrail neurodock-evals
2. Wire them into your MCP-aware client
npx --yes @neurodock/cli@latest init
Detects Claude Desktop, Claude Code, or Cursor and writes the server entries automatically.
3. Restart Claude (full quit, not close-window ā see the callout above).
About the neurodock command ā it lives on npm as @neurodock/cli,
not on PyPI. The pip install step gives you the MCP server binaries
that Claude calls over stdio; the CLI is separate. Two ways to run it:
# Option A ā run via npx, no install
npx --yes @neurodock/cli@latest doctor
# Option B ā install once, call 'neurodock' from anywhere
npm install -g @neurodock/cli
neurodock doctor
@neurodock/cli exposes: init, doctor, validate, update, sync,
uninstall, host install, host uninstall, profile show,
profile validate, install-all, install-hooks, examples,
plugin add/remove/list/enable/disable/validate.
Proactive guardrails (optional, recommended)
By default NeuroDock waits for you to ask. That's the wrong shape ā an ND user in hyperfocus is the one least likely to remember to run a break tool. One command flips it:
neurodock install-hooks --self-test
This wires a small Python script (bundled, stdlib-only ā no extra install needed) into Claude Code's hook system. It then runs silently on every tool call and auto-fires the chronometric / rumination / sycophancy heuristics when patterns trip. You get a one-line stderr banner on the next prompt ā never blocked, always dismissible.
For host-agnostic coverage (catches you working in the terminal at 02:00 too), add the standalone daemon:
neurodock install-hooks --install-daemon --self-test
That registers a per-user autostart entry (HKCU Run on Windows,
LaunchAgent on macOS, systemd --user on Linux). The daemon polls
every 5 min and surfaces OS-native notifications.
Opt out anytime:
neurodock install-hooks --uninstall # removes both
export NEURODOCK_GUARDRAILS=off # disables without removing
The browser extension carries its own equivalent (Phase 2 watchdog) ā
it's enabled by default and toggleable from chrome.storage.local via
the popup Settings tab.
See docs/.../proactive-guardrails for the design behind this and the
opt-out matrix.
Want to see it work without installing from PyPI/npm at all?
TESTING_LOCAL.md walks through the from-clone path.
</details>
<details> <summary><strong>Prefer a plugin, a one-click desktop extension, or the MCP Registry?</strong></summary>
The install-all command above is the recommended path. The same servers are
also distributed through three standard channels ā all install the identical
local stdio servers, so you can pick whichever fits your client:
Claude Code plugin ā bundles the five MCP servers and a set of ND-aware
skills in one step. Requires uv (the servers
run via uvx).
/plugin marketplace add tlennon-ie/neurodock
/plugin install neurodock@neurodock
Claude Desktop extension (.mcpb) ā one-click install, no config editing.
One bundle per server under mcpb/; build with
npx @anthropic-ai/mcpb pack mcpb/neurodock-mcp-translation and drag the
.mcpb onto Claude Desktop ā Settings ā Extensions. Requires uv.
Official MCP Registry ā each server ships a
server.json and is published to
registry.modelcontextprotocol.io
under the io.github.tlennon-ie/* namespace, so MCP-aware clients can discover
them directly.
Hosted remote server (no install) ā the stateless tools (translation,
guardrail, and decompose) are also served over OAuth at a hosted HTTPS
endpoint, so you can use them with no local install and no uv:
https://mcp.neurodock.org/mcp
In Claude (claude.ai or Desktop) ā Settings ā Connectors ā Add custom
connector ā paste that URL ā complete the sign-in prompt. The eight stateless
tools appear immediately. An opt-in memory surface (enable_hosted_storage,
connect_byos_storage, record_fact, recall_entity, ā¦) is also exposed but
does nothing until you explicitly enable storage for your signed-in account. The
personal cognitive graph and neurotype profile are never hosted ā they stay
on the local install. Full walkthrough: Hosted server.
The hosted remote server is live at mcp.neurodock.org.
</details>
Update
npx --yes @neurodock/cli@latest update
One command. Upgrades all six MCP servers (pip install --upgrade /
uv tool install), refreshes your wired client configs, and
re-registers the optional native-messaging host. Same flags as
install-all (--client, --profile, --installer, --dry-run,
--no-native-host, --yes).
The browser extension auto-updates through the Chrome / Firefox / Edge
store; sideloaded users git pull and rebuild.
Full-quit Claude after updating so it re-reads its MCP config ā same as first install.
Just want to re-shape client configs without touching package versions?
Use neurodock sync.
See it in action
The cognitive substrate in a real session ā you talk to Claude normally; under the hood it calls NeuroDock's MCP tools to remember, pace, and decompose.
https://github.com/user-attachments/assets/bcbf65ce-88dd-4f83-8dc1-d56bdde01bed
The browser extension ā translating corporate-speak inline on Gmail, Slack, and the rest, right where you read it, without context-switching back to Claude.
https://github.com/user-attachments/assets/5fa25044-923e-4c25-95bd-f1bd63fb3d6e
Prefer a written walkthrough? Try the Claude Desktop walkthrough.
Browser extension (optional)
There's also a browser extension that translates corporate-speak inline on Gmail, Slack, Linear, Notion, GitHub, Google Docs, and Outlook. It calls the same translation tools the MCP server exposes, but surfaces them where you'd actually use them ā a floating Translate button plus a right-click menu ā so you don't have to context-switch back to Claude just to decode "let's circle back on this."
You pick the LLM provider. Five options: Ollama (local, default), LM
Studio (local), OpenRouter (including its auto-router), Anthropic, OpenAI.
The API key, if you need one, stays in chrome.storage.local and never
leaves the device.
Store submission is still pending (the listing prep is done; the developer accounts and screenshots aren't). Until then, load it manually:
- Build it:
pnpm --filter @neurodock/extension-browser run build - Chrome / Edge: go to
chrome://extensions, turn Developer mode on, click Load unpacked, and pickpackages/extension-browser/.output/chrome-mv3/. - Firefox: go to
about:debugging, click This Firefox ā Load Temporary Add-on, and pickmanifest.jsoninsidepackages/extension-browser/.output/firefox-mv3/.
Full per-provider setup walkthrough lives in
packages/extension-browser/README.md.
What's inside
NeuroDock is built around three pillars. Each pillar is made of small, independent packages that you can use one at a time or all together.
flowchart TB
subgraph cognitive[Cognitive substrate]
chrono[mcp-chronometric<br/>time + sessions]
cgraph[mcp-cognitive-graph<br/>memory]
frac[mcp-task-fractionator<br/>decomposition]
end
subgraph comms[Communication layer]
trans[mcp-translation<br/>tone + meetings]
ext[extension-browser<br/>Gmail, Slack, ...]
end
subgraph safety[Clinical guardrails]
guard[mcp-guardrail<br/>rumination / hyperfocus / sycophancy]
clin[clinical<br/>heuristic library]
end
skills[skills/<br/>six markdown bundles] --> cognitive
skills --> comms
skills --> safety
cli[cli/<br/>install + manage] --> cognitive
cli --> comms
cli --> safety
<details> <summary>Prefer the directory tree? Open this.</summary>
neurodock/
āāā packages/
ā āāā mcp-chronometric/ Time + session + break management
ā āāā mcp-cognitive-graph/ Persistent memory + entity recall (SQLite)
ā āāā mcp-task-fractionator/ Decompose vague goals into atomic tasks
ā āāā mcp-translation/ Corporate-speak translator (MCP + browser ext)
ā āāā mcp-guardrail/ Rumination / hyperfocus / sycophancy detectors
ā āāā skills/ Six SKILL.md bundles activating on phrases
ā āāā extension-browser/ WXT-built Chrome / Firefox / Edge extension
ā āāā native-host/ Optional native messaging host (extension <-> profile.yaml)
ā āāā cli/ `npx neurodock init` and friends
ā āāā core/ Shared types, profile schema, plugin spec
ā āāā clinical/ Heuristic library for the guardrail server
ā āāā evals/ Eval harness + corpus contribution pipeline
āāā docs/ Astro Starlight site (deploys to docs.neurodock.org)
āāā plugins/ Drop your own plugins here; auto-discovered
āāā profiles/ Curated profile presets
</details>
Status
Public preview shipped. All three substrate pillars (cognitive,
communication, guardrails) are built, on main, and installable from
npm + PyPI. Latest substrate tag: v0.7.3.
MCP servers (PyPI)
neurodock-mcp-chronometricā 5 tools, 22 tests, mypy--strict.neurodock-mcp-cognitive-graphā 4 tools, SQLite + sqlite-vec- fastembed; 4-rung resolution cascade (exact ā alias ā fuzzy ā embedding).
Latest patch ships friendlier
record_facterrors so wrong-shape input no longer leaks raw Pydantic traces.
- fastembed; 4-rung resolution cascade (exact ā alias ā fuzzy ā embedding).
Latest patch ships friendlier
neurodock-mcp-task-fractionatorā 2 tools, 32 tests; ISO 8601 duration spec.neurodock-mcp-translationā 4 tools, 29 tests; deterministic baseline plus LLM refinement envelope.neurodock-mcp-guardrailā all three detectors live: rumination, hyperfocus, sycophancy (48 tests, public heuristics).neurodock-evalsā air-gapped harness, 10 seed corpus examples, contribution pipeline.neurodock-clinicalā reserved name; importable detector library (currently a stub).
CLI + browser surface (npm)
@neurodock/cliā 19 verbs across 7 groups:init,install-all,examples,doctor,validate,update,sync,uninstall,host install/uninstall,profile show/validate,install-hooks,plugin add/remove/list/enable/disable/validate.install-hookswires the proactive-guardrail hook into Claude Code and optionally registers the standalone daemon.@neurodock/coreā profile schema and plugin protocol manifests (JSON Schema 2020-12).@neurodock/native-hostā optional Chrome Native Messaging host for the extension ā profile sync.@neurodock/extension-browserā WXT MV3 build for Chrome / Firefox / Edge. Seven sites wired. Five real LLM providers: Ollama, LM Studio, Anthropic, OpenAI, OpenRouter. Includes the Phase 2 proactive watchdog for hyperfocus / late-night / single-host rumination signals. Not yet store-published.
Skills + docs
- Six launch skills ā
adhd-daily-planner,audhd-context-recovery,ocd-decision-finalizer(beta),hyperfocus-formatter,visual-organizer,asd-meeting-translator. - Docs site ā builds clean (Astro Starlight), deploys to
docs.neurodock.org.
Still deferred
- Browser-store submissions ā Chrome Web Store, Firefox Add-ons, Edge Add-ons developer accounts + screenshots; manual step.
How to actually test it right now
TESTING_LOCAL.md ā step-by-step guide to running this against your
Claude Desktop, today, from a clone. Takes about 5 minutes.
Documentation
The docs site lives at docs.neurodock.org.
Source is at docs/src/content/docs/. To preview locally:
pnpm --filter @neurodock/docs run dev
# opens http://localhost:4321
Architecture
The substrate splits into three pillars:
- Cognitive substrate ā externalises executive function (time, memory, decomposition). MCP servers: chronometric, cognitive-graph, task-fractionator.
- Communication layer ā translates corporate ambiguity; rewrites outgoing messages for register-appropriate tone; structures meeting transcripts. MCP server: translation. Browser extension surfaces the same prompts in Gmail / Slack / Linear / Notion / GitHub / Docs / Outlook.
- Clinical guardrails ā detects and intervenes on rumination
(repeat-validation loops), hyperfocus (escalating session-length
nudges), and sycophancy (unconditional agreement). MCP server: guardrail.
Heuristics are public and auditable per
ETHICS.md.
All three layers compose via the same MCP protocol the LLM client already speaks. There's no "NeuroDock app" ā the surface is your Claude client.
Design rationale lives in docs/decisions/:
- ADR 0001 ā chronometric tool design
- ADR 0002 ā cognitive-graph tool design
- ADR 0003 ā task-fractionator tool design
- ADR 0004 ā profile schema
- ADR 0005 ā translation tool design
- ADR 0006 ā guardrail tool design
- ADR 0007 ā plugin protocol
- ADR 0008 ā distribution & remote strategy
Contributing
CONTRIBUTING.md has the welcome + on-ramp. Pick whichever lane matches
what you want to do:
Smallest first PR (~15 min):
- Add a test to an existing skill (
packages/skills/<name>/tests/) - Add a seed eval example (
packages/evals/corpora/translation/) - Improve a tool's parameter description (the LLM uses these ā clearer descriptions = better tool use)
One-afternoon PR:
- Write a new skill ā markdown bundle activating on specific phrases.
Copy any
packages/skills/<name>/as a template; seedocs/src/content/docs/contribute/write-a-skill.mdx. - Sharpen the task-fractionator heuristics (regex / domain keyword maps).
- Add a new entity-resolution heuristic (e.g., phonetic) to
mcp-cognitive-graph.
Multi-day PR:
- Build an out-of-tree plugin (skill / mcp-server / profile / translation
pack / language pack / theme) per the ADR 0007 plugin protocol. See
docs/src/content/docs/contribute/write-a-plugin.mdx. - Translation language pack (e.g., Hiberno-English, German directness norms, Japanese keigo).
No code:
- Add an anonymised eval example from your own corporate inbox. The
contribution pipeline lives in
packages/evals/and is the highest- leverage non-code contribution.
All PRs run CI: pnpm turbo run lint typecheck test build + uv run pytest
uv run mypy --strict packages/.... Every published package has its own CHANGELOG. Use Conventional Commits in PR titles (feat:,fix:,docs:,test:,chore:,ci:).
Manifesto (short)
- Lower friction for users, and for contributors.
- Local-first by default; cloud is opt-in.
- The user is the authority. Self-ID sufficient.
- Composable over monolithic. No god-modules.
- Refuse where appropriate. AI that fuels rumination, hyperfocus, or anxiety is a regression, not a feature.
Full text in MANIFESTO.md. Ethics framework in ETHICS.md. Governance
in GOVERNANCE.md.
License
AGPL-3.0-or-later. Plugins must declare an AGPL-compatible license to load ā the SPDX whitelist is in ADR 0007.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.