MCP server for CodeMenu snippet manager.
This is a Model Context Protocol (MCP) server that provides integration with the CodeMenu local HTTP API, allowing AI assistants to access and search through code snippets stored in CodeMenu.
The server exposes the following tools for interacting with CodeMenu:
- list_snippets - List snippets without full code content (to reduce token usage). Returns id, title, description, language, abbreviation, tags, and group info. Supports filtering by query, language, tag, or group.
- get_snippet - Retrieve the full details of a specific snippet by ID, including complete code content
- list_tags - List all available tags in CodeMenu
- list_groups - List all available groups in CodeMenu
- CodeMenu must be running on your Mac (Learn more)
- API must be enabled in CodeMenu settings (CodeMenu → Settings → API)
- Node.js >= 18.0.0
- Open CodeMenu
- Go to Settings → API
- Enable the API server
- Note the port (default: 1300)
- Optionally, set an API key for authentication
The CodeMenu API runs locally at http://127.0.0.1:1300/v1 by default.
npm install -g git+https://github.com/Extiri/codemenu-mcp.gitgit clone https://github.com/Extiri/codemenu-mcp.git
cd codemenu-mcp
npm install
npm linkThe server connects to the local CodeMenu API and supports the following environment variables:
CODEMENU_API_URL- The base URL for the CodeMenu API (default:http://127.0.0.1:1300/v1)CODEMENU_API_KEY- Your CodeMenu API key
Add this to your Claude Desktop configuration file:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%/Claude/claude_desktop_config.json
{
"mcpServers": {
"codemenu": {
"command": "node",
"args": ["/path/to/codemenu-mcp/index.js"],
"env": {
"CODEMENU_API_URL": "http://127.0.0.1:1300/v1",
"CODEMENU_API_KEY": "your-api-key"
}
}
}
}Or if installed globally via npm:
{
"mcpServers": {
"codemenu": {
"command": "codemenu-mcp",
"env": {
"CODEMENU_API_KEY": "your-api-key"
}
}
}
}Note: If you didn't enable API key protection in CodeMenu settings, you can omit the CODEMENU_API_KEY environment variable.
Once configured, the server will be automatically started by your MCP client (e.g., Claude Desktop). The AI assistant will have access to your CodeMenu snippets and can:
- Browse and search through your code snippets
- Find snippets by language, tags, or groups
- Retrieve specific snippets with full code content when needed
- List available tags and groups for better organization
Searching snippets:
"Search my CodeMenu snippets for sorting algorithms"
Listing snippets by language:
"Show me all my JavaScript snippets from CodeMenu"
Getting a specific snippet:
"Show me the full code for snippet ID ABC123"
Listing tags:
"What tags do I have in CodeMenu?"
npm startThe server communicates over stdio, which is the standard transport for MCP servers.
npm testThis validates that the server correctly implements the MCP protocol. To test actual API calls, make sure CodeMenu is running with the API enabled.
index.js- Main server implementationpackage.json- Project metadata and dependenciestest.js- MCP protocol test suiteREADME.md- This fileLICENSE- MIT license.gitignore- Files to exclude from git
The server implements the Model Context Protocol and exposes tools that correspond to CodeMenu API endpoints:
GET /snippets- List snippets with optional filters (query, language, tag, group)GET /tags- List all tagsGET /groups- List all groups
For detailed information about the CodeMenu API, refer to the CodeMenu API documentation.
- Node.js >= 18.0.0
- CodeMenu application with API enabled
- MCP client (e.g., Claude Desktop)
MIT
Contributions are welcome! Please feel free to submit a Pull Request.
For issues related to:
- This MCP server: Open an issue on GitHub
- CodeMenu application or API: Refer to the CodeMenu documentation
- MCP specification: See the Model Context Protocol documentation
Server can't connect to CodeMenu:
- Ensure CodeMenu application is running
- Check that API is enabled in CodeMenu settings
- Verify the port matches your configuration (default: 1300)
- If you enabled API key protection, ensure
CODEMENU_API_KEYis set correctly
No snippets returned:
- Verify you have snippets in CodeMenu
- Check that your search filters aren't too restrictive
- Try listing without filters first
Authentication errors:
- Check if the
CODEMENU_API_KEYenvironment variable is set properly