Six tools. One install.
A single installable toolkit that brings six WhenLabs developer tools into your Claude Code / AI coding agent workflow. Once installed, all tools are available as MCP tools in every session — Claude uses them automatically when relevant.
Five tools (stale, envalid, berth, aware, vow) have CLI scan modes and run on a schedule. Velocity is the sixth tool — it is always-on and embedded (SQLite-backed), so it does not have a CLI scan mode and does not appear in doctor/watch/init/ci output.
npx @whenlabs/when installThis is a one-time setup. After install, all six tools are available in every project you open with Claude Code.
Running npx @whenlabs/when install will:
- Register a single MCP server (
whenlabs) in your Claude Code configuration — all six tools, including velocity, are served from one server - Inject CLAUDE.md instructions so Claude knows when to use each tool automatically — and prefers them over shell commands
- Clean up any legacy
velocity-mcpregistrations (velocity is now bundled)
Once connected, Claude can call any tool directly without you asking. For example, after a refactor Claude might run stale_scan to check for doc drift, or before a release it might run vow_check to validate licenses.
Tools run automatically in the background on a schedule and report findings in the Claude Code status line:
| Tool | Interval | Status line |
|---|---|---|
| berth | 15 min | ports:N — port conflicts found |
| stale | 30 min | stale:N — docs drifted from code |
| envalid | 30 min | env:N — .env validation issues |
| vow | 60 min | lic:N? — unknown licenses found |
| aware | 60 min | aware:stale — AI context files outdated |
Only problems are shown — if everything is clean, the status line stays uncluttered. When Claude sees an issue in the status line, it proactively tells you and offers to fix it.
These tools are available to Claude in every session after install:
| MCP Tool | What it does |
|---|---|
velocity_start_task |
Start timing a coding task |
velocity_end_task |
End timing and record results |
velocity_estimate |
Estimate time for a planned task |
velocity_stats |
Show aggregate performance stats with insights |
velocity_history |
Show task history |
stale_scan |
Detect documentation drift |
stale_fix |
Auto-fix documentation drift (wrong paths, dead links, phantom env vars) |
stale_auto_fix |
Scan + auto-fix drift in one call |
envalid_validate |
Validate .env files against schemas |
envalid_detect |
Find undocumented env vars in codebase |
envalid_generate_schema |
Generate .env.schema from code analysis |
envalid_auto_fix |
Detect undocumented vars + auto-generate schema entries |
berth_status |
Show active ports and conflicts |
berth_check |
Scan project for port conflicts |
berth_resolve |
Auto-resolve port conflicts (kill or reassign) |
berth_auto_resolve |
Check + auto-resolve conflicts in one call |
aware_init |
Auto-detect stack, generate AI context files |
aware_doctor |
Diagnose project health and config issues |
aware_auto_sync |
Diagnose + auto-sync stale AI context files |
vow_scan |
Scan and summarize dependency licenses |
vow_check |
Validate licenses against policy |
vow_hook_install |
Install pre-commit license check hook |
This table shows a highlights subset. Run
when <tool> --helpfor all available commands per tool.
Tools automatically suggest follow-up actions when they detect issues relevant to other tools. For example, aware_init triggers a stale_scan when it generates new files, and envalid_detect suggests berth_register when it finds service URL env vars. These cascading suggestions surface as "Tip:" lines in tool output.
Install MCP servers into other editors alongside Claude Code:
npx @whenlabs/when install --cursor # Cursor
npx @whenlabs/when install --vscode # VS Code
npx @whenlabs/when install --windsurf # Windsurf
npx @whenlabs/when install --all # All supported editorsWithout flags, install targets Claude Code only.
You can also run tools directly from the command line:
when init # Onboard a project — bootstrap configs, run all tools, auto-fix
when config # Show unified .whenlabs.yml config
when config init # Generate .whenlabs.yml from existing tool configs
when config validate # Validate config structure
when stale scan
when stale fix # Auto-fix documentation drift
when envalid validate
when envalid detect --generate # Generate schema from code
when berth status
when berth resolve # Auto-resolve port conflicts
when aware init
when vow scan
when vow hook install # Install pre-commit license hook
when status # Show installation status
when doctor # Run all tools, show unified health report
when doctor --watch # Continuous monitoring dashboard
when watch # Background daemon for status line
when ci # Run checks for CI (exits 1 on issues)One command to fully onboard any project:
- Bootstrap — creates
.env.schema,.vow.json,.stale.yml, and registers berth ports based on your project - Scan — runs all 5 CLI tools in parallel
- Auto-fix — automatically fixes stale drift if detected
- Config — generates a unified
.whenlabs.ymlfrom the bootstrapped configs
Manage the unified .whenlabs.yml project config. All six tools read their settings from this single file instead of separate config files. Subcommands: init (generate from existing configs), validate (check structure).
Runs all 5 CLI tools against the current project and displays a unified health report card. Supports --json for machine-readable output and --watch for continuous monitoring with a live dashboard.
Background daemon that runs all 5 CLI tools on intervals and writes results to ~/.whenlabs/status.json. Powers the Claude Code status line integration. Use --once for a single scan or --interval <seconds> to customize the schedule.
Runs stale, envalid, and vow checks — exits 1 if any tool finds issues. Designed for CI pipelines:
when ci --ci # GitHub Actions annotations (::error file=X::message)
when ci --json # Machine-readable JSON output- uses: WhenLabs-org/when@main
with:
checks: stale,envalid,vownpx @whenlabs/when uninstallRemoves the MCP server and cleans up CLAUDE.md instructions.
MIT — see LICENSE