Sinch SDKs
Overview
Cross-cutting skill that covers SDK installation and client initialization for all Sinch products. Determines the correct SDK and provides init code per language.
For authentication setup (credentials, OAuth2, Basic auth, signed requests), see sinch-authentication. For In-App Calling SDKs (Browser, iOS, Android), see sinch-in-app-calling.
Agent Instructions
If the user hasn't specified which language or platform, ask first — the SDK and init pattern differ by language. Use the table below to route to the correct reference.
SDK Installation
| Language | Package | Install | Auth Scope |
|---|
| Node.js | | npm install @sinch/sdk-core
| Project + Application |
| Python | | | Project + Application |
| Java | com.sinch.sdk:sinch-sdk-java
| Maven dependency | Project + Application |
| .NET | | NuGet package | Project + Application |
In-App Calling uses a
separate client-side SDK — not
. See
sinch-in-app-calling.
Product Coverage by SDK
Not all products are available in all SDKs. Check the table before recommending an SDK for a specific product.
| Product | Node.js | Java | .NET | Python |
|---|
| Conversation API | ✅ | ✅ | ⚠️ | ⚠️ |
| Voice API | ✅ | ✅ | ✅ | ✅ |
| Verification API | ✅ | ✅ | ✅ | ✅ |
| Numbers API | ✅ | ✅ | ✅ | ✅ |
| Number Lookup API | ✅ | ❌ | ❌ | ✅ |
| Elastic SIP Trunking | ✅ | ❌ | ❌ | ❌ |
| Fax API | ✅ | ❌ | ⚠️ | ❌ |
| Provisioning API | ✅ | ❌ | ❌ | ❌ |
| 10DLC Registration | ❌ | ❌ | ❌ | ❌ |
✅ = supported, ⚠️ = partial/preview, ❌ = not available (use direct HTTP)
When a product is not supported in the user's chosen SDK, guide them to use direct HTTP calls instead.
SDK Init References
For language-specific initialization code, use the references:
- Node.js: references/sdk-init-node.md
- Python: references/sdk-init-python.md
- Java: references/sdk-init-java.md
- .NET: references/sdk-init-dotnet.md
If language is unknown, ask first. The SDKs handle token refresh automatically.
Key Concepts
— Unified Node.js SDK covering all project-scoped and application-scoped Sinch APIs. Individual packages (e.g.,
,
) are also available.
(Python) — Python SDK (v2.0.0+) covering project-scoped and application-scoped APIs.
— Java SDK (v2.0.0+) via Maven Central.
Project-scoped init — Uses
,
,
. For Conversation, Numbers, Fax, EST, 10DLC, Number Lookup, Provisioning.
Application-scoped init — Uses
,
. For Voice, Verification, In-App Calling.
Multi-product client — Provide both project and application credentials in a single
to access all APIs.
Conversation region — Must be set explicitly when using the Conversation API. Values:
,
,
. Required in Python SDK v2.0.0+ and Java SDK v2.0.0+; recommended in Node.js and .NET.
Common Patterns
- Project-scoped quick start — Init with project credentials. See language-specific ref.
- Application-scoped quick start — Init with app key/secret. See language-specific ref.
- Multi-product client — Pass both credential sets to a single client instance.
- Regional Conversation API — Set during init (required in Python/Java, recommended elsewhere).
Gotchas
- Not all products are available in all SDKs — Check the Product Coverage table before recommending an SDK. For unsupported products, use direct HTTP calls.
- Conversation region is required — Python and Java SDKs fail at runtime without . Node.js and .NET don't enforce it yet but should set it explicitly.
- Voice/Verification use application credentials — These are a separate credential set from project Access Keys.
- SDKs auto-refresh OAuth2 tokens — No need to manually handle token expiry when using SDKs.
Links