The Twilio Client SDKs for Android & iOS have been deprecated and replaced by Twilio's new Programmable Voice SDK. The Programmable Voice SDK offers many improvements over the Twilio Client SDK, including greater stability, improved backgrounding, and built-in support for push notifications for incoming calls.
Get started with the new Programmable Voice SDK by checking out one of the links below:
- Programmable Voice SDK for Android Quickstart
- Programmable Voice SDK for iOS: Objective-C Quickstart
- Programmable Voice SDK for iOS: Swift Quickstart
If you're just getting started with a Twilio mobile application for voice calling, we recommend you use the Programmable Voice SDK. If you're already using the Twilio Client SDK, you should plan to upgrade to the Programmable Voice SDK as soon as you're able.
This repository includes server-side web application required for Twilio mobile sample apps such as Quickstart and BasicPhone. The Python script is responsible for generating capability tokens and serving TwiML.
Please sign up for a free Twilio account. You will need your Account Sid and Auth Token available in your Account Dashboard. You will also need to create a TwiML App. Please make sure that you point the TwiML app's Voice Request URL to your web application's public URL, e.g., http://companyfoo.com/call. You will also need a verified phone number to be used as caller ID when placing phone calls. See the "Verified Caller Ids" section under Numbers tab in your Twilio Account.
Click the button below to automatically set up the app using your Heroku account. Please enter your Twilio Account Sid, Auth token, TwiML App Sid and verified phone number when prompted.
If you prefer to run your application locally, please make sure that you have Python and
pip installed. Please install the required packages:
pip install -r requirements.txt
server.py with values from your Twilio account. Simply run the application by
python server.py. You can tunnel
localhost to the public Internet using
ngrok http 5000
Please open http://companyfoo.com/token in your browser. You should see a long string.
Please modify BasicPhone and Quickstart to point to your web applications's public URL.
At launch, the client connects to http://companyfoo.com/token to retrieve its capability token.
When you hit the "Call" button in the mobile app, it makes a call to your Twilio application that then makes a request to your web server (http://companyfoo.com/call). The script routes the call accordingly, either to a phone number or to another client.
If you want to receive a phone call in your mobile app you need to have a Twilio phone number (https://www.twilio.com/user/account/phone-numbers/incoming). Please configure the phone number's Voice Request URL to point to your web application's public URL (http://companyfoo.com/call). When someone calls your Twilio phone number, Twilio makes a request to your web application. Your web application returns TwiML that instructs Twilio to connect the phone call with client
jenny. Either a purchased number or your sandbox number can be used.