Printful MCP Server

Printful MCP Server

Connects Printful's print-on-demand API to AI assistants like Claude and Cursor to automate business operations. It enables users to browse catalogs, manage orders, generate mockups, and calculate shipping rates through natural language.

Category
Visit Server

README

<div align="center">

๐ŸŽจ Printful MCP Server

Automate Your Print-on-Demand Business with AI

Connect Printful's powerful API to Claude, Cursor, and other AI assistants through the Model Context Protocol.

๐Ÿ“š Quick Start โ€ข ๐Ÿ”ง Configuration โ€ข ๐Ÿš€ Examples โ€ข ๐Ÿ“– Documentation


Made by Purple Horizons License: MIT Python 3.10+ Printful API v2

GitHub Stars GitHub Forks


๐ŸŽ New to Printful?

<a href="https://www.printful.com/a/purplehorizons"> <img src="https://img.shields.io/badge/Sign_Up-Get_Started_Free-FA4616?style=for-the-badge&logo=printful&logoColor=white" alt="Sign up for Printful"> </a>

<sub>Start your print-on-demand business today โ€ข No upfront costs โ€ข 300+ products โ€ข Global fulfillment</sub>


</div>

โœจ Features

<table> <tr> <td width="50%">

๐ŸŽฏ Complete API Coverage

  • โœ… Full Printful API v2 support
  • โœ… Smart v1 fallback for legacy features
  • โœ… 17 tools across all major domains
  • โœ… Real-time stock & pricing data

</td> <td width="50%">

๐Ÿ›ก๏ธ Production Ready

  • โœ… Type-safe Pydantic validation
  • โœ… Robust error handling
  • โœ… Rate limit management
  • โœ… Dual output formats (JSON/Markdown)

</td> </tr> <tr> <td width="50%">

๐Ÿš€ Easy Integration

  • โœ… Works with Claude Desktop
  • โœ… Works with Cursor IDE
  • โœ… stdio + HTTP transports
  • โœ… No hosting required

</td> <td width="50%">

๐Ÿค– AI Skill Included

  • โœ… Cursor skill teaches AI how to use tools
  • โœ… Best practices built-in
  • โœ… Auto-applies workflows
  • โœ… Better experience out of the box

</td> </tr> </table>

๐ŸŽ Bonus: This repo includes a Cursor AI skill that automatically teaches AI assistants how to use the Printful MCP effectively. Just open the project and start asking questions!


๐Ÿš€ Quick Start

<details open> <summary><b>๐Ÿ“‹ Prerequisites</b></summary>

<br>

</details>

<details> <summary><b>โšก Installation (3 steps)</b></summary>

<br>

Step 1: Clone & Install

git clone https://github.com/Purple-Horizons/printful-ph-mcp.git
cd printful-ph-mcp
pip install -e .

Step 2: Set up API Key

cp .env.example .env
# Edit .env and add: PRINTFUL_API_KEY=your-key-here

Step 3: Configure Your AI Assistant

<details> <summary><b>For Cursor</b></summary>

Add to ~/.cursor/mcp.json:

{
  "mcpServers": {
    "printful": {
      "command": "python",
      "args": ["-m", "printful_mcp"],
      "cwd": "/path/to/printful-ph-mcp",
      "env": {
        "PRINTFUL_API_KEY": "your-api-key-here"
      }
    }
  }
}

</details>

<details> <summary><b>For Claude Desktop</b></summary>

Add to ~/Library/Application Support/Claude/claude_desktop_config.json:

{
  "mcpServers": {
    "printful": {
      "command": "python",
      "args": ["-m", "printful_mcp"],
      "cwd": "/path/to/printful-ph-mcp",
      "env": {
        "PRINTFUL_API_KEY": "your-api-key-here"
      }
    }
  }
}

</details>

โœ… That's it! Restart your AI assistant and start using Printful tools.

</details>


๐Ÿ”Œ Transport Options

By default, the server uses stdio transport (required for Cursor/Claude Desktop). For HTTP clients or tools like mcporter, you can use HTTP transport.

<details> <summary><b>๐Ÿ“ก Available Transports</b></summary>

<br>

Transport Use Case Command
stdio (default) Cursor, Claude Desktop python -m printful_mcp
http HTTP clients, mcporter python -m printful_mcp --transport http
sse Legacy SSE clients python -m printful_mcp --transport sse

HTTP Transport Example:

# Start server on port 8000
python -m printful_mcp --transport http --port 8000

# Or with custom host
python -m printful_mcp --transport http --host 0.0.0.0 --port 8080

Using with mcporter:

# Option 1: Use JSON args format (recommended)
mcporter call printful_mcp.printful_list_catalog_products --args '{"limit":20}'

# Option 2: Use typed values (colon for numbers)
mcporter call printful_mcp.printful_get_product product_id:71

</details>


๐ŸŽจ What You Can Do

<div align="center">

๐Ÿ›๏ธ Catalog ๐Ÿ“ฆ Orders ๐Ÿšš Shipping ๐Ÿ–ผ๏ธ Mockups ๐Ÿ“ Files ๐Ÿช Stores
Browse 300+ products Create & manage orders Calculate rates Generate mockups Upload designs View statistics
Check availability Confirm fulfillment List countries Check status Get file info Multi-store support
Get pricing Track orders Delivery times Custom placements - -

</div>


๐Ÿ’ก Usage Examples

๐ŸŽฏ Example 1: Find the Perfect Product

# Ask your AI assistant:
"Show me all t-shirts available for DTG printing under $15"

# It will use:
printful_list_catalog_products(
    types="T-SHIRT",
    techniques="dtg",
    limit=20,
    format="markdown"
)

๐Ÿ’ฐ Example 2: Get Pricing

# Ask your AI assistant:
"What's the price for variant 4011 in USD?"

# It will use:
printful_get_variant_prices(
    variant_id=4011,
    currency="USD",
    format="markdown"
)

๐Ÿ“ฆ Example 3: Create an Order

# Ask your AI assistant:
"Create a draft order for John Doe at 123 Main St, Los Angeles, CA 90001"

# It will use:
printful_create_order(
    recipient_name="John Doe",
    recipient_address1="123 Main St",
    recipient_city="Los Angeles",
    recipient_state_code="CA",
    recipient_country_code="US",
    recipient_zip="90001"
)

๐ŸŽจ Example 4: Generate Product Mockups

# Ask your AI assistant:
"Generate a mockup for product 71 with my design"

# It will use:
printful_create_mockup_task(
    product_id=71,
    variant_ids="4011,4012",
    design_url="https://example.com/design.png",
    placement="front"
)

<div align="center">

๐ŸŽฌ Want to see it in action?

๐Ÿ“บ Watch Demo Video โ€ข ๐Ÿ“– Read Full Documentation โ€ข ๐Ÿ’ฌ Join Community

</div>


๐Ÿ› ๏ธ Available Tools

<details> <summary><b>๐Ÿ›๏ธ Catalog Tools (5)</b> - Browse products & check availability</summary>

<br>

Tool Description Example Use
printful_list_catalog_products Browse 300+ products with filters "Show me all hoodies"
printful_get_product Get detailed product info "Tell me about product 71"
printful_get_product_variants Get all sizes/colors "What sizes are available?"
printful_get_variant_prices Get pricing by currency "How much in EUR?"
printful_get_product_availability Check stock status "Is this in stock?"

</details>

<details> <summary><b>๐Ÿ“ฆ Order Tools (4)</b> - Create & manage orders</summary>

<br>

Tool Description Example Use
printful_create_order Create draft order "Create order for John"
printful_get_order View order details "Show me order #12345"
printful_confirm_order Start fulfillment "Confirm this order"
printful_list_orders List all orders "Show my recent orders"

</details>

<details> <summary><b>๐Ÿšš Shipping Tools (2)</b> - Calculate rates & delivery</summary>

<br>

Tool Description Example Use
printful_calculate_shipping Get shipping rates & times "How much to ship to UK?"
printful_list_countries List supported countries "What countries do you ship to?"

</details>

<details> <summary><b>๐Ÿ–ผ๏ธ Mockup Tools (2)</b> - Generate product images</summary>

<br>

Tool Description Example Use
printful_create_mockup_task Generate mockup images "Create mockup with my design"
printful_get_mockup_task Check generation status "Is my mockup ready?"

</details>

<details> <summary><b>๐Ÿ“ File Tools (2)</b> - Upload & manage designs</summary>

<br>

Tool Description Example Use
printful_add_file Upload design file "Upload my logo"
printful_get_file Get file info & status "Check file #12345"

</details>

<details> <summary><b>๐Ÿช Store Tools (2)</b> - Manage stores & stats</summary>

<br>

Tool Description Example Use
printful_list_stores List your stores "Show all my stores"
printful_get_store_stats View sales & profit "What are my sales?"

</details>

<details> <summary><b>๐Ÿ”„ Sync Product Tools (2)</b> - Legacy v1 features</summary>

<br>

Tool Description Example Use
printful_list_sync_products List synced products "Show my Etsy products"
printful_get_sync_product Get sync product details "Details on sync #123"

</details>


๐ŸŽ“ Documentation

<table> <tr> <td align="center" width="33%">

๐Ÿ“– Quick Start Guide

Get up and running in 5 minutes

</td> <td align="center" width="33%">

๐Ÿ”‘ API Token Setup

Detailed token configuration guide

</td> <td align="center" width="33%">

๐Ÿงช Testing Guide

Learn how to test your integration

</td> </tr> <tr> <td align="center" width="33%">

๐Ÿ” API Scopes Reference

Required permissions explained

</td> <td align="center" width="33%">

๐Ÿ’ป Examples

Real code examples

</td> <td align="center" width="33%">

๐Ÿ”ง Cursor Config

Ready-to-use config file

</td> </tr> </table>


๐Ÿ”„ API Version Strategy

This server uses Printful API v2 (production-ready beta) with smart v1 fallback:

<table> <tr> <td width="50%">

๐ŸŽฏ v2 (Primary)

  • โœ… Catalog & Products
  • โœ… Orders & Fulfillment
  • โœ… Shipping Rates
  • โœ… Mockup Generation
  • โœ… File Management
  • โœ… Store Statistics

</td> <td width="50%">

๐Ÿ”„ v1 (Fallback)

  • โœ… Sync Products
  • โœ… Product Templates
  • โš ๏ธ Auto-switches when needed
  • ๐Ÿš€ Future-proof architecture

</td> </tr> </table>

Why v2? Better pagination โ€ข Real-time stock โ€ข Enhanced orders โ€ข Improved security โ€ข Standardized formats


โš™๏ธ Rate Limiting & Performance

<table> <tr> <td>

๐Ÿ“Š Rate Limits

  • 120 requests / 60 seconds
  • Leaky bucket algorithm
  • Auto-retry on 429 errors

</td> <td>

๐Ÿš€ Performance

  • Response times: 100-500ms
  • Concurrent requests: Supported
  • Timeout handling: Built-in

</td> </tr> </table>


๐Ÿ› Troubleshooting

<details> <summary><b>โŒ "PRINTFUL_API_KEY environment variable is required"</b></summary>

<br>

Solution: Make sure your API key is set in .env or passed via environment variables in the MCP config.

# Check your .env file
cat .env

# Should contain:
PRINTFUL_API_KEY=your-actual-key-here

</details>

<details> <summary><b>โฑ๏ธ "Rate limit exceeded"</b></summary>

<br>

Solution: Wait for the time specified in the error message (usually 60 seconds).

  • Default limit: 120 requests/minute
  • Consider implementing request batching
  • Check X-Ratelimit-Reset header for exact reset time

</details>

<details> <summary><b>๐Ÿ” "Resource not found"</b></summary>

<br>

Solution: Double-check the ID you're using.

  • For orders: You can use external IDs by prefixing with @ (e.g., @my-order-123)
  • For products: Verify the product/variant ID exists in the catalog
  • Check if the resource belongs to your store

</details>

<details> <summary><b>๐ŸŽจ Mockup generation stuck on "pending"</b></summary>

<br>

Solution: Mockup generation typically takes 10-30 seconds.

  • Wait at least 30 seconds before checking status
  • If stuck longer than 2 minutes, check task status - it may have failed
  • Verify your design URL is publicly accessible

</details>


๐Ÿงช Testing

<div align="center">

Choose Your Testing Method

</div>

<table> <tr> <td align="center" width="33%">

โšก Quick Test

Automated test suite

export PRINTFUL_API_KEY=your-key
python test_server.py

โœ… Tests 6 core features โฑ๏ธ Takes 30 seconds

</td> <td align="center" width="33%">

๐ŸŒ Interactive Test

Web-based MCP Inspector

export PRINTFUL_API_KEY=your-key
./test-with-inspector.sh

๐ŸŽฏ Test any tool visually ๐ŸŒ Opens at localhost:5173

</td> <td align="center" width="33%">

๐Ÿค– Live Test

In Claude/Cursor

Just ask:

"List Printful countries"

๐Ÿ’ฌ Natural language โœจ Real integration test

</td> </tr> </table>

๐Ÿ“– Full testing guide: See TESTING.md for comprehensive testing instructions.


๐Ÿ—๏ธ Project Structure

printful-ph-mcp/
โ”œโ”€โ”€ ๐Ÿ“ src/
โ”‚   โ””โ”€โ”€ ๐Ÿ“ printful_mcp/
โ”‚       โ”œโ”€โ”€ ๐Ÿ server.py          # FastMCP server + tool registrations
โ”‚       โ”œโ”€โ”€ ๐Ÿ”Œ client.py          # API client with auth/error handling
โ”‚       โ”œโ”€โ”€ ๐Ÿ“ tools/             # Tool implementations by domain
โ”‚       โ”‚   โ”œโ”€โ”€ ๐Ÿ›๏ธ catalog.py    # Product browsing (5 tools)
โ”‚       โ”‚   โ”œโ”€โ”€ ๐Ÿ“ฆ orders.py     # Order management (4 tools)
โ”‚       โ”‚   โ”œโ”€โ”€ ๐Ÿšš shipping.py   # Shipping rates (2 tools)
โ”‚       โ”‚   โ”œโ”€โ”€ ๐Ÿ–ผ๏ธ mockups.py    # Mockup generation (2 tools)
โ”‚       โ”‚   โ”œโ”€โ”€ ๐Ÿ“ files.py      # File management (2 tools)
โ”‚       โ”‚   โ”œโ”€โ”€ ๐Ÿช stores.py     # Store statistics (2 tools)
โ”‚       โ”‚   โ””โ”€โ”€ ๐Ÿ”„ sync.py       # v1 fallback (2 tools)
โ”‚       โ””โ”€โ”€ ๐Ÿ“ models/
โ”‚           โ””โ”€โ”€ ๐Ÿ“‹ inputs.py      # Pydantic input models
โ”œโ”€โ”€ ๐Ÿ“„ pyproject.toml
โ”œโ”€โ”€ ๐Ÿ” .env.example
โ””โ”€โ”€ ๐Ÿ“– README.md

๐Ÿค Contributing

We welcome contributions! Here's how you can help:

<table> <tr> <td width="50%">

๐Ÿ› Report Bugs

Found an issue? Open a bug report

โœจ Request Features

Have an idea? Suggest a feature

</td> <td width="50%">

๐Ÿ”ง Submit PRs

  1. Fork the repository
  2. Create your feature branch
  3. Commit your changes
  4. Push and open a Pull Request

</td> </tr> </table>


๐Ÿ“š Resources & Links

<div align="center">

Resource Link
๐Ÿ“˜ Printful API v2 Docs developers.printful.com/docs/v2-beta
๐Ÿ“— Printful API v1 Docs developers.printful.com/docs
๐Ÿ”Œ MCP Protocol Spec modelcontextprotocol.io
๐Ÿ FastMCP Framework github.com/modelcontextprotocol/python-sdk
๐ŸŽจ Purple Horizons purplehorizons.io
๐Ÿ‘จโ€๐Ÿ’ป Made by Gianni giannidalerta.com

</div>


๐Ÿ“„ License

<div align="center">

MIT License - Free to use, modify, and distribute

View License โ€ข Purple Horizons LLC โ€ข 2026

</div>


๐Ÿ’ Support This Project

<div align="center">

If this project helped you, consider:

โญ Star this repo on GitHub

๐Ÿฆ Share it on social media

๐Ÿค Contribute to the codebase

๐ŸŽจ Sign up for Printful using our affiliate link

<br>

<a href="https://www.printful.com/a/purplehorizons"> <img src="https://img.shields.io/badge/Try_Printful-Start_Free-FA4616?style=for-the-badge&logo=printful&logoColor=white" alt="Try Printful"> </a>

<br><br>

Made with โค๏ธ by Purple Horizons

Empowering businesses through AI automation

</div>


<div align="center">

๐Ÿš€ Ready to automate your print-on-demand business?

Get Started Now โ€ข View Examples โ€ข Read Docs

<sub>Questions? Issues? Open an issue or contact us</sub>

</div>

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured