Official Sinch API skills for AI coding agents — SMS, Voice, Verification, Numbers, Mailgun email, and more.
71
89%
Does it follow best practices?
Impact
—
No eval scenarios have been run
Advisory
Suggest reviewing before use
Queries phone numbers for carrier, line type, porting, SIM swap, VoIP detection, and reassigned number detection. Used for fraud prevention, routing, and data enrichment. One number per request — no batch endpoint.
Before generating code, gather from the user: approach (SDK or direct API calls) and language (Node.js, Python, Java, .NET/C#, curl). Do not assume defaults.
When the user chooses SDK, refer to sinch-sdks for installation, client initialization, and language-specific references. Note: Number Lookup is only supported in Node.js and Python (partial) SDKs — for Java and .NET, use direct HTTP calls.
Store credentials in environment variables — never hardcode tokens or keys in commands or source code:
export SINCH_PROJECT_ID="your-project-id"
export SINCH_KEY_ID="your-key-id"
export SINCH_KEY_SECRET="your-key-secret"
export SINCH_ACCESS_TOKEN="your-oauth-token"Ensure that authentication headers are properly set when making API calls. The Number Lookup API uses Bearer token authentication:
-H "Authorization: Bearer $SINCH_ACCESS_TOKEN"See sinch-authentication for full setup, most importantly how to obtain {SINCH_ACCESS_TOKEN} (OAuth2 client-credentials — do not mint your own JWT).
https://lookup.api.sinch.com
Endpoint: POST /v2/projects/{PROJECT_ID}/lookups
curl -X POST \
"https://lookup.api.sinch.com/v2/projects/$SINCH_PROJECT_ID/lookups" \
-H "Authorization: Bearer $SINCH_ACCESS_TOKEN" \
-H "Content-Type: application/json" \
-d '{
"number": "+12025550134",
"features": ["LineType", "SimSwap", "VoIPDetection", "RND"],
"rndFeatureOptions": { "contactDate": "2025-01-01" }
}'For SDK setup (Node.js, Python, Java, .NET), see the Getting Started Guide.
| Field | Type | Required | Notes |
|---|---|---|---|
number | string | Yes | Single E.164 number (with + prefix) |
features | string[] | No | LineType (default), SimSwap, VoIPDetection (alpha), RND (alpha) |
rndFeatureOptions.contactDate | string | If RND requested | YYYY-MM-DD format |
Critical: If features is omitted, only LineType is returned. You must explicitly request SimSwap, VoIPDetection, or RND.
Flat object (not an array). Each feature populates its own sub-object; unrequested features are null.
Top-level fields: number, countryCode (ISO 3166-1 alpha-2), traceId
line object:
| Field | Type | Values |
|---|---|---|
carrier | string | Carrier name, e.g. "T-Mobile USA" |
type | string enum | Landline, Mobile, VoIP, Special, Freephone, Other |
mobileCountryCode | string | MCC, e.g. "310" |
mobileNetworkCode | string | MNC, e.g. "260" |
ported | boolean | Whether ported |
portingDate | string | ISO 8601 datetime |
error | object|null | Per-feature error (status, title, detail, type) |
simSwap object:
| Field | Type | Values |
|---|---|---|
swapped | boolean | Whether SIM swap occurred |
swapPeriod | string enum | Undefined, SP4H, SP12H, SP24H, SP48H, SP5D, SP7D, SP14D, SP30D, SPMAX |
error | object|null | Per-feature error |
voIPDetection object (alpha):
| Field | Type | Values |
|---|---|---|
probability | string enum | Unknown, Low, Likely, High -- not numeric |
error | object|null | Per-feature error |
rnd object (alpha):
| Field | Type | Values |
|---|---|---|
disconnected | boolean | Disconnected after contactDate |
error | object|null | Per-feature error |
For full response schemas, see the API Reference.
features: ["SimSwap", "VoIPDetection"]simSwap.swapped is true and swapPeriod is SP4H or SP24H → flag as high riskvoIPDetection.probability is High or Likely → require additional verificationerror → fall back to the other feature's result for risk scoringfeatures: ["LineType", "RND"] (include rndFeatureOptions.contactDate)rnd.disconnected is true → remove from contact listline.type: SMS for Mobile, voice for Landlinefeatures: ["LineType", "SimSwap"]line.type is Landline → use voice verification instead of SMSsimSwap.swapped is true → skip SMS verification, use an alternative channelNo batch endpoint. Use parallel requests:
const results = await Promise.all(
numbers.map((number) => sinch.numberLookup.lookup({ number, features: ['LineType', 'SimSwap'] }))
);features must be explicit. Omitting it returns only LineType. SIM swap, VoIP, and RND require explicit opt-in.Unknown, Low, Likely, High.SP24H, SP7D -- not human-readable strings.error. A lookup can succeed for line but fail for simSwap.contactDate. Omitting rndFeatureOptions when requesting RND causes a 400.429 Too Many Requests when exceeded. Contact Sinch for tier info.402 means Account Locked (not payment required), 403 means the API is disabled for your project. If response includes a 403, direct the user to check this documentation.skills
sinch-10dlc
references
sinch-authentication
sinch-conversation-api
sinch-elastic-sip-trunking
references
sinch-fax-api
sinch-imported-numbers-hosting-orders
references
sinch-in-app-calling
sinch-mailgun
references
sinch-mailgun-inspect
references
sinch-mailgun-optimize
references
sinch-mailgun-validate
sinch-number-lookup-api
sinch-number-order-api
sinch-numbers-api
references
sinch-porting-api
sinch-provisioning-api
sinch-sdks
sinch-verification-api