Want to add VoIP calling to your iOS application?
Start by downloading the Voice Quickstart for Swift application source code. Prefer working with Objective-C? Follow the quickstart on the Voice Quickstart for Objective-C source code instead.
Next, follow the step-by-step instructions below (for Swift) to get you up and running quickly using Twilio's Programmable Voice SDK.
Please see our iOS 13 Migration Guide for the latest information on iOS 13.
To get started with the quickstart application follow these steps. Steps 1-5 will enable the application to make a call. The remaining steps 6-9 will enable the application to receive incoming calls in the form of push notifications using Apple's VoIP Service.
Swift Package Manager
Twilio Voice is now distributed via Swift Package Manager. To consume Twilio Voice using Swift Package Manager, add the https://github.com/twilio/twilio-voice-ios
repository as a Swift Pacakge
.
You must have the following installed:
Run npm install
to install all dependencies from NPM.
Install twilio-cli with:
npm install -g twilio-cli
Login to the Twilio CLI. You will be prompted for your Account SID and Auth Token, both of which you can find on the dashboard of your Twilio console.
twilio login
Once successfully logged in, an API Key, a secret get created and stored in your keychain as the twilio-cli
password in SKxxxx\|secret
format. Please make a note of these values to use them in the Server/.env
file.
This app requires the Serverless plug-in. Install the CLI plugin with:
twilio plugins:install @twilio-labs/plugin-serverless
Before deploying, create a Server/.env
by copying from Server/.env.example
cp Server/.env.example Server/.env
Update Server/.env
with your Account SID, auth token, API Key and secret
1ACCOUNT_SID=ACxxxx2AUTH_TOKEN=xxxxxx3API_KEY_SID=SKxxxx4API_SECRET=xxxxxx5APP_SID=APxxxx (available in step 3)6PUSH_CREDENTIAL_SID=CRxxxx (available in step 6)
The Server
folder contains a basic server component which can be used to vend access tokens or generate TwiML response for making call to a number or another client. The app is deployed to Twilio Serverless with the serverless
plug-in:
1cd Server2twilio serverless:deploy
The server component that's baked into this quickstart is in Node.js. If you'd like to roll your own or better understand the Twilio Voice server side implementations, please see the list of starter projects in the following supported languages below:
Follow the instructions in the project's README to get the application server up and running locally and accessible via the public Internet.
Next, we need to create a TwiML application. A TwiML application identifies a public URL for retrieving TwiML call control instructions. When your iOS app makes a call to the Twilio cloud, Twilio will make a webhook request to this URL, your application server will respond with generated TwiML, and Twilio will execute the instructions you've provided.
Use Twilio CLI to create a TwiML app with the make-call
endpoint you have just deployed (Note: replace the value of --voice-url
parameter with your make-call
endpoint you just deployed to Twilio Serverless)
1$ twilio api:core:applications:create \2--friendly-name=my-twiml-app \3--voice-method=POST \4--voice-url="https://my-quickstart-dev.twil.io/make-call"
You should receive an Application SID that looks like this
APxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Install the token
plug-in
twilio plugins:install @twilio-labs/plugin-token
Use the TwiML App SID you just created to generate an access token
twilio token:voice --identity=alice --voice-app-sid=APxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Copy the access token string. Your iOS app will use this token to connect to Twilio.
Now let's go back to the VoiceQuickstart.xcworkspace
. Update the placeholder of accessToken
with access token string you just copied
1import UIKit2import AVFoundation3import PushKit4import CallKit5import TwilioVoice67let accessToken = "PASTE_YOUR_ACCESS_TOKEN_HERE"8let twimlParamTo = "to"910let kCachedDeviceToken = "CachedDeviceToken"1112class ViewController: UIViewController {13...14}
Build and run the app. Leave the text field empty and press the call button to start a call. You will hear the congratulatory message. Support for dialing another client or number is described in steps 8 and 9. Tap "Hang Up" to disconnect.
``
The Programmable Voice SDK uses Apple's VoIP Services to let your application know when it is receiving an incoming call. If you want your users to receive incoming calls, you'll need to enable VoIP Services in your application and generate a VoIP Services Certificate.
Go to Apple Developer portal and generate a VoIP Service Certificate.
Once you have generated the VoIP Services Certificate, you will need to provide the certificate and key to Twilio so that Twilio can send push notifications to your app on your behalf.
Export your VoIP Service Certificate as a .p12
file from Keychain Access and extract the certificate and private key from the .p12
file using the openssl
command.
1openssl pkcs12 -in PATH_TO_YOUR_P12 -nokeys -out cert.pem -nodes2openssl x509 -in cert.pem -out cert.pem3openssl pkcs12 -in PATH_TO_YOUR_P12 -nocerts -out key.pem -nodes4openssl rsa -in key.pem -out key.pem
Use Twilio CLI to create a Push Credential using the cert and key.
1$ twilio api:chat:v2:credentials:create \2--type=apn \3--sandbox \4--friendly-name="voice-push-credential (sandbox)" \5--certificate="$(cat PATH_TO_CERT_PEM)" \6--private-key="$(cat PATH_TO_KEY_PEM)"
This will return a Push Credential SID that looks like this
CRxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
The --sandbox
option tells Twilio to send the notification requests to the sandbox endpoint of Apple's APNS service. Once the app is ready for distribution or store submission, create a separate Push Credential with a new VoIP Service certificate without the --sandbox
option.
Note: we strongly recommend using different Twilio accounts (or subaccounts) to separate VoIP push notification requests for development and production apps.
Now let's generate another access token and add the Push Credential to the Voice Grant.
1$ twilio token:voice \2--identity=alice \3--voice-app-sid=APxxxx \4--push-credential-sid=CRxxxxs
You are now ready to receive incoming calls. Update your app with the access token generated from step 6 and rebuild your app. The TwilioVoiceSDK.register()
method will register your mobile client with the PushKit device token as well as the access token. Once registered, hit your application server's /place-call endpoint: https://my-quickstart-dev.twil.io/place-call?to=alice
. This will trigger a Twilio REST API request that will make an inbound call to the identity registered on your mobile app. Once your app accepts the call, you should hear a congratulatory message.
Register your mobile client with the PushKit device token:
1TwilioVoiceSDK.register(accessToken: accessToken, deviceToken: cachedDeviceToken) { error in2if let error = error {3NSLog("An error occurred while registering: \(error.localizedDescription)")4} else {5NSLog("Successfully registered for VoIP push notifications.")6}7}
Please note that your application must have voip
enabled in the UIBackgroundModes
of your app's plist in order to be able to receive push notifications.
``
To make client to client calls, you need the application running on two devices. To run the application on an additional device, make sure you use a different identity in your access token when registering the new device.
Use the text field to specify the identity of the call receiver, then tap the "Call" button to make a call. The TwiML parameters used in TwilioVoice.connect()
method should match the name used in the server.
``
To make client to number calls, first get a verified Twilio number to your account via https://www.twilio.com/console/phone-numbers/verified. Update your server code and replace the callerNumber
variable with the verified number. Restart the server so it uses the new value.
``
You will also find additional examples that provide more advanced use cases of the Voice SDK:
TVOAudioDevice
and CoreAudio.INStartAudioCallIntent
in the user activity delegate method to start a call from the history.You can find the API documentation of the Voice SDK:
To learn more about how to use TwiML and the Programmable Voice Calls API, check out our TwiML quickstarts:
Please file any issues you find here on Github: Voice Swift Quickstart. Please ensure that you are not sharing any Personally Identifiable Information(PII) or sensitive account information (API keys, credentials, etc.) when reporting an issue.
For general inquiries related to the Voice SDK you can file a support ticket.
MIT