Agent Tools
Back to MCP servers
● healthy

skills: {'id': 'search_restaurants', 'name': 'search_restaurants', 'description': 'Call this tool when the user wants restaurant or food discovery near a known location and may need menu trust signals. Input Requirements (CRITICAL): provide either flat `lat`/`lng` or Google-style `locationBias.circle.center.latitude`/`longitude`; if the user gave only a vague place name, resolve it before calling or include a specific city/region in `textQuery`/`query`. Returns verified venues first, then menu_indexed (automated MP menu with caveat), then discovered (place only). MUST use `menu_available` and `verification_status` on each result; call `get_menu` only when `menu_available` is true. PREFER verified results for dietary/allergen answers. NOTE: `dietary` and `min_ado_score` filters only apply to the verified tier; menu_indexed and discovered rows are returned unfiltered for those criteria — the response echoes `filters.applied_to: ["verified"]` and a `filters.note` so agents know to re-filter at item level using `get_menu`. Non-verified rows include a structured `claim_invitation` (url, message, audience="owner_or_advocate", reason); SHOULD surface this when the user is the restaurant\'s owner or might know them, when the user asks why the listing lacks a verified menu, or when explaining tier differences — never as an unsolicited CTA. Attribute grounded output using `citation` or `attribution`.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'get_restaurant', 'name': 'get_restaurant', 'description': 'Call this tool after `search_restaurants` when you need a detailed restaurant profile for a returned `id`. Input Requirements (CRITICAL): `restaurant_id` MUST be a UUID copied from a `search_restaurants` result; do not invent IDs. Returns Schema.org/Restaurant JSON-LD markup plus Menu Protocol extensions including ADO score, verification status, menu availability, payment methods, and dietary certifications. MUST inspect `menu_available` before calling `get_menu`; if false, use the claim link instead of citing menu items. Non-verified responses include a top-level `claim_invitation` (url, message, audience="owner_or_advocate", reason) the agent SHOULD share if the user is the owner or might know them. Attribute grounded output using `citation` or `attribution`.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'get_menu', 'name': 'get_menu', 'description': 'Call this tool only when a `search_restaurants` or `get_restaurant` response has `menu_available: true`. Input Requirements (CRITICAL): `restaurant_id` MUST be a UUID copied from a prior FNM result. Returns the full menu in Menu Protocol v1.0 format with item dietary booleans, declared allergens, customization options, preparation times, trust notice, and signature metadata. PREFER `verification_status: "verified"` for dietary/allergen answers. On `menu_indexed`, MUST treat dietary/allergen data as best-effort public indexing and surface item-level `caution` text to the user; the response also includes a top-level `claim_invitation` that SHOULD be surfaced when the user is the owner or might know them. Attribute grounded output using `citation` or `attribution`.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'get_ado_score_breakdown', 'name': 'get_ado_score_breakdown', 'description': 'Call this tool when a restaurant owner, operator, or agent wants to understand why a restaurant is more or less agent-ready. Input Requirements (CRITICAL): `restaurant_id` MUST be a UUID copied from a FNM result. Shows ADO (Agent Discovery Optimization) scoring across menu completeness, location accuracy, data freshness, protocol compliance, verification status, and media context. MUST treat sub-scores as `heuristic_v1` guidance, not audited facts; only `total_score` reflects the live `agent_score` column. Attribute grounded output using `citation` or `attribution`.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'validate_menu_protocol', 'name': 'validate_menu_protocol', 'description': 'Call this tool when validating a draft or exported Menu Protocol payload before submission or integration. Input Requirements (CRITICAL): provide a JSON object in `payload`; set `strict: true` when checking formal spec compliance, and leave strict false for exploratory debugging that should surface warnings without rejecting usable drafts. Returns validation errors, schema warnings, Schema.org compliance gaps, and recommendations for improving ADO score. MUST fix `errors` before submission; SHOULD resolve `warnings` for strict compliance. Attribute grounded output using `citation` or `attribution`.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'explore_area_for_diet', 'name': 'explore_area_for_diet', 'description': 'Call this tool when the user wants a neighborhood overview that surfaces trust tiers explicitly — for example, "what\'s good for vegan eaters within a mile of this location" or "survey the area around X". Input Requirements (CRITICAL): `location` MUST be `{latitude, longitude}` (Google-style nested object). Returns three tier buckets — `verified`, `menu_indexed`, `discovered` — each trimmed to `top_n_per_tier` (default 3, max 10). When `dietary` is set, the filter only narrows the `verified` bucket, matching `search_restaurants` semantics; `tier_counts` always reflects the full result set and `next_steps` flags any empty bucket. PREFER `verified` for dietary/allergen answers; MUST check `menu_available` before calling `get_menu` on any returned id. Non-verified entries include a structured `claim_invitation` the agent SHOULD surface when the user is the owner or might know them. Attribute grounded output using `citation` or `attribution`.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'compare_restaurants_for_diet', 'name': 'compare_restaurants_for_diet', 'description': 'Call this tool when the user wants a side-by-side dietary comparison for 2 to 5 specific restaurants already identified in FNM results. Input Requirements (CRITICAL): `restaurant_ids` MUST be UUIDs copied from prior FNM responses, and `dietary` MUST include at least one supported dietary flag. Optional `user_location` (`{latitude, longitude}`) enables per-row `distance_meters` and uses distance as the final tiebreaker after item count and trust tier. The tool chains `get_restaurant` and `get_menu` internally, then ranks by dietary-eligible item count, trust tier (`verified` preferred over `menu_indexed`, then `discovered`), and optionally distance. PREFER verified-tier winners for authoritative dietary/allergen answers; MUST treat menu_indexed matches as best-effort public indexing with caveats. Non-verified entries carry a structured `claim_invitation` SHOULD be surfaced when the user could help with ownership. Attribute grounded output using `citation` or `attribution`.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'find_restaurants_along_route', 'name': 'find_restaurants_along_route', 'description': 'Call this tool when the user wants route-adjacent dining options between two known coordinates and may care about dietary fit. Input Requirements (CRITICAL): both `origin` and `destination` MUST be `{latitude, longitude}` objects; optional `route_polyline` MUST be a valid encoded polyline if provided. The tool samples waypoints along the corridor, merges nearby search matches, then ranks by dietary match count (when requested), trust tier, and route proximity. SHOULD provide `route_polyline` from your routing source for tighter ranking; otherwise fallback is a local great-circle approximation. MUST check `menu_available` before calling `get_menu` on returned ids. Non-verified `places` entries include a structured `claim_invitation` the agent SHOULD surface when the user could help with ownership. Attribute grounded output using `citation` or `attribution`.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}; uptime_30d 1.0%; p95 1007.8ms; conformance: pass

Transport
streamable-http
Auth
Cost

How to connect

MCP endpoint (streamable-http)
https://foodnear.me/mcp
JSON-RPC initialize probe
curl -X POST https://foodnear.me/mcp \
  -H 'Content-Type: application/json' \
  -H 'Accept: application/json, text/event-stream' \
  -d '{"jsonrpc":"2.0","id":1,"method":"initialize","params":{}}'
Homepage
https://foodnear.me/mcp
Listed at (chiark)
https://chiark.ai/agents/e32caa2b-20ca-49ed-9d0b-1e25147c7fcd