Connects Claude and other MCP-compatible editors to Neo's remote AI/ML execution backend. You describe a training job or data pipeline in plain language, Neo runs it on its infrastructure, then a local daemon writes all outputs directly to your workspace. The MCP layer exposes tools for submitting tasks, polling status, retrieving logs, sending feedback when Neo asks clarifying questions, and pausing or stopping long-running jobs. Also includes integration management for storing third-party credentials like GitHub, HuggingFace, and AWS tokens locally so Neo tasks can authenticate without re-prompting. Install via pip or npm, drop your API key in the editor config, and offload compute-heavy workflows without leaving your coding environment.
neo-mcp is the Model Context Protocol server that plugs Neo into Claude Code, Cursor, Codex, and the editors you already use. Neo is an autonomous AI engineer: describe any AI/ML task in plain English and it plans, builds, runs, and evaluates the full workflow.
Everything lands in your repo on your machine (code, models, metrics, reports). Nothing is stored remotely.
Neo is built for AI engineering, not general code chat, so it goes deeper on ML, LLM, and data workflows than a typical coding agent.
🌐 Neo · 📚 Docs · 🔑 Get an API key: Neo dashboard
Click to watch the full demo with sound.
Built for data scientists, ML engineers, analysts, researchers, and PMs who want results, not boilerplate.
Ask your agent to use Neo. For example:
Use Neo to fix the failing training run and re-run with logging
Benchmark these prompts on our eval set using Neo
Build or debug an end-to-end ML pipeline using Neo
Train a fraud detection model on fraud.csv, optimize for recall
Fine-tune a text classifier on my training data with 5-fold cross-validation
Neo runs the ML work. Your editor handles everything else.
pip install neo-mcp
Requires Python 3.11+.
Tip: use
pipx install neo-mcpto install in an isolated environment and avoid conflicts with your project's virtualenv.
Replace sk-v1-YOUR_KEY with your actual API key.
After setup, ask your agent: "What Neo tools do you have available?" You should see neo_submit_task, neo_task_status, neo_get_messages, and the rest.
claude mcp add --scope user neo \
-e NEO_SECRET_KEY=sk-v1-YOUR_KEY \
-- neo-mcp
Open a new Claude Code session after running this. Neo tools load at session start, not mid-session.
Scope options:
--scope user(global, recommended) ·--scope project(writes.mcp.jsonin current repo) ·--scope local(this machine only)
Verify it registered:
claude mcp list
You should see neo with a green checkmark.
Open the config:
Ctrl+Shift+J (Windows/Linux) or Cmd+Shift+J (Mac) → Tools & MCP → New MCP Server~/.cursor/mcp.json{
"mcpServers": {
"neo": {
"command": "neo-mcp",
"env": { "NEO_SECRET_KEY": "sk-v1-YOUR_KEY" }
}
}
}
Restart Cursor after editing the file directly. Changes via the GUI apply immediately.
Open the config:
codex mcp to manage servers interactively via CLI~/.codex/config.json{
"mcpServers": {
"neo": {
"command": "neo-mcp",
"env": { "NEO_SECRET_KEY": "sk-v1-YOUR_KEY" }
}
}
}
Windsurf (~/.codeium/windsurf/mcp_config.json):
{
"mcpServers": {
"neo": {
"command": "neo-mcp",
"env": { "NEO_SECRET_KEY": "sk-v1-YOUR_KEY" }
}
}
}
VS Code (GitHub Copilot) (.vscode/mcp.json in your workspace root; requires VS Code 1.99+ and Agent mode):
{
"servers": {
"neo": {
"type": "stdio",
"command": "neo-mcp",
"env": { "NEO_SECRET_KEY": "sk-v1-YOUR_KEY" }
}
}
}
Zed (~/.config/zed/settings.json):
{
"context_servers": {
"neo": {
"source": "custom",
"command": {
"path": "neo-mcp",
"args": [],
"env": { "NEO_SECRET_KEY": "sk-v1-YOUR_KEY" }
}
}
}
}
Continue.dev (~/.continue/config.yaml):
mcpServers:
- name: neo
command: neo-mcp
env:
NEO_SECRET_KEY: sk-v1-YOUR_KEY
More GUI paths and per-editor notes: docs/GUIDE.md
Your editor ──MCP──▶ neo-mcp server ──API──▶ Neo backend
│ │
└──────────────────▶ Local daemon
(writes files,
runs scripts)
neo_submit_task via MCPFiles are always written to your machine, never stored remotely.
Neo can also store third-party API keys locally (GitHub, HuggingFace, Anthropic, OpenRouter, OpenAI, AWS S3, Weights & Biases, Kaggle) so tasks can use them without asking every time. Keys stay on your machine and are never sent to Neo's backend. Full guide: docs/INTEGRATIONS.md.
| Tool | Description |
|---|---|
neo_submit_task | Submit an AI/ML task. Returns thread_id immediately. |
neo_list_tasks | List running and recent tasks. Reconnects pollers automatically. |
neo_task_status | Check status: RUNNING / COMPLETED / WAITING_FOR_FEEDBACK / PAUSED / TERMINATED. |
neo_get_messages | Read full task output when COMPLETED. Capped at ~20 000 tokens. |
neo_send_feedback | Reply when Neo asks a question (WAITING_FOR_FEEDBACK). |
neo_pause_task | Pause a running task. |
neo_resume_task | Resume a paused task. |
neo_stop_task | Stop and clean up a task permanently. |
neo_list_integrations | List stored third-party API keys (names only, never the value). |
neo_add_integration | Register a GitHub PAT, HuggingFace token, Anthropic key, or OpenRouter key for Neo tasks. |
neo_test_integration | Call the provider's API to confirm a stored key is still valid. |
neo_remove_integration | Delete a stored key from this machine. |
Integration tools store credentials locally (file mode
0o600under~/.neo/integrations/, or native tool files like~/.aws/credentials,~/.netrc,~/.kaggle/kaggle.json), or your OS keyring ifNEO_INTEGRATIONS_BACKEND=keyring. Keys never leave your machine. Full guide: docs/INTEGRATIONS.md.
Standard (tasks over a few minutes):
neo_submit_task → returns thread_id
↓
neo_task_status → poll until COMPLETED or WAITING_FOR_FEEDBACK
↓
neo_get_messages → read full output
Quick task: Pass wait_for_completion: true to neo_submit_task. It blocks until done and returns output directly. No polling needed.
Mid-task question: When status is WAITING_FOR_FEEDBACK, call neo_send_feedback with your reply. Neo resumes automatically.
Reconnecting after closing your editor:
neo_list_tasks → all tasks with live status + thread IDs
neo_task_status → check the specific task you care about
neo_get_messages → read output of any COMPLETED task
| Variable | Required | Description |
|---|---|---|
NEO_SECRET_KEY | Yes | API key (sk-v1-...) from heyneo.com/dashboard → Settings → API Keys |
NEO_DEPLOYMENT_ID | No | Pin a specific daemon UUID (auto-generated by default) |
NEO_WORKSPACE_DIR | No | Override workspace directory (useful in Docker or CI) |
NEO_READ_ONLY | No | true = expose only status/message tools; disables submit, stop, and pause |
neo-mcp status # daemon and key status
neo-mcp doctor # full health check; identifies common issues
neo-mcp list # list known threads
neo-mcp logs --source neo-mcp --lines 100 # MCP server logs
neo-mcp logs --source daemon --lines 100 # daemon logs
# JSON output
neo-mcp status --json
neo-mcp doctor --json
Claude Code logs:
claude mcp logs neo
| Symptom | Fix |
|---|---|
neo-mcp: command not found | Re-run pip install neo-mcp, verify with which neo-mcp |
✗ Failed to connect in claude mcp list | Run claude mcp logs neo. Most common cause: NEO_SECRET_KEY not set |
| Neo tools don't appear | Open a new session. Tools load at session start, not mid-session |
Invalid API key (401) | Re-check your key at heyneo.com/dashboard → Settings → API Keys |
Trial or quota ended (403) | Top up at the Neo dashboard |
No healthy deployments available (400) | Daemon failed to auto-start. Restart the MCP server and try again |
| Task submitted but no files written | Daemon stopped mid-task. Check neo-mcp status and restart |
Status stuck on RUNNING | Run neo-mcp doctor to diagnose; restart the MCP server |
| Output truncated | ~20 000 token cap. Use neo_task_status for progress, neo_get_messages for final output only |
Full setup guide (all editors, GUI paths): docs/GUIDE.md · Docs
NEO_SECRET_KEY*secretYour Neo API secret key (starts with sk-v1-). Get one at https://heyneo.com.
NEO_ENVIRONMENTdefault: productionNeo backend environment: 'production' (default) or 'staging'.
NEO_WORKSPACE_DIRProject root where Neo tasks read and write files. Must be the git/project root.