Metadata-Version: 2.1
Name: twilio
Version: 6.16.1
Summary: Twilio API client and TwiML generator
Home-page: https://github.com/twilio/twilio-python/
Author: Twilio
Author-email: help@twilio.com
License: UNKNOWN
Keywords: twilio,twiml
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3.4
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Topic :: Communications :: Telephony
Requires-Dist: six
Requires-Dist: pytz
Requires-Dist: PyJWT (>=1.4.2)
Requires-Dist: requests[security] (>=2.0.0); python_version<"3.0"
Requires-Dist: requests (>=2.0.0); python_version>="3.0"
Requires-Dist: pysocks; python_version>="3.0"

twilio-python
=============

.. image:: https://secure.travis-ci.org/twilio/twilio-python.png?branch=master
   :target: http://travis-ci.org/twilio/twilio-python
.. image:: https://img.shields.io/pypi/v/twilio.svg
   :target: https://pypi.python.org/pypi/twilio
.. image:: https://img.shields.io/pypi/pyversions/twilio.svg
   :target: https://pypi.python.org/pypi/twilio

A module for using the Twilio REST API and generating valid
`TwiML <http://www.twilio.com/docs/api/twiml/>`__.

Recent Update
-------------

As of release 6.5.0, Beta and Developer Preview products are now exposed
via the main ``twilio-python`` artifact. Releases of the ``alpha``
branch have been discontinued.

If you were using the ``alpha`` release line, you should be able to
switch back to the normal release line without issue.

If you were using the normal release line, you should now see several
new product lines that were historically hidden from you due to their
Beta or Developer Preview status. Such products are explicitly
documented as Beta/Developer Preview both in the Twilio docs and
console, as well as through in-line code documentation here in the
library.

Installation
------------

Install from PyPi using
`pip <http://www.pip-installer.org/en/latest/>`__, a package manager for
Python.

::

   pip install twilio

Don't have pip installed? Try installing it, by running this from the
command line:

::

   $ curl https://raw.github.com/pypa/pip/master/contrib/get-pip.py | python

Or, you can `download the source code
(ZIP) <https://github.com/twilio/twilio-python/zipball/master>`__ for
``twilio-python``, and then run:

::

   python setup.py install

You may need to run the above commands with ``sudo``.

Migrate from 5.x
~~~~~~~~~~~~~~~~

Please consult the `official migration
guide <https://www.twilio.com/docs/libraries/python/migration-guide>`__
for information on upgrading your application using twilio-python 5.x to
6.x

Feedback
--------

Report any feedback or problems with this Release Candidate to the
`Github Issues <https://github.com/twilio/twilio-python/issues>`__ for
twilio-python.

Getting Started
---------------

Getting started with the Twilio API couldn't be easier. Create a
``Client`` and you're ready to go.

API Credentials
~~~~~~~~~~~~~~~

The ``Twilio`` needs your Twilio credentials. You can either pass these
directly to the constructor (see the code below) or via environment
variables.

.. code:: python

   from twilio.rest import Client

   account = "ACXXXXXXXXXXXXXXXXX"
   token = "YYYYYYYYYYYYYYYYYY"
   client = Client(account, token)

Alternately, a ``Client`` constructor without these parameters will look
for ``TWILIO_ACCOUNT_SID`` and ``TWILIO_AUTH_TOKEN`` variables inside
the current environment.

We suggest storing your credentials as environment variables. Why?
You'll never have to worry about committing your credentials and
accidentally posting them somewhere public.

.. code:: python

   from twilio.rest import Client
   client = Client()

Make a Call
~~~~~~~~~~~

.. code:: python

   from twilio.rest import Client

   account = "ACXXXXXXXXXXXXXXXXX"
   token = "YYYYYYYYYYYYYYYYYY"
   client = Client(account, token)

   call = client.calls.create(to="9991231234",
                              from_="9991231234",
                              url="http://twimlets.com/holdmusic?Bucket=com.twilio.music.ambient")
   print(call.sid)

Send an SMS
~~~~~~~~~~~

.. code:: python

   from twilio.rest import Client

   account = "ACXXXXXXXXXXXXXXXXX"
   token = "YYYYYYYYYYYYYYYYYY"
   client = Client(account, token)

   message = client.messages.create(to="+12316851234", from_="+15555555555",
                                    body="Hello there!")

Handling a call using TwiML
~~~~~~~~~~~~~~~~~~~~~~~~~~~

To control phone calls, your application needs to output
`TwiML <http://www.twilio.com/docs/api/twiml/>`__. Use
``twilio.twiml.Response`` to easily create such responses.

.. code:: python

   from twilio.twiml.voice_response import VoiceResponse

   r = VoiceResponse()
   r.say("Welcome to twilio!")
   print(str(r))

.. code:: xml

   <?xml version="1.0" encoding="utf-8"?>
   <Response><Say>Welcome to twilio!</Say></Response>

Docker Image
~~~~~~~~~~~~

The `Dockerfile` present in this repository and its respective `twilio/twilio-python` Docker image are currently used by Twilio for testing purposes only.


