Canva MCP Server
A Model Context Protocol (MCP) server for Canva integration. Connect Claude Code or any MCP-compatible AI client to your Canva account to search designs, generate AI designs, edit content, manage folders, and collaborate through comments.
README
Canva MCP Server (Security-Hardened Fork)
A Model Context Protocol (MCP) server for Canva integration. Connect Claude Code or any MCP-compatible AI client to your Canva account — search designs, generate AI designs, edit content, manage folders, and collaborate through comments.
Quick Start
git clone https://github.com/your-username/canva-mcp-server.git
cd canva-mcp-server
npm install
cp .env.example .env
# Edit .env with your Canva credentials (see below)
./start.sh
Get Canva Credentials
- Visit https://www.canva.com/developers/
- Create a new app
- Under Authentication, copy your Client ID and Client Secret
- Add
http://127.0.0.1:8001/auth/callbackas a redirect URI - Enable these OAuth scopes:
asset:read,asset:write,comment:read,comment:write,design:content:read,design:content:write,design:meta:read,folder:read,folder:write,profile:read
Set your credentials in .env:
CANVA_CLIENT_ID=your_client_id_here
CANVA_CLIENT_SECRET=your_client_secret_here
CANVA_REDIRECT_URI=http://127.0.0.1:8001/auth/callback
Claude Code Setup
claude mcp add --transport sse --scope user canva http://127.0.0.1:8001/mcp
Then start the server (./start.sh) before opening Claude Code. On first tool call, the server returns an OAuth URL — visit it in your browser to authenticate.
Available Tools
| Tool | Description |
|---|---|
search-designs |
Search designs by title, sort order, and ownership |
get-design |
Get metadata for a specific design |
get-design-pages |
List all pages in a design with thumbnails |
get-design-content |
Extract all text content from a design |
generate-design |
Generate AI design candidates from a text description |
create-design-from-candidate |
Convert an AI candidate into an editable design |
start-editing-transaction |
Begin an editing session, returns a transaction ID |
perform-editing-operations |
Update title, replace text, or replace media |
commit-editing-transaction |
Save all changes in a transaction |
cancel-editing-transaction |
Discard all changes in a transaction |
get-design-thumbnail |
Get a page thumbnail during editing |
create-folder |
Create a folder (root or nested) |
move-item-to-folder |
Move a design or folder into another folder |
list-folder-items |
Browse folder contents with filtering |
comment-on-design |
Add a comment to a design |
list-comments |
List all comments on a design |
reply-to-comment |
Reply to a comment thread |
list-replies |
List all replies to a comment |
upload-asset-from-url |
Import an image or video from a URL |
get-assets |
Retrieve metadata for multiple assets |
Security
This fork hardens the original with:
- 127.0.0.1 binding — server listens on loopback only, not exposed to the network
- Auth middleware — optional Bearer token (
MCP_AUTH_TOKENin.env) secures the MCP endpoint - XSS protection — all UI widget templates use DOM API construction instead of
innerHTMLwith API data - CORS allowlist — configurable via
CORS_ORIGINSenv var, no wildcard in production paths - Input validation — Zod schemas on all tool inputs, size limits enforced
- Error sanitization — Canva API errors logged server-side, not reflected to clients
The src/server/worker.ts file is a development/demo stub for Cloudflare Workers deployment. For production, use the Node.js server (src/server/server.ts).
Project Structure
canva-mcp-server/
├── src/
│ └── server/
│ ├── server.ts # Main Node.js server
│ └── worker.ts # Cloudflare Worker demo stub
├── src/components/ # React widget components (compiled to assets/)
├── ui-components/ # Standalone HTML widget templates
├── assets/ # Compiled widget output (generated by npm run build)
├── .env.example # Environment variable template
├── start.sh # Start script
├── quick-start.sh # First-run setup script
└── README.md
Review Pipeline
This fork was security-hardened through a multi-agent parallel review pipeline built by The Funkatorium:
| Agent | Role | What they caught |
|---|---|---|
| Michael | Senior Security Specialist | Zero-auth MCP endpoints, 0.0.0.0 binding, reflected XSS in OAuth callbacks, CORS misconfiguration, leaked infrastructure IDs |
| Reeve | Code Craft Reviewer | Mock import overriding production code, dead if/else branches, AI-generated docs committed to repo, unused hook subscriptions |
| Fischer | Static Analysis Specialist | 20+ as any type assertions, z.any() bypassing validation, null-unsafe window.openai access |
| Nikita | Dependency Safety Specialist | Exposed Client ID in .env.example, dependency bloat analysis, license compatibility audit |
Three audit rounds. 12-point final gate check. All agents run in parallel — independent concerns, no bottleneck.
This is how MUSE Studio builds software.
Credit
Based on EmilyThaHuman/canva-mcp-server. Security-hardened by The Funkatorium.
License
MIT — see LICENSE
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.