A comprehensive local MCP server for Figma. Connect Figma with the Gemini CLI, Cursor, and Claude Desktop.
Install the server
git clone https://github.com/planetabhi/figma-mcp-server.git
cd figma-mcp-server
bun iCreate 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 descriptions and parameters from all available tools
bun run list-tools# Find bun path
which bun
# Get the absolute path of the MCP server
realpath mcpServer.js- 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>"]
}
}
}- Restart Claude Desktop to activate config change.
To try it out in Claude Desktop, first enable the
get_file_nodestool 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.
- Open a new terminal and create the
.geminidirectory (if it doesn't exist)
mkdir -p ~/.gemini- Create the
settings.jsonfile
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- Start Gemini CLI
export GEMINI_API_KEY="your_gemini_api_key_here"
npx https://github.com/google-gemini/gemini-cli- Use
/mcpto list all tools - Use
/mcp descto show server and tool descriptions - Use
/mcp schemato show tool parameter schemas - Use
/mcp nodescto hide descriptions
- Missing Figma token
- Error: missing or invalid
FIGMA_API_KEY. - Ensure
.envexists next tomcpServer.jswithFIGMA_API_KEY=....
- Error: missing or invalid
- Port already in use (SSE mode)
- Run SSE on a custom port:
PORT=3005 node mcpServer.js --sse.
- Run SSE on a custom port:
- Bun not found
- Ensure
which bunreturns a path. - Restart your shell after installing Bun.
- Ensure
- Using npm instead of Bun
- Replace
bun i→npm i - Replace
bun run list-tools→node index.js tools
- Replace
- Manual start not required
- Only start manually for SSE or local web endpoint:
node mcpServer.js --sse - Default port is
3001, override withPORT=<port>
- Only start manually for SSE or local web endpoint:
MIT License · By @planetabhi ⋛⋋( ⊙◊⊙)⋌⋚