Agent Skill · Sinch

sinch-imported-numbers-hosting-orders

Import, host, qualify, and text-enable phone numbers for Sinch SMS using the Imported Numbers and Hosting Orders API. Use when importing non-Sinch numbers as DCA, creating hosting orders, qualifying numbers for text-enablement, managing LOA workflows, or checking hosting order status.

Provider: Sinch Path in repo: skills/sinch-imported-numbers-hosting-orders/SKILL.md

Skill body

Sinch Imported Numbers & Hosting Orders

Overview

The Imported Numbers and Hosting Orders API imports non-Sinch phone numbers for use with Sinch SMS without porting. It manages the lifecycle from qualification through text-enablement, including LOA generation and carrier OSR updates.

Agent Instructions

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

  1. Goal — import a number (single or bulk), qualify numbers for text-enablement, text-enable qualified numbers, or check status of an existing order?
  2. LOA type (if text-enabling) — direct Sinch customer, reseller, or blanket LOA?
  3. Number type (if text-enabling) — Standard or Toll-Free?
  4. Language — any language, or curl. This API is REST-only; there is no SDK wrapper.

Refer to the 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.

Decision Tree

User wants to work with imported numbers →
├─ Import numbers
│  ├─ Single number    → Workflow A (Import Number)
│  └─ Bulk (≤5)        → Workflow B (Bulk Import via Hosting Order)
├─ Qualify numbers     → Workflow C (Qualify → email invoices)
├─ Text-enable numbers
│  ├─ Standard numbers → Workflow D (Text-Enable)
│  └─ Toll-Free        → Workflow D variant (TF endpoint)
├─ Check order status  → Workflow E (Hosting Order Status)
└─ Manage numbers      → Workflow F (CRUD operations)

Critical Rules

  1. E.164 format required. All phone numbers must include leading + (e.g., +12025550134).
  2. Qualification requires manual review. After addNumbers, the user must email invoices to orders@sinch.com. Takes 1–3 business days.
  3. Unlink before relinking. To change service plan or campaign, first set both to empty string "", then set new values in a separate request.
  4. Hosting orders are async. Poll order status or set callbackUrl per-request.
  5. List hosting orders requires all four params: states, type, servicePlanId, campaignId are all required.
  6. migrateToSinchTmo is read-only on responses. Exception: writable in hostingOrders:importNumbers requests.

Getting Started

Agent Credentials handling

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"
export SERVICE_PLAN_ID="your-service-plan-id"
export CAMPAIGN_ID="your-10dlc-campaign-id"

Authentication

Ensure that authentication headers are properly set when making API calls. The Imported Numbers / Hosting Orders API uses Bearer token authentication:

-H "Authorization: Bearer $SINCH_ACCESS_TOKEN"

See sinch-authentication for full auth setup. This API uses OAuth2 client credentials (production) or Basic Auth (testing only, rate-limited). For OAuth2, see how to obtain {SINCH_ACCESS_TOKEN} in the auth skill (do not mint your own JWT).

Base URL: https://imported.numbers.api.sinch.com

Region: US and CA only. Single global endpoint (not regionalized).

First API Call — Import a Number

curl -X POST \
  "https://imported.numbers.api.sinch.com/v1/projects/$SINCH_PROJECT_ID/importedNumbers" \
  -H "Authorization: Bearer $SINCH_ACCESS_TOKEN" \
  -H "Content-Type: application/json" \
  -d '{
    "phoneNumber": "+11234567890",
    "regionCode": "US",
    "displayName": "My Number",
    "smsConfiguration": {
      "servicePlanId": "$SERVICE_PLAN_ID",
      "campaignId": "$CAMPAIGN_ID"
    },
    "callbackUrl": "https://example.com/callback"
  }'

Key Concepts

Workflows

Workflow A: Import Single Number

Ask for: phoneNumber, regionCode, servicePlanId. Optional: campaignId, displayName, callbackUrl.

Numbers with their own NNID must complete NNID provisioning first.

API docs: Import numberGet imported number

Workflow B: Bulk Import via Hosting Order

Ask for: numbers (list, max 5), regionCode, servicePlanId. Optional: campaignId, callbackUrl, migrateToSinchTmo.

Limit: 5 numbers per request by default. Contact account manager to increase.

API docs: Import numbersGet orderList order numbers

Workflow C: Qualify Numbers

Ask for: list of phoneNumbers (E.164).

API docs: Create batchGet qualified number

Workflow D: Text-Enable Numbers

Ask for: numbers (list, max 500), regionCode, servicePlanId, and LOA info. Optional: campaignId, nnid, scheduledOsrUpdateTime, callbackUrl.

Determine LOA type:

For Toll-Free, use POST /qualifiedNumbers:textEnableTollFreeNumbers or POST /hostingOrders:textEnableTollFreeNumbers instead.

API docs: Text-enable (qualified) · Text-enable (hosting order) · TF (qualified) · TF (hosting order)

Workflow E: Check Hosting Order Status

API docs: List orders · Get order · Get report · List order numbers

Workflow F: Manage Numbers & Verification

Imported numbers: list, get, update, delete via /importedNumbers and /importedNumbers/{phoneNumber}.

Qualified numbers: list (requires states param), get, delete via /qualifiedNumbers.

Voice challenge (ownership verification):

API docs: List imported · Update imported · Delete imported · List qualified · Send challenge · Verify challenge

Callbacks

Callback URLs are set per-request via callbackUrl on import and text-enable operations (not project-level). Configure HMAC signing via PATCH /callbackConfiguration with {"hmacSecret": "..."} — verifies payloads via X-Sinch-Signature header.

See references/callbacks.md for full payload schema, event types, and failure codes.

Allowlist these IPs: 54.76.19.159, 54.78.194.39, 54.155.83.128

Gotchas and Best Practices

Security

Skill frontmatter

metadata: {"author" => "Sinch", "version" => "1.0.4", "category" => "Numbers", "tags" => "imported-numbers, hosting-orders, text-enablement, dca, loa", "uses" => ["sinch-authentication"]}