Voice iOS SDK Changelog
The Twilio Programmable Voice SDKs allow you to add voice-over-IP (VoIP) calling to your native iOS applications.
Warning
The Twilio Programmable Voice SDKs use Semantic Versioning. Twilio supports version N-1 for 12 months after the first GA release of version N. We recommend you upgrade to the latest version as soon as possible to avoid any breaking changes. Version 6.x is the latest iOS version.
Support for 4.x ceased on September 19, 2020. Please upgrade to the latest version
Support for 3.x ceased on June 28, 2020. Please upgrade to the latest version
Support for 2.x ceased on January 1, 2020. Please upgrade to the latest version
End-of-Life for 1.x will occur on March 23, 2021. A two-hour maintenance period is planned for 1.x at 9am Pacific Time on January 26, 2021. Please upgrade to the latest version. See this EoL notice for further details.
CocoaPods Trunk Read-only Plan
Cocoapods.org plans to turn the podspec repository trunk to read-only in December 2026. See CocoaPods Trunk Read-only Plan. Twilio will continue pushing new versions to Cocoapods.org, but we strongly recommend developers to switch to using Swift Package Manager to integrate the Twilio Voice iOS SDK.
October 8, 2025
- Programmable Voice iOS SDK 6.13.4 [XCFramework] (checksum: b3a09755761109935806be8a988d647ebb729494bef23c0b4aa793f989b42af5).
- Programmable Voice iOS SDK 6.13.4 [Static-XCFramework] (checksum: df03cf6ab7cb2b491691d3a2e981bb5ef0c752a7363117ea3e33e906693a18e6)
API Changes
- The
[TVOPreflightDelegate preflight:didCompleteWitReport:]is now[TVOPreflightDelegate preflight:didCompleteWithReport:]. The Swift name remains unchanged. - The
[TVOPreflightReport dictionaryReport]now returns the value ofcallQualityin string literals, i.e.Excellent,Great,Good,FairandDegraded. - The
[TVOPreflightReport dictionaryReport]now returns the value ofisTurnRequiredin true boolean values instead oftrueorfalsestrings. - The
[TVOPreflightReport dictionaryReport]now returns an empty array if there is no value in thewarningsorwarningsClearedfield.
Bug Fixes
- Fixed a crash when the SDK receives the Call Invite cancellation event.
- Fixed a crash when the SDK is publishing Voice Insights events with invalid dictionary entries.
Size Impact
Dynamic:
| Architecture | Compressed Size | Uncompressed App Size |
|---|---|---|
| arm64 | 3.8 MB | 8.7 MB |
- The app size is calculated by importing the TwilioVoice SDK into a bare-bones app.
Static:
| Architecture | Compressed Size | Uncompressed App Size |
|---|---|---|
| arm64 | 4.5 MB | 10.5 MB |
- The app size is calculated by importing the TwilioVoice SDK into a bare-bones app.
August 25, 2025
Please note that Cocoapods.org plans to turn the podspec repository trunk to read-only in December 2026. See CocoaPods Trunk Read-only Plan. Twilio will continue pushing new versions to Cocoapods.org, but we strongly recommend developers to switch to using Swift Package Manager to integrate the Twilio Voice iOS SDK.
- Programmable Voice iOS SDK 6.13.3 [XCFramework] (checksum: d9b041dbebdb2aaa9e0d1a61503f076136118702e4dafd6e538b6e5ee6fe4382).
- Programmable Voice iOS SDK 6.13.3 [Static-XCFramework] (checksum: ae8b9a0a24a7732bdc1cf1af0f781898b0c50d3e1ace362369e47a33f4e88b14)
API Changes
- The AVAudioSession option
AVAudioSessionCategoryOptionAllowBluetoothinTVODefaultAudioDevice.his deprecated and replaced withAVAudioSessionCategoryOptionAllowBluetoothHFPwhen building on Xcode 26.
Size Impact
Dynamic:
| Architecture | Compressed Size | Uncompressed App Size |
|---|---|---|
| arm64 | 3.8 MB | 8.7 MB |
- The app size is calculated by importing the TwilioVoice SDK into a bare-bones app.
Static:
| Architecture | Compressed Size | Uncompressed App Size |
|---|---|---|
| arm64 | 4.5 MB | 10.5 MB |
- The app size is calculated by importing the TwilioVoice SDK into a bare-bones app.
June 18, 2025
- Programmable Voice iOS SDK 6.13.2 [XCFramework] (checksum: e04b4790ebe35b8e66291d503ed2570dd6181d85dd4ab1f60b3c8ec2e0a571b1).
- Programmable Voice iOS SDK 6.13.2 [Static-XCFramework] (checksum: c25d14bd4b7c46c0d9f6caca2e80ad53cba95fd6f37d2043ccc97bd04cda5aa1)
Enhancements
- The SDK is now also available in the static XCFramework format. To add the static library to your iOS app, follow these steps:
- Extract
TwilioVoice.xcframeworkfromTwilioVoice-static.xcframework.zipand drag and drop it into your Xcode project. - In Frameworks, Libraries, and Embedded Content, add
SystemConfiguration.framework. - Add
@import TwilioVoice;to your source files.
- Extract
- The minimum supported iOS deployment target for the Twilio Voice SDK is now set to iOS 12.0. This version was built with Xcode 15.3.0.
Size Impact
Dynamic:
| Architecture | Compressed Size | Uncompressed App Size |
|---|---|---|
| arm64 | 3.8 MB | 8.7 MB |
- The app size is calculated by importing the TwilioVoice SDK into a bare-bones app.
Static:
| Architecture | Compressed Size | Uncompressed App Size |
|---|---|---|
| arm64 | 4.5 MB | 10.5 MB |
- The app size is calculated by importing the TwilioVoice SDK into a bare-bones app.
May 12, 2025
- Programmable Voice iOS SDK 6.13.1 [XCFramework] (checksum: c0216f0a35de40bb7bd8528afbfff5628c1fb0dbfd91333a37b61a348a7aa9d2).
Bug Fixes
- Fixed an issue where exception is raised when assigning audio device instance to the Voice SDK immediately after the previous call has ended.
- The Swift API name of the
TVOPreflightCallQualityenum has been renamed asPreflightReport.CallQualityto match the namespace.
Size Impact
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.8 MB | 8.5 MB |
January 22, 2025
- Programmable Voice iOS SDK 6.13.0 [XCFramework] (checksum: 2e296d64f51962b807a250d27aadf8ba2710218edd93f9b3bf2cb73cde4fbfdb).
Enhancements
- This release is based on Chromium WebRTC 124.
- The internal default audio device is now created and destroyed on the correct thread.
Size Impact
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.8 MB | 8.5 MB |
December 3, 2024
- Programmable Voice iOS SDK 6.12.1 [XCFramework] (checksum: f74b41d69451461e4fe0a4bc48eeb6d2e469d0c13175e5abbee3a38926eb4acd).
Bug Fixes
- Fixed a bug where
callSidis missing from the dictionary returned by[TVOPreflightTest dictionaryReport]. - Fixed a bug where the signaling library was throwing an exception while initiating a call with per-app based VPN enabled.
- Fixed the
TVOPreflightCallQualityenum Swift name alias typo.
Size Impact
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.4 MB | 7.8 MB |
October 21, 2024
- Programmable Voice iOS SDK 6.12.0 [XCFramework] (checksum: fb8e743bba78df579814a5860bbea8cde9dd3cedd137df85f97be7cafb5adfc8).
API Changes
- New methods
[TwilioVoiceSDK runPreflightTestWithAccessToken:delegate:]and[TwilioVoiceSDK runPreflightTestWithOptions:delegate:]to run a preflight test are added. - A new class
TVOPreflightOptionsis added. Use[TVOPreflightOptions optionsWithAccessToken:]or the builder method[TVOPreflightOptions optionsWithAccessToken:block:]to create the options object as an argument when calling the[TwilioVoiceSDK runPreflightTestWithOptions:delegate:]method. - A new class
TVOPreflightTestis added. This object cannot be initialized directly. Instead aTVOPreflightTestobject is returned when calling the[TwilioVoiceSDK runPreflightTestWithAccessToken:delegate:]and[TwilioVoiceSDK runPreflightTestWithOptions:delegate:]methods. Please note that thestop()method can be used to disconnect the preflight test but will result in the[TVOPreflightDelegate preflight:didFailWithError:]callback with theTVOPreflightTestStatusFailedstate of the preflight test. - A new protocol class
TVOPreflightDelegateis added. Status updates of the preflight test will be raised via the delegate methods in this class. - A new class
TVOPreflightReportis added. A comprehensive report object will be returned in the[TVOPreflightDelegate preflight:didCompleteWitReport:]callback. The report can also be retrieved using theTVOPreflightTest.preflightReportproperty when the preflight test has completed.
An example of making a preflight test
1class ViewController: UIViewController {2var preflightTest: PreflightTest? = nil34func performPreflight() {5let preflightOptions = PreflightOptions(accessToken: accessToken, block: { builder in6builder.preferredAudioCodecs = [OpusCodec()]7})89preflightTest = TwilioVoiceSDK.runPreflightTest(options: preflightOptions, delegate: self)10}11}1213extension ViewController: PreflightDelegate {14func preflightDidComplete(preflightTest: PreflightTest, report: PreflightReport) {15// Check the result in the report16}1718func preflightDidFail(preflightTest: PreflightTest, error: any Error) {19// Check the failure reason in the error20}2122func preflightDidConnect(preflightTest: PreflightTest) {23// preflight test has connected24}25}
Bug Fixes
- This release uses a WebRTC patch that addresses a potential ICE gathering or network handover issue on iOS 18.
Size Impact
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.4 MB | 7.8 MB |
September 10, 2024
- Programmable Voice iOS SDK 6.11.3 [XCFramework] (checksum: 0d8bcd777590bb7cf441a37d8fedfd1ce5babb1885f94a1d9976de9acbcf1611).
Enhancements
- The SDK is now using reSIProcate 1.12.0 for the signaling connection.
- The SDK now supports Server Name Indication (SNI) during initial TLS handshake with Twilio infrastructure.
Known Issues
- The
TVOCallMessageBuilder.contentTypehas no effect on the content type of theTVOCallMessageobject. The content type always defaults toapplication/json.
Size Impact
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.3 MB | 7.6 MB |
August 26, 2024
- Programmable Voice iOS SDK 6.11.2 [XCFramework] (checksum: 45a0a811379116d525336424b93a6671b3e8ed634ff48ae7fc7b307cec02b84f).
Enhancements
- The Call Message Events (Beta), originally released in 6.5.0, has been promoted to GA.
- The error code
TVOErrorCallMessageCallInUnexpectedStateErrorwill be raised when[TVOCall sendMessage:]is invoked when the Call has not reached the ringing state yet. error 31211 - Voice Insights publishing will fall back to sending uncompressed data if the compressed format is not supported.
API Changes
- The error code of
TVOErrorCallMessageEventPayloadSizeExceededErrorhas been changed to 31212. error 31212
Bug Fixes
- Fixed a bug where the SDK by default reports
customas the logger type to Voice Insights.
Known Issues
- The
TVOCallMessageBuilder.contentTypehas no effect on the content type of theTVOCallMessageobject. The content type always defaults toapplication/json.
Size Impact
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.3 MB | 7.5 MB |
June 4, 2024
- Programmable Voice iOS SDK 6.11.1 [XCFramework] (checksum: 30026a8e37d339d6275e572871ec02e2a968f3f57201c90e9cdff5e6436f1e39).
Enhancements
- The Voice Insights data is now compressed before uploading to save network bandwidth.
- Added new error code
TVOErrorCallMessageCallInUnexpectedStateErrorinTVOErrorthat happens[TVOCallInvite sendMessage:]is invoked when the Call Invite has not reached the ringing state yet.[TVOCallMessageDelegate messageFailedForCallSid:voiceEventSid:error:]callback will be invoked in this case with the above mentioned error code. error 31211
Size Impact
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.3 MB | 7.5 MB |
May 15, 2024
- Programmable Voice iOS SDK 6.11.0 [XCFramework] (checksum: c2befda6077f0c9ce6a3e2a098d75ed6d41f59e98e089beffba40fb2a1457393).
Enhancements
- The SDK XCFramework is now signed with Twilio's distribution signature.
- Added new error code 13224
TVOErrorInvalidPhoneNumberErrorinTVOErrorthat happens when a call is made to an invalid phone number. - Added new error code 31210
TVOErrorCallMessageTypeInvalidErrorfor invalid call message type whensendMessageAPI is invoked with aTVOCallMessageobject where themessageTypeis not set touser-defined-message. - The Privacy Manifest is updated since the SDK does not collect API usage or call quality data for tracking purposes according to Apple's documentation.
API Changes
- The SDK no longer validates the value of
TVOCallMessage.messageTypeand treats it as a pass-through for both inbound and outbound call messages. To send a user-defined message with the[TVOCall sendMessage:]or the[TVOCallInvite sendMessage:]method, set themessageTypetouser-defined-message. - The factory method
[TVOCallMessage messageWithContent:]is deprecated in favor of the[TVOCallMessage messageWithContent:messageType:block:]method. - A new warning type
TVOCallQualityWarningConstantAudioOutputLevelis added forTVOCallQualityWarningenum. This warning is raised whenstandard deviationof audio output levels for the last 10 samples is less than or equals 1% of the maximum possible audio output level of32767, i.e.327.67, and the call is not onholdby the local party. This warning is cleared whenstandard deviationof audio output levels for the last 10 samples is greater than 3% of the maximum possible audio output level, i.e.983.01. Please note, if the remote party mutes the audio track or places the call onhold, this warning will still be raised.
Size Impact
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.3 MB | 7.5 MB |
April 17, 2024
- Programmable Voice iOS SDK 6.10.4 [XCFramework] (checksum: 7f8d015360b86f516d5ef1662af6e0da8d40be817675a89da66646b0b804b19f).
Enhancements
- Increased sampling resolution of Voice Insights call quality metrics events.
- Added a missing API which is used internally by WebRTC to the SDK's privacy manifest.
Known Issues
- The SDK collects API usage and WebRTC call quality data and sends it back as Twilio Voice Insights events for post-call quality analysis and debugging purposes. On iOS 17, Voice Insights data collection will be impacted if the application user does not allow tracking when prompted with iOS
AppTrackingTransparencyframework authorization alert. iOS 16 and earlier versions will not be affected by the Privacy Manifest that ships with the SDK XCFramework.
Size Impact
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.3 MB | 7.5 MB |
March 26, 2024
- Programmable Voice iOS SDK 6.10.3 [XCFramework] (checksum: 2d90b96aa9e6a465b0889a562fd021f0fa70eba44356da93b15146b950ec9f7a).
Bug Fixes
- Fixed an issue where
PrivacyInfo.xcprivacyfile was causing a warning during app store submission.
Size Impact
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.3 MB | 7.5 MB |
March 12, 2024
- Programmable Voice iOS SDK 6.10.2 [XCFramework] (checksum: 11ec923fb78b3e3e1bf2e2d2581a1280e9a2cd0f91f59d3a118c4205a5b46478).
API Changes
-
New
TVOAudioOptionsandTVOAudioOptionsBuilderAPIs that enable audio processing operations to be performed on the local audio track/source has been added. You can use theTVOAudioOptionsBuilderclass to create an instance ofTVOAudioOptions. Please note that software Echo Cancellation and Automatic Gain Control for the microphone is not supported in iOS as WebRTC relies on OS provided capabilities.- Audio processing operations include noise suppression, high pass filtering, setting jitter buffer max size in packets, and setting jitter buffer minimum delay in milliseconds.
- By default,
noiseSuppressionis set tofalse,highpassFilteris set totrue,audioJitterBufferMaxPacketsis set to50packets, andaudioJitterBufferMinDelayMsis set to0milliseconds. - The default values can be modified and custom
TVOAudioOptionscan be set as part ofTVOConnectOptionswhen making outbound calls and/or as part ofTVOAcceptOptionswhen receiving incoming calls.
Please see the example below. In this example, high pass filtering is enabled, audioJitterBufferMaxPackets is set to 200 packets and audioJitterBufferMinDelayMs is set to 5 milliseconds.
12let audioOptions = AudioOptions() { builder in3builder.audioJitterBufferMaxPackets = 2004builder.audioJitterBufferMinDelayMs = 55builder.highpassFilter = true6}78let acceptOptions = TVOAcceptOptions(callInvite: callInvite) { builder in9builder.uuid = callInvite.uuid10builder.enableIceGatheringOnAnyAddressPorts = true11builder.audioOptions = audioOptions;12}1314let call = callInvite.accept(with: acceptOptions, delegate: self)
Size Impact
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.3 MB | 7.5 MB |
February 12, 2024
- Programmable Voice iOS SDK 6.10.1 [XCFramework] (checksum: a3e66546465c669645ff4cdc8db0498c22c0dad5f0c3bad3044d8952ff6fd212).
Enhancements
- The SDK now includes the privacy manifest in the XCFramework. The SDK collects analytic data such as API usage and WebRTC stats when the
TwilioVoiceSDK.insightsproperty is enabled. - Added new Call Error,
TVOErrorInvalidCallerIDErrorthat happens when a call is attempted with an invalid caller id error 13214.
API Changes
- The current set of
TVOCallMessageDelegatecallback methods have been deprecated and will be removed in a future release in favor of the new callback methods. Please note that the new APIs work for bothTVOCallInviteandTVOCall.
See examples as follows:
12// MARK: - TVOCallMessageDelegate3func messageSent(callSid: String, voiceEventSid: String) {4NSLog("Call message sent. Voice Event SID: \(voiceEventSid)")5}67func messageFailed(callSid: String, voiceEventSid: String, error: Error) {8NSLog("Failed to send call message. Voice Event SID: \(voiceEventSid). Error: \(error.localizedDescription)")9}1011func messageReceived(callSid: String, message: CallMessage) {12NSLog("Call message received: \(callMessage.content)")13}
Size Impact
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.3 MB | 7.5 MB |
November 30, 2023
- Programmable Voice iOS SDK 6.10.0 [XCFramework] (checksum: 050218acf4548b346fdaef9e62a4be10d0a80c6ea58954a41022d1ba63dc148a).
Enhancements
- This release is based on Chromium WebRTC 112.
Size Impact for 6.10.0
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.2 MB | 7.4 MB |
November 9, 2023
- Programmable Voice iOS SDK 6.9.2 [XCFramework] (checksum: 44527c3d6520df9991f503f8bb6a354b4a4cb18415f4e276951aba70419b729b).
Bug Fixes
- Fixed a crash when the background signaling thread is accessing the memory while the
TVOCallobject has been destroyed.
Size Impact for 6.9.2
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.3 MB | 7.5 MB |
October 02, 2023
- Programmable Voice iOS SDK 6.9.1 [XCFramework] (checksum: 6a4f677228de99f676146c0ba62a0e88a219b0ed531c6a34032c9709fa13ebb3).
API Changes
- New
threadproperty is added to theTVOLogParametersclass to specify thread name or thread id in the log.
Bug Fixes
- Fixed a bug where the incoming call answer timeout value might not be applied.
- Fixed a crash when SDK is tearing down the incoming call ringing monitor.
Size Impact for 6.9.1
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 4.2 MB | 12.6 MB |
September 05, 2023
- Programmable Voice iOS SDK 6.9.0 [XCFramework] (checksum: cbf301343afd5fafa80c3d7abeb4b0ddb933266dce36cf322644a620f989a277).
Enhancement
- In this release a new protocol
TVOLoggeris added. Users can implement this protocol to create their own custom logger.
API Changes
- New
TVODefaultLoggerclass is added. Users can use it to send their app logs to standard output. - A new
loggerproperty of typeTVOLoggeris added toTwilioVoiceSDK. You can set this property to your custom logger instance. The SDK will return an instance ofDefaultLoggerby default. If you intend to use SDK's logger utility to log your app logs, you can useDefaultLoggerto do so. - New
TVOLogParametersclass is added to pass log statement related parameters to the user defined logger implementation. TVOLogLevelandTVOLogModuleenums have been moved to the newTVOLogParametersheader file.
12class CustomLogger:NSObject {3//.. Your custom logger definition4}56extension CustomLogger:Logger {7func log(params logParameters: LogParameters!) {8print("\(logParameters.logModule) - \(logParameters.logLevel) - \(logParameters.message)");9}10}1112let logger = CustomLogger()13TwilioVoiceSDK.logger = logger14
Size Impact for 6.9.0
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 4.2 MB | 12.6 MB |
June 23, 2023
- Programmable Voice iOS SDK 6.8.1 [XCFramework] (checksum: 67c1fea7aef9d9ed3e57f300eb05b682564011d1430c39cd77dc93fde5ad25a8).
API Changes
- The
TVOAudioDeviceFormatChangedmethod is now marked as deprecated and will be removed in v7.0. UseTVOAudioDeviceReinitializeinstead.
Bug Fixes
- Fixed a bug where the incoming call invite can only ring up to 3 minutes instead of the maximum 10 minutes call timeout). Note that on iOS 16 and later versions CallKit will dismiss the incoming call in one minute by raising the
CXProviderDelegate [provider:performEndCallAction:]callback.
Size Impact for 6.8.1
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 4.1 MB | 12.5 MB |
June 13, 2023
- Programmable Voice iOS SDK 6.8.0 [XCFramework] (checksum: 298ff9bae7eb434e911dd14a2d40c3582dc97133d3e3dbbe23f2088726301ddf).
Enhancements
- This release uses WebRTC M105.
Size Impact for 6.8.0
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 4.1 MB | 12.5 MB |
May 17, 2023
- Programmable Voice iOS SDK 6.7.0 [XCFramework] (checksum: 97f1d2af07f308327f392fb347ce19e7a0711f1b8c8050b55c33afc78f8fbaef).
API Updates
- The SDK now supports sending and receiving user-defined messages via the
TVOCallInvitebefore it is answered or rejected. Sending user-defined messages while call is still ringing (before connected) is also supported now.
Example of sending and receiving call messages via the TVOCallInvite:
1// Pass `CallMessageDelegate` in the `handleNotification()` method2TwilioVoiceSDK.handleNotification(payload.dictionaryPayload, delegate: self, delegateQueue: nil, callMessageDelegate: self)34// MARK: - NotificaitonDelegate5func callInviteReceived(callInvite: CallInvite) {6let message = "{ \"foo\": \"bar\", \"marco\": \"polo\" }"7let callMessage = CallMessage(content: message)89// voiceEventSid can be used for tracking the message10let voiceEventSid = callInvite.sendMessage(callMessage)11}1213// MARK: - CallMessageDelegate14func callInviteDidSendMessage(callInvite: CallInvite, voiceEventSid: String) {15NSLog("Call message sent. Voice Event SID: \(voiceEventSid)")16}1718func callInviteDidFailToSendMessage(callInvite: CallInvite, voiceEventSid: String, error: Error) {19NSLog("Failed to send call message. Voice Event SID: \(voiceEventSid). Error: \(error.localizedDescription)")20}2122func callInviteDidReceiveMessage(callInvite: CallInvite, callMessage: CallMessage) {23NSLog("Call message received: \(callMessage.content)")24}
- Bitcode support is disabled since App Store no longer accepts bitcode submission from Xcode 14. (Release notes)
Size Impact for 6.7.0
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.9 MB | 11.4 MB |
May 12, 2023
- Programmable Voice iOS SDK 6.5.2 [XCFramework] (checksum: a14e7c33c1f78dbe650264cdf5808e7a306bfaecadc2fbac4e1bc1214263765d).
API updates
TVODefaultAudioDeviceclass now has a propertyignoresPreferredAttributeConfigurationErrorsto ignore errors during AVAudioSession setup. This is to mitigate the WebRTC issue reported here
Size Impact for 6.5.2
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.2 MB | 7.1 MB |
December 5, 2022
- Programmable Voice iOS SDK 6.5.0 [XCFramework] (checksum: 6a0cd9726e992582cb2cb20b6e6721cbb371de19dc67edaef611d92398d4e269).
API updates
-
The SDK now supports sending and receiving in-call user-defined messages. Use the
[TVOCall sendMessage:]method to send messages. Endpoints subscribed to the events of the call will be receiving the messages. The[TVOCallMessageDelegate call:didReceiveMessage:]callback will be raised to the application when a message is received by the client.Please visit this page for more details about this feature. Additionally, please see the following for more information on how to send and receive messages on the server.
NOTE: This feature should not be used with PII.
-
The
TVOCallMessageclass and theTVOCallMessageBuilderclass are introduced to represent the call messages.
Example of sending a call message:
1let call = TwilioVoiceSDK.connect(options: connectOptions, delegate: self)23// wait for call to be connected45let message = "{ \"foo\": \"bar\", \"marco\": \"polo\" }"6let callMessage = CallMessage(content: message)78// voiceEventSid can be used for tracking the message9let voiceEventSid = call.sendMessage(callMessage)1011extension ViewController: CallMessageDelegate {12func callDidSendMessage(call: Call, voiceEventSid: String) {13NSLog("Call message sent. Voice Event SID: \(voiceEventSid)")14}1516func callDidFailToSendMessage(call: Call, voiceEventSid: String, error: Error) {17NSLog("Failed to send call message. Voice Event SID: \(voiceEventSid). Error: \(error.localizedDescription)")18}19}
Example of handling incoming call messages:
1extension ViewController: CallMessageDelegate {23func callDidReceiveMessage(call: Call, message callMessage: CallMessage) {4NSLog("Call message received. Message: \(callMessage.content)")5}67}
Size Impact for 6.5.0
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.2 MB | 7.1 MB |
July 11, 2022
- Programmable Voice iOS SDK 6.4.2 [XCFramework] (checksum: caebcfde5540e6aefeab61edb5d131c55565eb72b690fc50e8201836f0c21735).
API Updates
- The
writableproperty of theTVOIceCandidatePairStatsclass has been renamed towriteable. - New edge
umatillais now supported. Set theTwilioVoiceSDK.edgeproperty before connecting or accepting the call.
Bug Fixes
- Fixed a symbol conflict (
RTCNativeAudioSessionDelegateAdapter) when using the SDK side by side with another WebRTC library.
Size Impact for 6.4.2
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.2 MB | 7.0 MB |
May 26, 2022
- Programmable Voice iOS SDK 6.4.1 [XCFramework] (checksum: 16080af560c584f574d00c04af408e340253f814b583b7920a718d66ed5ea6dd ).
Bug Fixes
- Fixed a crash when the home region specifier (
twr) in the access token isnull.
Size Impact for 6.4.1
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.2 MB | 7.0 MB |
May 3, 2022
- Programmable Voice iOS SDK 6.4.0 [XCFramework] (checksum: 5bb8ab2aa8f9f2e91d243e64c5e850cdc0c1365f4bfc64a37532b0688d118770).
API updates
- The Voice iOS SDK now supports Twilio Regional by providing the home region specifier in the access token header when calling the
TwilioVoiceSDK.register()method, theTwilioVoiceSDK.unregister()method, and theTwilioVoiceSDK.connect()method.
Existing customers can now migrate their Voice use-cases to data centers in Ireland or Australia to establish data residency within the region. In addition, new customers may now select Ireland or Australia as their region of choice for Voice related use cases. There is no additional cost to use the new data centers in Ireland or Australia. To learn more about Regional Voice, check out our blog post or head over to our developer docs to get started.
Example of specifying home region in the access token using the Twilio Node.js SDK:
1const accessToken = new twilio.jwt.AccessToken(2credentials.accountSid,3credentials.apiKeySid,4credentials.apiKeySecret, {5identity,6ttl,7region: 'au1',8},9);10
The decoded header of your access token should looks like this:
1{2"alg": "HS256",3"typ": "JWT",4"cty": "twilio-fpa;v=1",5"twr": "au1"6}
Maintenance
- Updated API doc of
[TVOCall getStatsWithBlock:].
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 6.4.0
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.2 MB | 7.0 MB |
February 8, 2022
- Programmable Voice iOS SDK 6.3.1 [XCFramework] (checksum: 08e5839eb77d8746baff8b132059f0babfb9e1ed860903553b7d9c02411442af ).
Enhancements
- The Voice SDK now validates full remote domain names while setting up the TLS connection.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 6.3.1
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.2 MB | 7.0 MB |
May 17, 2021
Enhancements
- This release is based on Chromium WebRTC 88.
- The simulator
arm64architecture on Apple Silicon Macs is now available. - The SDK uses Unified Plan SDP semantics instead of Plan-B.
Known Issues
- Carthage is not currently a supported distribution mechanism for Twilio Voice. Carthage does not currently work with
.xcframeworksas documented here. Once Carthage supports binary.xcframeworks, Carthage distribution will be re-added. - Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 6.3.0
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.2 MB | 7.1 MB |
March 29, 2021
- Programmable Voice iOS SDK 5.5.2 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Bug Fixes
- Fixed a potential crash in the core module where the logger could be accessed after being destroyed by another thread. #419
- Fixed a bug where caller might not receive the
[TVOCallDelegate call:didDisconnectiWithError:]callback when callee hangs up. - Fixed a bug where callee was not receiving the
[TVONotificationDelegate cancelledCallInviteReceived:error:]callback when signaling connection error happens.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 5.5.2
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 3.0 MB | 6.7 MB |
| arm64 | 3.0 MB | 6.7 MB |
March 11, 2021
Bug Fixes
- Fixed the SDK version number in the
Info.plistfile of the framework. - Fixed a potential crash in the core module where the logger could be accessed after being destroyed by another thread. #419
Known Issues
- The
TwilioVoice.xcframeworkdoes not currently support the simulator on Apple Siliconarm64Macs. - Carthage is not currently a supported distribution mechanism for Twilio Voice. Carthage does not currently work with
.xcframeworksas documented here. Once Carthage supports binary.xcframeworks, Carthage distribution will be re-added. - Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 6.2.2
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.1 MB | 7.0 MB |
February 4, 2021
Bug Fixes
- Fixed platform version in podspecs.
Known Issues
- The
TwilioVoice.xcframeworkdoes not currently support the simulator on Apple Siliconarm64Macs. - Carthage is not currently a supported distribution mechanism for Twilio Voice. Carthage does not currently work with
.xcframeworksas documented here. Once Carthage supports binary.xcframeworks, Carthage distribution will be re-added. - Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 6.2.1
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.1 MB | 7.0 MB |
February 1, 2021
Enhancements
- The Voice iOS SDK is built with Xcode 12.0.
- Twilio Voice is now delivered as an
.xcframework. The.xcframeworkpackage includes the.dSYMand.bcsymbolmapfiles to allow developers to symbolicate crash reports. - Twilio Voice is now distributed as a Swift Package.
Known Issues
- The
TwilioVoice.xcframeworkdoes not currently support the simulator on Apple Siliconarm64Macs. - Carthage is not currently a supported distribution mechanism for Twilio Voice. Carthage does not currently work with
.xcframeworksas documented here. Once Carthage supports binary.xcframeworks, Carthage distribution will be re-added. - Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 6.2.0
| Architecture | Compressed Size | Uncompressed Size |
|---|---|---|
| arm64 | 3.1 MB | 7.0 MB |
January 7, 2021
- Programmable Voice iOS SDK 6.1.0 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Enhancements
- Private IP addresses are masked in Release mode for the SDK logs and the
ice-candidateInsights event payload. - Private IP addresses will not be masked in
Debugmode. Theselected-ice-candidate-pairevent will contain private IP address of the local active ICE candidate for debugging purpose in both Release and Debug modes.
Bug fixes
- Fixed a bug where caller might not receive the
call:didDisconnectWithError:callback when the callee hangs up. - Fixed a bug where callee was not receiving the
cancelledCallInviteReceived:error:callback when signaling connection error happens. - The Voice SDK had the same
TwilioVoiceframework name and the class name. This was causing swift compile time errors when an app tries to access a TwilioVoice framework's class using the module name, e.g.TwilioVoice.ConnectOptions. Fixed this issues by renaming theTwilioVoiceclass name toTwilioVoiceSDK.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size impact for 6.1.0
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 3.1 MB | 6.9 MB |
| arm64 | 3.1 MB | 6.9 MB |
November 4, 2020
- Programmable Voice iOS SDK 6.0.2 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Bug fixes
- Fixed Swift compile time error for
AudioDeviceWorkerBlock.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size impact for 6.0.2
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 3.1 MB | 6.8 MB |
| arm64 | 3.1 MB | 6.8 MB |
November 2, 2020
- Programmable Voice iOS SDK 6.0.1 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Bug fixes
- Fixed Swift compile time error for
AudioDeviceContext.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size impact for 6.0.1
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 3.1 MB | 6.8 MB |
| arm64 | 3.1 MB | 6.8 MB |
September 15, 2020
- Programmable Voice iOS SDK 6.0.0 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
API change
- The Voice SDK has been updated for better Swift interoperability.
- The
TVOprefix has been removed from all Twilio Voice types - Many of the delegate function declarations have been revamped for better clarity of their intent
- Some of the class method declarations have been revamped for better clarity of their intent
- The
- This release has improved API for CallKit integration. In order to use CallKit with SDK, you must set
ConnectOptions.uuidorAcceptOptions.uuidwhile making or answering a Call. WhenConnectOptions.uuidorAcceptOptions.uuidis set, it is your responsibility to enable and disable the audio device. You should enable the audio device in[CXProviderDelegate provider:didActivateAudioSession:], and disable the audio device in[CXProviderDelegate provider:didDeactivateAudioSession:].
1func provider(_ provider: CXProvider, didActivate audioSession: AVAudioSession) {2audioDevice.isEnabled = true3}45func provider(_ provider: CXProvider, didDeactivate audioSession: AVAudioSession) {6audioDevice.isEnabled = false7}89func providerDidReset(_ provider: CXProvider) {10audioDevice.isEnabled = false11}
If you are not using CallKit in your app, you must not set ConnectOptions.uuid or AcceptOptions.uuid while making or answering a call. The Voice SDK will enable the audio device for you when the uuid is nil.
- The
uuidproperty ofTVOCallis now optional. - This release changes the underlying behavior of
[TVOCallDelegate callDidConnect:]such that it is raised when both ICE connection state is connected and DTLS negotiation has completed. Previously[TVOCallDelegate callDidConnect:]was raised when the DTLS negotiation had completed. - In this release,
[TVOCallDelegate callDidConnect:]is raised when both the ICE connection state is connected and DTLS negotiation has completed. There is no change in behavior however the SDK can detect DTLS failures and raisekTVOMediaDtlsTransportFailedErrorCodeif they occur. - Defined new error code
| Error Codes | ErrorCode | Error Message |
|---|---|---|
| 53407 | TVOMediaDtlsTransportFailedErrorCode | Media connection failed due to DTLS handshake failure |
- PeerConnection state is now reported to Insights
| Event Group | Level | Event Name | Description |
|---|---|---|---|
| pc-connection-state | DEBUG | new | Raised when peer connection state is new |
| pc-connection-state | DEBUG | connecting | Raised when peer connection state is connecting |
| pc-connection-state | DEBUG | connected | Raised when peer connection state is connected |
| pc-connection-state | DEBUG | disconnected | Raised when peer connection state is disconnected |
| pc-connection-state | ERROR | failed | Raised when peer connection state is failed |
| pc-connection-state | DEBUG | closed | Raised when peer connection state is closed |
- Removed the deprecated property
TwilioVoice.region. UseTwilioVoice.edgeto control the connectivity with Twilio. - The
[TwilioVoice registerWithAccessToken:deviceTokenData:completion:]and the[TwilioVoice unregisterWithAccessToken:deviceTokenData:completion:]have been renamed to replace the[TwilioVoice registerWithAccessToken:deviceToken:completion:]and the[TwilioVoice unregisterWithAccessToken:deviceToken:completion:]methods and now take theNSDatatype device token as parameter.
Enhancements
- This release is based on Chromium WebRTC 83.
- TwilioVoice.framework is now built with Xcode 11.4.1
- A new Insights event
selected-ice-candidate-pairis reported with the active local ICE candidate and remote ICE candidate.
| Event Group | Level | Event Name | Description |
|---|---|---|---|
| ice-candidate | DEBUG | selected-ice-candidate-pair | Raised when the active local and remote ICE candidates of the peer connection are determined |
moscalculation algorithm has been updated to make it monotonically decreasing with increasingjitterandpackets-lost-fractionvalues over a range ofrttvalues. The final mos should always be in the range [1.0, 4.6].
Maintenance
- Added a security patch to prevent host candidate DNS attacks. See Issue 11597 for details.
Bug fixes
- Fixed a crash when processing of empty stats reports or stats reports without remote audio tracks.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size impact for 6.0.0
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 3.1 MB | 6.8 MB |
| arm64 | 3.1 MB | 6.8 MB |
September 15, 2020
- Programmable Voice iOS SDK 5.5.1 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Bug Fixes
- Fixed the background task handling in
[TVOCall disconnect],[TVOCallInvite reject],[TwilioVoice registerWithAccessToken:deviceTokenData:completion:]and[TwilioVoice unregisterWithAccessToken:deviceTokenData:completion:]. iOS should no longer report a background task risk of termination warning. - Fixed a crash when processing of empty stats reports or stats reports without remote audio tracks.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 5.5.1
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 2.9 MB | 6.7 MB |
| arm64 | 2.9 MB | 6.7 MB |
July 9, 2020
- Programmable Voice iOS SDK 5.5.0 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
API Change
- A
TVOCallerInfoclass is introduced to represent information about the caller. Currently, this information is limited toSHAKEN/STIRstatus of incoming PSTN Calls, but may later be expanded to includeCNAM, and other endpoint types. Theverifiedproperty represents whether or not the caller's phone number has been verified by Twilio usingSHAKEN/STIRvalidation. The value of this attribute istrueif the caller has been validated at'A'level,falseif the caller has been verified at any lower level or has failed validation. IfSHAKEN/STIRinformation is unavailable for the caller or stir status value isnull, the property will benil. For details on how Twilio usesSHAKEN/STIRto make trusted calls and protect against unlawful spoofing, please visit /docs/voice/trusted-calling-using-shakenstir. - New property
callerInfoinTVOCallInvitereturns theTVOCallerInfoobject to represent the information about the caller.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 5.5.0
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 2.9 MB | 6.7 MB |
| arm64 | 2.9 MB | 6.7 MB |
June 25, 2020
- Programmable Voice iOS SDK 5.4.1 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Bug Fixes
- Fixed a crash that could occur when destroying the
TVOCallorTVOCallInviteobject.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 5.4.1
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 2.9 MB | 6.7 MB |
| arm64 | 2.9 MB | 6.7 MB |
June 3, 2020
- Programmable Voice iOS SDK 5.4.0 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
API Change
- This release includes support for the expansion of Twilio's Global Infrastructure via Edge Locations which allows customers to control their connectivity into and out of Twilio's platform. The Voice iOS SDK uses these Edges to connect to Twilio's infrastructure via the new property
TwilioVoice.edge. This new property supersedes the now deprecatedTwilioVoice.region. See the new Edge names and how they map to the old region names.
Here is an example
1// Connect using global low latency2TwilioVoice.edge = "roaming"
- This release also adds the Mean Opinion Score (MOS) measurement
mostoTVORemoteAudioTrackStats. Use[TVOCall getStatsWithBlock:]during a call to retrieve the score. Themosis computed once per second. Since the MOS is calculated from network performance measurements, it can be used to indicate the current network condition to the user to provide better usability. See API Docs for more information
Example
1call.getStatsWith { (reports) in2for report in reports {3let remoteAudioTracksStats = report.remoteAudioTrackStats4let mosLabel = "\(remoteAudioTracksStats.mos)"5}6}
Enhancements
- Network degradation warnings were previously only logged to Insights. With this release, a new
TVOCallDelegatemethodcall:didReceiveQualityWarnings:previousWarnings:is also invoked when the SDK detects those degradations. Use these to relay network condition to the user to provide a better user experience. See the delegate method and callQualityWarnings for more information. - The Mean Opinion Score (MOS) is now available in
TVOStatsReport. Use[TVOCall getStatsWithBlock:]during a Call to retrieve the score. Since the MOS is calculated from network performance measurements, it can be used to indicate the current network condition to the user to provide better usability. - By default ICE gathering is done on all interfaces except some VPN type interfaces. This makes it impossible to connect to Twilio in networks that require the use of VPN. In this release, the new Boolean property
enableIceGatheringOnAnyAddressPortsinTVOCallOptionsBuilderallows the gathering of ICE candidates from all available interfaces. This should be used in those networks where the default does not work. See enableIceGatheringOnAnyAddressPorts for more information.
Deprecations
TwilioVoice.regionis now deprecated. UseTwilioVoice.edgeinstead. See the new Edge names for possible values.
Bug Fixes
- Fixed a bug where the SDK was still raising the
[TVOCallDelegate callDidStartRinging:]callback if[TVOCall disconnect]was called. - Fixed a crash caused by a signaling race condition when user rejects a
TVOCallInvite.
Other
armv7builds are no longer available or supported.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 5.4.0
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 2.9 MB | 7.0 MB |
| arm64 | 2.8 MB | 6.9 MB |
April 9, 2020
- Programmable Voice iOS SDK 5.3.1 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Improvements
- Optimized
[TwilioVoice unregisterWithAccessToken:deviceTokenData:completion:]by reducing the number of network requests. - Added background handling support to
[TwilioVoice registerWithAccessToken:deviceTokenData:completion:]and[TwilioVoice unregisterWithAccessToken:deviceTokenData:completion:]. They will now finish execution even when the app is backgrounded.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 5.3.1
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 6.0 MB | 12.7 MB |
| arm64 | 2.8 MB | 6.9 MB |
| armv7 | 3.0 MB | 5.7 MB |
March 18, 2020
- Programmable Voice iOS SDK 5.3.0 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
API Changes
- New methods to register and unregister for VoIP push notifications have been added that rely on
NSDatarather thanNSString. The previous register and unregister methods have been deprecated in favor of these new methods.
1// TwilioVoice.h23+ (void)registerWithAccessToken:(nonnull NSString *)accessToken4deviceTokenData:(nonnull NSData *)deviceTokenData5completion:(nullable void(^)(NSError * __nullable error))completion6NS_SWIFT_NAME(register(withAccessToken\:deviceToken\:completion:));78+ (void)unregisterWithAccessToken:(nonnull NSString *)accessToken9deviceTokenData:(nonnull NSData *)deviceTokenData10completion:(nullable void(^)(NSError * __nullable error))completion11NS_SWIFT_NAME(unregister(withAccessToken\:deviceToken\:completion:));
Swift example
1func pushRegistry(_ registry: PKPushRegistry, didUpdate credentials: PKPushCredentials, for type: PKPushType) {2TwilioVoice.register(withAccessToken: accessToken, deviceToken: credentials.token) { (error) in3if let error = error {4NSLog("An error occurred while registering: \(error.localizedDescription)")5} else {6NSLog("Successfully registered for VoIP push notifications.")7}8}9}
Objective-C example
1- (void)pushRegistry:(PKPushRegistry *)registry2didUpdatePushCredentials:(PKPushCredentials *)credentials3forType:(NSString *)type {4[TwilioVoice registerWithAccessToken:accessToken5deviceTokenData:credentials.token6completion:^(NSError *error) {7if (error) {8NSLog(@"An error occurred while registering: %@", [error localizedDescription]);9} else {10NSLog(@"Successfully registered for VoIP push notifications.");11}12}];13}
Bug Fixes
- Fixed Voice Insights data with valid
transport_idvalue.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 5.3.0
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 6.0 MB | 12.7 MB |
| arm64 | 2.8 MB | 6.9 MB |
| armv7 | 3.0 MB | 5.7 MB |
March 11, 2020
- Programmable Voice iOS SDK 5.2.1 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Bug Fixes
- Fixed duplicated symbol linker errors in the static library.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 5.2.1
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 6.0 MB | 12.7 MB |
| arm64 | 2.8 MB | 6.9 MB |
| armv7 | 3.0 MB | 5.7 MB |
February 27, 2020
- Programmable Voice iOS SDK 5.2.0 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Enhancements
- Attempts to re-establish the media connection will be done preemptively if no media flow is detected for 3 seconds.
- An ongoing call will automatically switch to a more preferred network type if one becomes available. The following are the network types listed in preferred order: ETHERNET, LOOPBACK, WIFI, VPN, and CELLULAR. For example, if a WIFI network becomes available whilst in a call that is using CELLULAR data, the call will automatically switch to using the WIFI network.
- Proper data types are added to the Insights event payload.
Bug Fixes
- Fixed a crash when a canceled call invite is received but the
fromvalue isnil.
Things to Note
- Since media and signaling reconnect are two completely separate processes, it is likely that for a single network change event multiple
[TVOCallDelegate call:isReconnectingWithError:]and[TVOCallDelegate callDidReconnect:]callbacks will be received in the order specified i.e a[TVOCallDelegate call:isReconnectingWithError:]callback will always be followed by a[TVOCallDelegate callDidReconnect:]callback.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 5.2.0
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 6.0 MB | 12.7 MB |
| arm64 | 2.8 MB | 6.9 MB |
| armv7 | 3.0 MB | 5.6 MB |
February 24, 2020
- Programmable Voice iOS SDK 5.1.2 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Bug Fixes
- Fixed a crash when a canceled call invite is received and the
fromvalue isnil.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 5.1.2
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 6.0 MB | 12.6 MB |
| arm64 | 2.8 MB | 6.8 MB |
| armv7 | 3.0 MB | 5.6 MB |
December 9, 2019
- Programmable Voice iOS SDK 5.1.1 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Enhancements
- Application name, bundle ID, version, build number, Xcode version and min/major SDK version are now published to Insights. This helps with isolating problems if an issue is encountered.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 5.1.1
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 6.0 MB | 12.6 MB |
| arm64 | 2.8 MB | 6.8 MB |
| armv7 | 3.0 MB | 5.6 MB |
November 19, 2019
- Programmable Voice iOS SDK 5.1.0 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Enhancements
- Incoming call handling improvements. Previously, if we encountered network issues before an incoming call was answered or rejected, we disconnected the call. With this release, we will continue to try and establish a connection to Twilio for a maximum of 40 seconds before we disconnect the call.
- We added support for OpenSSL 1.1.x in the static library version of our SDK. To use this flavor of the SDK, please refer to the instructions included in the Static Library
- We now publish the negotiated codec and its associated parameters to Insights.
| Event Group | Level | Event Name | Description |
|---|---|---|---|
| settings | INFO | codec | Raised when the codec has been selected |
Other Improvements
- Improved the way we perform DNS resolution. Previously, some DNS requests could indirectly block the main thread. This is no longer the case.
listening-errorevent level was incorrectly reported as INFO instead of ERROR toinsights.
Deprecated
- Removed support for the iOS i386 architecture (32-bit iOS Simulator)
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 5.1.0
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.9 MB | 12.6 MB |
| arm64 | 2.8 MB | 6.8 MB |
| armv7 | 3.0 MB | 5.6 MB |
September 19, 2019
- Programmable Voice iOS SDK 5.0.0 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
This release adds support for the new PushKit push notification policy that iOS 13 and Xcode 11 introduced. To upgrade your application please follow the migration guide.
Insights
To provide observability for incoming call cancellations the following Insights events have been added:
| Event Group | Event Name | Level | Description |
|---|---|---|---|
connection | listen | info | Reported when an attempt to listen for cancellations is made |
connection | listening | info | Reported when an attempt to listen for cancellations has succeeded |
connection | cancel | info | Reported when a cancellation has been reported |
connection | listening-error | error | Reported when an attempt to listen for a cancellation has failed |
registration | unsupported-cancel-message-error | error | Reported when a "cancel" push notification is processed by the SDK. This version of the SDK does not support "cancel" push notifications |
API Changes
- Starting with 5.0.0, when
[TwilioVoice registerWithAccessToken:deviceToken:completion:]is called, the Voice SDK will only register for "call" push notifications and cancelled call invites will be determined internally by the SDK.[TwilioVoice handleNotification:delegate:delegateQueue:]no longer processes "cancel" push notification payloads and will returnfalseif provided with a cancel notification. - A valid call push notification, when passed to
[TwilioVoice handleNotification:delegate:delegateQueue:], will still result in aTVOCallInvitebeing raised[TVONotificationDelegate callInviteReceived:]. ATVOCancelledCallInvitewill be raised asynchronously via[TVONotificationDelegate cancelledCallInviteReceived:error:]if any of the following events occur:- The call is prematurely disconnected by the caller.
- The callee does not accept or reject the call in approximately 30 seconds.
- The Voice SDK is unable to establish a connection to Twilio.
You must retain the
TVOCallInviteto be notified of a cancellation via[TVONotificationDelegate cancelledCallInviteReceived:error:]. ATVOCancelledCallInvitewill not be raised if the invite is accepted or rejected.
[TwilioVoice handleNotification:delegate:]is now[TwilioVoice handleNotification:delegate:delegateQueue:]delegateQueue: the dispatch queue where the[TVONotificationDelegate cancelledCallInviteReceived:error:]callback is received. Ifnilis passed, the dispatch main queue will be used.- When a "call" notification is received, the Voice SDK will fire the
[TVONotificationDelegate callInviteReceived:]callback synchronously. - When a "cancel" notification is received, the method will return
false.
[TVONotificationDelegate cancelledCallInviteReceived:]is now[TVONotificationDelegate cancelledCallInviteReceived:error:]- The
errorindicates that the call was canceled as a result of an error. Theerror.codewill be set toTVOErrorCallCancelledErrorif a caller cancels the call before the called party could answer the call.
- The
- The property
enableInsightshas been renamed toinsightsand moved fromTVOCallOptions.htoTwilioVoice.h. - The property
regionhas moved fromTVOCallOptions.htoTwilioVoice.h. If you are specifying a region via theTwilioVoice.hregion property you must now do so before[TwilioVoice connectWithAccessToken:delegate:]or[TwilioVoice handleNotification:delegate:delegateQueue:]is called. - Class method
[TVOCallInvite isValid:]is added toTVOCallInvitefor apps to validate whether the notification payload is a valid call notification sent by Twilio. A valid notification payload will result in aTVOCallInvitebeing returned via the[TVONotificationDelegate callInviteReceived:]callback when passed to[TwilioVoice handleNotification:delegate:delegateQueue:].
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 5.0.0
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.9 MB | 12.6 MB |
| arm64 | 2.8 MB | 6.8 MB |
| armv7 | 3.0 MB | 5.6 MB |
August 19, 2019
- Programmable Voice iOS SDK 4.3.0 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Enhancements
The Differentiated Services Code Point (DSCP) Tagging API allows you to mark the audio packets with Expedited Forwarding (EF) for the purposes of improved packet routing. When enabled, supporting networks will prioritize audio packet delivery for improved audio quality.
Use enableDscp to enable or disable DSCP tagging. Note, enableDscp is enabled by default.
For example:
1// Configure DSCP with `TVOConnectOptions`2let connectOptions = TVOConnectOptions(accessToken: accessToken) { (builder) in3builder.enableDscp = true4}56let call = TwilioVoice.connect(with: connectOptions, delegate: callDelegate)
1// Configure DSCP with `TVOAcceptOptions`2let acceptOptions = TVOAcceptOptions(accessToken: accessToken) { (builder) in3builder.enableDscp = true4}56let call = callInvite.accept(with: acceptOptions, delegate: callDelegate)
For more information, refer to the docs.
Known Issues
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 4.3.0
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.9 MB | 12.4 MB |
| arm64 | 2.8 MB | 6.7 MB |
| armv7 | 3.0 MB | 5.5 MB |
August 8, 2019
- Programmable Voice iOS SDK 4.2.1 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
This release includes changes in how the static library libTwilioVoice.a is built and packaged. libTwilioVoice.a now contains all the dependencies of the static libraries. Use -lTwilioVoice in the Other Linker Flags setting to link the SDK. BoringSSL is not packaged as a separate artifact.
Known Issues
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 4.2.1
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.9 MB | 12.4 MB |
| arm64 | 2.7 MB | 6.7 MB |
| armv7 | 3.0 MB | 5.5 MB |
August 7, 2019
- Programmable Voice iOS SDK 4.2.0 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Enhancements
Custom Parameters in Canceled Call Notification
You can now retrieve the custom parameters set in your TwiML application from TVOCancelledCallInvite. With this addition, you can for example, display a missed call notification with the caller's display name retrieved from the TVOCancelledCallInvite customParameters.
For more information, refer to the API docs
Pass custom parameters in TwiML
1<?xml version="1.0" encoding="UTF-8"?>2<Response>3<Dial callerId="client:alice">4<Client>5<Identity>bob</Identity>6<Parameter name="caller_first_name" value="alice" />7<Parameter name="caller_last_name" value="smith" />8</Client>9</Dial>10</Response>
cancelledCallInvite.customParameters:
1{2"caller_first_name" = "alice";3"caller_last_name" = "smith";4}
Known Issues
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 4.2.0
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.9 MB | 12.4 MB |
| arm64 | 2.7 MB | 6.7 MB |
| armv7 | 3.0 MB | 5.5 MB |
July 15, 2019
- Programmable Voice iOS SDK 4.1.0 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
New Features
Max Average Bandwidth API
By default, the Opus codec is set up with a transmission rate of around 32 kbps (40-50kbps on the wire). With this release, you are able to set a custom max average bitrate to better control how much bandwidth your VoIP application should use. See RFC-7587 section 7.1 for information about Max Average Bitrate.
The main purpose of this API is to set a lower max average bitrate to minimize bandwidth usage. This is particularly useful in deployments where bandwidth is at a premium. Where bandwidth is not of concern, you do not need to use this API.
Max Average Bitrate can be set to as low as 6,000bps and as high as 51,000 bps. Values outside this range are ignored and the default Opus operation mode is used. See API Docs for more information.
As would be expected, lowering the max average bitrate impacts audio quality. We don't recommend setting max average bitrate to a value below 8,000 bps. On the other hand, setting values over 32,000 bps will have negligible audio quality improvements.
For example, to set a new max average bitrate to 16,000 bps:
1let connectOptions = TVOConnectOptions(accessToken: accessToken) { (builder) in2builder.params = params3builder.preferredAudioCodecs = [TVOOpusCodec(maxAverageBitrate: 16000)]4}56let call = TwilioVoice.connect(with: connectOptions, delegate: callDelegate)
Other Enhancements
- Programmable Voice iOS SDK transmits data for VoIP calls and for Insights. With this release, we have reduced Insights related data consumption by around 25%. This was accomplished by reducing the events reporting interval.
- CLIENT-6358 The SDK now reports
ice-candidateevents to Insights. These events are raised whenOnIceCandidateis called on thePeerConnection.
Known Issues
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 4.1.0
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.9 MB | 12.4 MB |
| arm64 | 2.7 MB | 6.7 MB |
| armv7 | 3.0 MB | 5.5 MB |
June 28, 2019
- Programmable Voice iOS SDK 4.0.0 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
New Features
Reconnecting State API
This release introduces the new Reconnecting State API. This API adds a new state TVOCallStateReconnecting to TVOCallState and two new optional TVOCallDelegate methods, call:isReconnectingWithError: and callDidReconnect:.
Call reconnection capability has been available since SDK 3.0. For example, if a call is established over a Wi-Fi network and the Wi-Fi network becomes unavailable, the SDK will automatically switch the call over to the next available network.
This release adds the reconnection related callbacks. call:isReconnectingWithError: is invoked to indicate a call is being reconnected due to a network disruption or network switch over and callDidReconnect: is called once the call has been re-connected. You can use this information to provide intuitive feedback to your App user when a reconnection is taking place.
Enhancements
Passing a malformed callee to either [TwilioVoice connectWithAccessToken:] or [TwilioVoice connectWithOptions:delegate:] will now result in TVOErrorAddressIncompleteError
Migration Guide
Please refer to our migration guide for more information about migrating from 3.x.
Known Issues
- Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Impact for 4.0.0
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.8 MB | 12.4 MB |
| arm64 | 2.7 MB | 6.7 MB |
| armv7 | 2.9 MB | 5.5 MB |
June 6, 2019
- Programmable Voice iOS SDK 3.1.1 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Bug Fixes
- CLIENT-6220 Fixed an issue where an
NSInvalidArgumentExceptionexception is raised while connecting a call. #13
Known Issues
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Report
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.8 MB | 12.4 MB |
| arm64 | 2.8 MB | 6.8 MB |
| armv7 | 3.0 MB | 5.6 MB |
May 16, 2019
- Programmable Voice iOS SDK 3.1.0 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Enhancements
Improved error codes
We now surface more details about errors encountered during [TwilioVoice registerWithAccessToken:deviceToken:completion:], [TwilioVoice unregisterWithAccessToken:deviceToken:completion:], [TwilioVoice connectWithOptions:delegate:], and [TVOCallInvite acceptWithOptions:delegate:]. Previously, these functions reported these errors with the generic error TVOErrorRegistrationError or TVOErrorConnectionError.
With the new error codes, you can make more informed decisions with how to remedy the problem. For example, TVOErrorBadRequestError and TVOErrorTooManyRequestsError indicate potential programming issues, while TVOErrorTokenAuthenticationRejected indicate an issue with your Access Token.
Please note, you may need to change your code if you have added special handling for TVOErrorRegistrationError or TVOErrorConnectionError.
For more information see the API docs
The following is a summary of the new codes available for [TwilioVoice registerWithAccessToken:deviceToken:completion:], [TwilioVoice unregisterWithAccessToken:deviceToken:completion:]:
| Error Code | Value | Error Message |
|---|---|---|
| TVOErrorBadRequestError | 31400 | Bad Request |
| TVOErrorForbiddenError | 31403 | Forbidden |
| TVOErrorNotFoundError | 31404 | Not Found |
| TVOErrorRequestTimeoutError | 31408 | Request Timeout |
| TVOErrorConflictError | 31409 | Conflict |
| TVOErrorUpgradeRequiredError | 31426 | Upgrade Required. This is most likely related to a TLS version not accepted by Twilio's infrastructure |
| TVOErrorTooManyRequestsError | 31429 | Too Many Requests |
| TVOErrorInternalServerError | 31500 | Internal Server Error |
| TVOErrorBadGatewayError | 31502 | Bad Gateway |
| TVOErrorServiceUnavailableError | 31503 | Service Unavailable |
| TVOErrorGatewayTimeoutError | 31504 | Gateway Timeout |
The following is a summary of the new codes available for [TwilioVoice connectWithOptions:delegate:], and [TVOCallInvite acceptWithOptions:delegate:]:
| Error Code | Value | Error Message |
|---|---|---|
| TVOErrorTransportError | 31009 | Transport Error |
| TVOErrorBadRequestError | 31400 | Bad Request |
| TVOErrorForbiddenError | 31403 | Forbidden |
| TVOErrorNotFoundError | 31404 | Not Found |
| TVOErrorRequestTimeoutError | 31408 | Request Timeout |
| TVOErrorTemporarilyUnavailableError | 31480 | Temporarily Unavailable |
| TVOErrorCallDoesNotExistError | 31481 | Call/Transaction Does Not Exist |
| TVOErrorBusyHereError | 31486 | Busy Here |
| TVOErrorRequestTerminatedError | 31487 | Request Terminated |
| TVOErrorInternalServerError | 31500 | Internal Server |
| TVOErrorBadGatewayError | 31502 | Bad Gateway |
| TVOErrorServiceUnavailableError | 31503 | Service Unavailable |
| TVOErrorGatewayTimeoutError | 31504 | Gateway Timeout |
| TVOErrorDNSResolutionError | 31530 | DNS Resolution Error |
| TVOErrorBusyEverywhereError | 31600 | Busy Everywhere |
| TVOErrorDeclineError | 31603 | Decline |
| TVOErrorDoesNotExistAnywhereError | 31604 | Does Not Exist Anywhere |
Known Issues
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Report
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.8 MB | 12.4 MB |
| arm64 | 2.8 MB | 6.8 MB |
| armv7 | 3.0 MB | 5.6 MB |
April 25, 2019
- Programmable Voice iOS SDK 3.0.0 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
We have promoted 3.0.0-beta13 to 3.0.0. Reference our migration guide to upgrade your applications to 3.0.
Known Issues
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Report
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.8 MB | 12.3 MB |
| arm64 | 2.8 MB | 6.8 MB |
| armv7 | 3.0 MB | 5.6 MB |
April 18, 2019
- Programmable Voice iOS SDK 3.0.0-beta13 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Bug Fixes
- CLIENT-5982 Fixed a bug where call quality warnings might be sent to Insights multiple times before the warning is cleared.
Known Issues
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Report
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.8 MB | 12.3 MB |
| arm64 | 2.8 MB | 6.8 MB |
| armv7 | 3.0 MB | 5.6 MB |
April 17, 2019
- Programmable Voice iOS SDK 3.0.0-beta12 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Enhancements
- CLIENT-5973 Removed
TVOErrorConnectionTimeoutError,TVOErrorSignalingConnectionError,TVOErrorSignalingConnectionTimeoutError,TVOErrorSignalingIncomingMessageInvalidError,TVOErrorSignalingOutgoingMessageInvalidError,TVOErrorConfigurationAcquireFailedErrorandTVOErrorConfigurationAcquireTurnFailedErrorfromTVOError.h.
Bug Fixes
- CLIENT-5935 Fixed a bug where constant audio level warning events are being sent to Insights when the call is muted or onhold.
- CLIENT-5969 Renamed
kDefaultAVAudioSessionConfigurationBlocktokTVODefaultAVAudioSessionConfigurationBlockso thatTwilioVoice.frameworkandTwilioVideo.frameworkmay be used in the same application. - CLIENT-5977 Fixed a bug where the SDK was sending double values for
packets_lost_fractionto Insights instead of integer.
Known Issues
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Report
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.8 MB | 12.3 MB |
| arm64 | 2.8 MB | 6.8 MB |
| armv7 | 3.0 MB | 5.6 MB |
April 4, 2019
- Programmable Voice iOS SDK 3.0.0-beta11 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Enhancements
- CLIENT-5379 Added network reachability monitoring for the signaling socket for a reliable network change detection.
Bug Fixes
- CLIENT-5379 Fixed a bug where WiFi to WiFi network hand off was causing one-way audio followed by Call disconnect.
Known Issues
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Report
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.8 MB | 12.4 MB |
| arm64 | 2.8 MB | 6.8 MB |
| armv7 | 3.0 MB | 5.6 MB |
April 2, 2019
- Programmable Voice iOS SDK 3.0.0-beta10 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Bug Fixes
- CLIENT-5828, CLIENT-5868 A network change that occurs during a reconnection will now trigger another reconnection attempt ensuring media is restored on the correct network.
- CLIENT-5882 Call metrics insights will always be available after a network handover when the call is in
TVOCallStateConnectedstate.
Known Issues
- CLIENT-5576 LTE -> WiFi may cause one way audio.
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Report
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.8 MB | 12.4 MB |
| arm64 | 2.8 MB | 6.8 MB |
| armv7 | 3.0 MB | 5.6 MB |
March 27, 2019
- Programmable Voice iOS SDK 3.0.0-beta9 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Enhancements
- CLIENT-5806 CLIENT-5807 Updated the API documentation for
[TVOCallInvite acceptWithDelegate:]and[TVOCallInvite acceptWithOptions:delegate:]. - CLIENT-5810 Updated the API documentation for
TVOCall.
API Changes
- Attempts to connect a Call via
[TwilioVoice connectWithDelegate:]or[TVOCallInvite acceptWithDelegate:]that fail prior to reaching theTVOCallStateConnectedstate will always result in thecall:didFailToConnectWithError:callback with an error code. However, if[TVOCall disconnect]is called while an attempt to connect or accept a call is made, thecall:didDisconnectWithError:callback will be raised with no error.
Bug Fixes
- CLIENT-5813 Network loss scenarios that resulted in a Call failure now raise the
call:didFailToConnectWithError:callback. Previously these scenarios erroneously raisedcall:didDisconnectWithError:. - CLIENT-5754 A Call that fails as a result of not establishing a media connection prior to being connected now raises the
call:didFailToConnectWithError:callback. Previously this scenario erroneously raisedcall:didDisconnectWithError:. - CLIENT-5821 The
packets_lost_fractionvalue reported to Insights is correctly computed and within the expect range of 0 to 100. - CLIENT-5835 Events were erroneously reported to Insights when the
TVOConnectOptions.enableInsightsproperty was set to false.
Known Issues
- CLIENT-5576 LTE -> WiFi may cause one way audio.
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - CLIENT-5882 Call metrics insights becomes unavailable after a network handover during a call.
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Report
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.8 MB | 12.4 MB |
| arm64 | 2.8 MB | 6.8 MB |
| armv7 | 3.0 MB | 5.6 MB |
March 20, 2019
- Programmable Voice iOS SDK 3.0.0-beta8 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Bug Fixes
- CLIENT-5796 Fixed an issue where the millisecond timestamp in the Insights event payload overflows on 32-bit architecture devices.
- CLIENT-5830 Removed scripts from
TwilioVoice.frameworkthat could cause code signing issue when uploading apps to iTunes Connect.
Known Issues
- CLIENT-5576 LTE -> WiFi may cause one way audio.
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - CLIENT-5821 The
packets_lost_fractionvalue reported to Insights is incorrectly computed and within the expect range of 0 to 100. - CLIENT-5835 Events were erroneously reported to Insights when the
TVOConnectOptions.enableInsightsproperty was set to false. - CLIENT-5882 Call metrics insights becomes unavailable after a network handover during a call.
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Report
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.8 MB | 12.4 MB |
| arm64 | 2.8 MB | 6.8 MB |
| armv7 | 3.0 MB | 5.6 MB |
March 19, 2019
- Programmable Voice iOS SDK 3.0.0-beta7 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
API Changes
- The
fromproperty of theTVOCallInviteandTVOCancelledCallInviteobjects is nownullablein case the value is not available in the call invite notification.
Bug Fixes
- CLIENT-5801 Fixed an issue where an incoming call invite that did not contain a from field was not considered a valid notification.
Known Issues
- CLIENT-5830 Apps using
3.0.0-beta7may have code signing issue when uploading to iTunes Connect due to some development scripts included inTwilioVoice.framework. - CLIENT-5576 LTE -> WiFi may cause one way audio.
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - CLIENT-5821 The
packets_lost_fractionvalue reported to Insights is incorrectly computed and within the expect range of 0 to 100. - CLIENT-5835 Events were erroneously reported to Insights when the
TVOConnectOptions.enableInsightsproperty was set to false. - CLIENT-5882 Call metrics insights becomes unavailable after a network handover during a call.
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Report
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.8 MB | 12.4 MB |
| arm64 | 2.8 MB | 6.8 MB |
| armv7 | 3.0 MB | 5.6 MB |
March 14, 2019
- Programmable Voice iOS SDK 3.0.0-beta6 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Enhancements
- CLIENT-5258 Reduced SDK size by stripping video software codecs.
- CLIENT-5353 Reduced SDK size by stripping SCTP data channels.
Known Issues
- CLIENT-5830 Apps using
3.0.0-beta6may have code signing issue when uploading to iTunes Connect due to some development scripts included inTwilioVoice.framework. - CLIENT-5576 LTE -> WiFi may cause one way audio.
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - CLIENT-5821 The
packets_lost_fractionvalue reported to Insights is incorrectly computed and within the expect range of 0 to 100. - CLIENT-5835 Events were erroneously reported to Insights when the
TVOConnectOptions.enableInsightsproperty was set to false. - CLIENT-5882 Call metrics insights becomes unavailable after a network handover during a call.
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Report
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 5.8 MB | 12.4 MB |
| arm64 | 2.8 MB | 6.8 MB |
| armv7 | 3.0 MB | 5.6 MB |
March 4, 2019
- Programmable Voice iOS SDK 3.0.0-beta5 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Enhancements
- CLIENT-5678 The size impact report now includes both armv7 and arm64 architectures.
- The
libboringssl.alibrary is now separated and shipped alongside the static librarylibTwilioVoice.a. Add-lboringsslin the Other Linker Flags to link the SDK properly.
Bug Fixes
- CLIENT-5664 The static library
libTwilioVoice.ais now properly linked with dependencies.
Known Issues
- CLIENT-5830 Apps using
3.0.0-beta5may have code signing issue when uploading to iTunes Connect due to some development scripts included inTwilioVoice.framework. - CLIENT-5576 LTE -> WiFi may cause one way audio.
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - CLIENT-4805 The SDK size is significantly larger than 2.x. A reduced size will be introduced during the beta period.
- CLIENT-5821 The
packets_lost_fractionvalue reported to Insights is incorrectly computed and within the expect range of 0 to 100. - CLIENT-5835 Events were erroneously reported to Insights when the
TVOConnectOptions.enableInsightsproperty was set to false. - CLIENT-5882 Call metrics insights becomes unavailable after a network handover during a call.
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Report
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 6.4 MB | 13.4 MB |
| arm64 | 3.1 MB | 7.4 MB |
| armv7 | 3.3 MB | 6.1 MB |
February 14, 2019
- Programmable Voice iOS SDK 3.0.0-beta4 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
API Changes
TVOCallFeedbackScoreNoScoreis replaced withTVOCallFeedbackScoreNotReported.
Known Issues
- CLIENT-5576 LTE -> WiFi may cause one way audio.
- CLIENT-5578 WiFi to WiFi handover may disconnect the Call.
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - CLIENT-4805 The SDK size is significantly larger than 2.x. A reduced size will be introduced during the beta period.
- CLIENT-5821 The
packets_lost_fractionvalue reported to Insights is incorrectly computed and within the expect range of 0 to 100. - CLIENT-5835 Events were erroneously reported to Insights when the
TVOConnectOptions.enableInsightsproperty was set to false. - CLIENT-5882 Call metrics insights becomes unavailable after a network handover during a call.
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Report
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 6.4 MB | 13.4 MB |
| arm64 | 3.1 MB | 7.3 MB |
| armv7 | 3.3 MB | 6.0 MB |
February 7, 2019
- Programmable Voice iOS SDK 3.0.0-beta3 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Enhancements
- The Voice SDK publishes Call Insights. Publishing is enabled by default. The preference can be updated by configuring
TVOCallOptions.enableInsights. - CLIENT-5595 Added
TVOErrorTokenAuthenticationRejected (51007). This error is raised when attempting to perform registration or unregistration with a token that is invalid. - Added
[TVOCall postFeedback:issue:]method toTVOCallthat posts the feedback collected for this Call to Twilio. IfTVOCallFeedbackScoreNoScoreandTVOCallFeedbackIssueNotReportedare passed, Twilio will report feedback was not available for this call. - CLIENT-2985 The SDK can connect to Twilio's Servers in an IPv6 environment.
- CLIENT-4998 Call will continue after network handoff.
Bug Fixes
- CLIENT-5573 Fixed a crash that occurred when a client issued a disconnect while already processing a termination request from the server.
Known Issues
- CLIENT-5576 LTE -> WiFi may cause one way audio.
- CLIENT-5578 WiFi to WiFi handover may disconnect the Call.
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - CLIENT-4805 The SDK size is significantly larger than 2.x. A reduced size will be introduced during the beta period.
- CLIENT-5821 The
packets_lost_fractionvalue reported to Insights is incorrectly computed and within the expect range of 0 to 100. - CLIENT-5835 Events were erroneously reported to Insights when the
TVOConnectOptions.enableInsightsproperty was set to false. - CLIENT-5882 Call metrics insights becomes unavailable after a network handover during a call.
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Report
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 3.1 MB | 7.3 MB |
| arm64 | 3.1 MB | 7.3 MB |
December 13, 2018
- Programmable Voice iOS SDK 3.0.0-beta2 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Enhancements
- Added a
preferredAudioCodecsproperty toTVOCallOptions. Support forOpusis added to the Voice SDK but yet to be enabled on Twilio infrastructure. It will be notified to the users of the Voice SDK whenOpuscodec is enabled on Twilio infrastructure. - Added new error code
31008. This error is raised when aTVOCallInviteis accepted after the Call has ended.
Bug Fixes
- CLIENT-5398 Unmuting a Call on hold causes audio to flow.
Known Issues
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - CLIENT-4805 The SDK size is significantly larger than 2.x. A reduced size will be introduced during the beta period.
- CLIENT-4998 Network handoff, and subsequent connection renegotiation is not supported.
- CLIENT-2985 IPv6 is not supported.
- CLIENT-4547 Insights is not published.
- CLIENT-4537 PCMU is the only supported codec. We plan on adding support for Opus moving forward. #117
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
Size Report
| Architecture | App Download Size | App Storage Size |
|---|---|---|
| Universal | 3.1 MB | 7.2 MB |
| arm64 | 3.1 MB | 7.2 MB |
November 26, 2018
- Programmable Voice iOS SDK 3.0.0-beta1 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Enhancements
- Added media and signaling related error codes.
Known Issues
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - CLIENT-5258 The SDK size is significantly larger than 2.x. A reduced size will be introduced during the beta period.
- CLIENT-4998 Network handoff, and subsequent connection renegotiation is not supported.
- CLIENT-2985 IPv6 is not supported.
- CLIENT-4547 Insights is not published.
- CLIENT-4537 PCMU is the only supported codec. We plan on adding support for Opus moving forward. #117
- CLIENT-5398 Unmuting a call on hold causes audio to flow.
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
October 24, 2018
- Programmable Voice iOS SDK 3.0.0-preview5 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Bug Fixes
- CLIENT-5186 Fixed a crash when network is lost during an active Call.
- CLIENT-5132 The
call:didDisconnectWithError:delegate method of the caller should be called withnilerror instead ofcall:didFailToConnectWithError:when theTVOCallInviteis rejected withanswerOnBridgeenabled. - CLIENT-4837 Fixed a crash caused by SIGPIPE when a signaling socket is closed due to an error.
Known Issues
- CLIENT-5059 Calls made to a client or PSTN number that have a long duration before answering may not get connected.
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - CLIENT-5258 The SDK size is significantly larger than 2.x. A reduced size will be introduced during the beta period.
- CLIENT-4998 Network handoff, and subsequent connection renegotiation is not supported.
- CLIENT-2985 IPv6 is not supported.
- CLIENT-4547 Insights is not published.
- CLIENT-4672 CLIENT-4673 Error codes 20157 and 20151 report different message and explanation text than Voice 2.0 SDKs.
- CLIENT-4537 PCMU is the only supported codec. We plan on adding support for Opus moving forward. #117
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
October 2, 2018
- Programmable Voice iOS SDK 3.0.0-preview4 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Enhancements
- Added
customParametersproperty toTVOCallInvite.
Pass custom parameters in TwiML
1<?xml version="1.0" encoding="UTF-8"?>2<Response>3<Dial callerId="client:alice">4<Client>5<Identity>bob</Identity>6<Parameter name="caller_first_name" value="alice" />7<Parameter name="caller_last_name" value="smith" />8</Client>9</Dial>10</Response>
callInvite.customParameters:
1{2"caller_first_name" = "alice";3"caller_last_name" = "smith";4}
Bug Fixes
- CLIENT-5202 Fixed a potential crash caused by a memory corruption when a custom
TVOAudioDeviceis created. - CLIENT-5160 The Voice SDK is built using the audio variant of WebRTC 67. Developers are no longer are required to add
NSCameraUsageDescriptionkey in app's Info.plist to consume the Voice SDK in an app and upload it to the App Store. #164 - CLIENT-5204 Call audio was not able to recover from
AVAudioSessioninterruptions.TVOAVAudioSessionConfigurationBlocknow configuresAVAudioSession.preferredIOBufferDurationto 20 milliseconds by default, to match changes in WebRTC.
Known Issues
- CLIENT-5059 Calls made to a PSTN number may not get connected when
answerOnBridgeis set to true. - CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio's Network Traversal Service. - CLIENT-5258 The SDK size is significantly larger than 2.x. A reduced size will be introduced during the beta period.
- CLIENT-4998 Network handoff, and subsequent connection renegotiation is not supported.
- CLIENT-2985 IPv6 is not supported.
- CLIENT-4547 Insights is not published.
- CLIENT-4672 CLIENT-4673 Error codes 20157 and 20151 report different message and explanation text than Voice 2.0 SDKs.
- CLIENT-4537 PCMU is the only supported codec. We plan on adding support for Opus moving forward. #117
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
September 12, 2018
- Programmable Voice iOS SDK 3.0.0-preview3 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs].
Bug Fixes
- CLIENT-5101 The
inject_credentials.shwhich was accidentally included in theTwilioVoice.frameworkbundle has been removed.
Enhancements
- This release is based on Chromium WebRTC 67.
- Provide a stateless mechanism for processing push notifications related to call invites and call invite cancellations. The
[TwilioVoice handleNotification:]no longer raises errors via thenotificationError:method when processing invalid notifications, instead aBOOLvalue is returned when it is called. The Boolean value isYESwhen the provided notification payload results in aTVOCallInviteorTVOCancelledCallInviteobject. If[TwilioVoice handleNotification:]returnsNOit means the data provided was not a Twilio Voice push notification. TheTVOCallInvitehas anaccept()and areject()method. While theTVOCancelledCallInviteprovides theto,from, andcallSidfields also available in theTVOCallInviteobject. ThecallSidcan be used to associate aTVOCallInvitewith aTVOCancelledCallInvite. notificationError:is removed from theTVONotificationDelegateprotocol.cancelledCallInviteReceived:is added for the SDK to notify the application when a Call cancellation notification is received.
Processing push notifications in 2.X
1- (void)pushRegistry:(PKPushRegistry *)registry2didReceiveIncomingPushWithPayload:(PKPushPayload *)payload3forType:(NSString *)type {4[TwilioVoice handleNotification:payload.dictionaryPayload delegate:self];5}67# pragma mark - TVONotificationDelegate89- (void)callInviteReceived:(TVOCallInvite *)callInvite {10if (callInvite.state == TVOCallInviteStatePending) {11[self handleCallInviteReceived:callInvite];12} else if (callInvite.state == TVOCallInviteStateCanceled) {13[self handleCallInviteCanceled:callInvite];14}15}1617- (void)notificationError:(NSError *)error {18NSLog(@"Failed processing notification payload: %@", error);19}2021- (void)handleCallInviteReceived:(TVOCallInvite *)callInvite {22// Call invite received23}2425- (void)handleCallInviteCanceled:(TVOCallInvite *)callInvite {26// Call invite canceled27}
Processing push notifications in 3.X
1- (void)pushRegistry:(PKPushRegistry *)registry2didReceiveIncomingPushWithPayload:(PKPushPayload *)payload3forType:(NSString *)type {4BOOL result = [TwilioVoice handleNotification:payload.dictionaryPayload delegate:self];5if (!result) {6NSLog(@"The processed data was not a Twilio push notification payload");7}8}910# pragma mark - TVONotificationDelegate1112- (void)callInviteReceived:(TVOCallInvite *)callInvite {13// Call invite received14}1516- (void)cancelledCallInviteReceived:(TVOCancelledCallInvite *)cancelledCallInvite {17// Call invite cancelled18}
API Changes
- Deprecated the
TVOAudioOptions.levelControlandTVOAudioOptions.levelControlInitialPeakLevelDBFSproperties as they are no longer supported in Chromium WebRTC 67.
Known Issues
- CLIENT-5121 The apps using
3.0.0-preview3may need to includeNSCameraUsageDescriptionkey and purpose string in it'sInfo.plistin order to submit the app to the App Store. The WebRTC used by the Twilio Voice SDK is using camera APIs. We are working on building the Voice SDK with the audio only variant of WebRTC where this workaround will not be required. #163 - CLIENT-5059 Calls made to a client or PSTN number that have a long duration before answering may not get connected.
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio Network Traversal Service. - CLIENT-4805 The SDK size is significantly larger than 2.x. A reduced size will be introduced during the beta period.
- CLIENT-4998 Network handoff, and subsequent connection renegotiation is not supported.
- CLIENT-2985 IPv6 is not supported.
- CLIENT-4698 Params that are passed to your TwiML Application while making calls are not URL encoded
- CLIENT-4547 Insights is not published
- CLIENT-4672 CLIENT-4673 Error codes 20157 and 20151 report different message and explanation text than Voice 2.0 SDKs
- CLIENT-4537 PCMU is the only supported codec. We plan on adding support for Opus moving forward. #117
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
August 28, 2018
- Programmable Voice iOS SDK 3.0.0-preview2 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs]
Enhancements
- Introduced a new callback method
[TVOCallDelegate callDidStartRinging:]. This callback is emitted once before the[TVOCallDelegate callDidConnect:]callback when the callee is being alerted of a Call. The duration of theTVOCallStateRingingis determined by theanswerOnBridgeflag provided in theDialverb of your TwiML application associated with this client. If theanswerOnBridgeflag isfalse, which is the default, the[TVOCallDelegate callDidConnect:]callback will be emitted immediately after[TVOCallDelegate callDidStartRinging:]. If theanswerOnBridgeflag istruethis will cause the Call to emit thecallDidConnectcallback only until the call is answered. See answeronbridge for more details on how to use it with theDialTwiML verb. If the TwiML response contains aSayverb, then the call will emit the[TVOCallDelegate callDidConnect:]callback immediately after[TVOCallDelegate callDidStartRinging:]is raised, irrespective of the value ofanswerOnBridgebeing set totrueorfalse. - Added a new Call state
TVOCallStateRinging. TwilioVoice.regionis moved toTVOCallOptions.region.- Added a
getStatsWithBlock:method toTVOCallthat builds aTVOStatsReportwith metrics for all the audio tracks in a Call.
Known Issues
- CLIENT-5121 The apps using
3.0.0-preview2may need to includeNSCameraUsageDescriptionkey and purpose string in it'sInfo.plistin order to submit the app to the App Store. The WebRTC used by the Twilio Voice SDK is using camera APIs. We are working on building the Voice SDK with the audio only variant of WebRTC where this workaround will not be required. #163 - CLIENT-5059 Calls made to a client or PSTN number that have a long duration before answering may not get connected.
- CLIENT-4943 Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio Network Traversal Service. - CLIENT-4805 The SDK size is significantly larger than 2.x. A reduced size will be introduced during the beta period.
- CLIENT-4998 Network handoff, and subsequent connection renegotiation is not supported.
- CLIENT-2985 IPv6 is not supported.
- CLIENT-4698 Params that are passed to your TwiML Application while making calls are not URL encoded
- CLIENT-4547 Insights is not published
- CLIENT-4672 CLIENT-4673 Error codes 20157 and 20151 report different message and explanation text than Voice 2.0 SDKs
- CLIENT-4537 PCMU is the only supported codec. We plan on adding support for Opus moving forward. #117
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
August 10, 2018
- Programmable Voice iOS SDK 3.0.0-preview1 [Carthage], [Cocoapods], [Dynamic Framework], [Static Library], [docs]
This is our first WebRTC based release using Chromium WebRTC 57.
This SDK introduces audio device APIs. The Voice SDK uses TVODefaultAudioDevice by default. This release introduces a new protocol, TVOAudioDevice. This protocol gives you the ability to replace TVODefaultAudioDevice. By implementing the TVOAudioDevice protocol, you can write your own audio capturer to feed audio samples to the Voice SDK and an audio renderer to receive the remote audio samples. For example, you could integrate with ReplayKit2 and capture application audio for broadcast or play music using AVAssetReader.
This SDK introduces TVOConnectOptions and TVOAcceptOptions to allow developers to make behavioral changes associated with a Call.
This SDK allows multiple active Calls to be managed by the application.
Enhancements
- Introduced
TwilioVoice.audioDeviceclass property. You should set your audio device onTwilioVoice.audioDevicebefore performing any other actions with the SDK such as creating Tracks or connecting to a Call. - Added
TVODefaultAudioDeviceto render and capture audio. By default, the Voice SDK usesTVODefaultAudioDeviceto capture and render audio. - Added the ability to provide your own audio capturing and rendering via the
TVOAudioDeviceprotocol. As a part of this change we've also addedTVOAudioFormatwhich describes audio that is being captured and rendered. - This release deprecates
CallKitIntegrationcategory fromTwilioVoicein favor of a new property calledTVODefaultAudioDevice.enabled. This property provides developers with a mechanism to enable or disable the activation of the audio device prior to connecting to a Call or to stop or start the audio device while you are already connected to a Call. A Call can now be connected without activating the audio device by settingTVODefaultAudioDevice.enabledtoNOand can be enabled during the lifecycle of the Call by settingTVODefaultAudioDevice.enabledtoYES. The default value isYES. This API change was made to ensure full compatibility with CallKit as well as supporting other use cases where developers may need to disable the audio device during a call.
Examples #1 - Changing the audio route from receiver to the speaker in a live call:
12// The Voice SDK uses TVODefaultAudioDevice by default.34// ... connect to a Call. The `TVODefaultAudioDevice` is configured to route audio to the receiver by default.56TVODefaultAudioDevice *audioDevice = (TVODefaultAudioDevice *)TwilioVoice.audioDevice;78audioDevice.block = ^ {9// We will execute `kDefaultAVAudioSessionConfigurationBlock` first.10kDefaultAVAudioSessionConfigurationBlock();1112if (![session overrideOutputAudioPort:AVAudioSessionPortOverrideSpeaker error:&error]) {13NSLog(@"AVAudiosession overrideOutputAudioPort %@",error);14}15};16audioDevice.block();
Example #2 - Connecting to a Call using the AVAudioSessionCategoryPlayback category:
1id<TVOAudioDevice> audioDevice = [TVODefaultAudioDevice audioDeviceWithBlock:^ {23// Execute the `kDefaultAVAudioSessionConfigurationBlock` first.4kDefaultAVAudioSessionConfigurationBlock();56// Overwrite the category to `playback`7AVAudioSession *session = [AVAudioSession sharedInstance];8NSError *error = nil;9if (![session setCategory:AVAudioSessionCategoryPlayback10mode:AVAudioSessionModeVoiceChat11options:AVAudioSessionCategoryOptionAllowBluetooth12error:&error]) {13NSLog(@"AVAudioSession setCategory:options:mode:error: %@",error);14}15}];1617TwilioVoice.audioDevice = audioDevice;1819TVOCall *call = [TwilioVoice connectWithOptions:connectOptions delegate:self];
- Migrated the API to make an outbound Call from
[TwilioVoice call]to[TwilioVoice connectWithOptions:delegate:].
1TVOConnectOptions *connectOptions = [TVOConnectOptions optionsWithAccessToken:self.accessToken2block:^(TVOConnectOptionsBuilder *builder) {3builder.params = twiMLParams;4builder.uuid = [NSUUID UUID];5}];6TVOCall *call = [TwilioVoice connectWithOptions:connectOptions delegate:self];
- Migrated the API to accept a
TVOCallInviteusingTVOAcceptOptions.
1TVOAcceptOptions *options = [TVOAcceptOptions optionsWithCallInvite:self2block:^(TVOAcceptOptionsBuilder *builder) {3builder.uuid = weakSelf.callInvite.uuid;4}];5TVOCall *call = [callInvite acceptWithOptions:options delegate:strongSelf];
- Added standalone log modules:
TVOLogModuleCore,TVOLogModulePlatform,TVOLogModuleSignalingandTVOLogModuleWebRTC. [TwilioVoice setModule:logLevel:]is now[TwilioVoice setLogLevel:module:].[TwilioVoice logLevelForModule:]is added for retrieving log level for specific module.[TwilioVoice version]is now[TwilioVoice getVersion]to avoid type conflict withNSObject.- Voice iOS SDK 3.0.0 supports iOS 10.0 and later versions.
Known Issues
- CLIENT-5121 The apps using
3.0.0-preview1may need to includeNSCameraUsageDescriptionkey and purpose string in it'sInfo.plistin order to submit the app to the App Store. The WebRTC used by the Twilio Voice SDK is using camera APIs. We are working on building the Voice SDK with the audio only variant of WebRTC where this workaround will not be required. #163 - CLIENT-5059 Calls made to a client or PSTN number that have a long duration before answering may not get connected.
- [CLIENT-4943] Restrictive networks may fail unless ICE servers are provided via
TVOConnectOptionsorTVOAcceptOptions. ICE servers can be obtained from Twilio Network Traversal Service. - [CLIENT-4805] The SDK size is significantly larger than 2.x. A reduced size will be introduced during the beta period.
- [CLIENT-4998] Network handoff, and subsequent connection renegotiation is not supported.
- [CLIENT-2985] IPv6 is not supported.
- [CLIENT-4698] Params that are passed to your TwiML Application while making calls are not URL encoded
- [CLIENT-4547] Insights is not published
- [CLIENT-4672] [CLIENT-4673] Error codes 20157 and 20151 report different message and explanation text than Voice 2.0 SDKs
- Using the Voice iOS SDK side by side with the WebRTC library will result in
RTCNativeAudioSessionDelegateAdaptersymbol conflict during compile time.
For older changelog entries including 2.x, click here