Agent Skill · Sinch

sinch-verification-api

Verify phone numbers via SMS, Flashcall, Phone Call, Data (seamless carrier-level), or WhatsApp with Sinch Verification API. Use when implementing user phone verification, OTP, two-factor authentication, or number ownership confirmation flows.

Provider: Sinch Path in repo: skills/sinch-verification-api/SKILL.md

Skill body

Sinch Verification API

Overview

The Sinch Verification API verifies phone numbers through SMS OTP, Flashcall (missed call CLI), Phone Call (spoken OTP), Data (carrier-level), and WhatsApp OTP. Used for registration, 2FA, and number ownership confirmation.

Agent Instructions

Before generating code, gather from the user (skip any item already specified in the prompt or context):

  1. Verification methodsms, flashcall, callout, seamless, or whatsapp.
  2. Approach — SDK or direct API calls (curl/fetch/requests)?
  3. Language — for SDK: Node.js, Python, Java, or .NET. For direct API: any language, or curl.

When the user chooses SDK, refer to the sinch-sdks skill for installation and client initialization, then to the Verification API Reference linked in Links.

When the user chooses direct API calls, refer to the Verification API Reference linked in Links for request/response schemas.

Security: See the Security section below for url fetching policy, handling inbound callback content, and credential handling.

Getting Started

Agent Credentials handling

Store credentials in environment variables — never hardcode application keys or secrets in commands or source code:

export SINCH_APPLICATION_KEY="your-application-key"
export SINCH_APPLICATION_SECRET="your-application-secret"

Authentication

Ensure that authentication headers are properly set when making API calls. The Verification API uses Application Key + Application Secret (from your Sinch dashboard app), not project-level OAuth2:

-u "$SINCH_APPLICATION_KEY:$SINCH_APPLICATION_SECRET"

See sinch-authentication skill for dashboard setup.

Three auth methods are supported:

Method Use for
Application Signed Request Secure authentication method for production traffic
Basic Auth Simple method for prototyping and trying out API calls
Public Auth Insecure environments (end user’s device). Android/iOS SDK only, requires callback webhook

Minimum auth level is configurable in the Sinch Dashboard — requests below that level are rejected. See the Authentication Guide for signing details.

Base URL

SDK Setup

See sinch-sdks for installation and client initialization across all languages. All SDKs initialize with applicationKey + applicationSecret (not project credentials).

Canonical Example — Start SMS Verification

# Uses Basic Auth (-u) for simplicity. Use Application Signed Requests in production.
curl -X POST \
  "https://verification.api.sinch.com/verification/v1/verifications" \
  -u "$SINCH_APPLICATION_KEY:$SINCH_APPLICATION_SECRET" \
  -H 'Content-Type: application/json' \
  -d '{
    "identity": { "type": "number", "endpoint": "+12025550134" },
    "method": "sms"
  }'

Response includes id (verification ID), sms.template, sms.interceptionTimeout, and _links with localized URLs for status/report actions.

Key Concepts

Verification Methods

Method Value Behavior
SMS sms Sends OTP via SMS. User enters code.
FlashCall flashcall Missed call — caller ID is the OTP. Auto-intercepted on Android; manual entry on iOS/JS.
Phone Call callout PSTN call dictates an OTP code. User enters the code into the app (same flow as SMS).
Data seamless Carrier-level verification via mobile data. No user interaction. Requires account manager to enable.
WhatsApp whatsapp Sends OTP via WhatsApp message. User enters code.

Core Model

API Endpoints

All endpoints documented in the Verification API Reference.

Start Verification

POST /verification/v1/verifications

Set method to sms, flashcall, callout, seamless, or whatsapp. Optional fields:

Method-specific options (backend-originated signed requests only): smsOptions, flashCallOptions, calloutOptions, whatsappOptions. See the API Reference for full schemas.

Report Verification

Report by identity: PUT /verification/v1/verifications/number/{endpoint}
Report by ID: PUT /verification/v1/verifications/id/{id}

Body includes method and a method-specific object with the user’s input:

Get Verification Status

By ID: GET /verification/v1/verifications/id/{id}
By method + number: GET /verification/v1/verifications/{method}/number/{endpoint}
By reference: GET /verification/v1/verifications/reference/{reference}

Note: The by-identity endpoint requires {method} in the path — it is NOT /verifications/number/{endpoint}.

Common Patterns

Standard Verification Flow

  1. StartPOST /verification/v1/verifications with identity + method → receive verification id
  2. Report — User receives code/call → PUT /verification/v1/verifications/id/{id} with the code/CLI
  3. Check statusGET /verification/v1/verifications/id/{id} → confirm SUCCESSFUL

If the code expires or verification fails, you cannot re-report — start a new verification.

Webhooks (Callbacks)

For production flows, configure a callback URL in the Sinch Dashboard. The API sends:

Callbacks are signed — verify signatures using Callback Signing.

Gotchas and Best Practices

  1. Auth is Application Key + Secret, not OAuth2. Do not use project-level credentials.
  2. Use Application Signed Requests in production. Application auth protects integrity of a request
  3. Base64-decode the secret before signing. The dashboard value is base64-encoded.
  4. FlashCall auto-intercepts on Android only. iOS/JS users must manually enter the incoming number. Android SDK is required to intercept calls.
  5. Method availability varies by country. SMS is the most widely available.
  6. Codes expire. Configurable via smsOptions.expiry. Start a new verification if expired — you cannot re-report on a completed/expired verification.
  7. Report by ID is more precise than reporting by phone number.
  8. Rate limit: avoid rapid re-verification of the same number. Implement backoff.
  9. Data verification requires account manager and mobile data (not Wi-Fi).
  10. SMS language may be overridden by carrier compliance (e.g., US shortcode requirements).

Security

Skill frontmatter

metadata: {"author" => "Sinch", "version" => "1.0.4", "category" => "Verification", "tags" => "verification, otp, sms, flashcall, 2fa, phone-verification, whatsapp", "uses" => ["sinch-authentication"]}