The iOS SDK uses the Messaging API under the hood. All WebSocket events, streaming, and handoff behavior documented in the API reference apply.
How it works
The SDK handles authentication, session management, WebSocket connections, and reconnection logic. Your app sends and receives messages through the SDK and renders them however you choose.Configure authentication
Add your API key (from Agent Studio) and register your app’s bundle identifier in Agent Studio. The backend rejects connections from unregistered bundle identifiers.
Start a session
Initialize the SDK and start a messaging session. The SDK handles access token exchange and WebSocket connection automatically.
Installation
The SDK is distributed as a native Swift package. Choose either method:- Swift Package Manager
- CocoaPods
In Xcode, go to File > Add Package Dependencies and enter the repository URL:Select the latest version and add the package to your target.
Authentication setup
The iOS SDK authenticates using a connector token and your app’s bundle identifier.Generate a connector token
In Agent Studio, go to Messaging > API Configuration and generate a new Messaging API key.
Key features
Session persistence
Sessions persist across app launches. If the user leaves and returns, the SDK reconnects to the existing session and replays the conversation history automatically. Network changes (Wi-Fi to cellular, brief drops) are handled with automatic reconnection and retry.Streaming responses
Enable streaming when creating a session to show agent responses as they’re generated, word by word. The SDK surfaces streaming chunks as they arrive — your UI can render them incrementally.Handoff to live agents
The full handoff flow is supported. When the PolyAI agent triggers a handoff, the SDK delivers the same handoff events (HANDOFF_ACCEPTED, HANDOFF_QUEUE_STATUS, LIVE_AGENT_JOINED, etc.) so your app can show queue status and live agent messages.
Response suggestions
Agent messages can includeresponse_suggestions — pre-written reply options. Render these as tappable buttons in your UI. When the user taps one, send its text as a message through the SDK.
Attachments
Agent messages may include rich content like links and images via theattachments field. Render these inline in your chat UI.
Platform values
When the SDK creates a session, it setsplatform to ios automatically. This is visible in Agent Studio analytics and can be used in your agent logic to tailor behavior for mobile users.
| Platform value | Source |
|---|---|
ios | iOS SDK (native) |
android | Android SDK (native) |
ios-web | Webchat widget on iOS Safari |
web | Webchat widget on desktop |
Limitations
These limitations apply to the initial release. Check the release notes for updates.
| Limitation | Details |
|---|---|
| Text only | Voice input is not supported in V1. WebRTC voice support is planned for a future release and will require declaring microphone permissions (NSMicrophoneUsageDescription) in your Info.plist. |
| No push notifications | While the app is active, the SDK delivers messages in real time. When the app is backgrounded, the SDK cannot receive messages. You can listen for incoming messages and trigger your own local notifications while the app is in the foreground, but true remote push notifications (APNs) are not yet supported. |
| iOS only | The SDK is native Swift. There is no React Native or Flutter wrapper. Cross-platform frameworks would require a separate SDK. |
Multichannel
The iOS SDK connects to the same agent project as your voice and webchat channels. Agent behavior, knowledge, and flows are shared — only channel-specific settings (greetings, formatting) differ. See multichannel agents for how to tailor behavior per channel. In your agent’s start function, detect the mobile channel usingconv.channel_type:
Related pages
Messaging API reference
Full WebSocket protocol, events, streaming, and handoff
Sessions and authentication
Access tokens, session creation, and platform values
Multichannel agents
Build agents that work across voice, webchat, and mobile
Best practices
Connection management, UX, and security recommendations

