JUHE API Marketplace
Travis-Prall avatar
MCP Server

GovInfo MCP Server

A Model Context Protocol server that provides LLM-friendly access to the official GovInfo API for searching and retrieving U.S. government documents including bills, laws, regulations, and other official publications.

3
GitHub Stars
8/22/2025
Last Updated
No Configuration
Please check the documentation below.

README Documentation

GovInfo MCP Server

A Model Context Protocol (MCP) server that provides LLM-friendly access to the official GovInfo API v4. This server enables searching and retrieving U.S. government documents, including bills, laws, regulations, and other official publications, for precise legal research and citation verification.

🎯 Purpose

The GovInfo MCP Server provides comprehensive access to federal regulations, statutes, and government documents through the GovInfo API. It is designed for LLMs and legal research tools to programmatically access up-to-date U.S. government information.

📦 Key Features

  • Access to bills, statutes, regulations (CFR), and more
  • Real-time updates from the official GovInfo API
  • Retrieve full document text and metadata in HTML, XML, PDF, or plain text
  • Search by keyword, collection, date, and more
  • Explore related documents and cross-references

🛠️ Available MCP Tools

Tool NameDescriptionExample Call
get_collectionsList all available GovInfo collectionsget_collections(page_size=10)
get_collection_detailsGet details for a specific collectionget_collection_details(collection_code="CFR")
search_packagesSearch packages by query and filterssearch_packages(query="discovery procedures", collection="CFR", page_size=5)
advanced_searchAdvanced search with Lucene syntax and filtersadvanced_search(query="title:discovery AND collection:CFR", sort_by="relevance")
get_packages_by_collectionList packages from a collectionget_packages_by_collection(collection="BILLS", congress=118, page_size=5)
get_package_summaryGet metadata for a specific packageget_package_summary(package_id="CFR-2023-title5-vol3")
get_package_contentDownload package content in various formatsget_package_content(package_id="CFR-2023-title5-vol3", content_type="html")
get_published_packagesGet packages published on a specific dateget_published_packages(date_issued="2024-01-15", collection="CFR")
get_published_rangeGet packages published within a date rangeget_published_range(start_date="2024-01-01", end_date="2024-01-31", collection="PLAW")
get_related_packagesFind packages related to a specific packageget_related_packages(package_id="BILLS-118hr1234-ih")
get_granule_relatedFind items related to a specific granuleget_granule_related(package_id="CFR-2023-title5-vol3", granule_id="CFR-2023-title5-vol3-sec1201-72")
search_statutesSearch US statutes across statute collectionssearch_statutes(query="civil rights", collection="USCODE", page_size=5)
get_public_laws_by_congressList public laws from a specific Congressget_public_laws_by_congress(congress=117, page_size=5)
get_statutes_at_largeSearch Statutes at Large by volumeget_statutes_at_large(volume="137", page_size=5)
get_uscode_titleSearch US Code sections within a titleget_uscode_title(title_number="42", page_size=5)
list_statute_collectionsList all statute-related collectionslist_statute_collections()

See app/README.md for full tool parameter documentation.

🚀 Setup

Prerequisites

  • Python 3.12+
  • uv for dependency management (Poetry is NOT used)
  • Internet connection for GovInfo API access
  • GovInfo API key (set GOVINFO_API_KEY in your environment)
  • Ubuntu/Linux recommended (all commands below are for bash)

Installation

  1. Clone the repository and navigate to the GovInfo project directory:

    git clone <repository-url>
    cd GovInfo
    
  2. Install dependencies using uv:

    uv pip install -r requirements.txt
    # or, if using pyproject.toml:
    uv pip install -r <(uv pip compile pyproject.toml)
    
  3. Set your GovInfo API key:

    export GOVINFO_API_KEY=your_api_key_here
    
  4. (Optional) Copy .env.example to .env and edit as needed.

Running the Server

Start the MCP server:

uv run python -m app.server

Or use the VS Code task "Run MCP Server".

Running Tests

See tests/README.md for details. Typical usage:

uv run pytest

API Usage

See app/README.md for detailed tool documentation and usage examples.

🔗 Links

📝 Notes

  • All code examples are tested and working.
  • File paths use relative references from the project root.
  • All commands use uv run where needed.
  • For Ubuntu/Linux. For Windows, adapt commands as needed.

Quick Actions

Key Features

Model Context Protocol
Secure Communication
Real-time Updates
Open Source