Stay sharp while your AI does the work.
devcoach connects to Claude Code, Claude Desktop, Cursor, Windsurf, and other MCP-compatible tools. After every task you complete, it delivers a short targeted lesson calibrated to what you already know — no generic tutorials, no repeated topics, nothing to open.
Everything runs locally. No data leaves your machine. One SQLite file at ~/.devcoach/coaching.db.
Built on the official Model Context Protocol TypeScript SDK, Node's embedded
node:sqlite, Hono (web dashboard), and Commander (CLI). Requires Node.js ≥ 24.
AI agents now write much of our code — which makes it easy to ship more while understanding less. devcoach turns each task your agent finishes into one short, in-context lesson, so you keep learning as you go. The deeper bet: as AI grows more capable, the scarce skill becomes validating what it produces — and that ability only survives if you keep practicing it.
flowchart TD
A([Task completed]) --> B[Check rate limit]
B -->|denied| Z([Silent])
B -->|allowed| D
subgraph loop["coaching loop"]
D[Select topic & depth]
E[Compose & deliver]
G[log_lesson]
end
D -->|nothing| Z
D -->|found| E
E --> G
G --> F([Done])
G -.->|prompts| U(["You: ✅ ❌ ⏭"])
→ Full decision flow: session startup · lesson selection · depth calibration
Everything stays on your machine. No telemetry, no accounts, no calls home. Just one SQLite file.
devcoach runs locally — a stdio MCP server that stores everything in ~/.devcoach/coaching.db on the machine where your agent runs. It works in Claude Code and Claude Desktop, but not on claude.ai web (which only supports hosted/remote connectors).
Requires Node.js ≥ 24 (devcoach uses the embedded node:sqlite module, available only from Node 24 onward).
Pick by how you like to work — each section is self-contained (install and connect):
- Developer, comfortable in a terminal → Homebrew — one
brew install, and you get thedevcoachCLI too. - Prefer a one-click, no-terminal setup → the Claude Code plugin or the
.mcpbextension. - Anything else (npx, manual config, other agents, claude.ai web) is under Other install methods.
macOS / Linux. Add and trust the tap once, install, then connect — you also get the devcoach CLI (so devcoach ui and the CLI work without an npx prefix):
# 1. Add the tap — registers github.com/UltimaPhoenix/homebrew-tap with Homebrew
brew tap UltimaPhoenix/tap
# 2. Trust the whole tap — required when Homebrew enforces HOMEBREW_REQUIRE_TAP_TRUST
brew trust --tap UltimaPhoenix/tap
# 3. Install
brew install devcoach
# 4. Connect (Homebrew puts `devcoach` on your PATH — no `npx -y` prefix needed)
devcoach installbrew tap registers the third-party repository; brew trust --tap marks it trusted so Homebrew will load its formulae when HOMEBREW_REQUIRE_TAP_TRUST is set. Both are one-time. To update later: brew upgrade devcoach. One-liner: brew install UltimaPhoenix/tap/devcoach (run brew trust --tap UltimaPhoenix/tap first if your Homebrew enforces tap trust). The formula declares depends_on "node", so Homebrew pulls in a recent Node automatically.
The simplest way to add devcoach to Claude Code — one click, nothing to configure. It bundles everything (MCP server + automatic-coaching Stop hooks + skill), so don't also run devcoach install (or the Stop hooks get registered twice).
# Add the marketplace once, then install (you can install any UltimaPhoenix plugin from it later)
/plugin marketplace add UltimaPhoenix/claude-plugins-marketplace
/plugin install devcoach@ultimaphoenixThe MCP server, hooks, and skill activate on install — no restart needed. The plugin does not add the devcoach CLI, so run the dashboard or CLI with npx -y devcoach ui (or use Homebrew / npm i -g devcoach for a bare devcoach).
Other ways to install the plugin (straight from the repo · offline zip)
# Straight from the devcoach repo (no separate marketplace)
/plugin marketplace add UltimaPhoenix/dev-coach
/plugin install devcoach@devcoach
# Offline — download devcoach-plugin-<version>.zip from a GitHub Release, unzip, then:
/plugin marketplace add /path/to/unzipped-folder
/plugin install devcoach@devcoachSee Claude Code plugin for how it works.
A single bundle that runs on Claude Desktop's built-in runtime — no Node or terminal needed:
npm run mcpb # → dist-mcpb/devcoach-<version>.mcpb
# Claude Desktop → Settings → Extensions → Install Extension… → pick the .mcpbnpm run mcpb:sign self-signs it (installs as an unverified publisher; a real code-signing cert is needed for a verified signature). Prebuilt .mcpb releases and a Desktop directory listing are planned.
npx / npm CLI (any MCP agent — no install)
No install required — npx runs devcoach on demand. For Claude Code and Claude Desktop, one command registers the MCP server and wires up automatic lesson delivery:
npx -y devcoach installRestart your agent afterward. Prefer a global binary? npm install -g devcoach, then run devcoach install (and drop the npx -y prefix everywhere).
Manual MCP config for Claude Code (if devcoach install isn't available)
Option A — via the claude mcp CLI (recommended):
claude mcp add devcoach npx -- -y devcoach mcp
# all projects (user scope)
claude mcp add --scope user devcoach npx -- -y devcoach mcpOption B — edit ~/.claude.json directly:
{ "mcpServers": { "devcoach": { "type": "stdio", "command": "npx", "args": ["-y", "devcoach", "mcp"] } } }Then add the Stop hooks to ~/.claude/settings.json for automatic lesson delivery:
{
"hooks": {
"Stop": [
{ "hooks": [{ "type": "command", "command": "npx -y devcoach onboard-hook" }] },
{ "hooks": [{ "type": "command", "command": "npx -y devcoach lesson-ready" }] }
]
}
}Tip: a global install puts
devcoachon yourPATH, so you can drop thenpx -yprefix.devcoach installdetects this automatically. Using the Claude Code plugin (above)? Skip the hooks here — the plugin already provides them.
Other MCP agents (Cursor, Windsurf, Cline, Continue, Zed…)
Add this to your agent's MCP config file:
{
"mcpServers": {
"devcoach": {
"command": "npx",
"args": ["-y", "devcoach", "mcp"]
}
}
}| Agent | Config file |
|---|---|
| Cursor | ~/.cursor/mcp.json |
| Windsurf | ~/.codeium/windsurf/mcp_config.json |
| Cline (VS Code) | VS Code Settings → cline.mcpServers |
| Continue.dev | ~/.continue/config.json → mcpServers |
| Zed | .zed/settings.json → context_servers |
Stop hooks (automatic lesson delivery after each task) are Claude Code-specific. Other agents have full access to all MCP tools and resources — coaching can be triggered manually or by prompting your agent.
claude.ai web (skill copy — no MCP)
Claude.ai does not support MCP servers. Install the coaching instructions as a skill instead:
- Copy the content of
assets/SKILL.md - Go to claude.ai → Settings → Custom instructions (or Skills, depending on your plan)
- Paste the content and save
This gives claude.ai the coaching behaviour without the MCP tools (lesson logging and profile tracking will not work).
Keep the skill up to date. For Claude Code / Claude Desktop, the skill is served automatically (via the MCP prompt or the plugin) and is always current. If you copied it manually to claude.ai, re-paste the latest
SKILL.mdafter each devcoach update.
The first time your agent connects to devcoach it detects that your profile isn't set up and walks you through it inline — no separate command needed.
devcoach: Your knowledge profile isn't set up yet.
Do you have an existing devcoach backup to restore?
If yes, provide the file path — otherwise I'll help you build your profile from scratch.
Option A — restore from backup: If you're on a new machine or reinstalling, provide the path to your backup zip and your full profile (knowledge map, lessons, settings) is imported instantly.
Option B — build from scratch: Choose between automatic detection or a guided conversation.
devcoach scans your project files and proposes your stack:
I detected these technologies in your project:
typescript → confidence 6 (keep? or enter 0–10 to adjust)
docker → confidence 7 (keep? or enter 0–10 to adjust)
github_actions → confidence 6 (keep? or enter 0–10 to adjust)
react → confidence 5 (keep? or enter 0–10 to adjust)
Anything I missed? List any tools, languages, or practices you work with regularly.
You confirm, adjust scores, or add topics the scan missed. Then devcoach proposes logical groups:
Here's how I'd organise these:
Languages → typescript, javascript
Frontend → react, html_css
DevOps → docker, github_actions
Databases → postgresql, redis
Does this look right? Any changes?
If you prefer to describe your stack manually, devcoach asks about each technology and your confidence level (1–3 still learning · 4–6 comfortable · 7–9 strong · 10 expert), then saves the profile.
✓ Profile saved — 24 topics across 6 groups.
From now on I'll deliver a short lesson after technical tasks,
calibrated to your current confidence on each topic.
That's it. You go back to work. Coaching happens silently in the background.
You work on a task as normal. After your agent responds, devcoach appends a lesson:
You: Refactor this endpoint to handle concurrent requests properly.
Agent: [refactors the code, explains the changes]
---
🎓 devcoach · TypeScript · Level: Mid
**Promise.allSettled vs Promise.all — don't let one failure sink the batch**
Promise.all rejects the moment any promise rejects, and you lose the results of
the ones that already succeeded. For independent work (fan-out fetches, batch
writes) that's usually the wrong default.
Promise.allSettled always resolves, giving you a status for every promise:
const results = await Promise.allSettled(ids.map(fetchUser));
const ok = results.filter(r => r.status === "fulfilled").map(r => r.value);
Use Promise.all when the tasks are genuinely all-or-nothing; reach for
allSettled when partial success is meaningful and you want to report failures.
💡 Senior tip: for coordinated work that *should* cancel siblings on failure,
an AbortController shared across the requests gives you all-or-nothing with
prompt cancellation — the structured-concurrency middle ground.
Did that land? ✅ know · ❌ don't know · ⏭ skip
Responding adjusts your confidence on that topic and shapes future lessons.
| Knowledge map (personalize here) | Lesson history | Settings |
|---|---|---|
![]() |
![]() |
![]() |
Every lesson stores where it happened — your project folder, repository, branch, commit hash, editor. You can also personalize your coaching with a learning notebook at ~/.devcoach/learning-state.md that shapes which topics devcoach prioritises and how deep the lessons go.
→ How to use context & personalization · Web dashboard guide
Open the dashboard at any time to review your progress, edit your profile, or manage settings:
npx -y devcoach ui # → http://localhost:7860| Page | What you can do |
|---|---|
| Knowledge map | See all topics with confidence bars; adjust scores directly |
| Lessons | Browse and filter your full lesson history; star lessons to revisit |
| Settings | Change rate limits, import/export your profile, take a backup |
Full reference: docs/usage/web-ui.md
The CLI is a secondary interface for querying and managing your coaching data. Everything is also available in the web dashboard. Run devcoach --help or devcoach <command> --help for full usage.
| Command | Description |
|---|---|
devcoach install |
Register with Claude Code / Claude Desktop |
devcoach profile |
Show your knowledge map with confidence bars |
devcoach stats |
Overview: lesson counts, weakest/strongest topics |
devcoach lessons |
Browse lesson history with filters |
devcoach lesson <id> |
Show a single lesson in full |
devcoach star <id> |
Mark a lesson as starred |
devcoach feedback <id> <know|dont_know|clear> |
Record comprehension |
devcoach set max_per_day <n> |
Max lessons per day (default 2) |
devcoach set min_gap_minutes <n> |
Minutes between lessons (default 240) |
devcoach backup [file.zip] |
Export knowledge + lessons + settings |
devcoach restore <file.zip> |
Restore from a backup |
devcoach setup |
Run the onboarding wizard in the terminal |
devcoach ui |
Open the web dashboard |
(Prefix with npx -y if you haven't installed globally.) Full reference: docs/cli.md
By default: up to 2 lessons/day, at least 4 hours apart. Want more coaching? Want less? Change it.
devcoach set max_per_day 5 # more lessons per day
devcoach set min_gap_minutes 60 # lessons closer togetherOr use the web dashboard Settings page. See docs/configuration.md for all options.
Over a typical work week with 1–2 tasks per day, you'll receive 2–4 lessons aligned to your stack and confidence level. Each lesson takes 30 seconds to read. After a month of normal AI-assisted development, you'll have built a coaching notebook specific to your gaps — exact patterns you struggle with, edge cases you tend to miss, the reasoning behind tools you reach for instinctively.
Too intense? Dial back the frequency: devcoach set max_per_day 1. Want more coaching? Crank it up: devcoach set max_per_day 5. Everything is tunable.
The compounding effect: developers who keep learning while tools get stronger stay in control of the result.
"Node version error"
devcoach requires Node.js ≥ 24. Check your version: node --version. If you're below 24, upgrade: brew upgrade node (Homebrew) or nvm install 24 (if using nvm).
"MCP server not connecting"
Run devcoach install to re-register the server with Claude Code or Claude Desktop, then restart the agent. If the issue persists, check ~/.claude.json (Claude Code) and confirm the devcoach entry is present and the command is correct.
"Stop hooks not firing"
Stop hooks (automatic lesson delivery after each task) are Claude Code-specific and require ~/.claude/settings.json to have the two devcoach hook entries (automatic if you ran devcoach install, manual if you did it yourself). Other agents (Cursor, Windsurf, Cline) don't support hooks — coaching is available on demand via MCP tools or manual prompting.
"SQLite permission error"
devcoach writes to ~/.devcoach/coaching.db. If you get a permission error, check the directory exists and you have write access: ls -ld ~/.devcoach. If missing, run devcoach install or devcoach setup to initialize it.
- claude.ai web: MCP servers are not supported. You can use the skill copy (coaching behaviour only, no data storage).
- Ephemeral sandboxes: If your agent runs in a fresh sandbox on each restart (like GitHub Codespaces), devcoach cannot persist data across sessions. It works fine for the current session, but lessons won't carry over.
- Windows: devcoach is tested on macOS and Linux. Windows support depends on Node.js ≥ 24 and
node:sqliteavailability (generally solid, but report issues). - Multi-user machines: devcoach writes to
~/.devcoach/, so each user gets their own coaching database. Profiles are not shared.
npm uninstall -g devcoach # if installed globally (npx: nothing to remove)
brew uninstall devcoach # if installed via Homebrew (brew untap UltimaPhoenix/tap to drop the tap)
claude mcp remove --scope user devcoach # remove from Claude Code (install uses user scope)
rm -rf ~/.devcoach # delete all coaching data (back up first: devcoach backup)For Claude Desktop, delete the devcoach key from the platform config file (paths in Manual setup above). Also remove the two hook entries from ~/.claude/settings.json → hooks.Stop.
Full documentation: The README is a quick start. For detailed guides, visit the official docs:
- Why devcoach exists — the philosophy and market opportunity
- How it works — session startup, coaching loop, lesson selection
- Using the web dashboard — personalise your knowledge map, filter lessons, jump to code context
- CLI reference — all commands for querying and managing data
- Configuration — rate limits, data location, schema
- Privacy & security — local-first architecture, what we collect
- Vision & roadmap — free tier today, courses and team SaaS planned
- Plugin marketplace — UltimaPhoenix plugin collection
- Star the repo — help others discover it
- GitHub Discussions — feature requests, feedback, and ideas
Help welcome! See CONTRIBUTING.md to get started.
git clone https://github.com/UltimaPhoenix/dev-coach && cd dev-coach
npm install
npm run dev -- mcp # run the MCP server from source
npm run dev -- ui # run the web dashboard from source
npm run lint && npm run typecheck && npm test
npm run build # tsup → dist/bin.js
npm run mcpb # build the Claude Desktop .mcpb (npm run mcpb:sign to self-sign)- MCP Inspector:
npx @modelcontextprotocol/inspector node dist/bin.js mcp - Stack:
@modelcontextprotocol/sdk·node:sqlite· Hono · Commander · Zod · Biome · Vitest · tsup
Tag a commit with v*:
git tag v1.2.3 && git push origin v1.2.3CI lints, type-checks, tests (Node 24 & 26), builds, and publishes to npm via OIDC provenance
(npm publish --provenance). First-time setup: configure a Trusted Publisher on npmjs.com for the
devcoach package (GitHub Actions, repo UltimaPhoenix/dev-coach, workflow ci.yml).
Copyright (C) 2026 UltimaPhoenix
devcoach is licensed under the GNU Affero General Public License v3.0 (AGPL-3.0-only).
You may use, modify, and distribute it — provided that any modified version you distribute, or run
as a network service, is also released as open source under the AGPL. A separate commercial
license is available for proprietary/closed use without AGPL's copyleft obligations —
open an issue to enquire.
devcoach is and stays 100% free to download, install, and use — for everyone, forever, including at work and on commercial projects. AGPL is not a price tag: you only ever pay if you want to ship a proprietary/closed derivative of devcoach itself without complying with the AGPL.
Using devcoach does not put your code under the AGPL. It runs as a separate process over
stdio/MCP (npx -y devcoach mcp); talking to it at arm's length is not a derivative work — exactly
like querying an AGPL-licensed database. Your own projects keep whatever license you choose.
- ✅ "I use devcoach inside Claude Code while building my closed-source startup app." — Free. Your app stays proprietary, zero obligations.
- ✅ "My whole team installs devcoach to get coaching on our internal/commercial repos." — Free. Using the unmodified tool at a company is fine.
⚠️ "I fork devcoach, add a feature, and publish the package or host its dashboard as a public service." — You must release your modified devcoach source under the AGPL.- 💼 "I want to embed devcoach in my paid product and keep my changes closed." — You need a commercial license.
Keep using devcoach as a tool/executable (not as an imported library) and the AGPL never reaches your own code.


