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
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 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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bac14730c1af6ef8ed22894ab86ad9e271652456905d6d6fcc9dfc5c26c82acc
|
|
| MD5 |
98eb08b63f7c29588bc0aa26bd59f94c
|
|
| BLAKE2b-256 |
1452e7a55193f8086df2e276b3f7d742d5ae57436c711255daceb69fd7e21f12
|
Provenance
The following attestation bundles were made for webcal_mcp-0.1.3.tar.gz:
Publisher:
publish.yml on mnot/webcal-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
webcal_mcp-0.1.3.tar.gz -
Subject digest:
bac14730c1af6ef8ed22894ab86ad9e271652456905d6d6fcc9dfc5c26c82acc - Sigstore transparency entry: 1663238215
- Sigstore integration time:
-
Permalink:
mnot/webcal-mcp@43cd65ae29d0dd4305ac0d2d87b7fdd7fdd05427 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/mnot
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@43cd65ae29d0dd4305ac0d2d87b7fdd7fdd05427 -
Trigger Event:
push
-
Statement type:
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7f0e0ddfa5852db2a32138a0e82c0cb186f6f19d675140ee2476713280583d77
|
|
| MD5 |
2f8c0fad092808e2fbe971f8253862d8
|
|
| BLAKE2b-256 |
752a38691d440837350fc1747a733801431e2cf443d67ded432fcb00451f10fb
|
Provenance
The following attestation bundles were made for webcal_mcp-0.1.3-py3-none-any.whl:
Publisher:
publish.yml on mnot/webcal-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
webcal_mcp-0.1.3-py3-none-any.whl -
Subject digest:
7f0e0ddfa5852db2a32138a0e82c0cb186f6f19d675140ee2476713280583d77 - Sigstore transparency entry: 1663238344
- Sigstore integration time:
-
Permalink:
mnot/webcal-mcp@43cd65ae29d0dd4305ac0d2d87b7fdd7fdd05427 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/mnot
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@43cd65ae29d0dd4305ac0d2d87b7fdd7fdd05427 -
Trigger Event:
push
-
Statement type: