A Model Context Protocol (MCP) server that provides access to the Roman Catholic Liturgical Calendar API allowing retrieval of liturgical calendar data for any year, or for various nations, or dioceses.
The MCP server is a secure interface for AI assistants to access liturgical calendar data, providing a unified interface as a structured toolset for AI agents. This enables compliant AI systems (like ChatGPT MCP clients, LangChain agents, and custom LLM runtimes) to reason over liturgical dates, seasons, feasts, saints, and liturgical rankings with full contextual intelligence.
This MCP server provides a secure interface for AI assistants to access liturgical calendar data from the Liturgical Calendar API maintained by Rev. John R. D'Orazio. It supports querying the General Roman Calendar, national calendars, and diocesan calendars with historical accuracy from 1970 to 9999.
list_available_calendars- List all available national and diocesan calendars with their locales and settingsget_general_calendar- Retrieve the General Roman Calendar for a specific year with optional localeget_national_calendar- Retrieve the liturgical calendar for a specific nation (i.e. IT, US, NL, VA, CA...) and yearget_diocesan_calendar- Retrieve the liturgical calendar for a specific diocese and yearget_liturgy_of_the_day- Retrieve the liturgical celebrations for a specific date (or today if not specified), from any supported calendarget_announcement_easter_and_moveable_feasts- Retrieve the announcement of Easter and the moveable feasts (aka Noveritis) as pronounced on Epiphany for a specific year for any supported calendar
When retrieving national or diocesan calendars, the server automatically identifies and highlights celebrations that are particular (unique) to that calendar:
-
Hybrid Detection Approach: Events are marked as particular using two methods:
- Event Key Comparison - Events whose
event_keyis not found in the General Roman Calendar - Square Bracket Detection - Events with square brackets in their name (e.g.,
[USA],[Diocese of Rome])
- Event Key Comparison - Events whose
-
Intelligent Filtering: Weekday events (grade 0) are automatically excluded from particular celebrations, as they represent minor liturgical differences that are not significant enough to highlight
-
Use Cases:
- Identify patron saints specific to a nation or diocese
- Discover local feast days and memorials
- Compare regional liturgical variations
- Plan liturgical celebrations with local context
This feature helps distinguish between universal celebrations (found in the General Roman Calendar) and regional celebrations particular to specific nations or dioceses.
- Docker Desktop with MCP Toolkit enabled
- Docker MCP CLI plugin (
docker mcpcommand) - No authentication required - the API is publicly accessible
For more detailed information, see the step-by-step instructions and screenshots provided in the project wiki: Setting-up-Docker-MCP-Toolkit.
-
Install Docker Desktop
Download and install Docker Desktop from https://www.docker.com/products/docker-desktop/.
-
Enable Docker MCP Toolkit
Open the Docker Desktop settings and enable the MCP Toolkit under the "Beta Features" tab. You should now see the "MCP Toolkit" icon in the Docker Desktop left sidebar. Perhaps try enabling a tool from the catalog as a proof of concept, for example "Obsidian". Then connect the MCP Toolkit to a client like Claude Desktop. After restarting Claude Desktop, when clicking on the "Tools" icon below the chat prompt, you should see an "MCP_DOCKER" category, and clicking on the arrow next to that you should see available tool calls (for example obsidian tool calls if you enabled the Obsidian tool from the Docker MCP catalog).
-
Clone the repository
git clone https://github.com/CatholicOS/liturgical-calendar-mcp.git cd liturgical-calendar-mcp -
Build the Docker image
docker build -t liturgical-calendar-mcp . -
Update the Docker Desktop MCP catalog
Edit the file %USERPROFILE%\.docker\mcp\catalogs\docker-mcp.yaml, and paste this at the end:
litcal:
description: "Access Roman Catholic Liturgical Calendar data for any year, nation, or diocese from 1970-9999"
title: "Liturgical Calendar"
type: server
dateAdded: "2025-10-22T00:00:00Z"
image: litcal-mcp-server:latest
ref: ""
readme: ""
toolsUrl: ""
source: ""
upstream: ""
icon: ""
tools:
- name: get_general_calendar
- name: get_national_calendar
- name: get_diocesan_calendar
- name: list_available_calendars
- name: get_liturgy_of_the_day
- name: get_announcement_easter_and_moveable_feasts
metadata:
category: integration
tags:
- catholic
- liturgy
- calendar
- religious
license: MIT
owner: locallitcal should be a descendant of registry.
Edit the file %USERPROFILE%\.docker\mcp\registry.yaml, and paste this at the end:
litcal:
ref: ""Again, litcal should be a descendant of registry.
No need to start any containers, Docker MCP Toolkit will spin up the tool container on demand when an agent attempts to access the tool.
Try with Claude Desktop: if it was already started, exit Claude Desktop completely (make sure it is not running in the background in the tray) and start it again.
You should now see the "Liturgical Calendar" tool in the tools list under MCP_DOCKER category.
Note
Docker MCP Toolkit only officially supports MCP servers already published in the online catalog,
so every time you restart Docker Desktop it will remove any custom entries in the registry.yaml and catalogs/docker-mcp.yaml files.
If you find that the tool calls suddenly stop working, you may have to manually update the registry.yaml and catalogs/docker-mcp.yaml files again.
If you want to run the MCP server locally and integrate it with Claude Desktop or VS Code without the Docker MCP Toolkit, see CLAUDE_VSCODE_INSTALL.md for step-by-step instructions.
The MCP server can be customized through a user configuration file. This allows you to adjust API endpoints, cache settings, and more without modifying the codebase.
-
Copy the example configuration file:
cp litcal.config.example.yaml litcal.config.yaml
-
Edit
litcal.config.yamlwith your preferred settings:# API Configuration api_base_url: "https://litcal.johnromanodorazio.com/api/dev" default_timeout: 30 # Cache Configuration metadata_cache_expiry_hours: 24 calendar_cache_expiry_hours: 168 cache_dir: "./cache"
-
Your
litcal.config.yamlfile is automatically ignored by git and will not be committed.
api_base_url- Base URL for the Liturgical Calendar API (default:https://litcal.johnromanodorazio.com/api/dev)default_timeout- Timeout for API requests in seconds (default:30)
metadata_cache_expiry_hours- How long to cache the list of available calendars (default:24hours)calendar_cache_expiry_hours- How long to cache liturgical calendar data (default:168hours / 1 week)cache_dir- Directory for cache files, absolute or relative to project root (default:./cache)
You can also override any configuration setting using environment variables (highest priority):
LITCAL_API_BASE_URLLITCAL_DEFAULT_TIMEOUTLITCAL_METADATA_CACHE_EXPIRY_HOURSLITCAL_CALENDAR_CACHE_EXPIRY_HOURSLITCAL_CACHE_DIR
Example:
export LITCAL_DEFAULT_TIMEOUT=60
python litcal_server.pySettings are loaded in the following order (highest priority first):
- Environment variables
- User configuration file (
litcal.config.yaml) - Default settings (
settings.py)
In Claude Desktop, you can ask:
- "List all available national liturgical calendars"
- "Show me the liturgical calendar for the United States in 2024"
- "What is the calendar for the Diocese of Rome for this year?"
- "What liturgical events are celebrated in Canada?"
- "What are the particular celebrations for Italy this year?"
- "Show me the patron saints and local feasts for the Diocese of Boston"
- "Get the liturgy of the day"
- "Get the liturgy of the day for the Diocese of Rome"
- "Get the liturgy of the day for the Diocese of Rome for 2024"
- "Get the liturgy for September 8th 3036 for the United States"
flowchart LR
ClaudeDesktop --> MCPGateway --> LiturgicalCalendarMCPServer --> LiturgicalCalendarAPI
- Base URL: https://litcal.johnromanodorazio.com/api/dev
- Documentation: openapi.json Based on OpenAPI 3.1.0 specification
- License: Apache 2.0
- Maintainer: Rev. John R. D'Orazio
- Supported Years: 1970-9999
- Available Locales: en, fr, it, la, nl
The universal calendar for the Roman Catholic Church
- IT - Italy
- US - United States
- NL - Netherlands
- VA - Vatican
- CA - Canada
Various dioceses within national territories (use list_available_calendars to see all)
# Run directly
python3.12 -m venv venv
source venv/bin/activate
pip install -r requirements.txt -r requirements-dev.txt
python litcal_server.py
# Ctrl+C to stop (you may have to do so a few times)
# Test MCP protocol
python test_mcp_list_tools.py | python litcal_server.py | jq
# This should output, in pretty-printed JSON format, the tools made available by the MCP server
# Ctrl+C to stop
# There are a few other similar test scripts for testing the various tool calls- Add the function to
litcal_server.py - Decorate with
@mcp.tool() - Ensure all parameters have well defined types
- Method docstring should summarize the purpose of the tool, and explain how the parameters should be implemented, possibly offering a few examples; the LLM reads the docstring, which therefore gives it context on how to use the tool
- Return formatted strings with emojis
- Rebuild the Docker image
- Verify Docker image built successfully:
docker images | grep litcal - Check catalog and registry files for correct formatting
- Ensure Docker Desktop MCP config files include the
litcaltool - Restart Claude Desktop completely
- Verify internet connectivity
- Check API status at https://litcal.johnromanodorazio.com/api/dev
- Use
list_available_calendarsto see valid nation and diocese codes - Nation codes must be uppercase ISO 3166-1 alpha-2 codes (
IT,US,NL,VA,CA) - Diocese codes are lowercase with underscore (
romamo_it,boston_us)
The Liturgical Calendar API strives for historical accuracy:
- Based on original sources (Roman Missals, Vatican decrees)
- Memorials and feast days only generated from their introduction year
- Follows Mysterii Paschalis and other liturgical documents
- Not copied from potentially inaccurate online sources
Events are graded by importance (0-7):
- 0 - Weekday
- 1 - Commemoration
- 2 - Optional Memorial
- 3 - Memorial
- 4 - Feast
- 5 - Feast of the Lord
- 6 - Solemnity
- 7 - Higher Solemnity (takes precedence over regular solemnities)
- No authentication required (public API)
- Running as non-root user in container
- All data is read-only
- No sensitive information handled
Apache 2.0 License
Liturgical Calendar API created and maintained by Rev. John R. D'Orazio API Documentation: Swagger UI
Note: This server accesses a development API endpoint. For production use, consider using the stable API endpoint when available.
This MCP server is part of a broader initiative to make the liturgical, biblical, and canonical patrimony of the Church accessible to AI systems in a faithful and structured way.
“Missionaries have always gone with Christ to new frontiers, while the Holy Spirit pushed and preceded them” (SR 17c). We can only regard this so-called new continent with the zeal of a Francis Xavier or a Mother Cabrini. — Cardinal Michael Czerny, A New World and a New Mission