figma-mcp-server

planetabhi/figma-mcp-server

3.3

If you are the rightful owner of figma-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.

A simple MCP server for Figma that facilitates communication between Figma and other applications using the Model Context Protocol.

Figma MCP Server

A comprehensive local MCP server for Figma. Connect Figma with the Gemini CLI, Cursor, and Claude Desktop.

Prerequisites

Install

Install the server

git clone https://github.com/planetabhi/figma-mcp-server.git
cd figma-mcp-server
bun i

Set tool environment variable

Create a .env file and set the FIGMA_API_KEY to your Figma API key.

FIGMA_API_KEY=

To generate a new personal access token, log in to your Figma account, then from the top-left menu, head to Settings, click on the security tab, find the Personal access tokens section, and click Generate new token to open the configuration modal where you can set the expiration and scopes before clicking Generate token.

List All Tools

List descriptions and parameters from all available tools

bun run list-tools

Run the MCP Server

Find bun and server path

# Find bun path
which bun

# Get the absolute path of the MCP server
realpath mcpServer.js

Run with Claude Desktop

  1. Open Claude Desktop โ†’ Settings โ†’ Developers โ†’ Edit Config and add your server:
{
  "mcpServers": {
    "figma-mcp-server": {
      "command": "<absolute_path_to_bun>",
      "args": ["<absolute_path_to_mcpServer.js>"]
    }
  }
}
  1. Restart Claude Desktop to activate config change.

To try it out in Claude Desktop, first enable the get_file_nodes tool from the tools list. Copy a design node link from a Figma file, then paste it into Claude Desktop prompt. It will return the design node data and other information.

Run with Gemini CLI

  1. Open a new terminal and create the .gemini directory (if it doesn't exist)
mkdir -p ~/.gemini
  1. Create the settings.json file
echo '{
  "mcpServers": {
    "figma-mcp-server": {
      "command": "<absolute_path_to_bun>",
      "args": ["mcpServer.js"],
      "cwd": "<absolute_path_to_working_directory>",
      "env": {
        "FIGMA_API_KEY": "your_figma_api_key_here"
      },
      "trust": true
    }
  }
}' > ~/.gemini/settings.json
  1. Start Gemini CLI
export GEMINI_API_KEY="your_gemini_api_key_here"
npx https://github.com/google-gemini/gemini-cli
  • Use /mcp to list all tools
  • Use /mcp desc to show server and tool descriptions
  • Use /mcp schema to show tool parameter schemas
  • Use /mcp nodesc to hide descriptions

Troubleshooting

  • Missing Figma token
    • Error: missing or invalid FIGMA_API_KEY.
    • Ensure .env exists next to mcpServer.js with FIGMA_API_KEY=....
  • Port already in use (SSE mode)
    • Run SSE on a custom port: PORT=3005 node mcpServer.js --sse.
  • Bun not found
    • Ensure which bun returns a path.
    • Restart your shell after installing Bun.
  • Using npm instead of Bun
    • Replace bun i โ†’ npm i
    • Replace bun run list-tools โ†’ node index.js tools
  • Manual start not required
    • Only start manually for SSE or local web endpoint: node mcpServer.js --sse
    • Default port is 3001, override with PORT=<port>

MIT License ยท By @planetabhi โ‹›โ‹‹( โŠ™โ—ŠโŠ™)โ‹Œโ‹š