Skip to main content
Glama
isaac-levine

Forage MCP Server

by isaac-levine

๐ŸŒฟ Forage

Self-improving tool discovery for AI agents.

Install one MCP server. Your agent finds the rest.

npm version npm downloads License: MIT

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.

Why?

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

Quick Start

Claude Code

claude mcp add forage -- npx -y forage-mcp

Cursor

npx forage-mcp init --client cursor

That's it. Start a new session and Forage is ready.

Tools

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

How It Works

Forage is a gateway/proxy MCP server:

  1. You install Forage once โ€” it's the only MCP server you configure manually

  2. Forage discovers tools โ€” searches the Official MCP Registry, Smithery, and npm in parallel

  3. Forage installs tools โ€” starts them as child processes, wraps their capabilities

  4. No restart needed โ€” emits list_changed notifications so the agent picks up new tools instantly

  5. Knowledge persists โ€” forage_learn writes to agent rule files, manifest auto-starts tools next session

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  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:

  1. Forage runs npx -y <package> as a child process

  2. Connects to it via StdioClientTransport (MCP client)

  3. Discovers the child server's tools via listTools

  4. Re-registers each tool on the Forage server with a namespaced name (foraged__<server>__<tool>)

  5. Sends tools/list_changed notification โ€” the agent sees new tools immediately

  6. When the agent calls a proxied tool, Forage forwards the call to the child server

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.

CLI

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 Cursor

Security

IMPORTANT

Forage cannot install tools without explicit user approval. Everyforage_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.

Development

git clone https://github.com/isaac-levine/forage.git
cd forage
npm install
npm run build

Test locally with Claude Code:

claude mcp add forage-dev -- node /path/to/forage/dist/server.js

See CONTRIBUTING.md for more details.

Roadmap

Features

  • 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 .env files

  • forage doctor โ€” diagnose common setup issues

Distribution

Community

  • 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

License

MIT

A
license - permissive license
-
quality - not tested
B
maintenance

Maintenance

โ€“Maintainers
โ€“Response time
โ€“Release cycle
1Releases (12mo)

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/isaac-levine/forage'

If you have feedback or need assistance with the MCP directory API, please join our Discord server