Skip to main content

MCP server for the FBI Crime Data Explorer API

Project description

FBI Crime Data MCP Server

CI codecov

An MCP (Model Context Protocol) server that provides access to the FBI's Crime Data Explorer API.

Query crime statistics, arrest data, hate crimes, NIBRS incidents, law enforcement employment, and more — directly from any MCP-compatible client.

Created for data journalists, researchers, and anyone interested in exploring US crime data with the power of language models. Initially created for use by the Policy Analyst Agent of the qsv Claude Cowork plugin.

Features

  • 17 tools covering a wide range of crime data topics
    • Crime trends and Summary Reporting System (SRS) crime data
    • National Incident Based Reporting System (NIBRS) incident-based data and national estimates
    • Arrest statistics with demographic breakdowns
    • Hate crime incidents by bias motivation
    • Expanded homicide and property crime details
    • Police employment, Law Enforcement Officers Killed and Assaulted (LEOKA), Law Enforcement Suicide Data Collection (LESDC), and use of force
    • Agency lookup, reference data, cache management, and spillover reading
  • Three query levels — national, state, and agency — with automatic parameter validation
  • Smart yearly aggregation — monthly API data is automatically rolled up into yearly totals (sums for counts, averages for rates, last value for population), with an option for monthly granularity
  • Tiered disk-backed caching — 90-day time-to-live (TTL) for stable data (trends, reference, summaries) and 30-day TTL for dynamic data (incidents, arrests, agency lookups)
  • Spillover handling — responses exceeding 128K characters are saved to disk with a preview returned, so large queries are never silently truncated
  • Input validation — date format/ordering checks, offense and bias code validation, and level-based parameter requirements with clear error messages
  • Sliding-window rate limiting — 1,000 requests/hour with transparent wait-time feedback
  • Reference tools for agency lookups (by state, Originating Agency Identifier (ORI), or district with name filtering) and code translations

Quick Start

  1. Get a free API key from api.data.gov

  2. Run with Claude Desktop — add to your claude_desktop_config.json:

{
  "mcpServers": {
    "fbi-crime-data": {
      "command": "uvx",
      "args": ["fbi-crime-data-mcp"],
      "env": {
        "FBI_API_KEY": "your-api-key-here"
      }
    }
  }
}
  1. Or run directly:
FBI_API_KEY=your-key uvx fbi-crime-data-mcp

Available Tools (17)

Core Crime Data

Tool Description
get_summarized_crime_data SRS crime data — rates, actuals, clearances for violent crime, property crime, homicide, rape, robbery, assault, burglary, larceny, motor vehicle theft, arson
get_nibrs_data NIBRS incident-based data for 70+ offense types
get_arrest_data Arrest statistics by offense with optional demographic breakdowns (sex, race)
get_crime_trends National crime trend percent changes across 10 crime types
get_nibrs_estimation NIBRS national estimates by state, region, agency type, or population size

Specialized Crime Data

Tool Description
get_hate_crime_data Hate crime incidents by bias motivation (30+ categories)
get_expanded_homicide_data Supplementary Homicide Reports — victim/offender demographics, weapons, circumstances
get_expanded_property_data Expanded property crime details — stolen/recovered values for burglary, larceny, motor vehicle theft (MVT), robbery

Law Enforcement Data

Tool Description
get_police_employment Officer and civilian employee counts by gender, rates per 1,000 population
get_leoka_data Officers killed and assaulted — weapons, circumstances, demographics
get_lesdc_data Law enforcement suicide data — demographics, race, duty status, and more
get_use_of_force_data Use of force incidents resulting in death, serious injury, or firearm discharge

Overview

Tool Description
get_cde_homepage_summary CDE homepage summary — mission statement, navigation, data freshness, date ranges, and national crime trends

Reference & Lookup

Tool Description
lookup_agency Find law enforcement agencies by state, ORI code, or judicial district
get_reference_data State lists, offense/bias code lookups, data refresh dates
manage_cache View cache stats, clear all entries, or clear only expired entries
read_spillover Read spillover files saved when tool responses exceed the size limit

Large Responses

When a tool response exceeds 128,000 characters, the full result is saved to ~/.cache/fbi-crime-data-mcp/spillover/ and a truncated preview is returned with the file path. To avoid this, narrow your query (shorter date range, specific state/agency).

Data Sources

All data comes from the FBI's Crime Data Explorer API, which provides Uniform Crime Reporting (UCR) data including both the Summary Reporting System (SRS) and the National Incident-Based Reporting System (NIBRS).

API Rate Limits

  • Registered key: 1,000 requests per hour (rolling window)
  • DEMO_KEY: 30 requests per IP per hour

The server includes a built-in rate limiter (1,000 req/hr). The DEMO_KEY limit is enforced API-side.

Development

# Install dependencies
uv sync

# Run the server locally
FBI_API_KEY=your-key uv run fbi-crime-data-mcp

# Run tests
uv run pytest

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fbi_crime_data_mcp-0.3.0.tar.gz (137.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fbi_crime_data_mcp-0.3.0-py3-none-any.whl (39.8 kB view details)

Uploaded Python 3

File details

Details for the file fbi_crime_data_mcp-0.3.0.tar.gz.

File metadata

  • Download URL: fbi_crime_data_mcp-0.3.0.tar.gz
  • Upload date:
  • Size: 137.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for fbi_crime_data_mcp-0.3.0.tar.gz
Algorithm Hash digest
SHA256 9d738453e802df03a0ac007bd338d1df6da31eb960f2ad2edb48dd01e6ee88c0
MD5 dd1036cc27c4c26c0a4d33bd472dbb69
BLAKE2b-256 6c4b9a3aa13247843334e76167f41b7ef7d3f85ef9f4f8846d977705577d1a05

See more details on using hashes here.

Provenance

The following attestation bundles were made for fbi_crime_data_mcp-0.3.0.tar.gz:

Publisher: publish.yml on dathere/fbi-crime-data-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file fbi_crime_data_mcp-0.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for fbi_crime_data_mcp-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5285ca92b8109407534e238944958a33522405db7816e6e9f667ad73cbc41988
MD5 a7d3e1c047b18bb180758501ac806ceb
BLAKE2b-256 39e572be9e2a82da2a3f209e2c2479d03d939cdbafb0f9b3bd03b4ba5f1fbe2f

See more details on using hashes here.

Provenance

The following attestation bundles were made for fbi_crime_data_mcp-0.3.0-py3-none-any.whl:

Publisher: publish.yml on dathere/fbi-crime-data-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page