run.cityheart/heart-routes
https://zhenwiaphfwetckfysod.supabase.co/functions/v1/mcpskills: {'id': 'find_heart_route_in_city', 'name': 'find_heart_route_in_city', 'description': 'Find an existing heart-shaped running route in a given city. Returns up to 5 AI-validated routes matching the city (and optionally a target distance). Use this when a user mentions a city and wants a heart route — e.g. "find me a heart-shaped route in Paris" or "I want to run a heart in Tokyo for my mum\'s birthday".', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'get_route_details', 'name': 'get_route_details', 'description': 'Get full details for a specific heart route by its slug. Use after find_heart_route_in_city when the user picks one. Returns: city, distance, image URL, share URL, dedication (if any), and the GPX download deep-link.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'list_supported_cities', 'name': 'list_supported_cities', 'description': 'List cities that have at least one heart route available. Use when the user asks "where can I run a heart?" or hasn\'t picked a city yet. Returns city names + route counts, sorted by inventory size.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'generate_heart_route', 'name': 'generate_heart_route', 'description': 'Start a new heart-shaped route for a given city. Returns existing AI-validated matches from inventory PLUS a deep-link to the live builder for an on-demand fresh generation with the user\'s exact dedication and cause. Use when the user explicitly wants a NEW heart, or when an existing match is "close enough but not personal yet". Optional dedication / cause_url pre-fill the builder fields, so the URL deep-link arrives configured.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'add_dedication', 'name': 'add_dedication', 'description': "Compose a builder URL with a dedication pre-filled — the name shows on the runner's GPS watch and in the Strava activity title. Use after the user picks a route (find/generate) and decides who the heart is for. Pure URL builder, no server-side state.", 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'add_cause', 'name': 'add_cause', 'description': "Compose a builder URL with a fundraising link pre-filled — the URL is embedded into the GPX metadata (description, filename) so it surfaces in the runner's Strava activity after they sync. CityHeart never collects the donation; the runner's donors click straight through to JustGiving / GoFundMe / Leetchi / etc.", 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'export_gpx', 'name': 'export_gpx', 'description': 'Return the GPX download / checkout URL for a specific public route. The download itself happens on cityheart.run after a one-time €4.99 payment (Stripe — CityHeart never charges through the chat). Use after the user has picked a final route (find / get_details) and confirms they want it.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}; uptime_30d 1.0%; p95 1649.3ms; conformance: pass
How to connect
https://zhenwiaphfwetckfysod.supabase.co/functions/v1/mcp
curl -X POST https://zhenwiaphfwetckfysod.supabase.co/functions/v1/mcp \
-H 'Content-Type: application/json' \
-H 'Accept: application/json, text/event-stream' \
-d '{"jsonrpc":"2.0","id":1,"method":"initialize","params":{}}'