Historic Environment Records MCP Server
Project description
chuk-mcp-her
Historic Environment Records MCP Server -- A Model Context Protocol (MCP) server for querying Historic Environment Records across England. Searches listed buildings, scheduled monuments, registered parks, battlefields, protected wrecks, and World Heritage Sites via live ArcGIS REST APIs from Historic England.
This is a demonstration project provided as-is for learning and testing purposes.
Features
This MCP server provides structured access to Historic Environment Records through 23 tools across 8 categories, querying 5 data sources via live ArcGIS REST APIs and Heritage Gateway web scraping.
Key capabilities:
- Source registry pattern -- pluggable adapters for NHLE, AIM, Conservation Areas, Heritage at Risk, and Heritage Gateway with unified query interface
- Spatial-first queries -- bounding box, point+radius, and area searches via ArcGIS Feature Service
- BNG/WGS84 coordinate support -- automatic conversion between British National Grid (EPSG:27700) and WGS84 (EPSG:4326)
- All tools return fully-typed Pydantic v2 models for type safety, validation, and excellent IDE support
- All tools support
output_mode="text"for human-readable output alongside the default JSON
1. Server Discovery (her_status, her_list_sources, her_capabilities)
Check server health, list registered data sources, and get full capabilities:
- Source availability and status
- Supported query types per source
- LLM guidance for query planning
2. NHLE Queries (her_search_monuments, her_get_monument, her_search_listed_buildings, her_search_designations, her_count_features)
Search the National Heritage List for England:
- Scheduled monuments by location, name, or description
- Listed buildings with grade filtering (I, II*, II)
- Generic designation search across all 6 designation types
- Fast feature counts without fetching full records
- Pagination with offset-based paging
3. Aerial Mapping (her_search_aerial, her_count_aerial, her_get_aerial_feature)
Search aerial investigation mapping data:
- Archaeological features from aerial photographs and LiDAR
- Cropmarks, earthworks, and features not in the NHLE
- Monument type and period filtering
- Fast feature counts without fetching full records
- Full details for individual aerial mapping features
4. Conservation Areas (her_search_conservation_areas, her_count_conservation_areas, her_get_conservation_area)
Search Historic England's 8,000+ conservation areas:
- Search by name, Local Planning Authority, or location
- Bounding box and point+radius spatial queries
- Fast counts without fetching full records
- Full details including designation date and area
5. Heritage at Risk (her_search_heritage_at_risk, her_count_heritage_at_risk, her_get_heritage_at_risk)
Search the Heritage at Risk Register:
- Annual register of heritage assets at risk of loss
- Filter by heritage category (Listed Building, Scheduled Monument, etc.)
- Spatial search by bounding box or point+radius
- Risk methodology details for each entry
6. Heritage Gateway (her_search_heritage_gateway)
Search local Historic Environment Records via Heritage Gateway:
- Best-effort access to 60+ local HERs via web scraping
- Undesignated sites, findspots, and HER monument entries
- Returns empty results gracefully when Gateway unavailable
7. Cross-Referencing (her_cross_reference, her_enrich_gateway, her_nearby)
Spatial matching, enrichment, and proximity search:
- Cross-reference candidate locations against known heritage assets
- Classify candidates as match, near, or novel
- Grid-based spatial indexing for efficient batch processing (O(n+m) amortised)
- Optional AIM aerial feature integration (
include_aimparameter) - Designation type filtering (single type or comma-separated)
- Enriched match output with 11 fields per asset (source, grade, monument_type, period, form, evidence)
- Enrich Gateway records with resolved BNG coordinates for cross-referencing
- Find nearby heritage assets with distance and bearing
- Accepts both WGS84 and BNG coordinates
8. Export (her_export_geojson, her_export_for_lidar)
Export and format results:
- GeoJSON FeatureCollection for QGIS, Leaflet, or other GIS tools
- LiDAR cross-reference format with enriched metadata per source:
- NHLE sites with grade
- AIM aerial features with monument_type, period, form, evidence
- Gateway sites with monument_type and period
- Optional AIM integration (
include_aim) and Gateway sites (gateway_sites) for LiDAR export
Tool Reference
All tools accept an optional output_mode parameter ("json" default, or "text" for human-readable output).
| Tool | Category | Description | Status |
|---|---|---|---|
her_status |
Discovery | Server health and source availability | Active |
her_list_sources |
Discovery | List registered data sources with capabilities | Active |
her_capabilities |
Discovery | Full server capability listing for LLM planning | Active |
her_search_monuments |
NHLE | Search scheduled monuments by location or name | Active |
her_get_monument |
NHLE | Get full details for a specific monument | Active |
her_search_listed_buildings |
NHLE | Search listed buildings with grade filter | Active |
her_search_designations |
NHLE | Search across all designation types | Active |
her_count_features |
NHLE | Fast count of features in an area | Active |
her_search_aerial |
Aerial | Search aerial investigation mapping data | Active |
her_count_aerial |
Aerial | Count aerial mapping features in an area | Active |
her_get_aerial_feature |
Aerial | Get full details of an aerial mapping feature | Active |
her_search_conservation_areas |
Conservation | Search conservation areas by name, LPA, or location | Active |
her_count_conservation_areas |
Conservation | Count conservation areas in an area | Active |
her_get_conservation_area |
Conservation | Get full details of a conservation area | Active |
her_search_heritage_at_risk |
At Risk | Search heritage at risk register entries | Active |
her_count_heritage_at_risk |
At Risk | Count heritage at risk entries in an area | Active |
her_get_heritage_at_risk |
At Risk | Get full details of a heritage at risk entry | Active |
her_search_heritage_gateway |
Gateway | Search local HER data via Heritage Gateway | Active |
her_cross_reference |
Cross-Ref | Cross-reference candidates against known assets | Active |
her_enrich_gateway |
Cross-Ref | Resolve Gateway record coordinates for cross-referencing | Active |
her_nearby |
Cross-Ref | Find heritage assets near a point | Active |
her_export_geojson |
Export | Export results as GeoJSON FeatureCollection | Active |
her_export_for_lidar |
Export | Export known sites for LiDAR cross-referencing | Active |
Data Sources
| Source | Name | Organisation | Coverage | API Type | Status |
|---|---|---|---|---|---|
nhle |
National Heritage List for England | Historic England | England | ArcGIS Feature Service | Active |
aim |
Aerial Investigation and Mapping | Historic England | England | ArcGIS Feature Service | Active |
conservation_area |
Conservation Areas | Historic England / LPAs | England | ArcGIS Feature Service | Active |
heritage_at_risk |
Heritage at Risk Register | Historic England | England | ArcGIS Feature Service | Active |
heritage_gateway |
Heritage Gateway (Local HERs) | Historic England / Local HERs | England | Web scraper | Active |
NHLE Designation Types
| Type | Description |
|---|---|
listed_building |
Listed buildings (Grades I, II*, II) |
scheduled_monument |
Scheduled monuments |
park_and_garden |
Registered parks and gardens |
battlefield |
Registered battlefields |
protected_wreck |
Protected wreck sites |
world_heritage_site |
World Heritage Sites |
Installation
Using uvx (Recommended -- No Installation Required!)
uvx chuk-mcp-her
Using uv (Recommended for Development)
# Install from PyPI
uv pip install chuk-mcp-her
# Or clone and install from source
git clone <repository-url>
cd chuk-mcp-her
uv sync --dev
Using pip (Traditional)
pip install chuk-mcp-her
Optional: Sub-metre Coordinate Accuracy
# Install pyproj for sub-metre BNG<->WGS84 conversion
# Without pyproj, Helmert approximation (~5m accuracy) is used
pip install chuk-mcp-her[pyproj]
Usage
With Claude Desktop
Option 1: Run Locally with uvx
MacOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%/Claude/claude_desktop_config.json
{
"mcpServers": {
"her": {
"command": "uvx",
"args": ["chuk-mcp-her"]
}
}
}
Option 2: Run Locally with pip
{
"mcpServers": {
"her": {
"command": "chuk-mcp-her"
}
}
}
With Python SDK
from mcp import ClientSession, StdioServerParameters
from mcp.client.stdio import stdio_client
server_params = StdioServerParameters(
command="uvx",
args=["chuk-mcp-her"],
)
async with stdio_client(server_params) as (read, write):
async with ClientSession(read, write) as session:
await session.initialize()
result = await session.call_tool(
"her_search_monuments",
{"name": "Stonehenge", "max_results": 5},
)
Standalone
# STDIO mode (default, for MCP clients)
chuk-mcp-her stdio
# HTTP mode (for web access)
chuk-mcp-her http
chuk-mcp-her http --port 8010
# Auto-detect mode
chuk-mcp-her
STDIO mode is for MCP clients like Claude Desktop and mcp-cli. HTTP mode runs a web server on http://localhost:8010 for HTTP-based MCP clients.
CLI (mcp-cli)
mcp-cli chat --server her
Example Usage
Once configured, you can ask Claude questions like:
- "List the available heritage data sources"
- "Search for scheduled monuments near Stonehenge"
- "Find Grade I listed buildings in central London"
- "How many heritage assets are in this bounding box?"
- "Get the full record for monument 1002345"
- "What heritage assets are within 500m of the Tower of London?"
- "Export all scheduled monuments in the Maldon area as GeoJSON"
- "Cross-reference these LiDAR survey points against known heritage assets"
- "Search for protected wrecks along the English coast"
- "Find registered parks and gardens near Bath"
Running the Examples
cd examples
python capabilities_demo.py # server capabilities, sources, tools
python quick_start.py # quick intro: status, count, search, nearby
python nhle_search_demo.py # scheduled monument and listed building search
python aerial_search_demo.py # aerial investigation mapping features
python conservation_area_demo.py # conservation area search
python heritage_at_risk_demo.py # heritage at risk register
python nearby_demo.py # find heritage assets near a point
python export_demo.py # GeoJSON export
python gateway_search_demo.py # Heritage Gateway local HER search
python cross_reference_demo.py # cross-reference candidates (with AIM)
python enrichment_pipeline_demo.py # Gateway enrichment + cross-reference
python blackwater_estuary_scenario.py # multi-source scenario
| Script | Network | Tools Demonstrated |
|---|---|---|
capabilities_demo.py |
No | her_capabilities, her_list_sources, her_status |
quick_start.py |
Yes | her_status, her_count_features, her_search_monuments, her_get_monument, her_nearby |
nhle_search_demo.py |
Yes | her_search_monuments, her_get_monument, her_search_listed_buildings, her_search_designations, her_count_features |
aerial_search_demo.py |
Yes | her_search_aerial, her_count_aerial, her_get_aerial_feature |
conservation_area_demo.py |
Yes | her_search_conservation_areas, her_count_conservation_areas, her_get_conservation_area |
heritage_at_risk_demo.py |
Yes | her_search_heritage_at_risk, her_count_heritage_at_risk, her_get_heritage_at_risk |
nearby_demo.py |
Yes | her_nearby |
export_demo.py |
Yes | her_export_geojson, her_export_for_lidar |
gateway_search_demo.py |
Yes | her_search_heritage_gateway |
cross_reference_demo.py |
Yes | her_cross_reference (with include_aim) |
enrichment_pipeline_demo.py |
Yes | her_enrich_gateway, her_search_heritage_gateway, her_cross_reference, her_count_features |
blackwater_estuary_scenario.py |
Yes | Multi-source scenario using NHLE, AIM, Conservation Areas, Heritage at Risk |
Architecture
MCP Client (Claude, mcp-cli, etc.)
|
| MCP protocol (stdio / HTTP)
v
+-------------------------------+
| Tool Functions |
| discovery/ nhle/ aerial/ |
| conservation_area/ |
| heritage_at_risk/ gateway/ |
| crossref/ export/ |
+-------------------------------+
|
| validate params, format response
v
+-------------------------------+
| SourceRegistry |
| (unified query interface) |
+-------------------------------+
| | | | |
NHLEAdapter | CA HAR |
AIMAdapter | Adapter Adapter|
| GatewayAdapter
v v v v
+------------------+ +------------------+
| ArcGIS Client | | Gateway Client |
| (httpx, async, | | (httpx, bs4, |
| rate-limited) | | best-effort) |
+------------------+ +------------------+
| |
v v
+---------------------+ +-------------------+
| HE ArcGIS Services | | Heritage Gateway |
| NHLE, AIM, CA, HAR | | (60+ local HERs) |
+---------------------+ +-------------------+
Built on top of chuk-mcp-server, this server uses:
- Async-First: Native async/await with httpx for all HTTP requests
- Type-Safe: Pydantic v2 models with
extra="forbid"for all responses - Source Registry Pattern: Pluggable adapters registered at startup, queried through unified interface
- BNG/WGS84 Conversion: Helmert transformation with optional pyproj for sub-metre accuracy
- Filesystem Cache: TTL-based per-source caching to reduce API load
- Rate Limiting: Per-client rate limiting with exponential backoff on 429/5xx
- Dual Output: All 23 tools support
output_mode="text"for human-readable responses - Error Messages: All error strings from
ErrorMessagesconstants -- no hardcoded strings
See ARCHITECTURE.md for design principles and data flow diagrams. See SPEC.md for the full tool specification with parameter tables. See ROADMAP.md for the development roadmap and planned features.
Development
Setup
# Clone the repository
git clone <repository-url>
cd chuk-mcp-her
# Install with uv (recommended)
uv sync --dev
# Or with pip
pip install -e ".[dev]"
Running Tests
# Run tests
pytest tests/
# Run tests with coverage
pytest tests/ --cov=src/chuk_mcp_her --cov-report=term-missing
# Run a specific test file
pytest tests/test_coordinates.py -v
Code Quality
# Lint and format with ruff
ruff check src/ tests/
ruff format src/ tests/
# Type checking
mypy src/
# Security scan
bandit -r src/ -x tests/
Building
# Build package
python -m build
# Or with uv
uv build
Configuration
Environment Variables
| Variable | Default | Description |
|---|---|---|
MCP_STDIO |
- | Set to any value to force stdio mode |
HER_CACHE_DIR |
~/.cache/chuk-mcp-her |
Filesystem cache directory |
HER_NHLE_CACHE_TTL |
86400 |
NHLE cache TTL in seconds (24 hours) |
HER_AIM_CACHE_TTL |
604800 |
AIM cache TTL in seconds (7 days) |
HER_HG_CACHE_TTL |
3600 |
Heritage Gateway cache TTL in seconds (1 hour) |
HER_RATE_LIMIT |
5.0 |
Max requests per second to ArcGIS |
HER_TIMEOUT |
30.0 |
HTTP request timeout in seconds |
License
Apache License 2.0 -- See LICENSE for details.
References
- Historic England -- National Heritage List for England
- NHLE ArcGIS Feature Service -- Live data endpoint
- ArcGIS REST API -- Query specification
- Heritage Gateway -- Federated HER search
- Model Context Protocol -- MCP specification
- Anthropic -- Claude and MCP support
- British National Grid -- EPSG:27700 coordinate reference system
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
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 chuk_mcp_her-0.1.2.tar.gz.
File metadata
- Download URL: chuk_mcp_her-0.1.2.tar.gz
- Upload date:
- Size: 138.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dd3a1676458f3a88238b2bbf3d4d6fc6204a204abf4acd71b19514af44e637c8
|
|
| MD5 |
38c484f8dea827343c66f95680a6a6b2
|
|
| BLAKE2b-256 |
ef89f616d51288d8ace8480654983090571d3cccadf2454d245c33dfcd70afbd
|
File details
Details for the file chuk_mcp_her-0.1.2-py3-none-any.whl.
File metadata
- Download URL: chuk_mcp_her-0.1.2-py3-none-any.whl
- Upload date:
- Size: 77.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ec67de1c7a9fc71590c72c4d2c949a89480016496eaebfa3bd854d1d3499040a
|
|
| MD5 |
78858c7d5838f62297d13624a85307ed
|
|
| BLAKE2b-256 |
3aff221a8af9e66442d22a4daf90e60d57a468c88320db39277b726d3d8323e2
|