rygwdn
MCP Serverrygwdnpublic

calendar app mcp

An MCP server for the macOS Calendar.app

Repository Info

1
Stars
0
Forks
1
Watchers
1
Issues
Python
Language
MIT License
License

About This Server

An MCP server for the macOS Calendar.app

Model Context Protocol (MCP) - This server can be integrated with AI applications to provide additional context and capabilities, enabling enhanced AI interactions and functionality.

Documentation

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 range
  • get_reminders: Retrieve reminders for a specific date range
  • list_calendars: List all available calendars
  • get_today_summary: Get a summary of today's events and reminders
  • search: Search for events and reminders containing a specific term
  • get_current_time: Get the current date and time in any timezone
  • convert_time: Convert a time from one timezone to another
  • list_timezones: List available timezones, optionally filtered by region

Resources

  • calendar://events/{date}: Access events for a specific date
  • calendar://calendars: Access the list of available calendars
  • datetime://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:

  1. Update the version number in pyproject.toml
  2. Run tests to verify everything works: uv run pytest --black --ruff
  3. Build the package: UV_NO_CONFIG=1 uv run python -m build
  4. Upload to PyPI:
    UV_NO_CONFIG=1 uv run twine upload dist/calendar_app_mcp-X.Y.Z*
    
    Replace X.Y.Z with the actual version number.
  5. Verify the package can be installed: uvx calendar-app-mcp@latest --version
  6. 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

Quick Start

1

Clone the repository

git clone https://github.com/rygwdn/calendar-app-mcp
2

Install dependencies

cd calendar-app-mcp
npm install
3

Follow the documentation

Check the repository's README.md file for specific installation and usage instructions.

Repository Details

Ownerrygwdn
Repocalendar-app-mcp
LanguagePython
LicenseMIT License
Last fetched8/10/2025

Recommended MCP Servers

💬

Discord MCP

Enable AI assistants to seamlessly interact with Discord servers, channels, and messages.

integrationsdiscordchat
🔗

Knit MCP

Connect AI agents to 200+ SaaS applications and automate workflows.

integrationsautomationsaas
🕷️

Apify MCP Server

Deploy and interact with Apify actors for web scraping and data extraction.

apifycrawlerdata
🌐

BrowserStack MCP

BrowserStack MCP Server for automated testing across multiple browsers.

testingqabrowsers

Zapier MCP

A Zapier server that provides automation capabilities for various apps.

zapierautomation