MCP server for GSA Per Diem Rates API. Federal travel lodging and M&IE rates for IGCEs and travel cost estimation.
Project description
gsa-perdiem-mcp
MCP server for the GSA Per Diem Rates API. Federal travel lodging and M&IE rates for IGCEs and travel cost estimation.
Works without configuration using DEMO_KEY. Optional free API key for higher rate limits.
Tested and hardened through six rounds of integration testing against the live GSA Per Diem API, including a round-6 live audit with a real api.data.gov key. 172 regression tests covering 1 P0 path-traversal bug, 23 P1 silent-wrong-data bugs, and 21 P2 validation gaps fixed. See TESTING.md for the full testing record.
What it does
Exposes the GSA Per Diem API as 6 MCP tools:
Core lookups
lookup_city_perdiem- Rates by city/state (auto-selects best NSA match)lookup_zip_perdiem- Rates by ZIP codelookup_state_rates- All NSA rates for a stateget_mie_breakdown- M&IE tier table (meal components)
Workflow
estimate_travel_cost- Calculate trip per diem (lodging + M&IE with first/last day at 75%)compare_locations- Compare rates across multiple cities
Get your own API key (strongly recommended)
This server hits api.gsa.gov, which uses api.data.gov for rate limiting.
- Without a key: falls back to the shared
DEMO_KEYwhich is capped at ~10 requests per hour across everyone using it. A couple real prompts will blow through that limit and you'll start seeing 429 errors. - With a personal key: 1,000 requests per hour, yours alone.
Get a free key (takes 30 seconds):
- Go to api.data.gov/signup
- Enter your name and email — no approval, no wait
- Copy the key from the confirmation page
- Paste it into your Claude Desktop config as
PERDIEM_API_KEY(see below)
The same key works for every api.data.gov-backed API (GSA Per Diem, NASA, FEC, FCC, etc.).
Installation
uvx gsa-perdiem-mcp
Claude Desktop configuration
Recommended (with your own key):
{
"mcpServers": {
"gsa-perdiem": {
"command": "uvx",
"args": ["gsa-perdiem-mcp"],
"env": {
"PERDIEM_API_KEY": "paste-your-api-data-gov-key-here"
}
}
}
}
Without a key (works for a handful of calls per hour, then 429s until the hour rolls over):
{
"mcpServers": {
"gsa-perdiem": {
"command": "uvx",
"args": ["gsa-perdiem-mcp"]
}
}
}
Example prompts
- "What's the per diem rate for Washington DC in FY2026?"
- "Estimate travel costs for 4 nights in Boston in March."
- "Compare per diem rates for DC, New York, and San Francisco."
- "What are all the NSA per diem locations in Virginia?"
- "Show me the M&IE meal breakdown for the $92 tier."
- "Build a travel estimate: 3 trips to Seattle (4 nights each) and 2 trips to DC (3 nights each)."
Important: maximum reimbursement, not actual prices
Per diem rates are federal reimbursement ceilings per 41 CFR 301-11. They are not actual hotel prices. CONUS only. OCONUS rates are from the State Department. Lodging taxes generally not included. First/last travel day M&IE at 75%.
Companion tools
Use alongside bls-oews-mcp (wage data) and gsa-calc-mcp (ceiling rates) for complete IGCE development. Per diem covers the travel component; BLS and CALC+ cover labor.
License
MIT
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 gsa_perdiem_mcp-0.2.2.tar.gz.
File metadata
- Download URL: gsa_perdiem_mcp-0.2.2.tar.gz
- Upload date:
- Size: 85.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 |
2924989e820c09df8d2089988783925561f81564a15640ab9a7f4bbed0b725a7
|
|
| MD5 |
ecc5aa62b05bc884a184b85cf509365b
|
|
| BLAKE2b-256 |
4d71f47be52da4b24cf9d4fdd97c24d1944240e941bf6e86aa362dbe166753c6
|
Provenance
The following attestation bundles were made for gsa_perdiem_mcp-0.2.2.tar.gz:
Publisher:
publish-pypi.yml on 1102tools/federal-contracting-mcps
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
gsa_perdiem_mcp-0.2.2.tar.gz -
Subject digest:
2924989e820c09df8d2089988783925561f81564a15640ab9a7f4bbed0b725a7 - Sigstore transparency entry: 1352995470
- Sigstore integration time:
-
Permalink:
1102tools/federal-contracting-mcps@581576bf2d92e464f92a22d5a028e75c763a7e2e -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/1102tools
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@581576bf2d92e464f92a22d5a028e75c763a7e2e -
Trigger Event:
push
-
Statement type:
File details
Details for the file gsa_perdiem_mcp-0.2.2-py3-none-any.whl.
File metadata
- Download URL: gsa_perdiem_mcp-0.2.2-py3-none-any.whl
- Upload date:
- Size: 13.0 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 |
b40af2256a39292b0afb379b6091333e56c31e4fcac475d8b3d00c7335e867ff
|
|
| MD5 |
78da65fdd9eeef093369a6519a47440a
|
|
| BLAKE2b-256 |
4bd9271181b22d08f1198a2f62c3da00b4a72ecd7bc100a95934ccafd559faea
|
Provenance
The following attestation bundles were made for gsa_perdiem_mcp-0.2.2-py3-none-any.whl:
Publisher:
publish-pypi.yml on 1102tools/federal-contracting-mcps
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
gsa_perdiem_mcp-0.2.2-py3-none-any.whl -
Subject digest:
b40af2256a39292b0afb379b6091333e56c31e4fcac475d8b3d00c7335e867ff - Sigstore transparency entry: 1352995560
- Sigstore integration time:
-
Permalink:
1102tools/federal-contracting-mcps@581576bf2d92e464f92a22d5a028e75c763a7e2e -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/1102tools
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@581576bf2d92e464f92a22d5a028e75c763a7e2e -
Trigger Event:
push
-
Statement type: