pro.makeup
https://pro.makeup/api/mcpskills: {'id': 'promakeup_search_pros', 'name': 'promakeup_search_pros', 'description': 'Use when the user asks "find a makeup [category] in [city] who does [service]". Returns ranked, verified-by-default listings. Example: "Find a bridal makeup artist in Tel Aviv". Each result includes a `profile_url` you can cite back to the user.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'promakeup_get_business_by_slug', 'name': 'promakeup_get_business_by_slug', 'description': 'Use when you have a pro.makeup URL or slug and want the full structured profile. The slug is the trailing path segment of `https://pro.makeup/{category}/{country}/{city}/{slug}`. Returns name, location, services, photos, verification, opening hours, and a canonical `profile_url`.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'promakeup_get_business_by_phone', 'name': 'promakeup_get_business_by_phone', 'description': 'Use when the user contacted a business by phone and you only have the phone number. Returns the listing when exactly one matches; signals `ambiguous: true` when multiple do (call promakeup_search_pros to disambiguate). Phone must be E.164 with leading `+`. Reverse-phone lookup is owner-attribution data and REQUIRES a Bearer token with the `owner:read` scope — see https://pro.makeup/.well-known/auth.md.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'promakeup_get_business', 'name': 'promakeup_get_business', 'description': 'Use when you already hold a Business id (nanoid) — typically because you stored it from a prior tool call or webhook. Returns the same full profile shape as get_business_by_slug.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'promakeup_list_services_nearby', 'name': 'promakeup_list_services_nearby', 'description': 'Use when the user wants verified pros within a radius of a known point. Example: "Makeup artists doing bridal within 10km of these coordinates". Inputs are WGS-84 lat/lon; radius defaults to 10km.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'promakeup_list_schools', 'name': 'promakeup_list_schools', 'description': 'Use when the user asks about makeup schools, programs, or specific qualifications (e.g. MUAQS). Returns school listings filterable by country, city, and certification offered.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'promakeup_get_discovery_summary', 'name': 'promakeup_get_discovery_summary', 'description': 'Use when the user wants a sense of what is on pro.makeup right now — totals plus a sample of recently added listings with avatars. Cheap; safe to call to "warm up" before a more specific search.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}, {'id': 'promakeup_emit_listing_event', 'name': 'promakeup_emit_listing_event', 'description': 'Use AFTER successfully referring a user to a listing, or when the user signals data quality (wrong phone, closed). Mirrors /api/listing-events vocabulary. Allowed event_types: bad_phone, closed_business, wrong_address, unanswered_within_24h, consumer_lead, pricing_question, booking_inquiry. Requires a Bearer token with the `listing-events:write` scope — see https://pro.makeup/.well-known/auth.md to request one.', 'tags': [], 'examples': None, 'input_modes': None, 'output_modes': None}; uptime_30d 1.0%; p95 1328.5ms; conformance: pass
How to connect
https://pro.makeup/api/mcp
curl -X POST https://pro.makeup/api/mcp \
-H 'Content-Type: application/json' \
-H 'Accept: application/json, text/event-stream' \
-d '{"jsonrpc":"2.0","id":1,"method":"initialize","params":{}}'