Self-improving tool discovery for AI agents.
Install one MCP server. Your agent finds the rest.
npm Β· GitHub Β· Contributing
Forage is an MCP server that lets AI agents discover, install, and learn to use new tools β automatically. When an agent hits a wall, it forages for the right tool, installs it, and teaches itself how to use it. No restarts. No manual config. The agent gets permanently smarter.
AI coding agents are limited to whatever tools they're configured with at session start. Need to query a database? Deploy to Vercel? Search Slack? The agent apologizes and you manually install the right MCP server.
Forage closes that loop:
Agent encounters a task it can't do
β forage_search("query postgres database")
β forage_install("@modelcontextprotocol/server-postgres")
β Tools available IMMEDIATELY (no restart)
β forage_learn() saves instructions to CLAUDE.md
β Next session: auto-starts, agent already knows how to use it
Claude Code
claude mcp add forage -- npx -y forage-mcpCursor
npx forage-mcp init --client cursorThat's it. Start a new session and Forage is ready.
| Tool | Description |
|---|---|
forage_search |
Search for MCP servers across the Official MCP Registry, Smithery, and npm |
forage_evaluate |
Get details on a package β downloads, README, install command |
forage_install |
Install and start an MCP server as a proxied subprocess (requires user approval) |
forage_learn |
Write usage instructions to CLAUDE.md / AGENTS.md / .cursor/rules/ |
forage_status |
List all installed and running tools |
forage_uninstall |
Remove a tool and clean up rules |
Forage is a gateway/proxy MCP server:
- You install Forage once β it's the only MCP server you configure manually
- Forage discovers tools β searches the Official MCP Registry, Smithery, and npm in parallel
- Forage installs tools β starts them as child processes, wraps their capabilities
- No restart needed β emits
list_changednotifications so the agent picks up new tools instantly - Knowledge persists β
forage_learnwrites to agent rule files, manifest auto-starts tools next session
Architecture
βββββββββββββββββββββββββββββββββββββββββββββββ
β Claude Code / Cursor / Codex β
β β
β "I need to query a Postgres database" β
ββββββββββββββββββββ¬βββββββββββββββββββββββββββ
β MCP
βΌ
βββββββββββββββββββββββββββββββββββββββββββββββ
β Forage MCP Server β
β β
β forage_search βββ Official Registry β
β forage_install Smithery β
β forage_learn npm β
β forage_status β
β β
β βββββββββββββββ βββββββββββββββ β
β β Postgres MCPβ β GitHub MCP β ... β
β β (subprocess)β β (subprocess)β β
β βββββββββββββββ βββββββββββββββ β
βββββββββββββββββββββββββββββββββββββββββββββββ
When you install a tool through Forage:
- Forage runs
npx -y <package>as a child process - Connects to it via
StdioClientTransport(MCP client) - Discovers the child server's tools via
listTools - Re-registers each tool on the Forage server with a namespaced name (
foraged__<server>__<tool>) - Sends
tools/list_changednotification β the agent sees new tools immediately - When the agent calls a proxied tool, Forage forwards the call to the child server
Persistence
Forage stores its state in ~/.forage/:
| File | Purpose |
|---|---|
manifest.json |
Installed tools, command/args, auto-start configuration |
install-log.json |
Audit trail of all installs and uninstalls |
cache/ |
Cached registry search results |
On startup, Forage reads the manifest and auto-starts all previously installed servers. Your agent picks up right where it left off.
Forage also includes a CLI for humans:
forage search "postgres database" # Search registries
forage list # List installed tools
forage init # Set up for Claude Code
forage init --client cursor # Set up for CursorImportant
Forage cannot install tools without explicit user approval. Every forage_install call requires confirm: true.
- Audit trail β every install/uninstall is logged with timestamps to
~/.forage/install-log.json - No remote backend β everything runs locally. Registry searches are read-only GET requests to public APIs.
- No secrets stored β environment variables for child servers are passed at install time, not persisted.
git clone https://github.com/isaac-levine/forage.git
cd forage
npm install
npm run buildTest locally with Claude Code:
claude mcp add forage-dev -- node /path/to/forage/dist/server.jsSee CONTRIBUTING.md for more details.
-
forage updateβ check for newer versions of installed tools - Support for pip/cargo/brew packages (not just npm)
- Smarter search ranking (weight by downloads, stars, description relevance)
- Auto-configure environment variables from
.envfiles -
forage doctorβ diagnose common setup issues
- Publish to npm
- Submit to the Official MCP Registry
- Submit to Smithery
- Submit to mcp.so and glama.ai
- Landing page at forage.dev
- Demo GIF / video in README
- Write launch blog post
- Post to r/ClaudeAI, r/LocalLLaMA, Hacker News (Show HN)
- Share in MCP Discord / community channels
- Write use-case guides (e.g. "Add Postgres to Claude Code in 30 seconds")
- Add GitHub Discussions for Q&A and feature requests