figma-tunnel-mcp
Allows AI agents to control and export from Figma, including reading designs, modifying nodes, text content, styling, layout, creating elements, and bulk text replacement via a WebSocket bridge.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@figma-tunnel-mcpExport the main frame as a 2x PNG"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
figma-tunnel-mcp
Control and export from Figma using any MCP client (Claude Code, Cursor, …) over a local WebSocket bridge — optionally exposed to the internet via a Cloudflare tunnel.
Fork of sonnylazuardi/cursor-talk-to-figma-mcp with practical additions:
Fixed channel (
figma) instead of a new random one on every reconnect — clients and tunnels always know the channel.Background mode — a Windows launcher that starts Figma with render-throttling disabled and minimized, so image export works while Figma is hidden and never steals your focus.
Raw-WebSocket helpers — export/query nodes without even running the MCP server.
"Export All" plugin — one click dumps the whole file (PNG + SVG + original image fills + full layer JSON) into a single ZIP.
What's in here
Path | What it is |
| MCP server (50+ Figma tools) |
| WebSocket relay (port 3055) |
| Figma plugin (the bridge) — fixed channel |
| Windows launcher: Figma in background, no throttling, minimized |
| Export any node → PNG via raw WS (no MCP server needed) |
| Raw-WS test / diagnostic clients |
| Standalone "Export All" plugin (PNG + SVG + images + JSON → ZIP) |
Related MCP server: Agent to Figma MCP
Setup
Prereqs: Bun, Node.js, the Figma desktop app (Windows for the background launcher).
Install deps:
bun installStart the relay and keep it running:
bun socket→ listens onws://localhost:3055(optional) add the MCP server to your client, e.g. Claude Code:
claude mcp add TalkToFigma -- bunx cursor-talk-to-figma-mcp@latestIn Figma: Plugins → Development → Import plugin from manifest… →
src/cursor_mcp_plugin/manifest.jsonRun the plugin → it connects to channel
figma.
Your MCP client then does join_channel("figma") and uses the tools.
Background mode (Windows) — export images without Figma stealing focus
Figma (Chromium) throttles rendering when its window is backgrounded, which makes export_node_as_image time out. Fix: launch Figma with throttling disabled.
Double-click
Start-FigmaBg.vbs(or make a desktop shortcut to it). It finds the current Figma, launches it with the right flags, and minimizes it.Run the plugin once (channel stays
figma).Image export now works while Figma is minimized / not focused — nothing pops to the foreground.
Export images without the MCP server (raw WebSocket)
node _export_node.cjs figma "<nodeId>" 2 out.png ws://localhost:3055<nodeId> looks like 15:6239 (from the Figma URL node-id=15-6239); 2 is the scale. Saves a PNG to out.png.
Remote access (Cloudflare tunnel)
Expose the relay to the internet (ephemeral, no account needed):
cloudflared tunnel --url http://localhost:3055You get a https://<random>.trycloudflare.com URL. A remote MCP client connects with:
bunx cursor-talk-to-figma-mcp@latest --server=<random>.trycloudflare.comthen join_channel("figma").
⚠️ No authentication. Anyone who has the tunnel URL + channel name can read and modify your file. Use it briefly and stop the tunnel when done. The quick-tunnel URL changes on every restart.
Notes
The "Export All" plugin (
figma-export-plugin/) renders every container (frames, components, groups, instances, sections). On large files that is thousands of images and a big ZIP, and can be slow. For specific screens prefer targeted_export_node.cjs.
Talk to Figma MCP (upstream docs)
This project implements a Model Context Protocol (MCP) integration between AI agent (Cursor, Claude Code) and Figma, allowing AI agent to communicate with Figma for reading designs and modifying them programmatically.
https://github.com/user-attachments/assets/129a14d2-ed73-470f-9a4c-2240b2a4885c
Project Structure
src/talk_to_figma_mcp/- TypeScript MCP server for Figma integrationsrc/cursor_mcp_plugin/- Figma plugin for communicating with Cursorsrc/socket.ts- WebSocket server that facilitates communication between the MCP server and Figma plugin
How to use
Install Bun if you haven't already:
curl -fsSL https://bun.sh/install | bashRun setup, this will also install MCP in your Cursor's active project
bun setupStart the Websocket server
bun socketNEW Install Figma plugin from Figma community page or install locally
Quick Video Tutorial
Design Automation Example
Bulk text content replacement
Thanks to @dusskapark for contributing the bulk text replacement feature. Here is the demo video.
Instance Override Propagation Another contribution from @dusskapark Propagate component instance overrides from a source instance to multiple target instances with a single command. This feature dramatically reduces repetitive design work when working with component instances that need similar customizations. Check out our demo video.
Manual Setup and Installation
MCP Server: Integration with Cursor
Add the server to your Cursor MCP configuration in ~/.cursor/mcp.json:
{
"mcpServers": {
"TalkToFigma": {
"command": "bunx",
"args": ["cursor-talk-to-figma-mcp@latest"]
}
}
}WebSocket Server
Start the WebSocket server:
bun socketFigma Plugin
In Figma, go to Plugins > Development > New Plugin
Choose "Link existing plugin"
Select the
src/cursor_mcp_plugin/manifest.jsonfileThe plugin should now be available in your Figma development plugins
Windows + WSL Guide
Install bun via powershell
powershell -c "irm bun.sh/install.ps1|iex"Uncomment the hostname
0.0.0.0insrc/socket.ts
// uncomment this to allow connections in windows wsl
hostname: "0.0.0.0",Start the websocket
bun socketUsage
Start the WebSocket server
Install the MCP server in Cursor
Open Figma and run the Cursor MCP Plugin
Connect the plugin to the WebSocket server by joining a channel using
join_channelUse Cursor to communicate with Figma using the MCP tools
Local Development Setup
To develop, update your mcp config to direct to your local directory.
{
"mcpServers": {
"TalkToFigma": {
"command": "bun",
"args": ["/path-to-repo/src/talk_to_figma_mcp/server.ts"]
}
}
}MCP Tools
The MCP server provides the following tools for interacting with Figma:
Document & Selection
get_document_info- Get information about the current Figma documentget_selection- Get information about the current selectionread_my_design- Get detailed node information about the current selection without parametersget_node_info- Get detailed information about a specific nodeget_nodes_info- Get detailed information about multiple nodes by providing an array of node IDsset_focus- Set focus on a specific node by selecting it and scrolling viewport to itset_selections- Set selection to multiple nodes and scroll viewport to show them
Annotations
get_annotations- Get all annotations in the current document or specific nodeset_annotation- Create or update an annotation with markdown supportset_multiple_annotations- Batch create/update multiple annotations efficientlyscan_nodes_by_types- Scan for nodes with specific types (useful for finding annotation targets)
Prototyping & Connections
get_reactions- Get all prototype reactions from nodes with visual highlight animationset_default_connector- Set a copied FigJam connector as the default connector style for creating connections (must be set before creating connections)create_connections- Create FigJam connector lines between nodes, based on prototype flows or custom mapping
Creating Elements
create_rectangle- Create a new rectangle with position, size, and optional namecreate_frame- Create a new frame with position, size, and optional namecreate_text- Create a new text node with customizable font properties
Modifying text content
scan_text_nodes- Scan text nodes with intelligent chunking for large designsset_text_content- Set the text content of a single text nodeset_multiple_text_contents- Batch update multiple text nodes efficiently
Auto Layout & Spacing
set_layout_mode- Set the layout mode and wrap behavior of a frame (NONE, HORIZONTAL, VERTICAL)set_padding- Set padding values for an auto-layout frame (top, right, bottom, left)set_axis_align- Set primary and counter axis alignment for auto-layout framesset_layout_sizing- Set horizontal and vertical sizing modes for auto-layout frames (FIXED, HUG, FILL)set_item_spacing- Set distance between children in an auto-layout frame
Styling
set_fill_color- Set the fill color of a node (RGBA)set_stroke_color- Set the stroke color and weight of a nodeset_corner_radius- Set the corner radius of a node with optional per-corner control
Layout & Organization
move_node- Move a node to a new positionresize_node- Resize a node with new dimensionsdelete_node- Delete a nodedelete_multiple_nodes- Delete multiple nodes at once efficientlyclone_node- Create a copy of an existing node with optional position offset
Components & Styles
get_styles- Get information about local stylesget_local_components- Get information about local componentscreate_component_instance- Create an instance of a componentget_instance_overrides- Extract override properties from a selected component instanceset_instance_overrides- Apply extracted overrides to target instances
Export & Advanced
export_node_as_image- Export a node as an image (PNG, JPG, SVG, or PDF) - limited support on image currently returning base64 as text
Connection Management
join_channel- Join a specific channel to communicate with Figma
MCP Prompts
The MCP server includes several helper prompts to guide you through complex design tasks:
design_strategy- Best practices for working with Figma designsread_design_strategy- Best practices for reading Figma designstext_replacement_strategy- Systematic approach for replacing text in Figma designsannotation_conversion_strategy- Strategy for converting manual annotations to Figma's native annotationsswap_overrides_instances- Strategy for transferring overrides between component instances in Figmareaction_to_connector_strategy- Strategy for converting Figma prototype reactions to connector lines using the output of 'get_reactions', and guiding the use 'create_connections' in sequence
Development
Building the Figma Plugin
Navigate to the Figma plugin directory:
cd src/cursor_mcp_pluginEdit code.js and ui.html
Best Practices
When working with the Figma MCP:
Always join a channel before sending commands
Get document overview using
get_document_infofirstCheck current selection with
get_selectionbefore modificationsUse appropriate creation tools based on needs:
create_framefor containerscreate_rectanglefor basic shapescreate_textfor text elements
Verify changes using
get_node_infoUse component instances when possible for consistency
Handle errors appropriately as all commands can throw exceptions
For large designs:
Use chunking parameters in
scan_text_nodesMonitor progress through WebSocket updates
Implement appropriate error handling
For text operations:
Use batch operations when possible
Consider structural relationships
Verify changes with targeted exports
For converting legacy annotations:
Scan text nodes to identify numbered markers and descriptions
Use
scan_nodes_by_typesto find UI elements that annotations refer toMatch markers with their target elements using path, name, or proximity
Categorize annotations appropriately with
get_annotationsCreate native annotations with
set_multiple_annotationsin batchesVerify all annotations are properly linked to their targets
Delete legacy annotation nodes after successful conversion
Visualize prototype noodles as FigJam connectors:
Use
get_reactionsto extract prototype flows,set a default connector with
set_default_connector,and generate connector lines with
create_connectionsfor clear visual flow mapping.
License
MIT
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/skulidropek/figma-tunnel-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server