MCP server for managing Apple Reminders on macOS
Project description
Apple Reminders MCP Server
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 (runwhich python3to find it).
Available Tools
1. create_reminder
Creates a new reminder in Apple Reminders.
Parameters:
title(required): The title of the reminderdue_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 textlist_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 listcompleted(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 deletelist_name(optional): Specific list to search in (searches all lists if not provided)
Troubleshooting
Common Issues
-
Permission errors with AppleScript
- Grant Terminal/IDE permission to control Reminders in System Preferences → Security & Privacy → Automation
-
"No reminder list found" error
- Make sure the list name exactly matches (case-sensitive)
- Use
list_reminder_liststo see available lists
-
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
- Built with FastMCP
- Uses AppleScript for native macOS integration
- Compatible with the Model Context Protocol
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dc63bb621203fdaa952cf8e632ab63615c49d53eb6b37b6a40b6403b5ab3e6d6
|
|
| MD5 |
21c13a5129b1d32b3c9f43db86a086b4
|
|
| BLAKE2b-256 |
28a894f809ec91abc7ab40a885fada8854405120d634d248b3d2f2bbd7a1a109
|
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
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
apple_reminders_mcp-0.1.0.tar.gz -
Subject digest:
dc63bb621203fdaa952cf8e632ab63615c49d53eb6b37b6a40b6403b5ab3e6d6 - Sigstore transparency entry: 830933122
- Sigstore integration time:
-
Permalink:
shreyanshjain05/apple_reminder_mcp_server@6e25f9db6f5ce965abd5362fcb8169cae6f53ef9 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/shreyanshjain05
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@6e25f9db6f5ce965abd5362fcb8169cae6f53ef9 -
Trigger Event:
release
-
Statement type:
File details
Details for the file apple_reminders_mcp-0.1.0-py3-none-any.whl.
File metadata
- Download URL: apple_reminders_mcp-0.1.0-py3-none-any.whl
- Upload date:
- Size: 17.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4b1b020dd77ffaae2f88d23494afee5a4510703a95046d7ef39ff88c90e4e985
|
|
| MD5 |
d128ef20b75d08b76069f4039dd3c06d
|
|
| BLAKE2b-256 |
cd1d4751cdf2352cd94a73d744b82af62711e3c46522ce37f45956eab8893a97
|
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
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
apple_reminders_mcp-0.1.0-py3-none-any.whl -
Subject digest:
4b1b020dd77ffaae2f88d23494afee5a4510703a95046d7ef39ff88c90e4e985 - Sigstore transparency entry: 830933170
- Sigstore integration time:
-
Permalink:
shreyanshjain05/apple_reminder_mcp_server@6e25f9db6f5ce965abd5362fcb8169cae6f53ef9 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/shreyanshjain05
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@6e25f9db6f5ce965abd5362fcb8169cae6f53ef9 -
Trigger Event:
release
-
Statement type: