Curated Claude Code catalog
Updated 07.05.2026 · 19:39 CET
01 / Skill
isaac-levine

forage

Quality
9.0

Forage is an MCP server that empowers AI agents with self-improving tool discovery. Instead of manual configuration, agents can dynamically search for, evaluate, and install new MCP servers from registries like npm or Smithery. It proxies these new tools, making them instantly available without restarting the agent session. Forage also helps agents learn and persist usage instructions, ensuring newly acquired skills are retained across sessions. This closes the loop on agent limitations, allowing them to adapt and expand their capabilities on demand.

USP

Automates AI agent tool acquisition: agents find, install, and learn new MCP servers on demand, instantly expanding capabilities without restarts. Permanently smarter, session after session.

Use cases

  • 01Dynamically adding a database query tool to an agent's capabilities.
  • 02Enabling an agent to deploy code to cloud platforms like Vercel.
  • 03Allowing an agent to search internal communication tools like Slack.
  • 04Automating the setup of new development tools for AI coding agents.
  • 05Ensuring agents retain learned tool usage instructions across sessions.

Detected files (1)

  • server.jsonmcp_server
    Show content (1600 bytes)
    {
      "$schema": "https://static.modelcontextprotocol.io/schemas/2025-12-11/server.schema.json",
      "name": "io.github.isaac-levine/forage",
      "description": "Self-improving tool discovery for AI agents. Find, install, and use new MCP servers automatically.",
      "repository": {
        "url": "https://github.com/isaac-levine/forage",
        "source": "github"
      },
      "version": "0.1.1",
      "packages": [
        {
          "registryType": "npm",
          "identifier": "forage-mcp",
          "version": "0.1.1",
          "transport": {
            "type": "stdio"
          }
        }
      ],
      "tools": [
        {
          "name": "forage_search",
          "description": "Search for MCP servers and tools across registries. Describe what capability you need and get ranked results."
        },
        {
          "name": "forage_evaluate",
          "description": "Get detailed information about a specific package — version, downloads, README summary, install command."
        },
        {
          "name": "forage_install",
          "description": "Install an MCP server and start it as a proxied subprocess. Tools become available immediately — no restart needed."
        },
        {
          "name": "forage_learn",
          "description": "Write usage instructions to agent rule files (CLAUDE.md, AGENTS.md, .cursor/rules/) for cross-session persistence."
        },
        {
          "name": "forage_status",
          "description": "List all tools that Forage has installed and is currently proxying."
        },
        {
          "name": "forage_uninstall",
          "description": "Remove a previously installed tool. Stops the server, removes from manifest, and cleans up agent rules."
        }
      ]
    }
    

README

🌿 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

ToolDescription
forage_searchSearch for MCP servers across the Official MCP Registry, Smithery, and npm
forage_evaluateGet details on a package — downloads, README, install command
forage_installInstall and start an MCP server as a proxied subprocess (requires user approval)
forage_learnWrite usage instructions to CLAUDE.md / AGENTS.md / .cursor/rules/
forage_statusList all installed and running tools
forage_uninstallRemove 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 persistsforage_learn writes 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:

  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
Persistence

Forage stores its state in ~/.forage/:

FilePurpose
manifest.jsonInstalled tools, command/args, auto-start configuration
install-log.jsonAudit 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. 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.

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