Skip to main content

MCP server exposing a remote iCalendar (webcal) feed as queryable read-only tools

Project description

webcal-mcp

A small read-only Model Context Protocol server that exposes one or more remote iCalendar feeds (the webcal:// or .ics kind) as queryable tools for an LLM agent.

Install

pipx install webcal-mcp

Or from a checkout:

pipx install .

This puts a webcal-mcp script on your PATH. Python 3.10 or later is required.

Configure

Create ~/.config/webcal-mcp/config.toml (or point WEBCAL_MCP_CONFIG at any other path). See config.example.toml:

default_ttl_seconds = 900

[calendars.personal]
url = "webcal://example.com/personal.ics"
description = "Personal calendar"

[calendars.work]
url = "https://example.com/work.ics"
description = "Work calendar"

webcal:// and webcals:// URLs are normalized to https://.

Local calendars via EventKit (macOS)

On macOS, any calendar already set up in Calendar.app — iCloud, local, subscribed .ics, CalDAV, Google — can be read directly through Apple's EventKit framework. No webcal:// URL hunting required:

[calendars.personal]
source = "eventkit"
identifier = "Personal"   # display name from Calendar.app, or its UUID
description = "iCloud personal calendar"

identifier matches the calendar's display name first, then falls back to its UUID. Run webcal-mcp list-eventkit to see what's available (this dumps title uuid [source] for every calendar).

First use triggers a one-time TCC prompt for Calendar access; the grant is bound to the binary that invokes EventKit (the Python interpreter behind webcal-mcp), so re-granting may be needed if you reinstall. The PyObjC dependency installs automatically on macOS only.

Run

webcal-mcp

The server speaks MCP over stdio. Wire it into an MCP-aware client (Claude Desktop, Claude Code, etc.) by pointing at the webcal-mcp script. For example, for Claude Code:

claude mcp add webcal -- webcal-mcp

Tools

Tool Purpose
list_calendars Names, descriptions, capability flags for the configured calendars. Re-reads the config file, so calendars added or changed since startup appear without restarting the server.
list_events Events in a date range, with optional query, categories, location filters and brief / full / markdown detail modes. Either bound may be omitted for open-ended windows.
events_on All events occurring on a given date.
get_event Full record for a single UID.

Recurring events are expanded within the requested window. Responses are cached in memory with a per-calendar TTL; revalidation uses HTTP ETag and Last-Modified.

Read-only

Calendars are read-only today. The CalendarSource abstraction reserves a writable capability flag so future write-capable backends can be added without changing the tool surface.

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

webcal_mcp-0.1.3.tar.gz (19.1 kB view details)

Uploaded Source

Built Distribution

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

webcal_mcp-0.1.3-py3-none-any.whl (17.1 kB view details)

Uploaded Python 3

File details

Details for the file webcal_mcp-0.1.3.tar.gz.

File metadata

  • Download URL: webcal_mcp-0.1.3.tar.gz
  • Upload date:
  • Size: 19.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for webcal_mcp-0.1.3.tar.gz
Algorithm Hash digest
SHA256 bac14730c1af6ef8ed22894ab86ad9e271652456905d6d6fcc9dfc5c26c82acc
MD5 98eb08b63f7c29588bc0aa26bd59f94c
BLAKE2b-256 1452e7a55193f8086df2e276b3f7d742d5ae57436c711255daceb69fd7e21f12

See more details on using hashes here.

Provenance

The following attestation bundles were made for webcal_mcp-0.1.3.tar.gz:

Publisher: publish.yml on mnot/webcal-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 webcal_mcp-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: webcal_mcp-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 17.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for webcal_mcp-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 7f0e0ddfa5852db2a32138a0e82c0cb186f6f19d675140ee2476713280583d77
MD5 2f8c0fad092808e2fbe971f8253862d8
BLAKE2b-256 752a38691d440837350fc1747a733801431e2cf443d67ded432fcb00451f10fb

See more details on using hashes here.

Provenance

The following attestation bundles were made for webcal_mcp-0.1.3-py3-none-any.whl:

Publisher: publish.yml on mnot/webcal-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