Skip to main content
Glama

๐ŸŽจ 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?

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


โœจ Features

๐ŸŽฏ 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

๐Ÿ›ก๏ธ Production Ready

  • โœ… Type-safe Pydantic validation

  • โœ… Robust error handling

  • โœ… Rate limit management

  • โœ… Dual output formats (JSON/Markdown)

๐Ÿš€ Easy Integration

  • โœ… Works with Claude Desktop

  • โœ… Works with Cursor IDE

  • โœ… stdio + HTTP transports

  • โœ… No hosting required

๐Ÿค– AI Skill Included

  • โœ… Cursor skill teaches AI how to use tools

  • โœ… Best practices built-in

  • โœ… Auto-applies workflows

  • โœ… Better experience out of the box

๐ŸŽ 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

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

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"
      }
    }
  }
}

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"
      }
    }
  }
}

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


๐Ÿ”Œ 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.

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

๐ŸŽจ What You Can Do

๐Ÿ›๏ธ 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

-

-


๐Ÿ’ก 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"
)

๐ŸŽฌ Want to see it in action?

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


๐Ÿ› ๏ธ Available Tools

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?"

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"

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?"

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?"

Tool

Description

Example Use

printful_add_file

Upload design file

"Upload my logo"

printful_get_file

Get file info & status

"Check file #12345"

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?"

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"


๐ŸŽ“ Documentation

๐Ÿ“– Quick Start Guide

Get up and running in 5 minutes

๐Ÿ”‘ API Token Setup

Detailed token configuration guide

๐Ÿงช Testing Guide

Learn how to test your integration

๐Ÿ” API Scopes Reference

Required permissions explained

๐Ÿ’ป Examples

Real code examples

๐Ÿ”ง Cursor Config

Ready-to-use config file


๐Ÿ”„ API Version Strategy

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

๐ŸŽฏ v2 (Primary)

  • โœ… Catalog & Products

  • โœ… Orders & Fulfillment

  • โœ… Shipping Rates

  • โœ… Mockup Generation

  • โœ… File Management

  • โœ… Store Statistics

๐Ÿ”„ v1 (Fallback)

  • โœ… Sync Products

  • โœ… Product Templates

  • โš ๏ธ Auto-switches when needed

  • ๐Ÿš€ Future-proof architecture

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


โš™๏ธ Rate Limiting & Performance

๐Ÿ“Š Rate Limits

  • 120 requests / 60 seconds

  • Leaky bucket algorithm

  • Auto-retry on 429 errors

๐Ÿš€ Performance

  • Response times: 100-500ms

  • Concurrent requests: Supported

  • Timeout handling: Built-in


๐Ÿ› Troubleshooting

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

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

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

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


๐Ÿงช Testing

Choose Your Testing Method

โšก Quick Test

Automated test suite

export PRINTFUL_API_KEY=your-key
python test_server.py

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

๐ŸŒ Interactive Test

Web-based MCP Inspector

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

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

๐Ÿค– Live Test

In Claude/Cursor

Just ask:

"List Printful countries"

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

๐Ÿ“– 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:

๐Ÿ› Report Bugs

Found an issue? Open a bug report

โœจ Request Features

Have an idea? Suggest a feature

๐Ÿ”ง Submit PRs

  1. Fork the repository

  2. Create your feature branch

  3. Commit your changes

  4. Push and open a Pull Request


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


๐Ÿ“„ License

MIT License - Free to use, modify, and distribute

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


๐Ÿ’ Support This Project

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

Made with โค๏ธ by Purple Horizons

Empowering businesses through AI automation


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

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

Questions? Issues? Open an issue or contact us

Install Server
A
security โ€“ no known vulnerabilities
A
license - permissive license
-
quality - not tested

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

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/Purple-Horizons/printful-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server