Skip to main content

MCP server for managing Apple Reminders on macOS

Project description

Apple Reminders MCP Server

PyPI version Python 3.10+ License: MIT Tests

A Model Context Protocol (MCP) server that enables AI assistants to interact with Apple Reminders on macOS. This server provides tools to create, read, list, and delete reminders programmatically through AppleScript.

Features

  • ✅ Create reminders with due dates, times, notes, and locations
  • 📋 List all reminder lists
  • 🔍 Fetch reminders from specific lists (completed or pending)
  • 🗑️ Delete reminders by name
  • 🤖 Compatible with Claude Desktop and other MCP clients
  • 🍎 Native macOS integration via AppleScript
  • 🔒 Input sanitization to prevent AppleScript injection

Demo

https://github.com/user-attachments/assets/d36e0df3-ff4b-4f48-bb29-41ddb5483c6b

Prerequisites

  • macOS (required for AppleScript)
  • Python 3.10 or higher
  • Apple Reminders app

Installation

Option 1: Install from PyPI (Recommended)

pip install apple-reminders-mcp

Option 2: Install from source

git clone https://github.com/shreyanshjain05/apple_reminder_mcp_server.git
cd apple_reminder_mcp_server
pip install -e .

Usage

Running the Server

If installed via pip:

apple-reminders-mcp

Or run directly:

python -m apple_reminders_mcp.server

Testing with MCP Inspector

npx @modelcontextprotocol/inspector python3 server.py

This will:

  • Start a proxy server on localhost:6277
  • Open the inspector interface in your browser at http://localhost:6274
  • Display a session token for authentication

Integration with Claude Desktop

Add to your Claude Desktop configuration file:

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

{
  "mcpServers": {
    "apple-reminders": {
      "command": "python3",
      "args": ["/path/to/apple_reminder_mcp_server/server.py"]
    }
  }
}

Note: Replace /path/to/ with the actual path where you cloned the repo. If you get "Server disconnected" errors, use the full path to your Python executable (run which python3 to find it).

Available Tools

1. create_reminder

Creates a new reminder in Apple Reminders.

Parameters:

  • title (required): The title of the reminder
  • due_date (required): Due date (e.g., "2024-12-25", "tomorrow", "next Friday")
  • due_time (optional): Time in HHMMSS format (default: 090000 for 9 AM)
  • notes (optional): Additional notes/body text
  • list_name (optional): Target list name (default: "Reminder Created using Agent")
  • location (optional): Location for location-based reminders

Example:

{
  "title": "Team Meeting",
  "due_date": "tomorrow",
  "due_time": "140000",
  "notes": "Discuss Q1 goals",
  "list_name": "Work"
}

2. get_reminder

Fetches reminders from a specific list.

Parameters:

  • list_name (required): Name of the reminder list
  • completed (optional): Whether to fetch completed reminders (default: false)
  • limit (optional): Maximum number of reminders to return (default: 20)

3. list_reminder_lists

Returns all available reminder lists. No parameters required.

4. delete_reminder

Deletes a reminder by name.

Parameters:

  • name (required): The exact name of the reminder to delete
  • list_name (optional): Specific list to search in (searches all lists if not provided)

Troubleshooting

Common Issues

  1. Permission errors with AppleScript

    • Grant Terminal/IDE permission to control Reminders in System Preferences → Security & Privacy → Automation
  2. "No reminder list found" error

    • Make sure the list name exactly matches (case-sensitive)
    • Use list_reminder_lists to see available lists
  3. Date parsing errors

    • Use standard formats like "YYYY-MM-DD" or natural language like "tomorrow"

Development

Running Tests

pip install -e ".[dev]"
pytest tests/ -v

Project Structure

apple_reminder_mcp_server/
├── apple_reminders_mcp/
│   ├── __init__.py
│   └── server.py          # Main MCP server implementation
├── tests/
│   └── test_server.py     # Unit tests
├── .github/workflows/
│   ├── test.yml           # CI testing
│   └── publish.yml        # PyPI publishing
├── pyproject.toml         # Package configuration
└── README.md

Contributing

See CONTRIBUTING.md for guidelines.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgments

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

apple_reminders_mcp-0.1.0.tar.gz (8.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

apple_reminders_mcp-0.1.0-py3-none-any.whl (17.5 kB view details)

Uploaded Python 3

File details

Details for the file apple_reminders_mcp-0.1.0.tar.gz.

File metadata

  • Download URL: apple_reminders_mcp-0.1.0.tar.gz
  • Upload date:
  • Size: 8.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for apple_reminders_mcp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 dc63bb621203fdaa952cf8e632ab63615c49d53eb6b37b6a40b6403b5ab3e6d6
MD5 21c13a5129b1d32b3c9f43db86a086b4
BLAKE2b-256 28a894f809ec91abc7ab40a885fada8854405120d634d248b3d2f2bbd7a1a109

See more details on using hashes here.

Provenance

The following attestation bundles were made for apple_reminders_mcp-0.1.0.tar.gz:

Publisher: publish.yml on shreyanshjain05/apple_reminder_mcp_server

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file apple_reminders_mcp-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for apple_reminders_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4b1b020dd77ffaae2f88d23494afee5a4510703a95046d7ef39ff88c90e4e985
MD5 d128ef20b75d08b76069f4039dd3c06d
BLAKE2b-256 cd1d4751cdf2352cd94a73d744b82af62711e3c46522ce37f45956eab8893a97

See more details on using hashes here.

Provenance

The following attestation bundles were made for apple_reminders_mcp-0.1.0-py3-none-any.whl:

Publisher: publish.yml on shreyanshjain05/apple_reminder_mcp_server

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page