mcp-homedepot
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@mcp-homedepotI need to find a cordless drill"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
mcp-homedepot
A Model Context Protocol server for Home Depot Canada (homedepot.ca). It exposes the store's product catalogue — search, product detail, store-level stock and a store finder — to MCP clients such as Claude and Cursor.
Unofficial. This project is not affiliated with, endorsed by, or sponsored by The Home Depot. It reads publicly available endpoints of homedepot.ca for personal, noncommercial use. Respect Home Depot's terms of service and use responsibly.
Tools
Tool | Description |
| Product search / listings by keyword. Returns products (SKU, name, brand, model, price, rating, online stock, URL, image), total count, facets and sort options. |
| Full product card by SKU: name, brand, model, description, images, rating/reviews, warranty, categories, price, in-store stock + aisle/bay, online stock, fulfillment options. |
| In-store stock of a SKU across a store and its nearby stores, sorted in-stock first. Per store: name, address, phone, coordinates, stock level/status, aisle/bay, pickup status. |
| Store directory / find stores near a postal code (geocoded → distance-sorted with |
More tools (suggestions, categories) are planned.
hd_search
Param | Type | Default | Notes |
| string | — | Search keyword (required). |
| string |
| Store id for store-specific stock/pricing. |
|
|
| Response language. |
|
|
| Sort order. |
| int |
| 0-indexed page. |
| int (1–60) |
| Results per page. |
hd_product
Param | Type | Default | Notes |
| string | — | Product SKU / code (required), e.g. |
| string | — | Postal code, e.g. |
| string |
| Store id for store-specific price/stock/aisle. Override default with |
|
|
| Response language. |
hd_store_availability
Param | Type | Default | Notes |
| string | — | Product SKU / code (required). |
| string | — | Postal code; nearby stores are taken around it (overrides |
| string |
| Reference store; nearby stores are taken from it. |
|
|
| Response language. |
| int (1–20) |
| Max number of stores to check. |
Default store: product/availability tools default to store
7074(Langford, BC). SetHD_DEFAULT_STOREenv var, or passstoreId, to use your local store. Usehd_storeswith a postal code to find the right store id.
hd_stores
Param | Type | Default | Notes |
| string | — | Canadian postal code, e.g. |
| number | — | Alternative to |
|
|
| Response language. |
| int (1–200) | 20 / all | Max stores. Default 20 for a proximity search, all (~183) otherwise. |
The store API geosorts by coordinates only, so a postal code is first geocoded via
api.zippopotam.us(free, no key).distanceKmis computed locally (haversine).
Related MCP server: MCP Tools
How it talks to Home Depot
homedepot.ca/api/* is behind Akamai Bot Manager, which gates on both the
HTTP version and the client's TLS (JA3) fingerprint. Node's native HTTP stack
(fetch/undici, node:http2) gets 403. Only curl --http2 is
allowlisted, so every request shells out to curl. No cookies are needed for
the public search APIs.
Requirement: curl with HTTP/2 support must be on PATH (standard on macOS
and most Linux distros).
Build & run
npm install
npm run build
npm start # runs the MCP server on stdioQuick smoke test of the search layer:
node --input-type=module -e 'import {search} from "./dist/search.js"; console.log(await search({query:"drill", pageSize:3}))'Inspect with the MCP Inspector:
npm run inspectConnecting a client
Add to your MCP client config (e.g. Claude Desktop claude_desktop_config.json),
pointing at the built entrypoint:
{
"mcpServers": {
"homedepot": {
"command": "node",
"args": ["/absolute/path/to/mcp_homedepot/dist/index.js"],
"env": { "HD_DEFAULT_STORE": "7074" }
}
}
}HD_DEFAULT_STORE is optional (defaults to 7074, Langford BC).
Project layout
src/
index.ts MCP server + tool registration (stdio)
hd.ts curl --http2 transport for homedepot.ca
search.ts hd_search implementation + response mapping
product.ts hd_product + hd_store_availability (summary, buybox, storesvc APIs)
stores.ts hd_stores (store directory + postal-code geocode → nearest)License
PolyForm Noncommercial License 1.0.0 — free to use, modify and share for noncommercial purposes. Commercial use requires a separate license from the author.
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/sstepanovvl/mcp_homedepot'
If you have feedback or need assistance with the MCP directory API, please join our Discord server