Skip to main content

Read-only Mac Calendar MCP server with indexed archive search.

Project description

Mac Calendar MCP

Python 3.11+ License: GPL v3 macOS MCP Code style: ruff

Read-only Mac Calendar MCP server with indexed archive search. It exposes Apple Calendar data to MCP clients through a small read surface for listing calendars, browsing event ranges, reading event details, searching archived events, and building agendas.

This package is developed in the apple-app-mcp workspace alongside Mac Mail MCP.

Quick Start

pipx install mac-calendar-mcp

Add to your MCP client:

{
  "mcpServers": {
    "calendar": {
      "command": "mac-calendar-mcp",
      "args": ["--watch", "serve"]
    }
  }
}

Build the Search Index (Recommended)

# Requires Calendar automation permission for Terminal or your MCP client
# System Settings -> Privacy & Security -> Automation

mac-calendar-mcp index

The index enables fast archive search and date-range reads from a local SQLite and FTS5 database.

Run the MCP server with watch mode to periodically refresh the index while events change in Calendar.app:

mac-calendar-mcp --watch serve

Watch mode defaults to a 300-second refresh interval. Override it with --watch-interval SECONDS when you need faster updates.

Configure (Optional)

Mac Calendar MCP reads settings from environment variables and an optional TOML config file at $HOME/.mac-calendar-mcp/config.toml.

Common environment variables:

Variable Purpose
APPLE_CALENDAR_INDEX_PATH Override the SQLite index location.
APPLE_CALENDAR_INDEX_STALENESS_HOURS Hours before an index is considered stale.
APPLE_CALENDAR_INDEX_PAST_YEARS Limit historical indexing window.
APPLE_CALENDAR_INDEX_FUTURE_YEARS Limit future indexing window.
APPLE_CALENDAR_DEFAULT_CALENDARS Comma-separated default calendar names or IDs.

Tools

Tool Purpose
list_calendars() List accessible calendars
get_events(start, end, calendar_ids?, limit?, offset?) List event occurrences in a date range
get_event(event_id, occurrence_start?) Get full event or occurrence detail
search_events(query, start?, end?, calendar_ids?, fields?, limit?, offset?) Search indexed event archives
get_agenda(start?, days?, calendar_ids?) Chronological agenda helper
calendar_index_status() Index health and coverage summary

All tools are read-only. The server does not create, update, delete, RSVP, subscribe to calendars, or open Calendar.app UI in v1.

Search and Indexing

Calendar search is backed by SQLite and FTS5. Indexed fields include event title, location, notes, URL, attendee names/emails, and calendar name.

Recurring events are expanded into occurrence rows for listing and search. The current recurrence layer supports common daily, weekly, monthly, and yearly patterns, including intervals, counts, until dates, weekly BYDAY, and Calendar exception dates. Unsupported recurrence rules are counted in index status instead of being silently treated as complete.

Configuration

Per-client env overrides via the MCP client's launch config work:

{
  "mcpServers": {
    "calendar": {
      "command": "mac-calendar-mcp",
      "env": {
        "APPLE_CALENDAR_DEFAULT_CALENDARS": "Work,Personal",
        "APPLE_CALENDAR_INDEX_FUTURE_YEARS": "2"
      }
    }
  }
}

The default index path is $HOME/.mac-calendar-mcp/index.db.

CLI Usage

All read tools are also available as standalone CLI commands:

mac-calendar-mcp calendars
mac-calendar-mcp index
mac-calendar-mcp status
mac-calendar-mcp search "quarterly planning" --limit 10
mac-calendar-mcp events 2026-05-01 2026-06-01 --limit 50
mac-calendar-mcp agenda --days 7
mac-calendar-mcp rebuild

All data commands output JSON where practical.

Development

git clone https://github.com/wagamama/apple-app-mcp
cd apple-app-mcp
uv sync
uv run ruff check packages/mac-calendar-mcp/src
uv run --package mac-calendar-mcp pytest packages/mac-calendar-mcp/tests
uv build --package mac-calendar-mcp

See CALENDAR.md for domain architecture, tool design, testing guidance, and implementation notes.

License

GPL-3.0-or-later

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

mac_calendar_mcp-0.5.0.tar.gz (20.1 kB view details)

Uploaded Source

Built Distribution

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

mac_calendar_mcp-0.5.0-py3-none-any.whl (21.0 kB view details)

Uploaded Python 3

File details

Details for the file mac_calendar_mcp-0.5.0.tar.gz.

File metadata

  • Download URL: mac_calendar_mcp-0.5.0.tar.gz
  • Upload date:
  • Size: 20.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for mac_calendar_mcp-0.5.0.tar.gz
Algorithm Hash digest
SHA256 838ab609c550d6e1e38bee2ef8d444d18d471db3ebe1d8a642d516a5dbb9cd64
MD5 4cdded5c26a0585c6ae4049123764159
BLAKE2b-256 0a2896b44ed3b69c391c56f085db91311c4a65fcfbd23a7826c6661bdfb416d8

See more details on using hashes here.

Provenance

The following attestation bundles were made for mac_calendar_mcp-0.5.0.tar.gz:

Publisher: release.yml on wagamama/apple-app-mcp

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

File details

Details for the file mac_calendar_mcp-0.5.0-py3-none-any.whl.

File metadata

File hashes

Hashes for mac_calendar_mcp-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ae6503e66ebb1f972113e55a04b552d6fe2b7ab49f3c675b12407e17aa450c7c
MD5 c05a3528dc12750f07bfac8a62e92569
BLAKE2b-256 732fda7b12a7c9db7bf647d655c031c0fab410fa3abf1e806f20b69e06b932af

See more details on using hashes here.

Provenance

The following attestation bundles were made for mac_calendar_mcp-0.5.0-py3-none-any.whl:

Publisher: release.yml on wagamama/apple-app-mcp

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