MCP server for USASpending.gov federal contract and award data
Project description
usaspending-gov-mcp
MCP server for the USASpending.gov federal contract, award, subaward, recipient, agency, and federal account API.
No API key required. Works with any MCP-compatible client (Claude Desktop, Claude Code, Cursor, Cline, Continue, Zed, etc.).
Tested and hardened through nine rounds of integration testing against the live USASpending.gov API. v0.3 added 38 new tools and 243 tests across the new endpoints (76 live). See testing.md for the full testing record.
What it does
Exposes the USASpending.gov REST API as 55 MCP tools covering:
Search and aggregation
search_awards- Primary search for contracts, IDVs, grants, loans, direct paymentsget_award_count- Dimensional counts across award categoriesspending_over_time- Time series aggregation (fiscal year, quarter, month)spending_by_category- Top N breakdowns by agency, vendor, NAICS, PSC, state, etc.spending_by_transaction- Modification-level transaction searchspending_by_geography- State, county, or congressional district breakdownnew_awards_over_time- Pipeline trend for a recipient
Award detail
get_award_detail- Full record for a single awardget_transactions- Full modification history for an awardget_award_funding- File C funding data (Treasury account, object class, program activity)get_award_funding_rollup- Single-line funding summaryget_award_subaward_count,get_award_federal_account_count,get_award_transaction_countget_idv_children- Task/delivery orders under an IDVawards_last_updated- Data freshness check
Subawards (FFATA)
search_subawards- Subawards under a single primespending_by_subaward_grouped- Subaward search with full filter set
Recipients
search_recipients- Search recipients by keywordget_recipient_profile- Full recipient recordget_recipient_children- Subsidiaries of a parent recipientautocomplete_recipient- Find recipient hashes by partial namelist_states- All states with FIPS codes
Agency depth
list_toptier_agencies,get_agency_overview,get_agency_awardsget_agency_budgetary_resources- Budget resources by FYget_agency_sub_agencies- Subordinate orgs with obligationsget_agency_federal_accounts- Funding sources (TAS)get_agency_object_classes- Spending categories (OMB)get_agency_program_activities- Program-level breakdownget_agency_obligations_by_award_category- Contract vs grant mix
IDV depth
get_idv_amounts- Top-line IDV rollupget_idv_funding,get_idv_funding_rollup- File C for IDVget_idv_activity- Child orders under an IDV
Federal accounts (Treasury)
list_federal_accounts- Search TASget_federal_account_detail,get_federal_account_object_classes,get_federal_account_program_activities,get_federal_account_fy_snapshot
Autocomplete
autocomplete_psc,autocomplete_naicsautocomplete_awarding_agency,autocomplete_funding_agencyautocomplete_cfda(grants),autocomplete_glossary,autocomplete_recipient
Reference data
get_naics_details,get_psc_filter_treeget_award_types_reference- All award type codes (A=BPA Call etc.)get_def_codes_reference- Disaster Emergency Fund codes (COVID, IIJA, IRA)get_glossary- Acquisition/spending vocabularyget_submission_periods- Agency reporting period coverageget_state_profile- State-level spending profile
Workflow convenience
lookup_piid- Auto-detects contract vs IDV and returns the matching award
Installation
Via pip
pip install usaspending-gov-mcp
Via uvx (recommended, no venv needed)
uvx usaspending-gov-mcp
From source
git clone https://github.com/1102tools/federal-contracting-mcps.git
cd federal-contracting-mcps/servers/usaspending-gov-mcp
pip install -e .
Claude Desktop configuration
Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):
{
"mcpServers": {
"usaspending": {
"command": "uvx",
"args": ["usaspending-gov-mcp"]
}
}
}
If you installed via pip install -e . or a regular pip install:
{
"mcpServers": {
"usaspending": {
"command": "python",
"args": ["-m", "usaspending_gov_mcp.server"]
}
}
}
Restart Claude Desktop. The server should appear in the MCP tools panel.
Claude Code configuration
Add to ~/.claude.json or your project's .claude.json:
{
"mcpServers": {
"usaspending": {
"command": "uvx",
"args": ["usaspending-gov-mcp"]
}
}
}
Example prompts
Once configured, try:
- "Show me the top 10 NAVSEA contracts awarded in FY2025 by dollar value."
- "Find all software development contracts at NASA with sole-source justifications in the last year."
- "How much has Leidos received in federal awards since 2020? Group by fiscal year."
- "What are the top 15 recipients of HUBZone set-aside contracts at DoD?"
- "Pull the full modification history for PIID N00024-24-C-0085."
- "Compare FFP vs T&M award counts for IT services at Air Force in FY2024."
Design notes
- No authentication required. USASpending.gov is a free, public API.
- Award type groups cannot be mixed. The
award_typeparameter takes one of:contracts,idvs,grants,loans,direct_payments,other. Use separate calls for separate categories. - Actionable error messages. Common API errors (422 mixed award types, 400 sort field missing, 400 empty keywords) are translated into guidance for the calling LLM.
- Sort field auto-handling. The USASpending API requires the sort field to appear in the fields array; this server adds it automatically.
- Sensible defaults. Search limits default to 25 (API max 100). Default fields cover the most common columns for each award category.
- Flat filter parameters. Most common filters are surfaced as named parameters (
keywords,awarding_agency,naics_codes, etc.) rather than a nested filter dict, for better LLM tool discovery.
Data source
All data is sourced from USASpending.gov, which aggregates FPDS-NG contract data, FAADC assistance data, and agency DATA Act submissions. Data freshness varies by agency: non-DoD contract data is typically available within 5 business days, DoD and USACE procurement data has a 90-day reporting delay in FPDS, and financial assistance data is available within 2 days of submission.
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 usaspending_gov_mcp-0.3.0.tar.gz.
File metadata
- Download URL: usaspending_gov_mcp-0.3.0.tar.gz
- Upload date:
- Size: 131.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bcf7f4ed6e6ac50e79f198c5817e8b25e77791f28477414224fe5740879062ab
|
|
| MD5 |
0f2cdc440ec4a565329db9ef3fc516a0
|
|
| BLAKE2b-256 |
01446010f21bc2e04209658d1c4f9191cb46cfd3b064f3497d07a05b64ba2272
|
Provenance
The following attestation bundles were made for usaspending_gov_mcp-0.3.0.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:
usaspending_gov_mcp-0.3.0.tar.gz -
Subject digest:
bcf7f4ed6e6ac50e79f198c5817e8b25e77791f28477414224fe5740879062ab - Sigstore transparency entry: 1379044121
- Sigstore integration time:
-
Permalink:
1102tools/federal-contracting-mcps@6913f2be99ba7477b7f537610add42cb6b3b1528 -
Branch / Tag:
refs/tags/v0.1.17 - Owner: https://github.com/1102tools
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@6913f2be99ba7477b7f537610add42cb6b3b1528 -
Trigger Event:
push
-
Statement type:
File details
Details for the file usaspending_gov_mcp-0.3.0-py3-none-any.whl.
File metadata
- Download URL: usaspending_gov_mcp-0.3.0-py3-none-any.whl
- Upload date:
- Size: 24.4 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 |
1ca90a436fb020ced3a840321564dfe8f195d57dafde406dc6fffb029d0358d7
|
|
| MD5 |
e8083d46555b024264df1803770e5638
|
|
| BLAKE2b-256 |
d52520c2313146083eaf0557dc945e43f2322ea59440da1c7e21304262e4fd8c
|
Provenance
The following attestation bundles were made for usaspending_gov_mcp-0.3.0-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:
usaspending_gov_mcp-0.3.0-py3-none-any.whl -
Subject digest:
1ca90a436fb020ced3a840321564dfe8f195d57dafde406dc6fffb029d0358d7 - Sigstore transparency entry: 1379044272
- Sigstore integration time:
-
Permalink:
1102tools/federal-contracting-mcps@6913f2be99ba7477b7f537610add42cb6b3b1528 -
Branch / Tag:
refs/tags/v0.1.17 - Owner: https://github.com/1102tools
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@6913f2be99ba7477b7f537610add42cb6b3b1528 -
Trigger Event:
push
-
Statement type: