Send to Kindle MCP Server

Send to Kindle MCP Server

A Model Context Protocol (MCP) server that allows Claude Desktop to send documents directly to your Kindle e-reader.

Category
Visit Server

README

Send to Kindle MCP Server

A Model Context Protocol (MCP) server that allows Claude Desktop to send documents directly to your Kindle e-reader. Convert text or markdown content into beautifully formatted EPUB files and deliver them instantly to your Kindle library.

Features

  • 📚 Convert text and markdown to EPUB format
  • 📧 Send documents directly to Kindle via email
  • 📖 Automatic chapter creation from markdown headings (H1, H2, etc.)
  • 🎨 Properly formatted with CSS styling for optimal reading
  • âš¡ Fast and easy integration with Claude Desktop
  • 🔒 Secure email configuration with environment variables
  • 👤 Customizable author name via environment variable

Prerequisites

  • Python 3.10 or higher
  • A Kindle e-reader or Kindle app
  • An email account with SMTP access (Gmail recommended)
  • Your Kindle email address (found in Amazon account settings)

Installation

1. Clone or download this repository

cd ~/path/to/your/projects
git clone <repository-url> send-to-kindle-mcp
cd send-to-kindle-mcp

2. Create a virtual environment and install dependencies

python -m venv venv
source venv/bin/activate  # On Windows: venv\Scripts\activate
pip install -e .

3. Configure your credentials

Option A: Create a .env file (for local testing)

Copy the example environment file and fill in your details:

cp .env.example .env

Edit .env with your information:

# For Gmail users:
SMTP_HOST=smtp.gmail.com
SMTP_PORT=587
SMTP_USER=your-email@gmail.com
SMTP_PASSWORD=your-app-password  # See note below

# Your Kindle email address
KINDLE_EMAIL=your-kindle@kindle.com

# Sender email (usually same as SMTP_USER)
FROM_EMAIL=your-email@gmail.com

# Author name (optional - defaults to "Claude" if not set)
AUTHOR_NAME=Your Name

Note: The .env file is useful for local testing (e.g., using test_smtp.py), but Claude Desktop does NOT automatically load .env files. You must also set these values in the Claude Desktop config file (see step 4).

Important Notes:

  • Gmail Users: You must use an App Password, not your regular Gmail password
  • Kindle Email: Find this in your Amazon account under "Manage Your Content and Devices" → "Preferences" → "Personal Document Settings"
  • Approved Senders: Make sure to add your sending email address to your Kindle's approved email list in Amazon settings

4. Configure Claude Desktop

Add the server to your Claude Desktop configuration file:

macOS: ~/Library/Application Support/Claude/claude_desktop_config.json

Windows: %APPDATA%\Claude\claude_desktop_config.json

{
  "mcpServers": {
    "send-to-kindle": {
      "command": "/path/to/send-to-kindle-mcp/venv/bin/python",
      "args": ["/path/to/send-to-kindle-mcp/server.py"],
      "env": {
        "SMTP_HOST": "smtp.gmail.com",
        "SMTP_PORT": "587",
        "SMTP_USER": "your-email@gmail.com",
        "SMTP_PASSWORD": "your-app-password",
        "KINDLE_EMAIL": "your-kindle@kindle.com",
        "FROM_EMAIL": "your-email@gmail.com",
        "AUTHOR_NAME": "Your Name"
      }
    }
  }
}

Replace the following:

  • /path/to/send-to-kindle-mcp with the actual path to this directory
  • All placeholder values in the env section with your actual credentials

Note: If you created a .env file in step 3, you can copy those same values into the env section above. The values must be set here for Claude Desktop to use them.

5. Restart Claude Desktop

Quit and restart Claude Desktop for the changes to take effect.

Usage

Once configured, you can ask Claude to send documents to your Kindle:

"Please send this research paper to my Kindle"
"Create a summary of this conversation and send it to my Kindle as 'Meeting Notes'"
"Convert this markdown document to EPUB and send to Kindle"

Claude will use the send_to_kindle tool to:

  1. Ask you for a title and author (if not provided)
  2. Convert your content to a properly formatted EPUB with chapter navigation
  3. Email it to your Kindle address
  4. Confirm successful delivery

Chapter Navigation: The tool automatically detects markdown headings (H1, H2, etc.) and creates separate chapters for each major section. This makes it easy to navigate longer documents on your Kindle using the table of contents.

The document will appear in your Kindle library within a few minutes.

Troubleshooting

Viewing Error Logs

The server logs detailed information to help debug issues. To view logs in Claude Desktop:

macOS:

  • Open Console.app (Applications → Utilities → Console)
  • Filter by "Claude" or search for "send-to-kindle"
  • Look for log messages with timestamps

Windows:

  • Check the Claude Desktop logs in %APPDATA%\Claude\logs\
  • Or view logs in the Windows Event Viewer

The logs will show:

  • Connection attempts to SMTP servers
  • Authentication steps and errors
  • Detailed error messages with troubleshooting hints
  • Configuration validation issues

Email not sending

  • Most common issue: Environment variables not set in Claude Desktop config file. Remember: .env files are NOT automatically loaded by Claude Desktop. You must set all variables in the claude_desktop_config.json file.
  • Verify your SMTP credentials are correct in the Claude Desktop config file
  • For Gmail, ensure you're using an App Password, not your regular password
  • Test your connection using python test_smtp.py to verify credentials work
  • Check the logs (see above) for specific error messages
  • Restart Claude Desktop after making config changes

Document not appearing on Kindle

  • Verify your Kindle email address is correct
  • Check your Amazon approved email list includes your sending address
  • Look in your Amazon "Personal Documents" section to see if it was received
  • Check your spam folder

Import errors

# Make sure you're in the virtual environment
source venv/bin/activate

# Reinstall dependencies
pip install -e .

Development

Testing SMTP Connection

Test your SMTP configuration independently of Claude Desktop:

source venv/bin/activate
python test_smtp.py

This will verify your credentials and connection work correctly before using with Claude Desktop.

Running the Server Standalone

To run the server standalone for testing:

source venv/bin/activate
python server.py

Security Notes

  • Never commit your .env file or expose your credentials
  • Use App Passwords for email services that support them
  • Keep your Kindle approved sender list limited to trusted addresses

License

MIT License - feel free to modify and distribute as needed.

Contributing

Contributions are welcome! Please feel free to submit pull requests or open issues for bugs and feature requests.

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