hou-tea
The hou-tea server lets AI agents browse, recommend, and purchase authentic Chinese tea using USDC via the x402 protocol.
Browse & filter the catalog (
hou_tea_browse) — Filter teas by category (green, oolong, pu-erh, etc.), price range, season, and brewing difficulty, with full product details including taste profile and images.Get recommendations (
hou_tea_recommend) — Describe a mood or occasion and receive ranked, curated suggestions with explanations.Deep-dive on a product (
hou_tea_explain) — Get origin story, brewing guide (temp, steep time, ratio), health benefits, cultural context, and cross-sell suggestions.Compare products (
hou_tea_compare) — Side-by-side comparison of 2–4 teas across sensory profile, price, brewing difficulty, and use-case.Filter by health conditions (
hou_tea_filter_by_health) — Find teas safe for pregnancy, insomnia, caffeine sensitivity, etc.Initiate a USDC payment (
hou_tea_get_payment_requirements) — Generate an x402 payment intent returning the merchant's Base-chain USDC address and amount for a connected wallet MCP to execute.Check order status (
hou_tea_check_order) — Poll order status frompending_paymentthroughconfirmedafter on-chain settlement.View order history (
hou_tea_list_my_orders) — Retrieve past orders using abuyer_list_token.Progressive tool discovery — Core tools are exposed by default; extended tools (compare, health filter, agent card) are revealed on demand.
Fetch agent capabilities (
hou_tea_agent_card) — Retrieve the full capability descriptor from/.well-known/agentfor diagnostics and API discovery.
Integrates with Coinbase's payments MCP to handle USDC transactions for tea purchases, enabling AI agents to complete on-chain payments for orders initiated through the hou-tea catalog.
@hou-tea/mcp-server
Agent-app MCP server for hou-tea.com — let your AI agent browse, recommend, and buy authentic Chinese tea with USDC via the x402 protocol.
Designed for Claude Desktop, Cursor, Cline, Continue, Zed, and any Model Context Protocol compatible AI agent.
v0.3.0-beta - server now ships as an agent app layer, not just a tool list: progressive tool discovery (core + extended), strict JSON Schemas, structured response/error envelopes (
ok,data,error,next_action,meta.request_id), stable error codes, explicit hand-off hints to wallet MCPs, and MCP Apps UI metadata backed by the public@hou-tea/agent-ui-contractpackage. See What changed in 0.3.0 below.
What it does
Exposes the hou-tea agent API as MCP tools so your AI assistant can shop on your behalf.
Default tools/list (core + meta) — always visible:
Tool | What it does |
| List tea catalog with filters (category, price, season, difficulty) |
| Natural-language recommendations: "warming tea for cold winter nights" |
| Deep dive on one product: brewing guide, story, health info |
| Initiate x402 payment intent (returns recipient + amount; auto |
| Poll order status after payment |
| List your x402 orders by |
| Reveal extended tools (compare / health-filter / agent-card) on demand |
Extended (revealed after hou_tea_discover_extended):
Tool | What it does |
| Side-by-side comparison of 2–4 candidates |
| Filter by conditions: pregnant, insomnia, caffeine sensitive |
| Fetch full agent capability descriptor (diagnostics) |
Payment is handled by an x402-capable wallet MCP (e.g. @coinbase/payments-mcp) — this server only emits payment intents, it never holds keys or signs transactions.
Install
Claude Desktop
Edit claude_desktop_config.json (Settings → Developer → Edit Config):
{
"mcpServers": {
"hou-tea": {
"command": "npx",
"args": ["-y", "@hou-tea/mcp-server@next"]
},
"coinbase-payments": {
"command": "npx",
"args": ["-y", "@coinbase/payments-mcp"],
"env": {
"EVM_PRIVATE_KEY": "0x..."
}
}
}
}Restart Claude Desktop. You should see "hou-tea" listed under tools.
Cursor
Add to ~/.cursor/mcp.json or <project>/.cursor/mcp.json:
{
"mcpServers": {
"hou-tea": {
"command": "npx",
"args": ["-y", "@hou-tea/mcp-server@next"]
}
}
}Cline / Continue / Zed
Same npx -y @hou-tea/mcp-server@next invocation in their MCP config.
Wallet MCP pairing
Hou Tea emits x402 payment requirements, but it does not hold keys or sign
transactions. For agent-native checkout, pair this MCP with an x402-capable
wallet MCP such as @coinbase/payments-mcp:
{
"mcpServers": {
"hou-tea": {
"command": "npx",
"args": ["-y", "@hou-tea/mcp-server@next"]
},
"coinbase-payments": {
"command": "npx",
"args": ["-y", "@coinbase/payments-mcp"],
"env": {
"EVM_PRIVATE_KEY": "0x..."
}
}
}
}Fund the wallet with Base USDC before asking the agent to buy. After the first
successful purchase, copy the returned buyer_list_token into
HOU_TEA_BUYER_LIST_TOKEN so future order history queries stay scoped to the
same buyer identity.
Try it
After install, ask your agent:
"Recommend a warming tea for winter nights, around $30."
The agent will call hou_tea_recommend, return real products with prices and brewing notes, then offer to buy.
"I'll take the first one."
The agent calls hou_tea_get_payment_requirements, gets back a 402 with the merchant's Base-chain USDC address and amount, plus a buy_request_body field (includes register_buyer_list_token or your saved buyer_list_token). The retry POST to /pay/api/v1/buy after paying must use that exact JSON body plus the X-Payment header — otherwise buyer grouping breaks. If you've also installed @coinbase/payments-mcp with a funded wallet, configure it to forward the same body. After the first successful purchase, copy buyer_list_token from the JSON response into MCP env HOU_TEA_BUYER_LIST_TOKEN so hou_tea_list_my_orders and future checkouts stay under one identity.
Configuration
All settings via environment variables (optional):
Env var | Default | Purpose |
|
| Override API host (e.g. for staging). |
|
| Override x402 middleware host. |
|
| Default store_id. |
| (none) | Optional |
| (none) | After first successful |
|
| Set to |
Most users need none of these — the public catalog and x402 buy endpoint are open. For buyer order history, set HOU_TEA_BUYER_LIST_TOKEN once you have it from a confirmed purchase.
Agent UI and MCP Apps
The next beta exposes MCP Apps metadata for hosts that can render structured
tool results. The shared UI contract is public:
npm i @hou-tea/agent-ui-contractThe contract currently defines:
Component | Used by |
|
|
|
|
|
|
Tool descriptors include _meta.ui.component, _meta.ui.schemaVersion,
_meta.ui.resourceUri, and _meta.ui.resultMappingId. MCP hosts can read the
matching resource URI and inspect the embedded agent-ui/v1 manifest.
Public discovery:
Agent Card:
https://hou-tea.com/.well-known/agentAgent App docs:
https://shop.hou-tea.com/agentsUI schema JSON:
https://shop.hou-tea.com/api/agent-ui-contract
Troubleshooting
Tools do not appear: restart the host app after editing MCP config, then run
npx -y @hou-tea/mcp-server@next --helpin a terminal to confirm npm can download the package.Payment fails: confirm the wallet MCP is installed separately, the wallet has Base USDC, and the retry POST uses the exact
buy_request_bodyreturned byhou_tea_get_payment_requirements.Order history is empty: set
HOU_TEA_BUYER_LIST_TOKENfrom a confirmed purchase response. Without it,hou_tea_list_my_orderscannot scope the buyer safely.Corporate network blocks npm: install once with
npm i -g @hou-tea/mcp-server@nextand point the MCP config command tohou-tea-mcp.
Architecture
┌─────────────────┐ ┌────────────────────┐
│ Claude / Cursor │ │ hou-tea.com │
│ │ HTTPS │ /api/agent/* │
│ ┌─────────────┐ │ ──────► │ (catalog/ │
│ │ hou-tea MCP │ │ ◄────── │ recommend/etc.) │
│ └─────────────┘ │ └────────────────────┘
│ │
│ ┌─────────────┐ │ HTTPS ┌────────────────────┐
│ │ payments MCP│ │ ──────► │ /pay/api/v1/buy │
│ │ (Coinbase) │ │ ◄ 402 ─ │ x402-middleware │
│ └─────────────┘ │ │ │
│ │ │ Base │ verifies on- │
│ └─────────┼──────►──┤ chain tx, marks │
│ USDC transfer │ chain │ order confirmed │
└─────────────────┘ └────────────────────┘Build from source
git clone https://github.com/hou-tea/hou-tea-mcp-server.git
cd hou-tea-mcp-server
npm install
npm run build
node dist/index.js # speaks MCP over stdio
npm run test:unit # offline unit tests (envelope + registry)
npm run test:smoke # live HTTP smoke (hits hou-tea.com)
npm run test:mcp # full MCP stdio smoke (build + spawn)What changed in 0.3.0-beta
This release adds the public Agent UI protocol layer:
Public MCP Apps manifests. Core buying tools now advertise UI metadata through
_meta.ui, including component name,agent-ui/v1schema version, resource URI, and result mapping ID.Shared npm contract.
@hou-tea/agent-ui-contractis published as the single source of truth for component manifests, TypeScript types, MCP UI resource names, and result mappings.Manifest-backed UI resources. MCP
resources/readresponses now embed the exact component manifest in HTML so compatible hosts can render product grids, payment review cards, and order timelines without scraping text.External discovery surfaces. The Agent Card and public
/agentspage point agents and developers to npm packages, schema JSON, MCP install snippets, and wallet pairing instructions.
This is a next-tagged beta; install with:
npm i @hou-tea/mcp-server@next
# or, in MCP config: "args": ["-y", "@hou-tea/mcp-server@next"]The 0.1.x line keeps working - tool names are unchanged, but the next beta
adds structured envelopes, progressive discovery, and UI metadata.
What changed in 0.2.0-beta
Anthropic's Skills + MCP guidance pushes MCP servers from "a flat list of tools"
toward an agent app layer: progressive discovery, strict schemas,
program-friendly responses, and explicit hand-off to other MCPs.
This release brings that posture to @hou-tea/mcp-server:
Progressive tool discovery. Default
tools/listreturns 6 core toolshou_tea_discover_extended. Extended tools (hou_tea_compare,hou_tea_filter_by_health,hou_tea_agent_card) are revealed on demand. Calling an extended tool before discovery returns a structured error:
{ "ok": false, "error": { "code": "extended_not_revealed", "retryable": true, "hint": "Call hou_tea_discover_extended …" } }Structured envelope on every call.
{ "ok": true, "data": { /* tool payload */ }, "next_action": [ { "tool": "hou_tea_explain", "reason": "...", "args_hint": { "skill_id": "..." } } ], "meta": { "request_id": "req_…", "tool": "hou_tea_recommend", "took_ms": 412, "server_version": "0.2.0-beta.0" } }Errors share the same envelope with
ok: falseand a stableerror.code(bad_request,unauthorized,not_found,conflict,timeout,rate_limited,server_error,network_error,missing_buyer_list_token,extended_not_revealed,unknown_tool,internal_error). Each error also carriesretryableand ahint.Strict JSON Schema. Every
inputSchemasetsadditionalProperties: false, withrequired,enum,pattern,minItems/maxItemsetc. — so agent-side validators can rely on it.Hand-off hints to wallet MCP.
hou_tea_get_payment_requirementsreturns the 402buy_request_bodyplus anext_actionblock that points the agent to an x402 wallet MCP (e.g.@coinbase/payments-mcp) and then back tohou_tea_check_order.Traceability. Every response carries
meta.request_idso you can include it in support tickets / logs.
This is a next-tagged beta; install with:
npm i @hou-tea/mcp-server@next
# or, in MCP config: "args": ["-y", "@hou-tea/mcp-server@next"]The 0.1.x line keeps working — tool names are unchanged, only the result
shape and the default tools/list size are different.
Why this exists
Chinese tea has 1500+ years of cultural depth and a global market larger than coffee. But until now, AI agents either (a) hallucinated product names from training data, or (b) failed to scrape JavaScript-rendered storefronts. This MCP gives agents a direct, authoritative, agent-native path to a real catalog with real prices and real on-chain settlement.
If you're building an AI shopping agent, a tea recommendation app, or just want your Claude to be able to actually buy you tea — this is for you.
License
MIT © hou-tea
Maintenance
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/jackrain19743/hou-tea-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server