what is Calendar App MCP?
Calendar App MCP is an MCP (Model Context Protocol) server that provides access to macOS Calendar.app events and reminders for integration with AI assistants like Claude.
how to use Calendar App MCP?
To use Calendar App MCP, run it as an MCP server using the command uv run calendar-app mcp
, allowing AI assistants to interact with your calendar data.
key features of Calendar App MCP?
- Access to macOS Calendar.app events and reminders
- Filtering by date range, calendar names, and all-day/busy status
- Output formatting in JSON or Markdown
- Secure, local access to calendar data
use cases of Calendar App MCP?
- Integrating calendar data with AI assistants for event management.
- Checking upcoming events and finding free time slots.
- Accessing reminders and filtering events based on user preferences.
FAQ from Calendar App MCP?
- Can I use Calendar App MCP with any AI assistant?
Yes! Calendar App MCP is designed to work with any AI assistant that supports the MCP protocol.
- Is there a command-line interface for Calendar App MCP?
Yes! You can use it as a command-line tool to access calendar data directly with various commands.
- How do I install Calendar App MCP?
You can install it using the
uv
package manager with the commanduv install -e .
.
Calendar App MCP
An MCP (Model Context Protocol) server that provides access to macOS Calendar.app events and reminders for use with Claude and other AI assistants.
MCP Integration
This package can be run as an MCP server to integrate with Claude and other AI assistants supporting the MCP protocol, enabling them to access and interact with your macOS calendar data.
# Run as MCP server for AI assistant integration
uvx calendar-app-mcp # Automatically runs as MCP server with no arguments
uvx calendar-app-mcp mcp # Explicitly runs the MCP server
Once running, Claude can interact with your calendar data through the MCP protocol, allowing it to:
- Check your upcoming events
- Find free time slots
- View event details
- Access reminders
- Filter events by calendar, date range, and more
MCP Tools and Resources
This package provides several MCP tools and resources:
Tools
get_events
: Retrieve events for a specific date rangeget_reminders
: Retrieve reminders for a specific date rangelist_calendars
: List all available calendarsget_today_summary
: Get a summary of today's events and reminderssearch
: Search for events and reminders containing a specific termget_current_time
: Get the current date and time in any timezoneconvert_time
: Convert a time from one timezone to anotherlist_timezones
: List available timezones, optionally filtered by region
Resources
calendar://events/{date}
: Access events for a specific datecalendar://calendars
: Access the list of available calendarsdatetime://current/{timezone}
: Get the current time in a specific timezone
Prompts
daily_agenda
: Generate a prompt for reviewing your daily schedule
Features
- Access macOS Calendar.app events and reminders
- Filter by date range, calendar names, and all-day/busy status
- Format output as JSON or Markdown
- Secure, local access to calendar data
Installation
# Install from PyPI
pip install calendar-app-mcp
# Using uv
uv pip install calendar-app-mcp
# Using uvx (direct execution without installation)
uvx calendar-app-mcp calendars
uvx calendar-app-mcp mcp
Available Command Names
After installation, the package provides two command-line executables:
# General-purpose calendar app tool - shows help when run without arguments
calendar-app
# MCP-focused variant - defaults to running the MCP server when no arguments are provided
calendar-app-mcp
Both commands support the same subcommands, but calendar-app-mcp
is optimized for use as an MCP server.
Development Installation
# Clone the repository
git clone https://github.com/rygwdn/calendar-app-mcp.git
cd calendar-app-mcp
# Install uv package manager if not already installed
# https://github.com/astral-sh/uv
# Install the package in development mode
uv install -e .
# Install with development dependencies (for testing)
uv install -e '.[dev]'
CLI Usage
In addition to functioning as an MCP server, this package can be used as a command-line tool to access calendar data directly:
# List available calendars
uvx calendar-app-mcp calendars
# Get today's events and reminders
uvx calendar-app-mcp today
# Get only events
uvx calendar-app-mcp events
# Get only reminders
uvx calendar-app-mcp reminders
# Get both events and reminders
uvx calendar-app-mcp all
# Show JSON schema
uvx calendar-app-mcp schema
# Check version
uvx calendar-app-mcp --version
# or
uvx calendar-app-mcp version
Command Options
Most subcommands accept these options:
# Output in JSON format (default is markdown)
uvx calendar-app-mcp events --json
# Filter by date range
uvx calendar-app-mcp events --from 2024-12-01 --to 2024-12-31
# Filter by specific calendars
uvx calendar-app-mcp events --calendars "Work" "Personal"
# Only show all-day events
uvx calendar-app-mcp events --all-day-only
# Only show busy events
uvx calendar-app-mcp events --busy-only
# Include completed reminders
uvx calendar-app-mcp reminders --include-completed
Development
Using UV with Public PyPI Registry
To ensure UV uses the public PyPI registry rather than any locally configured repositories:
# Generate a lock file using only PyPI
UV_NO_CONFIG=1 uv lock
# Install dependencies using only PyPI
UV_NO_CONFIG=1 uv install
The UV_NO_CONFIG=1
environment variable tells UV to ignore any system-level configuration and use only the public PyPI registry.
Publishing to PyPI
To publish a new version to PyPI:
- Update the version number in
pyproject.toml
- Run tests to verify everything works:
uv run pytest --black --ruff
- Build the package:
UV_NO_CONFIG=1 uv run python -m build
- Upload to PyPI:
Replace X.Y.Z with the actual version number.UV_NO_CONFIG=1 uv run twine upload dist/calendar_app_mcp-X.Y.Z*
- Verify the package can be installed:
uvx calendar-app-mcp@latest --version
- Create and push a version tag:
git tag vX.Y.Z && git push origin vX.Y.Z
See the CLAUDE.md
file for more detailed instructions.
Running Tests
Run all tests:
python -m pytest
Run tests with coverage report:
python -m pytest --cov=calendar_app
Run specific test file:
python -m pytest tests/unit/utils/test_date_utils.py
Run specific test:
python -m pytest tests/unit/utils/test_date_utils.py::TestParseDate::test_valid_date