npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

affinity-mcp-bridge

v0.2.0

Published

A standalone MCP stdio bridge for Affinity by Canva's local MCP SSE server.

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/sse

Most users do not need to change this.

Quick Start

  1. Open Affinity.
  2. Enable Settings > Model Context Protocol > Enable MCP server.
  3. Restart Affinity.
  4. Configure your MCP client with one of the examples below.
  5. Ask your assistant to run the affinity_status tool.

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-bridge

You can also install it globally:

npm install -g affinity-mcp-bridge

Then use:

affinity-mcp-bridge

Install 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 build

Then configure your MCP client to run:

node /absolute/path/to/affinity-mcp-bridge/dist/index.js

On 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 = 30

For 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 = 30

Custom 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_status is 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:

  1. Affinity is open.
  2. Settings > Model Context Protocol > Enable MCP server is enabled.
  3. Affinity was restarted after enabling MCP.
  4. 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-bridge
  • node C:/path/to/affinity-mcp-bridge/dist/index.js

For Developers

npm install
npm run build
npm run check
npm run smoke

npm run smoke starts the bridge and lists MCP tools. If Affinity is not reachable, it should still list affinity_status.

License

MIT