Capacities MCP Bridge (Unofficial)
Enables interaction with the Capacities.io note-taking API via MCP, supporting operations like searching content, saving weblinks, and appending to daily notes.
README
<div style="text-align:center">

Unofficial Capacities.io MCP Tools
</div>
Disclaimer
This project provides several methods for connecting to the Capacities note taking app API using the Model Context Protocol (MCP). It was 100% vibe-coded with the help of Gemini 2.5 Pro. While it works, it relies on third-party adapter services and, in some cases, your own hosting. Use at your own risk.
For everyone looking for a native Bun implementation, there exists another project https://github.com/jem-computer/capacities-mcp
Table of Contents
- Setup for Claude Desktop (with Node.js Bridge)
- Use this if you need to connect Claude Desktop and it requires simple tool names.
- Setup for Simple SSE Clients (CLion, VS Code)
- Use this for a direct connection from a compatible IDE plugin.
- Advanced Setup for Genspark (Self-Hosted Server)
- The most reliable and robust method. Use this for Genspark or any other client if you have your own server/VPS.
General Prerequisites
- A Capacities API Token. You can generate this from your Capacities account settings if you have a paid account.
- The MCP Link Generator tool: https://mcp-link.vercel.app/
Setup 1: Claude Desktop (with Node.js Bridge)
This method uses the included capacities-claude-bridge.js script to act as a translator between Claude Desktop (which needs simple tool names) and the MCP adapter (which creates complex names).
Step 1.1: Install Node.js and Download Files
-
Install Node.js: Go to the official Node.js website and download and install the LTS version for your operating system.
-
Download the Bridge Code: Open a terminal (like Git Bash, Command Prompt, or PowerShell) and run the following commands:
# Clone the repository to a permanent location git clone https://github.com/natkitten/capacities-mcp-bridge-unofficial.git # Navigate into the project folder cd capacities-mcp-bridge-unofficial -
Install Dependencies: While inside the
capacities-mcp-bridge-unofficialfolder, run:npm install
Step 1.2: Generate the Server URL for the Bridge
- Go to mcp-link.vercel.app.
- Fill in the form:
- OpenAPI Specification URL:
Use this specific URL for the Claude bridge setup. It uses snake_case
operationIds.https://gist.githubusercontent.com/natkitten/e6ce1335c2cdad87a9237156c5cda315/raw/capacities_openapi_2.json - API Base URL:
https://api.capacities.io - HTTP Headers: Enter your Authorization header:
Authorization: Bearer YOUR_CAPACITIES_API_TOKEN - Path Filters: Leave this field completely empty.
- Encoding Options: Select "Base64 (JSON Encoded)".
- OpenAPI Specification URL:
Use this specific URL for the Claude bridge setup. It uses snake_case
- Click "Generate MCP Link" and copy the resulting URL.
Step 1.3: Configure the Bridge Script
- Open the
capacities-claude-bridge.jsfile (located in the folder you just downloaded) in a text editor. - Paste the URL you just copied, replacing the placeholder text for the
SSE_URLconstant.const SSE_URL = 'https://mcp-openapi-to-mcp-adapter.onrender.com/sse?code=...'; // YOUR URL HERE - Save the file.
Step 1.4: Configure Claude Desktop (Windows)
- Open File Explorer and navigate to your Claude Desktop config file by pasting this path into the address bar:
%APPDATA%\Claude Desktop\claude_desktop_config.json - Open the file and add the
mcp_bridgessection as shown below.CRUCIAL: Replace{ "mcpServers": { "capacities": { "command": "node", "args": ["C:\\path\\to\\your\\capacities-mcp-bridge-unofficial\\capacities-claude-bridge.js"] } } }C:\\path\\to\\your\\capacities-mcp-bridge-unofficialwith the actual, absolute path to the folder where you cloned the repository. Remember to use double backslashes\\. - Save the
claude_desktop_config.jsonfile and restart Claude Desktop.
Capacities API at a glance
| Endpoint | What it does | Typical use-case |
|---|---|---|
GET /spaces |
Lists all Capacities spaces the token can access | Show a picker or verify the token |
GET /space-info |
Returns structures, collections & property definitions of a space | Needed once at startup to map IDs to human labels |
GET /search |
Full-text or title search across one or many spaces | Let the LLM find existing notes before it creates new ones |
POST /save-weblink |
Saves an external URL (and optional tags/markdown) into a space | Quick bookmarking from chat |
POST /save-to-daily-note |
Appends Markdown to today’s daily note in a space | Fast journaling / meeting-note dump |
Current rate-limits (per user / 60 s window):
/spaces&/space-info: 5 requests/search: 120 requests/save-weblink: 10 requests/save-to-daily-note: 5 requests
For everything else (errors, structures, OpenAPI spec), see the official docs ➜ https://api.capacities.io/docs/.
https://github.com/user-attachments/assets/257aada5-5f65-4aec-b7da-4766452e3cb5
Setup 2: Simple SSE for IDEs (Cline/RooCode in VS Code)
This method is for MCP plugins that can handle the mcplink_... tool names directly. No bridge script is needed.
- Follow Step 1.2 above to generate your unique Server URL from
mcp-link.vercel.app, using thecapacities_openapi_2.jsonand leaving "Path Filters" empty. - Find the MCP configuration file for your IDE. It's often located at
YOUR_HOME_DIRECTORY/.mcp/servers.json. - Add the following entry, replacing the placeholder with your generated URL:
{ "servers": { "capacities": { "url": "PASTE_YOUR_GENERATED_URL_HERE" } } } - Restart your IDE. The tools should appear with their full
mcplink_...names.
Setup 3: Advanced Self-Hosted Server for Genspark
This is the most reliable method. It runs the MCP server on your own VPS. This setup requires a slightly different OpenAPI spec to work around a parser bug in the self-hosted server package.
Step 3.1: VPS and Node.js Setup
- Connect to your VPS via SSH (
ssh root@YOUR_VPS_IP). - Install
nvm(Node Version Manager):curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash - Activate
nvm:export NVM_DIR="$HOME/.nvm" [ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" - Add
nvmto your shell profile so it loads automatically on every login:echo 'export NVM_DIR="$HOME/.nvm"' >> ~/.bashrc echo '[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh"' >> ~/.bashrc - Install Node.js (LTS version):
nvm install --lts
Step 3.2: Create and Configure the Server
- Create a project directory on your VPS and navigate into it:
mkdir capacities-mcp-server cd capacities-mcp-server - Initialize a Node.js project: This creates the
package.jsonfile.npm init -y - Set the project type to "module": Open the
package.jsonwithnano package.jsonand add"type": "module",after the"main": "index.js",line. - Install
pm2and the server package locally: We install them here to keep the project self-contained.npm install pm2 @ivotoby/openapi-mcp-server
Step 3.3: Create the Server Configuration
-
Create an
ecosystem.config.cjsfile forpm2. The.cjsextension is important.nano ecosystem.config.cjs -
Paste the following configuration into the file. This uses the locally installed
pm2and server script.module.exports = { apps : [{ name : 'capacities-mcp', script : './node_modules/@ivotoby/openapi-mcp-server/dist/cli.js', args : [ '--openapi-spec', 'https://gist.githubusercontent.com/natkitten/37e88b5dab4195b0f4d650f31f5505bf/raw/capacities_openapi_3.json', '--api-base-url', 'https://api.capacities.io', '--headers', 'Authorization:Bearer YOUR_CAPACITIES_API_TOKEN', '--toolNameFormat', '**', '--transport', 'http', '--host', '0.0.0.0', '--port', '8448' // Or your preferred port ] }] }Replace
YOUR_CAPACITIES_API_TOKENwith your actual token. -
Save and exit (
CTRL + X,Y,Enter).
Step 3.4: Run the Server
- Start the server using the local
pm2:./node_modules/pm2/bin/pm2 start ecosystem.config.cjs - Check logs to confirm it's listening on your port:
pm2 logs capacities-mcp - Save the configuration for reboots:
pm2 save - Enable
pm2on startup: Runpm2 startupand follow the on-screen instructions.
Step 3.5: Configure Firewall, Caddy, and Genspark
- Firewall: Open your chosen port (
8448in this example) on both your VPS firewall (sudo ufw allow 8448) and your cloud provider's firewall (in the Hostinger dashboard). - Caddy: For a secure HTTPS URL, set up a reverse proxy in your
Caddyfile.
Reload Caddy to apply the changes (mcp.yourdomain.com { reverse_proxy localhost:8448 }sudo systemctl reload caddy). - Genspark:
- Server Type:
StreamableHttp - Server URL:
https://mcp.yourdomain.com/mcp(using the/mcppath). - Request Header:
{"Content-Type": "application/json"}
- Server Type:
- Add the server and test it.
Licensed under the MIT License — see LICENSE for details
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.