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
The Porting API automates port-in operations — transferring phone numbers from another carrier into Sinch. It supports portability checks, order creation and management, document uploads, on-demand activation, and webhook notifications for status updates. Currently supports North American (US/CA) numbers only.
Before generating code, gather from the user:
desiredPortDate) or on-demand (onDemandActivation: true)?Note: The @sinch/sdk-core Node.js SDK does not currently have dedicated porting methods. Use direct HTTP calls for all porting operations.
Store credentials in environment variables — never hardcode tokens, PINs, 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 Porting 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).
| Environment | URL |
|---|---|
| Production | https://porting.api.sinch.com/v1/projects/{PROJECT_ID} |
Always check portability before creating an order:
curl -X POST \
"https://porting.api.sinch.com/v1/projects/$SINCH_PROJECT_ID/portabilityChecks" \
-H "Authorization: Bearer $SINCH_ACCESS_TOKEN" \
-H "Content-Type: application/json" \
-d '{
"phoneNumbers": ["+15551234567", "+15559876543"]
}'Response:
{
"phoneNumbers": [
{
"phoneNumber": "+15551234567",
"portable": true,
"carrier": "T-Mobile"
},
{
"phoneNumber": "+15559876543",
"portable": false,
"carrier": "Verizon",
"reason": "Number is not portable"
}
]
}curl -X POST \
"https://porting.api.sinch.com/v1/projects/$SINCH_PROJECT_ID/orders/portIns" \
-H "Authorization: Bearer $SINCH_ACCESS_TOKEN" \
-H "Content-Type: application/json" \
-d '{
"desiredPortSchedule": {
"desiredPortDate": "2026-05-15",
"desiredPortTime": "09:00:00",
"desiredPortTimeZone": "US/Eastern"
},
"customerOrderReference": "my-ref-123",
"phoneNumbers": [
{
"phoneNumber": "+15551234567",
"endUser": {
"name": "Acme Corp",
"streetNum": "123",
"streetName": "Main",
"streetType": "St",
"city": "Anytown",
"state": "CA",
"zipCode": "90210",
"typeOfService": "B"
},
"portOutInfo": {
"existingPortOutPin": "1234"
}
}
]
}'
existingPortOutPin— Obtain this PIN from the losing carrier before submitting the order. See Create Port-In Order for full field reference.
Response:
{
"id": 12345,
"status": "PENDING",
"customerOrderReference": "my-ref-123",
"desiredPortSchedule": {
"desiredPortDate": "2026-05-15",
"desiredPortTime": "09:00:00",
"desiredPortTimeZone": "US/Eastern"
},
"phoneNumbers": [
{
"phoneNumber": "+15551234567",
"status": "PENDING"
}
]
}# Auth: same Bearer token header as above
curl -X GET \
"https://porting.api.sinch.com/v1/projects/$SINCH_PROJECT_ID/orders/portIns/12345" \
-H "Authorization: Bearer $SINCH_ACCESS_TOKEN"Response:
{
"id": 12345,
"status": "CONFIRMED",
"customerOrderReference": "my-ref-123",
"desiredPortSchedule": {
"desiredPortDate": "2026-05-15",
"desiredPortTime": "09:00:00",
"desiredPortTimeZone": "US/Eastern"
},
"phoneNumbers": [
{
"phoneNumber": "+15551234567",
"status": "CONFIRMED",
"focDate": "2026-05-15"
}
]
}First check which number groups are ready:
# Auth: same Bearer token header as above
curl -X GET \
"https://porting.api.sinch.com/v1/projects/$SINCH_PROJECT_ID/orders/portIns/12345/availableActivations" \
-H "Authorization: Bearer $SINCH_ACCESS_TOKEN"Response:
{
"activationGroups": [
{
"groupId": "grp-001",
"phoneNumbers": ["+15551234567"],
"status": "READY"
}
]
}Then activate:
# Auth: same Bearer token header as above
curl -X POST \
"https://porting.api.sinch.com/v1/projects/$SINCH_PROJECT_ID/orders/portIns/12345/activate" \
-H "Authorization: Bearer $SINCH_ACCESS_TOKEN" \
-H "Content-Type: application/json" \
-d '{
"groupIds": ["grp-001"]
}'id and tracks the overall lifecycle.PENDING (can update/cancel) → CONFIRMED (locked, awaiting port date) → COMPLETED (numbers active). Also: PENDING_CANCELATION → CANCELED.PENDING → CONFIRMED → ACTIVATED. Also: REJECTED (see rejectReason), CANCELED, EXCLUDED (see exclusionReason).focDate on each phone number once confirmed. On-demand activation requires FOC date to be today or earlier.name, streetNum, streetName, city, state, zipCode. Must match the losing carrier's records exactly.existingPortOutPin is needed. May also include accountNum, accountPhoneNumber, authorizingName, authorizingDate.POST /orders/portIns/{orderId}/documents.onDemandActivation: true, numbers are not auto-activated on the port date. Instead, call POST /orders/portIns/{orderId}/activate after FOC date is reached and numbers are routing on Sinch network.type: RTC (programmable voice, requires appId), EST (elastic SIP trunking, requires trunkId), FAX (requires serviceId).A2PLC (Application-to-Person Long Code) and SMSMMS feature types. Configured alongside voice options on each phone number in the order.desiredPortDate (ISO date, required), desiredPortTime (defaults to project config or 09:00:00), desiredPortTimeZone (one of: US/Eastern, US/Central, US/Mountain, US/Pacific).POST /configuration, updated via PUT /configuration.Check portability — POST /portabilityChecks with phoneNumbers array. Always do this before creating an order; non-portable numbers cause order failure.
Create port-in order — POST /orders/portIns with desiredPortSchedule, phoneNumbers (each with endUser and portOutInfo). Returns order id and initial PENDING status.
List and filter orders — GET /orders/portIns with query params: orderStatus, phoneNumber, customerOrderReference, createdDateStart/createdDateEnd, focStartDate/focEndDate, pageSize (default 100, max 1000), page.
Get order details — GET /orders/portIns/{orderId} returns full order with phone numbers, notes, and documents.
Get phone number groups — GET /orders/portIns/phoneGroups/{orderId} returns phone numbers grouped by their status or activation group within the order. Porting is processed by groups.
Update a pending order — PUT /orders/portIns/{orderId} — sends the full object (not a patch). Only works on PENDING orders.
Cancel a pending order — DELETE /orders/portIns/{orderId} — only works on PENDING orders.
Add note to order — POST /orders/portIns/{orderId}/notes — use to respond to issues flagged by Sinch during processing.
Upload document (LOA) — POST /orders/portIns/{orderId}/documents — attach authorization documents.
Get document details — GET /orders/portIns/{orderId}/documents/{documentId} — retrieve metadata or content for a previously uploaded document.
On-demand activation — First GET /orders/portIns/{orderId}/availableActivations to see which number groups are ready, then POST /orders/portIns/{orderId}/activate to activate them. FOC date must be today or earlier and numbers must be routing on Sinch network.
Configure defaults — POST /configuration to create, PUT /configuration to update, GET /configuration to read. Sets default contact, webhook URL, port time, and timezone.
POST /portabilityChecks before creating an order. Orders with non-portable numbers will fail.+15551234567). Numbers not in this format will be rejected.customerOrderReference max 100 characters — Longer values will be rejected at validation.countryCode is US or CA).PUT /orders/portIns/{orderId} requires the complete order object. Omitting fields will clear them.CONFIRMED, orders cannot be modified. Cancel creates PENDING_CANCELATION state during which the same numbers cannot be resubmitted.typeOfService defaults to B (Business); set to R for residential.existingPortOutPin in portOutInfo. Only provide accountNum, accountPhoneNumber, authorizingName if the carrier requires them.authorizingDate cannot be in the future — Must be today or earlier.desiredPortTime and desiredPortTimeZone on the order and haven't configured project defaults, the system uses 09:00:00 US/Eastern.US/Eastern, US/Central, US/Mountain, US/Pacific are accepted. No generic timezone strings.POST /configuration or the dashboard. Use webhooks instead of polling GET /orders/portIns/{orderId} for status updates.voiceConfiguration is a discriminated union — Must include type field: RTC (with appId), EST (with trunkId), or FAX (with serviceId).@sinch/sdk-core Node.js SDK does not have dedicated porting methods. Use direct REST calls.resellerName required for Canadian numbers — An additional field needed when porting CA numbers.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