MunicipalMCP
A Model Context Protocol (MCP) server for accessing municipal codes and ordinances from the Municode digital library. This server provides programmatic access to municipal legal documents including city ordinances, zoning codes, and other local regulations for thousands of municipalities across the United States.
🏛️ Overview
Municode hosts municipal codes for thousands of cities and counties across the United States. This MCP server leverages the unofficial Municode API to provide structured access to this valuable public information through a standardized MCP interface.
Features
🏛️ Municipal Discovery: Find municipalities by state
📜 Code Navigation: Browse municipal code structures
🔍 Search Capabilities: Search through ordinances and codes
📋 Content Retrieval: Get specific code sections and content
🌐 URL Generation: Generate direct links to municipal codes
🔗 MCP Integration: Works with any MCP-compatible client
🚀 Quick Start
Installation
Clone the repository:
git clone https://github.com/yourusername/MunicipalMCP.git cd MunicipalMCPInstall dependencies:
pip install -r requirements.txtTest the server:
python3 test_server.py
Adding to MCP Clients
Warp Terminal
Create or update your MCP configuration file at ~/.config/mcp/mcp.json:
Claude Desktop App
Add to your claude_desktop_config.json:
🛠️ Available Tools
1. get_states_info
Get information about a US state by its abbreviation.
Parameters:
state_abbr(string) - Two-character state abbreviation
2. list_municipalities
List all municipalities in a state that use Municode.
Parameters:
state_abbr(string) - Two-character state abbreviation
3. get_municipality_info
Get detailed information about a specific municipality.
Parameters:
municipality_name(string) - Name of the municipalitystate_abbr(string) - Two-character state abbreviation
4. get_code_structure
Get the table of contents structure for a municipality's code.
Parameters:
municipality_name(string) - Name of the municipalitystate_abbr(string) - Two-character state abbreviationnode_id(string, optional) - Specific node ID (defaults to root)
5. get_code_section
Get the content of a specific section of municipal code.
Parameters:
municipality_name(string) - Name of the municipalitystate_abbr(string) - Two-character state abbreviationnode_id(string) - Node ID of the specific code section
6. search_municipal_codes
Search through municipal codes and ordinances.
Parameters:
municipality_name(string) - Name of the municipalitystate_abbr(string) - Two-character state abbreviationsearch_query(string) - Text to search forpage_size(integer, optional) - Results per page (default: 10)page_number(integer, optional) - Page number (default: 1)titles_only(boolean, optional) - Search only titles (default: false)
7. get_municipality_url
Get the URL for a municipality's code library page.
Parameters:
municipality_name(string) - Name of the municipalitystate_abbr(string) - Two-character state abbreviation
📝 Example Usage
Basic Municipal Research
Searching Municipal Codes
🏗️ Use Cases
Urban Planning & Development
Compare zoning ordinances across municipalities
Research building code requirements
Analyze development regulations and procedures
Legal & Compliance Research
Find relevant municipal ordinances for compliance
Research local law requirements
Cross-reference regulations across jurisdictions
Academic & Policy Research
Study municipal governance structures
Analyze regulatory patterns across regions
Research evolution of local laws
Civic Engagement
Understand local regulations affecting residents
Prepare for city council meetings
Research municipal procedures and policies
⚙️ Technical Details
API Integration
This server uses the unofficial Municode API with endpoints including:
State and municipality discovery
Code structure navigation
Content retrieval
Full-text search capabilities
Data Structure
Municipal codes are organized hierarchically:
Each municipality may have multiple products (Code of Ordinances, Zoning Ordinance, etc.), each with its own hierarchical structure.
⚠️ Limitations
Uses unofficial API endpoints that may change
Not all municipalities have all features available
Some content may be in PDF format and not searchable via API
Rate limiting may apply to API requests
Municipality names must match Municode's exact formatting
🤝 Contributing
Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.
Development Setup
Fork the repository
Create a feature branch (
git checkout -b feature/AmazingFeature)Commit your changes (
git commit -m 'Add some AmazingFeature')Push to the branch (
git push origin feature/AmazingFeature)Open a Pull Request
📄 License
This project is licensed under the MIT License - see the LICENSE file for details.
🙏 Acknowledgments
Based on the unofficial Municode API documentation by ~partytax
Municode and CivicPlus for providing public access to municipal code information
The MCP community for developing the Model Context Protocol standard
⚖️ Legal Notice
This is an unofficial tool created to provide programmatic access to publicly available municipal code information. It is not affiliated with or endorsed by Municode or CivicPlus. Always verify critical legal information with official sources and respect Municode's terms of service.
Made with ❤️ for civic transparency and accessibility