business-day-mcp
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@business-day-mcpIs July 4, 2025 a business day in the US?"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
business-day-mcp
MCP server for business-day arithmetic with country-aware holiday calendars (fastmcp + holidays).
What is this?
business-day-mcp exposes business-day math — "is today a business day?", "next business day after X", "how many business days between A and B?" — as tools an MCP client can call. Holiday calendars are provided by the holidays library and cover 60+ countries, with optional regional subdivisions. It is intended for use with MCP clients such as Claude Desktop, Kiro, and any other tool that speaks the Model Context Protocol. Requires Python >= 3.10.
Example questions it can answer:
Is today a business day in Germany?
When is the last business day of April 2026?
How many business days between Apr 21 and May 5 in the US?
Features / Tools
get_current_date— current date in a given IANA timezone.is_business_day— check whether a date is a business day for a country (+ optional subdivision).next_business_day/previous_business_day— step forward/backward by N business days.last_business_day_of_month— last business day of a given month.business_days_between— count business days between two dates.list_holidays— holidays for a country/year (+ optional subdivision).get_supported_countries— supported ISO 3166-1 alpha-2 codes and their subdivisions.get_supported_subdivisions— subdivisions and aliases for a single country.
All tools are read-only and safe to auto-approve.
Install
From the package
uvx business-day-mcpOr persistent install:
pip install business-day-mcpRun the server:
business-day-mcp
# or
python -m business_day_mcpFrom source
git clone https://github.com/fbdo/business-day-mcp.git
cd business-day-mcp
uv sync --all-extras
uv run business-day-mcpRun the test suite (coverage must stay ≥ 90%):
uv run pytestConfigure
Add to your mcp.json:
{
"mcpServers": {
"business-day-mcp": {
"command": "uvx",
"args": ["business-day-mcp"],
"autoApprove": [
"get_current_date",
"is_business_day",
"next_business_day",
"previous_business_day",
"last_business_day_of_month",
"business_days_between",
"list_holidays",
"get_supported_countries",
"get_supported_subdivisions"
]
}
}
}From a local clone
Run uv sync --all-extras in the cloned repo first, then replace /absolute/path/to/business-day-mcp below with the clone's absolute path (you can copy the same autoApprove array from the package example above if desired):
{
"mcpServers": {
"business-day": {
"command": "uv",
"args": [
"--directory",
"/absolute/path/to/business-day-mcp",
"run",
"business-day-mcp"
]
}
}
}Usage Examples
The examples below show typical agent questions and the actual JSON returned by the server. Dates reflect the real 2025/2026 calendars from the holidays library.
Is this a business day?
"Is July 4, 2025 a business day in the US?"
Tool call: is_business_day(date="2025-07-04", country="US")
{
"date": "2025-07-04",
"country": "US",
"is_business_day": false,
"is_weekend": false,
"is_holiday": true,
"holiday_name": "Independence Day"
}Today's date in a specific timezone
"What's today's date in New York?"
Tool call: get_current_date(timezone="America/New_York")
{
"date": "2026-04-23",
"timezone": "America/New_York",
"day_of_week": "Thursday",
"iso_week": 17
}Next business day
"I'm scheduling a task for July 3, 2025 in the US. What's the next business day after that?"
Tool call: next_business_day(date="2025-07-03", country="US")
{
"input_date": "2025-07-03",
"next_business_day": "2025-07-07",
"country": "US",
"skipped_days": 4
}Previous business day
"What was the last business day before July 4, 2025 in the US?"
Tool call: previous_business_day(date="2025-07-04", country="US")
{
"input_date": "2025-07-04",
"previous_business_day": "2025-07-03",
"country": "US",
"skipped_days": 1
}Last business day of the month
"When is the last business day of May 2026 in the US?"
Tool call: last_business_day_of_month(year=2026, month=5, country="US")
{
"year": 2026,
"month": 5,
"country": "US",
"last_business_day": "2026-05-29",
"last_calendar_day": "2026-05-31"
}Business days between two dates
"How many business days are between December 20, 2025 and January 5, 2026 in the US?"
Tool call: business_days_between(start_date="2025-12-20", end_date="2026-01-05", country="US")
{
"start_date": "2025-12-20",
"end_date": "2026-01-05",
"country": "US",
"inclusive": false,
"business_days": 8,
"calendar_days": 16,
"holidays_in_range": [
{ "date": "2025-12-25", "name": "Christmas Day" },
{ "date": "2026-01-01", "name": "New Year's Day" }
]
}List holidays for a year (regional subdivision)
"List the 2026 public holidays in Bavaria, Germany."
Tool call: list_holidays(year=2026, country="DE", subdiv="BY")
{
"year": 2026,
"country": "DE",
"holidays": [
{ "date": "2026-01-01", "name": "New Year's Day" },
{ "date": "2026-01-06", "name": "Epiphany" },
{ "date": "2026-04-03", "name": "Good Friday" },
{ "date": "2026-04-06", "name": "Easter Monday" },
{ "date": "2026-05-01", "name": "Labor Day" },
{ "date": "2026-05-14", "name": "Ascension Day" },
{ "date": "2026-05-25", "name": "Whit Monday" },
{ "date": "2026-06-04", "name": "Corpus Christi" },
{ "date": "2026-10-03", "name": "German Unity Day" },
{ "date": "2026-11-01", "name": "All Saints' Day" },
{ "date": "2026-12-25", "name": "Christmas Day" },
{ "date": "2026-12-26", "name": "Second Day of Christmas" }
],
"subdiv": "BY"
}Discover supported subdivisions
"Which German states (subdivisions) can I use for holiday lookups?"
Tool call: get_supported_subdivisions(country="DE")
{
"country": "DE",
"subdivisions": ["BB","BE","BW","BY","HB","HE","HH","MV","NI","NW","RP","SH","SL","SN","ST","TH","Augsburg"],
"aliases": {
"Brandenburg": "BB",
"Berlin": "BE",
"Baden-Württemberg": "BW",
"Bayern": "BY",
"Bremen": "HB",
"Hessen": "HE",
"Hamburg": "HH",
"Mecklenburg-Vorpommern": "MV",
"Niedersachsen": "NI",
"Nordrhein-Westfalen": "NW",
"Rheinland-Pfalz": "RP",
"Schleswig-Holstein": "SH",
"Saarland": "SL",
"Sachsen": "SN",
"Sachsen-Anhalt": "ST",
"Thüringen": "TH"
}
}See
get_supported_countries()for the full list of 250+ supported countries and their subdivision codes.
Conventions
Dates: ISO 8601 strings (
YYYY-MM-DD).Countries: ISO 3166-1 alpha-2 codes (
DE,US,GB, ...) — case-insensitive.Timezones: IANA names (
Europe/Berlin,America/New_York, ...).Subdivisions (optional): country-specific region codes (
BYfor Bavaria,CAfor California, ...). Case-sensitive — pass exactly as returned byget_supported_countries. Omit to get nation-wide holidays only.
Regional subdivisions: all country-aware tools (is_business_day, next_business_day, previous_business_day, last_business_day_of_month, business_days_between, list_holidays) accept an optional subdiv parameter. Example: country="DE", subdiv="BY" treats Epiphany (Jan 6) as a holiday in Bavaria. Discover valid codes via get_supported_countries (returns a subdivisions: list[str] per country; [] for countries without regional variants, e.g. JP). For a single-country lookup that also includes alias names (e.g. "Bavaria" → "BY"), use get_supported_subdivisions(country="DE") — returns {subdivisions: ["BY", ...], aliases: {"Bavaria": "BY", ...}}.
Contributing
Contributions are welcome. See CONTRIBUTING.md for build, test, issue, and pull request guidelines. The project repo is at https://github.com/fbdo/business-day-mcp.
License
This project is licensed under the MIT License. See LICENSE.
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/fbdo/business-day-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server