Model Context Protocol (MCP) server for the Homedata UK property data API - 29M UK addresses, EPC, planning, flood risk, demographics and more.
Project description
Homedata MCP Server
A Model Context Protocol server that exposes the Homedata UK property data API as native tools for AI coding assistants - Claude Desktop, Claude Code, Cursor, and any other MCP client.
29M UK addresses keyed by UPRN, with EPCs, sale history, planning, flood risk, council tax, demographics, crime, schools, broadband and transport - all queryable directly from your assistant chat.
Data is sourced from Home.co.uk's 30-year panel of partners, the Environment Agency, ONS Census 2021, the Valuation Office Agency, Ofcom, Ofsted, data.police.uk and HM Land Registry.
Install
Requires Python 3.10+.
pip install homedata-mcp
For local development from this repository:
git clone https://github.com/wehomemove/homedata-mcp.git
cd homedata-mcp
pip install -e .
You will need a Homedata API key. Sign up at homedata.co.uk/developer - the Free tier gives 100 calls / month with no card required.
export HOMEDATA_API_KEY=hd_live_xxx
homedata-mcp --help
Wire it into Claude Desktop
Edit ~/Library/Application Support/Claude/claude_desktop_config.json
(macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):
{
"mcpServers": {
"homedata": {
"command": "homedata-mcp",
"env": {
"HOMEDATA_API_KEY": "your_api_key_here"
}
}
}
}
Restart Claude Desktop. You should see the 16 Homedata tools appear in the tool picker.
Cursor / Claude Code
Both Cursor and Claude Code accept the same MCP server spec. Add an entry
pointing command at homedata-mcp and put your key in env.
Tools
All UPRN tools take a single 12-digit Unique Property Reference Number; all postcode tools accept any common UK postcode format.
| # | Tool | Endpoint | Inputs |
|---|---|---|---|
| 1 | lookup_property |
GET /api/properties/{uprn}/ |
uprn |
| 2 | lookup_epc |
GET /api/epc-checker/{uprn}/ |
uprn |
| 3 | lookup_flood_risk |
GET /api/flood-risk/?uprn= |
uprn |
| 4 | lookup_council_tax |
in development — returns a "coming soon" response | uprn |
| 5 | search_property_listings |
GET /api/property_listings/?uprn= |
uprn |
| 6 | get_comparables |
GET /api/comparables/{uprn}/?count= |
uprn, count (default 20, max 200) |
| 7 | get_planning_applications |
GET /api/planning/search/?uprn= |
uprn |
| 8 | get_demographics |
GET /api/demographics/?postcode= |
postcode |
| 9 | get_crime |
GET /api/crime/?postcode= |
postcode, date (YYYY-MM, optional) |
| 10 | get_schools |
GET /api/schools/?uprn=&radius_m= |
uprn, radius_m (default 1000) |
| 11 | get_broadband |
GET /api/broadband/?postcode= |
postcode |
| 12 | get_transport |
GET /api/transport/?uprn=&radius_m= |
uprn, radius_m (default 800) |
| 13 | get_postcode_profile |
GET /api/postcode-profile/?postcode= |
postcode |
| 14 | search_address |
GET /api/address/find/?q= |
query, postcode (optional) |
| 15 | get_property_sales |
GET /api/property_sales/?uprn= |
uprn |
| 16 | batch_property_lookup |
POST /api/property/batch/ |
uprns (list, max 50) |
Typical workflow
- Resolve text → UPRN with
search_address. - Look up the property:
lookup_property,lookup_epc,lookup_council_tax,lookup_flood_risk. - Add market context:
search_property_listings,get_property_sales,get_comparables. - Add area context:
get_postcode_profile(cheap one-shot), or callget_demographics/get_crime/get_schools/get_broadband/get_transportindividually.
Configuration
| Variable | Required | Default | Notes |
|---|---|---|---|
HOMEDATA_API_KEY |
yes | - | Your Homedata API key (Authorization: Api-Key ...). |
HOMEDATA_BASE_URL |
no | https://api.homedata.co.uk |
Override for staging or self-hosted. |
Every tool returns either the parsed JSON body from the API, or
{"error": "...", "status_code": N, "detail": ...} on failure - tools never
raise exceptions out into the MCP protocol layer.
Pricing
Calls made via this MCP server count against your Homedata API plan exactly the same as any other API call. Plans (as of writing):
| Plan | Price | Calls / month |
|---|---|---|
| Free | £0 | 100 |
| Starter | £49 | 2,000 |
| Growth | £149 | 10,000 |
| Pro | £349 | 50,000 |
| Scale | £699 | 250,000 |
See homedata.co.uk/pricing for the current list.
Development
pip install -e ".[dev]"
HOMEDATA_API_KEY=hd_live_xxx pytest -v
Tests are skipped automatically when no API key is present, so the suite is safe to run in CI without secrets.
Project layout
homedata-mcp/
pyproject.toml
README.md
homedata_mcp/
__init__.py
server.py # FastMCP server + CLI entry point
client.py # httpx wrapper with auth + uniform error handling
tools/
__init__.py
property.py # lookup_property, batch_property_lookup
epc.py # lookup_epc
risk.py # lookup_flood_risk, lookup_council_tax
listings.py # search_property_listings, get_property_sales, get_comparables
planning.py # get_planning_applications
local.py # get_demographics, get_crime, get_schools, get_broadband, get_transport
address.py # search_address
profile.py # get_postcode_profile
tests/
test_tools.py
License
MIT - see LICENSE.
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 homedata_mcp-0.1.1.tar.gz.
File metadata
- Download URL: homedata_mcp-0.1.1.tar.gz
- Upload date:
- Size: 14.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
da6ea3af4e51637ea5d93f7246c38cff9d5519558285d430ceac6a5cf9fe8d72
|
|
| MD5 |
5ae2688ea6f011034bdf0a7786cc7b43
|
|
| BLAKE2b-256 |
7e54b6a602574c48f272d6cdb8d39870b64526ddcb1c9d4b001ab5f121a4acb5
|
Provenance
The following attestation bundles were made for homedata_mcp-0.1.1.tar.gz:
Publisher:
release-homedata-mcp.yml on wehomemove/loki
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
homedata_mcp-0.1.1.tar.gz -
Subject digest:
da6ea3af4e51637ea5d93f7246c38cff9d5519558285d430ceac6a5cf9fe8d72 - Sigstore transparency entry: 1511794183
- Sigstore integration time:
-
Permalink:
wehomemove/loki@53bf7190c24374bb7df858d772f8faf804fa6be1 -
Branch / Tag:
refs/tags/homedata-mcp-v0.1.1 - Owner: https://github.com/wehomemove
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release-homedata-mcp.yml@53bf7190c24374bb7df858d772f8faf804fa6be1 -
Trigger Event:
push
-
Statement type:
File details
Details for the file homedata_mcp-0.1.1-py3-none-any.whl.
File metadata
- Download URL: homedata_mcp-0.1.1-py3-none-any.whl
- Upload date:
- Size: 15.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7778aa128324e910b018b158c223f6f327aab1916f16b9b75d21349cae9e994a
|
|
| MD5 |
bbcaf0fa889455d0dd480c2796abe0c9
|
|
| BLAKE2b-256 |
78941e5b22ba8cf9e4e318b66dd914c07a55edc63ef8ecb2584805f7ec188edd
|
Provenance
The following attestation bundles were made for homedata_mcp-0.1.1-py3-none-any.whl:
Publisher:
release-homedata-mcp.yml on wehomemove/loki
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
homedata_mcp-0.1.1-py3-none-any.whl -
Subject digest:
7778aa128324e910b018b158c223f6f327aab1916f16b9b75d21349cae9e994a - Sigstore transparency entry: 1511794358
- Sigstore integration time:
-
Permalink:
wehomemove/loki@53bf7190c24374bb7df858d772f8faf804fa6be1 -
Branch / Tag:
refs/tags/homedata-mcp-v0.1.1 - Owner: https://github.com/wehomemove
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release-homedata-mcp.yml@53bf7190c24374bb7df858d772f8faf804fa6be1 -
Trigger Event:
push
-
Statement type: