affinity-mcp-bridge
v0.2.0
Published
A standalone MCP stdio bridge for Affinity by Canva's local MCP SSE server.
Maintainers
Readme
Affinity MCP Bridge
Use Affinity by Canva from any MCP-compatible assistant.
Affinity MCP Bridge is a small local bridge that lets clients like Claude Desktop, Codex, Cursor, or other MCP hosts connect to Affinity's built-in local MCP server without depending on Claude's private extension folder.
Instead of configuring a path like this:
C:\Users\<you>\AppData\Roaming\Claude\Claude Extensions\...you can install this bridge once and point your MCP client to it.
What You Can Do
When Affinity is open and its MCP server is enabled, your assistant can use Affinity tools through this bridge. Depending on the tools exposed by your Affinity version, this can include:
- Checking whether Affinity is reachable.
- Reading Affinity SDK documentation.
- Running scripts inside the current Affinity document.
- Rendering spreads or selections for visual verification.
- Working with Affinity's script library.
This bridge does not replace Affinity. It only connects your MCP client to the Affinity app running on your computer.
Requirements
- Node.js 20 or newer.
- Affinity by Canva 3.2 or newer.
- Affinity running on the same computer.
- Affinity MCP enabled in Settings > Model Context Protocol > Enable MCP server.
After enabling the MCP server, restart Affinity.
By default, Affinity MCP Bridge connects to:
http://localhost:6767/sseMost users do not need to change this.
Quick Start
- Open Affinity.
- Enable Settings > Model Context Protocol > Enable MCP server.
- Restart Affinity.
- Configure your MCP client with one of the examples below.
- Ask your assistant to run the
affinity_statustool.
If affinity_status reports that Affinity is reachable, the bridge is working.
Install From npm
If the package is available on npm, the easiest setup is to run it with npx from your MCP client:
npx -y affinity-mcp-bridgeYou can also install it globally:
npm install -g affinity-mcp-bridgeThen use:
affinity-mcp-bridgeInstall From GitHub
If you want to use the GitHub version directly:
git clone https://github.com/andre-carbajal/affinity-mcp-bridge.git
cd affinity-mcp-bridge
npm install
npm run buildThen configure your MCP client to run:
node /absolute/path/to/affinity-mcp-bridge/dist/index.jsOn Windows, use the full path to node.exe if your MCP client does not find node automatically.
Claude Desktop
For npm or npx usage:
{
"mcpServers": {
"affinity": {
"command": "npx",
"args": ["-y", "affinity-mcp-bridge"]
}
}
}For a local GitHub clone:
{
"mcpServers": {
"affinity": {
"command": "node",
"args": ["/absolute/path/to/affinity-mcp-bridge/dist/index.js"]
}
}
}Windows example:
{
"mcpServers": {
"affinity": {
"command": "C:/Program Files/nodejs/node.exe",
"args": ["C:/Users/you/path/to/affinity-mcp-bridge/dist/index.js"]
}
}
}Codex
Add this to your Codex config.toml.
For npm or npx usage:
[mcp_servers.affinity]
command = "npx"
args = ["-y", "affinity-mcp-bridge"]
startup_timeout_sec = 30For a local GitHub clone:
[mcp_servers.affinity]
command = "C:/Program Files/nodejs/node.exe"
args = ["C:/absolute/path/to/affinity-mcp-bridge/dist/index.js"]
startup_timeout_sec = 30Custom Affinity URL
If your Affinity MCP server is not using the default URL, set AFFINITY_MCP_SSE_URL.
Claude Desktop example:
{
"mcpServers": {
"affinity": {
"command": "npx",
"args": ["-y", "affinity-mcp-bridge"],
"env": {
"AFFINITY_MCP_SSE_URL": "http://localhost:6767/sse"
}
}
}
}Codex example:
[mcp_servers.affinity]
command = "npx"
args = ["-y", "affinity-mcp-bridge"]
startup_timeout_sec = 30
[mcp_servers.affinity.env]
AFFINITY_MCP_SSE_URL = "http://localhost:6767/sse"Test Your Setup
After configuring your MCP client, ask your assistant:
Use the affinity_status tool and tell me if Affinity is reachable.Expected result:
- The bridge starts successfully.
affinity_statusis available.- Affinity is reported as reachable when the app is open and MCP is enabled.
If Affinity is not reachable, the rest of the Affinity tools may not be available yet.
Troubleshooting
affinity_status says Affinity is not reachable
Check these items:
- Affinity is open.
- Settings > Model Context Protocol > Enable MCP server is enabled.
- Affinity was restarted after enabling MCP.
- No other app is blocking port
6767.
On Windows, you can check the port owner with:
Get-NetTCPConnection -LocalPort 6767 | ForEach-Object {
Get-Process -Id $_.OwningProcess
}If another app owns 127.0.0.1:6767 but Affinity owns ::1:6767, keep the default http://localhost:6767/sse; do not force 127.0.0.1.
My MCP client cannot find npx
Use the full path to Node and run the local clone instead:
{
"mcpServers": {
"affinity": {
"command": "C:/Program Files/nodejs/node.exe",
"args": ["C:/Users/you/path/to/affinity-mcp-bridge/dist/index.js"]
}
}
}I installed globally but the command does not start
Some Windows MCP clients handle .cmd launchers inconsistently. If that happens, prefer either:
npx -y affinity-mcp-bridgenode C:/path/to/affinity-mcp-bridge/dist/index.js
For Developers
npm install
npm run build
npm run check
npm run smokenpm run smoke starts the bridge and lists MCP tools. If Affinity is not reachable, it should still list affinity_status.
License
MIT
