{"audit":{"version":"1.3","generated_at":"2026-05-22T23:02:25.699788+00:00","generated_by":"Agenstry","report_url":"https://agenstry.com/agents/coordinalo.com","methodology_url":"https://agenstry.com/methodology","verifier_jwks_url":"https://agenstry.com/.well-known/jwks.json","subject":{"domain":"coordinalo.com","name":"Coordinalo","url":"https://coordinalo.com/.well-known/agent.json"}},"identity":{"provider":{"organization":"Coordinalo","url":"https://coordinalo.com"},"registry_verification":null,"signature":{"signed":false,"signature_valid":null}},"protocol":{"version":null,"supports_streaming":false,"supports_push_notifications":false},"operational":{"live_state":"wrong_response","live_responds":false,"last_status_code":200,"last_elapsed_ms":929,"last_error":null},"track_record":{"first_seen":"2026-05-18T14:43:28.686224+00:00","last_checked":"2026-05-22T12:51:35.103577+00:00","last_seen_ok":"2026-05-22T12:51:35.103577+00:00","checks_total":6,"checks_ok":6,"uptime_pct":100.0,"archived":false,"archived_reason":null},"conformance":{"score":51,"grade":"D","summary":"D-grade: significant issues — auth-gated, partially broken, or stale.","criteria":[{"key":"valid_card","label":"Valid AgentCard","points":10,"max_points":10,"status":"pass","detail":"Schema-validated A2A AgentCard returned by the well-known endpoint."},{"key":"live_responds","label":"Live JSON-RPC","points":5,"max_points":25,"status":"fail","detail":"Endpoint replies but body isn't a valid JSON-RPC 2.0 A2A response."},{"key":"protocol_version","label":"Protocol version","points":0,"max_points":10,"status":"fail","detail":"No protocolVersion in card."},{"key":"signature","label":"JWS signature","points":0,"max_points":10,"status":"info","detail":"Card is unsigned (most published agents are)."},{"key":"uptime","label":"Uptime track record","points":15,"max_points":15,"status":"pass","detail":"6/6 probes succeeded (100% uptime)."},{"key":"skills","label":"Skill declaration","points":10,"max_points":10,"status":"pass","detail":"Declares 96 skills with structured metadata."},{"key":"verified_identity","label":"Verified Identity","points":5,"max_points":10,"status":"partial","detail":"Provider declared: Coordinalo (https://coordinalo.com). Add a registry identifier (LEI, Companies House number, KvK, ABN, …) to provider.legalEntity for full verified-business credit."},{"key":"freshness","label":"Freshness + modern flags","points":4,"max_points":5,"status":"pass","detail":"seen in upstream source within 0d"},{"key":"security","label":"Security declaration","points":2,"max_points":5,"status":"partial","detail":"Declares 2 security scheme(s) but none use PKCE or mTLS."}]},"skills":[{"id":"booking_create","name":"Create Booking","description":"Create a new session/appointment for a client. providerId is optional — if omitted, the system auto-assigns a provider using the agenda assignment strategy (round_robin, least_booked, etc.). When a client has a titular provider, that provider is preferred automatically. Without providerId and without publicAgendaId, the org default public agenda is used. Preconditions: (1) service must exist and be active, (2) client must exist (use client_create first). Use availability_get_slots to find valid time slots before calling this. Set retroactive: true to register past sessions (skips slot validation, sets status to completed by default). Use autoCharge: true with retroactive to auto-generate the charge. Retroactive sessions are tagged with self_declared provenance. Max 365 days in the past. Past dates are auto-detected as retroactive — the retroactive flag is optional (system infers it from scheduledAt).","tags":["booking","sessions","scheduling","retroactive"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"booking_get","name":"Get Booking","description":"Get complete details of a session/appointment by its ID, including client, provider, service, financial, and delivery proof information.","tags":["booking","sessions"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"booking_list","name":"List Bookings","description":"List sessions for an organization with filters by provider, client, service, status, and date range. Supports cursor-based pagination.","tags":["booking","sessions","listing"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"booking_cancel","name":"Cancel Booking","description":"Cancel an existing session. Optionally applies cancellation policy charges. Requires confirm: true.","tags":["booking","sessions","cancellation"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"booking_reschedule","name":"Reschedule Booking","description":"Reschedule a session to a new time. Cancels the original and creates a new one. Requires confirm: true.","tags":["booking","sessions","rescheduling"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"booking_update_status","name":"Update Booking Status","description":"Advance a session through the Servicialo lifecycle: confirm, start, complete, or mark as no-show. NOTE: the \"deliver\" action is NOT available via MCP (ref PDC-SEC-001) — MCP authentication cannot validate actor-as-Proveedor. Delivery must be performed via the REST endpoint PATCH /api/organizations/[orgSlug]/coordinalo/sessions/[sessionId]/deliver which enforces provider binding.","tags":["booking","sessions","lifecycle"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"booking_create_recurring","name":"Create Recurring Booking","description":"Create recurring sessions (e.g. weekly therapy). Generates multiple individual sessions linked by a recurrence series ID. Max 52 occurrences.","tags":["booking","sessions","recurring"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"availability_get_slots","name":"Get Available Slots","description":"Query available time slots within a date range. Agenda-aware: without clientId, filters by the org default public agenda — each org decides which services to expose. With clientId, resolves the client titular provider and returns their full service catalog. Five modes: (1) orgSlug only — slots from the public agenda grouped by service, provider auto-assigned at booking; (2) orgSlug + clientId — resolves titular provider if set, falls back to agenda; (3) orgSlug + agendaId — slots for a specific agenda; (4) serviceId — slots for all providers assigned to that service; (5) providerId — slots for a specific provider. Modes 1–3 hide provider details. Use before booking_create.","tags":["availability","scheduling","slots"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"availability_get_provider_schedule","name":"Get Provider Schedule","description":"Get the configured weekly availability schedule for a provider (not free slots, but the base configuration). Use admin_set_availability to modify.","tags":["availability","scheduling","providers"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"client_list","name":"List Clients","description":"List clients of an organization with search and pagination. Can filter by provider or outstanding debt.","tags":["clients","crm","listing"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"client_get","name":"Get Client","description":"Get complete details of a client including financial summary and recent sessions.","tags":["clients","crm"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"client_create","name":"Create Client","description":"Create a new client in the organization. If a Person with the same email exists, it will be linked (not duplicated).","tags":["clients","crm"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"client_update","name":"Update Client","description":"Update an existing client's personal data. Email cannot be changed via MCP.","tags":["clients","crm"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"service_create","name":"Create Service","description":"Create a new bookable service in an existing organization. Use this for day-to-day service management (requires X-Org-Api-Key). For initial org setup, prefer admin_create_service instead. After creating, use service_assign_provider to link providers. A service without providers cannot accept bookings.","tags":["services","catalog"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"service_list","name":"List Services","description":"List services of an organization. Can filter by active status, discoverability, or category.","tags":["services","catalog","listing"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"service_update","name":"Update Service","description":"Update an existing service (price, duration, status, etc.). Creates a price history entry if price changes.","tags":["services","catalog"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"service_assign_provider","name":"Assign Provider to Service","description":"Assign or unassign a provider to/from a service. Controls which providers can deliver which services.","tags":["services","providers"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"provider_get","name":"Get Provider","description":"Get complete details of a provider including services, schedule, and session stats.","tags":["providers"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"provider_create","name":"Create Provider","description":"Create a new provider in the organization. Links or creates a Person record by email.","tags":["providers"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"provider_update","name":"Update Provider","description":"Update provider data: status, commission, coverage areas, permissions.","tags":["providers"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"provider_get_stats","name":"Get Provider Stats","description":"Get detailed performance metrics for a provider over a date range: sessions, occupancy, no-show rate, revenue.","tags":["providers","reporting"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"finance_list_cobros","name":"List Charges","description":"List charges (cobros) for an organization. Filter by client, status, or date range. Includes summary totals.","tags":["finance","charges","listing"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"finance_get_cobro","name":"Get Charge","description":"Get details of a specific charge (cobro) including all associated payments.","tags":["finance","charges"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"finance_create_cobro","name":"Create Charge","description":"Create a manual charge (cobro) for a client. Not linked to a sale/venta.","tags":["finance","charges"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"finance_register_payment","name":"Register Payment","description":"Register a manual payment against an existing charge (cobro). Updates cobro status automatically. Requires confirm: true.","tags":["finance","payments"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"finance_client_balance","name":"Get Client Balance","description":"Get the complete financial balance for a client: total sales, charges, payments, pending debt, and credits.","tags":["finance","clients"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"finance_list_payments","name":"List Payments","description":"List payments received with filters. Includes summary by payment type.","tags":["finance","payments","listing"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"finance_list_ventas","name":"List Sales","description":"List sales (ventas) for an organization. Filter by client, service, provider, or status.","tags":["finance","sales","listing"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"finance_create_venta","name":"Create Sale","description":"Create a service sale (venta) for a client. Optionally auto-creates a charge (cobro) depending on org configuration. Requires confirm: true.","tags":["finance","sales"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"finance_aging","name":"Accounts Receivable Aging","description":"Get accounts receivable aging report: pending charges grouped by age buckets (0-7, 7-30, 30-90, 90+ days). Use to answer \"who owes money\" or \"old debts\" questions.","tags":["finance","reporting","aging"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"finance_list_confirmations","name":"List Charge Confirmations","description":"List pending charge confirmations and their status. Shows cobros in pending_confirmation state that await client verification. Filter by client or confirmation status (pending, confirmed, disputed, auto_confirmed).","tags":["finance","confirmations","provenance"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"finance_send_confirmations","name":"Send Confirmation Digest","description":"Send pending confirmation digest to clients. Groups all pending_confirmation charges by client and sends a single message per client via WhatsApp or email. Creates confirmation tokens and sets a grace period for auto-confirmation. Requires confirm: true.","tags":["finance","confirmations","communications"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"comms_get_preferences","name":"Get Communication Preferences","description":"Get the communication preferences for an organization (WhatsApp, email, confirmation, reminder channels and messages).","tags":["communications","preferences"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"comms_update_preferences","name":"Update Communication Preferences","description":"Enable or disable communication channels and features for an organization. Partial update — only provided fields are changed. Creates preferences if none exist.","tags":["communications","preferences"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"comms_list_campaigns","name":"List Campaigns","description":"List communication campaigns (WhatsApp/email) for the organization. Filter by status.","tags":["communications","campaigns","listing"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"comms_get_campaign","name":"Get Campaign","description":"Get details of a specific campaign with optional delivery logs per recipient.","tags":["communications","campaigns"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"comms_send_message","name":"Send Message","description":"Send a single WhatsApp or email message to a specific client. Use templateKey for predefined templates or customMessage for free text. Requires confirm: true.","tags":["communications","messaging"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"comms_render_message","name":"Render Visual Message","description":"Render a communication template as a visual image (PNG). Available templates: session-confirmation, session-reminder, payment-reminder. Use action \"preview\" to get the image URL, \"send\" to render and send via WhatsApp with the image attached. Each template requires specific data fields (clientName, providerName, date, time, etc.).","tags":["communications","rendering","visual"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"comms_create_campaign","name":"Create Email Campaign","description":"Create a new email campaign with HTML body to send to a segmented audience. Supports variable substitution: {nombre}, {apellido}, {nombre_completo}, {email}, {telefono}, {organizacion}. Use audienceType \"predefined\" with audienceId \"active\"/\"inactive\"/\"new\"/\"with_whatsapp\"/\"without_whatsapp\", or \"adhoc\" with custom filters. Returns campaign ID and recipient count. Campaign starts as draft — use comms_send_campaign to execute. Requires confirm: true.","tags":["communications","campaigns","email"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"comms_send_campaign","name":"Send Campaign","description":"Execute a draft or scheduled campaign. Sends messages to all matching recipients asynchronously. Campaign must be in draft or scheduled status. Returns immediately — use comms_get_campaign to track progress. Requires confirm: true.","tags":["communications","campaigns"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"report_dashboard","name":"Dashboard Report","description":"Executive summary of the organization: today's sessions, monthly metrics, revenue, pending charges, and alerts.","tags":["reporting","dashboard"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"report_occupancy","name":"Occupancy Report","description":"Calculate provider occupancy rates for a period. Group by provider, day, or week.","tags":["reporting","occupancy"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"report_revenue","name":"Revenue Report","description":"Calculate revenue for a period grouped by day, week, month, service, or provider.","tags":["reporting","revenue"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"report_no_shows","name":"No-Shows Report","description":"Report no-show statistics for a period. Group by client, provider, service, or day.","tags":["reporting","no-shows"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"report_sc_summary","name":"SC Summary Report","description":"Breakdown of Servicio Coordinado (SC) events by month and resolver path (backfill, cac-native, live, compensalo). Use to validate SC coverage and monitor live SC resolution growth. Key metric: sc_live shows SCs resolved in production (not backfill).","tags":["reporting","sc","validation"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"report_deuda_real","name":"Real Debt Report","description":"Real-time report of clients with genuine outstanding debt. Excludes temporal payment mismatches (prepaid clients whose global balance is covered). Shows: client name, debt amount, periods with debt, last payment date, and collection status (active/inactive/never_paid). Use to answer \"who actually owes money\" questions.","tags":["reporting","finance","deuda","cac"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"org_summary","name":"Organization Summary","description":"Compact organization overview (~500 tokens). Returns services, providers, schedules, active features, key counts, and an onboarding_status checklist showing what is configured vs missing (services, providers, availability, public agenda). Use as first call to orient yourself — cheaper than report_dashboard. If onboarding_status.ready is false, follow the missing steps before booking.","tags":["reporting","organization","onboarding"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"agendas_list","name":"List Agendas","description":"List public agendas for an organization. Returns agendas with their provider, service, and session counts.","tags":["agendas","booking"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"agendas_create","name":"Create Agenda","description":"Create a public agenda — a shareable booking page where external clients can self-book appointments. Links to a specific provider and/or service. The agenda gets a public URL at /{orgSlug}/agenda/{slug}. Create this after services and availability are configured. Without a public agenda, clients can only be booked via the API or dashboard.","tags":["agendas","booking"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"agendas_get","name":"Get Agenda","description":"Get complete details of a public agenda by ID. Returns all configuration including booking flow (service_first, provider_first, auto), selection modes, assignment strategy, booking policies (advance booking, same-day, on-demand), cancellation policies, privacy settings, linked provider/service, and session count. Use before agendas_update to inspect current settings.","tags":["agendas","booking"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"agendas_update","name":"Update Agenda","description":"Update a public agenda’s configuration. Partial update — only provided fields are changed. Supports modifying: title, description, visibility (isPublic/isActive), booking flow order (service_first/provider_first/auto), selection modes for service and provider (required/optional/auto/hidden), assignment strategy (manual/round_robin/least_booked/most_available/priority/random), booking policies (min/max advance, same-day, on-demand), cancellation policies (type, deadline, penalty), privacy flags (showSessions, showClientNames, showProviderUtilization, showProviderList), prepayment, and provider/service linking. When a provider is assigned, their services are auto-linked to the agenda.","tags":["agendas","booking","settings"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"agendas_delete","name":"Delete Agenda","description":"Delete a public agenda permanently. Cascades to related sessions booked through this agenda, comments, and service configs. Requires confirm: true. Cannot be undone.","tags":["agendas","booking"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"org_update","name":"Update Organization","description":"Update organization profile fields: name, description, logo URL, or vertical. Only provided fields are updated.","tags":["organization","settings"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"members_list","name":"List Members","description":"List members of an organization with their roles and status.","tags":["members","team"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"members_invite","name":"Invite Member","description":"Invite a new member to the organization by email. Sends an invitation email. Requires confirm: true.","tags":["members","team"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"disputes_list","name":"List Disputes","description":"List disputes for an organization. Filter by status or type. Returns disputes with client and provider info.","tags":["disputes","support"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"email_domain_get","name":"Get Email Domain","description":"Get the email sending domain configured for an organization and its verification status (PENDING, VERIFIED, FAILED). Returns null if no domain is configured. Use email_domain_register to set one up.","tags":["email","domain","configuration"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"email_domain_register","name":"Register Email Domain","description":"Register a custom email sending domain for an organization via Resend. Returns DNS records that must be configured in the domain provider before verification. Replaces any previously configured domain. After adding DNS records, call email_domain_verify to check status.","tags":["email","domain","configuration"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"email_domain_verify","name":"Verify Email Domain","description":"Trigger DNS verification for the configured email domain and return updated status. Call this after the organization has added the required DNS records. Status will be VERIFIED (ready to send), PENDING (DNS not yet propagated), or FAILED.","tags":["email","domain","verification"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"email_domain_delete","name":"Delete Email Domain","description":"Remove the configured email sending domain from the organization. This deletes it from both Resend and the database. The organization will revert to using the default Coordinalo sending address. Requires confirm: true.","tags":["email","domain","configuration"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"dunning_get_config","name":"Get Dunning Config","description":"Get the current dunning (payment recovery) configuration for an organization. Returns whether dunning is enabled, grace period, step timings, and blocking settings.","tags":["dunning","finance","configuration"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"dunning_configure","name":"Configure Dunning","description":"Update dunning (payment recovery) configuration for an organization. All fields except organizationSlug are optional — only provided fields are updated, rest stays unchanged.","tags":["dunning","finance","configuration"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"settings_get","name":"Get Settings","description":"Get organization settings by chapter or specific keys. Chapters: basics (name, description, vertical, timezone, currency), availability (weekday hours, saturday, assisted assignment), communication (channels, phone required), finances (provider payment type, client payment timing, max balance), policies (no-show strikes, blocking duration, no-show charge, auto-apply), reminders (session 24h, booking, payment, confirmation timeout), client_data (required fields: lastName, rut, email, phone, direccion). Use chapter param for a group, or keys param for specific settings (comma-separated, e.g. \"policies.noShowMaxStrikes,finances.clientPaymentTiming\").","tags":["settings","configuration"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"settings_update","name":"Update Settings","description":"Update organization settings. Partial update — only provided keys are changed. Pass a settings object with key-value pairs (e.g. {\"policies.noShowMaxStrikes\": 3, \"finances.clientPaymentTiming\": \"BEFORE\"}). All values are validated before writing — if any key fails validation, no changes are applied. Returns the full updated settings for the affected chapters. See settings_get for available keys and valid values.","tags":["settings","configuration"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"reminders_get_config","name":"Get Reminder Configuration","description":"Get the full reminder/notification configuration for an organization. Returns detailed settings for each reminder type: bookingReminder (post-booking follow-up), sessionReminder24h (24h before), sessionReminder1h (1h before), paymentReminder (payment due), paymentOverdue (overdue payment), notificationFollowup (post-session NPS/follow-up), pendingConfirmation (auto-cancel unconfirmed). Each has enabled, timing, and frequency settings. More granular than settings_get reminders chapter.","tags":["reminders","notifications","configuration"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"reminders_update_config","name":"Update Reminder Configuration","description":"Update reminder/notification configuration for an organization. Partial update — only provided sections are changed. Sections: bookingReminder {enabled, daysAfter, maxReminders, interval}, sessionReminder24h {enabled, hoursBefore, sendTime}, sessionReminder1h {enabled, hoursBefore}, paymentReminder {enabled, daysAfter, maxReminders, interval}, paymentOverdue {enabled, daysOverdue, maxReminders, interval}, notificationFollowup {enabled, daysAfter, maxFollowups, interval}, pendingConfirmation {enabled, timeoutHours, autoConfirm}. Returns the full configuration after update.","tags":["reminders","notifications","configuration"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"admin_create_organization","name":"Create Organization","description":"Create a new organization from scratch. Use this first when onboarding a new client — no org needs to exist yet. Requires X-Bootstrap-Key header (not X-Org-Api-Key, because the org does not exist yet). Returns a one-time admin API key (sk_admin_...) for subsequent admin_create_service, admin_set_availability, and admin_toggle_discoverable calls. To get a bootstrap key, visit https://coordinalo.com/developers — free, self-service, issued in minutes. IMPORTANT: Always pass an idempotencyKey (e.g. a UUID) to safely handle retries — if a previous call with the same key and slug succeeded, the existing org is returned without creating a duplicate. Errors with isRetryable: false should NOT be retried with the same parameters.","tags":["admin","onboarding","organization"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"admin_list_providers","name":"List Providers (Admin)","description":"List active providers (professionals) for an organization. Use this to get providerId before calling admin_set_availability. The org owner is auto-provisioned as a provider. Requires X-Org-Api-Key header.","tags":["admin","providers"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"admin_create_service","name":"Create Service (Admin)","description":"Add a bookable service to an organization. Use after admin_create_organization. Auto-discoverable by default. If the org has exactly one active provider, the service is auto-assigned to them. With multiple providers, use service_assign_provider to assign manually — unassigned services block admin_toggle_discoverable. Next step: admin_set_availability to configure the provider schedule. Requires X-Org-Api-Key header.","tags":["admin","services","onboarding"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"admin_set_availability","name":"Set Availability (Admin)","description":"Replace the weekly availability schedule for a provider (not additive — overwrites all existing blocks). Get providerId from admin_list_providers first. Schedule uses day names and HH:MM times. Requires X-Org-Api-Key header.","tags":["admin","availability","scheduling"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"admin_toggle_discoverable","name":"Toggle Discoverable (Admin)","description":"Publish or unpublish an organization in the Servicialo global registry. Use as the last step after configuring services and availability. Note: first call after admin_create_organization may return registry_updated: false — call again to confirm. Requires X-Org-Api-Key header.","tags":["admin","registry","discovery"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"cierre_preview_cliente","name":"Preview Client Closing","description":"Preview the financial snapshot for a client in a period WITHOUT creating the closing. Returns totals for ventas, cobros, pagos, sessions.","tags":["cierre","finance","preview"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"cierre_crear_cliente","name":"Create Client Closing","description":"Create a client monthly closing (immutable financial snapshot). Requires historialCompleto=true on the client. One closing per client per period.","tags":["cierre","finance"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"cierre_listar_clientes","name":"List Client Closings","description":"List client closings for an organization. Filter by period and/or client.","tags":["cierre","finance","listing"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"cierre_eliminar_cliente","name":"Delete Client Closing","description":"Delete (reopen) a client closing. Only allowed if the organizational period is not frozen. Requires confirm: true.","tags":["cierre","finance"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"cierre_evaluar_org","name":"Evaluate Org Closing Readiness","description":"Evaluate organizational closing readiness for a period. Returns: active clients, closed count, excluded count, pending count, completion percentage, and whether closing is possible.","tags":["cierre","finance","reporting"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"cierre_cerrar_org","name":"Close Organizational Period","description":"Close the organizational period. Requires ALL active clients with historialCompleto=true to be closed first. Freezes the period.","tags":["cierre","finance"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"cierre_distribuir_utilidades","name":"Distribute Profits","description":"Distribute profits for a closed period. Freezes the current period and all prior open periods. Requires the period to be organizationally closed first. Requires confirm: true.","tags":["cierre","finance"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"cierre_listar_utilidades","name":"List Retained Earnings","description":"List retained earnings (utilidades retenidas) for an organization. Returns per-period records with accumulated totals: ingresos, costos, utilidadNeta, distribuido, retenido.","tags":["cierre","finance","listing"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"nps_get_summary","name":"NPS Summary","description":"Get NPS summary for the organization: score, trend, promoter/passive/detractor counts. Use to answer questions about customer satisfaction.","tags":["nps","reporting","satisfaction"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"payroll_list_records","name":"List Payroll Records","description":"List payroll records for an organization. Filter by period, provider, or status.","tags":["payroll","finance","listing"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"payroll_get_summary","name":"Payroll Summary","description":"Get payroll summary for a period: total per provider, total cost, pending approvals.","tags":["payroll","finance","reporting"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"public_service_list","name":"Public Service List","description":"List publicly bookable services for an organization. Does NOT require an API key. Returns only active, discoverable services with assigned providers. Use this as the first step in the public booking flow to show available services to end users or agents.","tags":["public","services","discovery","booking"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"public_availability_get_slots","name":"Public Availability Slots","description":"Query available time slots for public booking. Does NOT require an API key. Returns slots grouped by service from the organization's public agenda. Provider details are hidden — the system auto-assigns at booking time. Use after public_service_list to find bookable times.","tags":["public","availability","slots","booking"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"public_booking_create","name":"Public Booking Create","description":"Create a public booking request. Does NOT require an API key, but DOES require: (1) requester identity — fullName plus at least email or phone, (2) submission context — channel and whether an agent assisted, (3) authorization.humanIntentConfirmed must be true. The booking is created as pending_confirmation — use public_booking_confirm with the returned confirmationToken to confirm. A bookingToken is also returned for future lifecycle management (cancel, reschedule). Rate-limited per IP+org. All requests are audited with semantic decision codes. Use public_service_list → public_availability_get_slots → public_booking_create → public_booking_confirm as the complete public booking flow.","tags":["public","booking","identity-validated"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"public_booking_confirm","name":"Public Booking Confirm","description":"Confirm a pending public booking using the confirmationToken returned by public_booking_create. Advances the booking from pending_confirmation to scheduled. The token expires after 30 minutes. Does NOT require an API key. Rate-limited.","tags":["public","booking","confirmation"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"public_booking_get","name":"Public Booking Get","description":"Get details of a public booking using the bookingToken returned by public_booking_create. Returns status, scheduled time, service, and requester info. Does NOT require an API key — the booking token is the credential. Only returns public-safe data.","tags":["public","booking","lifecycle"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"public_booking_cancel","name":"Public Booking Cancel","description":"Cancel a public booking using the bookingToken. Only works for bookings in pending_confirmation, scheduled, or confirmed status. Optionally include a reason. Does NOT require an API key. The booking token scopes access to a single booking.","tags":["public","booking","lifecycle","cancellation"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"public_booking_reschedule","name":"Public Booking Reschedule","description":"Reschedule a public booking using the bookingToken. Cancels the original and creates a new pending_confirmation booking at the new time. Returns new confirmationToken and bookingToken. Only works for bookings in pending_confirmation, scheduled, or confirmed status. Does NOT require an API key.","tags":["public","booking","lifecycle","rescheduling"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"lifecycle_history","name":"Get Lifecycle History","description":"Get the SCEvent stream for a session — all observed transitions reconstructed from status_history. Returns events[] with discriminated union by event_type (sc.scheduled, sc.confirmed, sc.completed, sc.delivered, sc.verified, sc.cancelled, etc.), plus stream_completeness (\"complete\" | \"partial_pre_trigger\") and pagination cursor. Events carry origin=\"reprojected_from_status_history\" and canonical SCEvent shape per docs/protocol/sc-event-canonical-schema-2026-04-18.md §7.2. Filters: event_types (e.g. [\"sc.delivered\"]), from_sequence (cursor), limit (default 50, max 500). PII note: delivery_proof clinical fields (summary, outcome, next_steps) are returned only for admin-scoped keys. IMPORTANT: backfilled sc_resolved timestamps do NOT emit sc.resolved events in this stream (Forma B, see decisions log 2026-04-18-lifecycle-history-backfill-policy). For current resolution status, use lifecycle_get_state.sc_resolution. Requires X-Org-Api-Key.","tags":["servicialo","lifecycle","spec-compliant","sc-events","stream"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"lifecycle_get_state","name":"Get Lifecycle State","description":"Get the current lifecycle state of a session, including available transitions, state history, and SC resolution. Returns current_state, available_transitions, verification_deadline (when state=delivered), timestamps, duration, sc_resolution (the fundamental SC event: resolved, resolved_at, resolved_by, billing_model), and recent transition history with from/to/at/by/method fields. Requires X-Org-Api-Key. Shape per docs/protocol/sc-event-canonical-schema-2026-04-18.md §7.1.","tags":["servicialo","lifecycle","spec-compliant","sc-resolution"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"lifecycle_transition","name":"Lifecycle Transition","description":"Execute a state transition on a session. Accepts either to_state (target state name per Servicialo spec: confirmed, in_progress, completed, verified, documented, cancelled, no_show) or action (semantic verb: confirm, start, complete, verify, document, cancel, no_show). When to_state=no_show, no_show_type is required. NOTE: to_state=\"delivered\" / action=\"deliver\" is NOT available via MCP (ref PDC-SEC-001) — MCP authentication cannot validate actor-as-Proveedor. Delivery must be performed via the REST endpoint PATCH /api/organizations/[orgSlug]/coordinalo/sessions/[sessionId]/deliver which enforces provider binding. Returns transition record with from, to, at, by, method fields. Requires X-Org-Api-Key.","tags":["servicialo","lifecycle","spec-compliant"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"scheduling_book","name":"Book Session","description":"Book a session (Servicialo spec). Returns confirmation_credential (opaque token, valid 30 min) and booking_id. Use scheduling_confirm with the credential to finalize. Does NOT require an API key — uses requester identity (fullName + email or phone). Accepts optional submission context for audit trail.","tags":["servicialo","scheduling","spec-compliant","public"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"scheduling_confirm","name":"Confirm Scheduling","description":"Confirm a booking (Servicialo spec). Dual-mode: (1) with credential — uses the confirmation token from scheduling_book, no API key needed; (2) with booking_id — uses API key to confirm an existing session. Returns confirmed status with timestamp.","tags":["servicialo","scheduling","spec-compliant"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"scheduling_cancel","name":"Cancel Session","description":"Cancel a session (Servicialo spec). Applies cancellation policy based on time remaining before scheduled time. Requires confirm: true and X-Org-Api-Key.","tags":["servicialo","scheduling","spec-compliant"],"examples":[],"inputModes":[],"outputModes":[]},{"id":"scheduling_reschedule","name":"Reschedule Session","description":"Reschedule a session to a new time (Servicialo spec). Cancels the original session and creates a new one at the specified datetime. Requires confirm: true and X-Org-Api-Key.","tags":["servicialo","scheduling","spec-compliant"],"examples":[],"inputModes":[],"outputModes":[]}],"provenance":[{"source":"mcp_registry","first_seen":"2026-05-18T14:43:28.686224+00:00"},{"source":"recrawl_hot","first_seen":"2026-05-21T00:28:49.280830+00:00"}],"recent_probes":[{"fetched_at":"2026-05-22T12:51:35.103577+00:00","ok":true,"status_code":200,"error":null,"elapsed_ms":929,"live_responds":false},{"fetched_at":"2026-05-22T06:38:38.576505+00:00","ok":true,"status_code":200,"error":null,"elapsed_ms":881,"live_responds":false},{"fetched_at":"2026-05-21T00:28:49.280830+00:00","ok":true,"status_code":200,"error":null,"elapsed_ms":497,"live_responds":false},{"fetched_at":"2026-05-18T23:40:35.732205+00:00","ok":true,"status_code":200,"error":null,"elapsed_ms":520,"live_responds":false},{"fetched_at":"2026-05-18T20:59:34.725681+00:00","ok":true,"status_code":200,"error":null,"elapsed_ms":802,"live_responds":false},{"fetched_at":"2026-05-18T14:43:28.686224+00:00","ok":true,"status_code":200,"error":null,"elapsed_ms":979,"live_responds":false}],"catalog_attestation":null,"verification_history":[],"signatures":[{"protected":"eyJhbGciOiJFUzI1NiIsImprdSI6Imh0dHBzOi8vYWdlbnN0cnkuY29tLy53ZWxsLWtub3duL2p3a3MuanNvbiIsImtpZCI6ImFnZW50ZmluZGVyLWVzMjU2LTEiLCJ0eXAiOiJKT1NFIn0","signature":"GtAv1X75xXnnNqQW8k1HAD91w_Nv-HS5JvqgX_mb8H4Ja7I4U8P7sr0sY7BetbDc-I_iYOg-hBf4W3DyJX6IOQ"}]}