.. _api-rest:

###############################
Twilio Rest Resources
###############################

**************
List Resources
**************

.. phpautoclass:: Services_Twilio_ListResource
    :filename: ../Services/Twilio/ListResource.php
    :members:

All of the below classes inherit from the :php:class:`ListResource
<Services_Twilio_ListResource>`.

Accounts
===========

.. phpautoclass:: Services_Twilio_Rest_Accounts
    :filename: ../Services/Twilio/Rest/Accounts.php
    :members:

AvailablePhoneNumbers
========================

.. php:class:: Services_Twilio_Rest_AvailablePhoneNumbers

   For more information, see the `AvailablePhoneNumbers API Resource <http://www.twilio.com/docs/api/rest/available-phone-numbers#local>`_ documentation at twilio.com.

   .. php:method:: getList($country, $type)

    Get a list of available phone numbers.

    :param string country: The 2-digit country code for numbers ('US', 'GB',
        'CA')
    :param string type: The type of phone number ('TollFree' or 'Local')
    :return: An instance of the :php:class:`Services_Twilio_Rest_AvailablePhoneNumbers` resource.

    .. php:attr:: available_phone_numbers

       A list of :php:class:`Services_Twilio_Rest_AvailablePhoneNumber` instances.

    .. php:attr:: uri

       The uri representing this resource, relative to https://api.twilio.com.


Calls
=======

.. php:class:: Services_Twilio_Rest_Calls

   For more information, see the `Call List Resource <http://www.twilio.com/docs/api/rest/call#list>`_ documentation.

   .. php:method:: create($from, $to, $url, params = array())

      Make an outgoing call

      :param string $from: The phone number to use as the caller id.
      :param string $to: The number to call formatted with a '+' and country code
      :param string $url: The fully qualified URL that should be consulted when
                          the call connects. This value can also be an ApplicationSid.
      :param array $params: An array of optional parameters for this call

      The **$params** array can contain the following keys:

      *Method*
        The HTTP method Twilio should use when making its request to the above Url parameter's value. Defaults to POST. If an ApplicationSid parameter is present, this parameter is ignored.

      *FallbackUrl*
        A URL that Twilio will request if an error occurs requesting or executing the TwiML at Url. If an ApplicationSid parameter is present, this parameter is ignored.

      *FallbackMethod*
        The HTTP method that Twilio should use to request the FallbackUrl. Must be either GET or POST. Defaults to POST. If an ApplicationSid parameter is present, this parameter is ignored.

      *StatusCallback*
        A URL that Twilio will request when the call ends to notify your app. If an ApplicationSid parameter is present, this parameter is ignored.

      *StatusCallbackMethod*
        The HTTP method Twilio should use when requesting the above URL. Defaults to POST. If an ApplicationSid parameter is present, this parameter is ignored.

      *SendDigits*
        A string of keys to dial after connecting to the number. Valid digits in the string include: any digit (0-9), '#' and '*'. For example, if you connected to a company phone number, and wanted to dial extension 1234 and then the pound key, use SendDigits=1234#. Remember to URL-encode this string, since the '#' character has special meaning in a URL.

      *IfMachine*
        Tell Twilio to try and determine if a machine (like voicemail) or a human has answered the call. Possible values are Continue and Hangup. See the answering machines section below for more info.

      *Timeout*
        The integer number of seconds that Twilio should allow the phone to ring before assuming there is no answer. Default is 60 seconds, the maximum is 999 seconds. Note, you could set this to a low value, such as 15, to hangup before reaching an answering machine or voicemail.

CredentialListMappings
=========================

.. phpautoclass:: Services_Twilio_Rest_CredentialListMappings
    :filename: ../Services/Twilio/Rest/CredentialListMappings.php
    :members:


CredentialLists
=================

.. phpautoclass:: Services_Twilio_Rest_CredentialLists
    :filename: ../Services/Twilio/Rest/CredentialLists.php
    :members:

Credentials
==============

.. phpautoclass:: Services_Twilio_Rest_Credentials
    :filename: ../Services/Twilio/Rest/Credentials.php
    :members:

Domains
==========

.. phpautoclass:: Services_Twilio_Rest_Domains
    :filename: ../Services/Twilio/Rest/Domains.php
    :members:


IncomingPhoneNumbers
========================

.. phpautoclass:: Services_Twilio_Rest_IncomingPhoneNumbers,Services_Twilio_Rest_Local,Services_Twilio_Rest_Mobile,Services_Twilio_Rest_TollFree
    :filename: ../Services/Twilio/Rest/IncomingPhoneNumbers.php
    :members:

IpAccessControlListMappings
==============================

.. phpautoclass:: Services_Twilio_Rest_IpAccessControlListMappings
    :filename: ../Services/Twilio/Rest/IpAccessControlListMappings.php
    :members:

IpAccessControlLists
=======================

.. phpautoclass:: Services_Twilio_Rest_IpAccessControlLists
    :filename: ../Services/Twilio/Rest/IpAccessControlLists.php
    :members:

IpAddresses
=======================

.. phpautoclass:: Services_Twilio_Rest_IpAddresses
    :filename: ../Services/Twilio/Rest/IpAddresses.php
    :members:

Media
======

.. phpautoclass:: Services_Twilio_Rest_Media
    :filename: ../Services/Twilio/Rest/Media.php
    :members:

Members
===========

.. php:class:: Services_Twilio_Rest_Members

  For more information, including a list of filter parameters, see the `Member List Resource <http://www.twilio.com/docs/api/rest/member#list>`_ documentation.

  .. php:method:: front()

      Return the :php:class:`Services_Twilio_Rest_Member` at the front of the
      queue.

Messages
========

.. phpautoclass:: Services_Twilio_Rest_Messages
    :filename: ../Services/Twilio/Rest/Messages.php
    :members:

Queues
===========

.. php:class:: Services_Twilio_Rest_Queues

  For more information, including a list of filter parameters, see the
  `Queues List Resource <http://www.twilio.com/docs/api/rest/queues#list>`_
  documentation.

  .. php:method:: create($friendly_name, $params = array())

     Create a new :php:class:`Services_Twilio_Rest_Queue`.

     :param string $friendly_name: The name of the new Queue.
     :param array $params: An array of optional parameters and their values, 
        like `MaxSize`.
     :returns: A new :php:class:`Services_Twilio_Rest_Queue`


UsageRecords
==============

.. php:class:: Services_Twilio_Rest_UsageRecords

  For more information, including a list of filter parameters, see the `UsageRecords List Resource <http://www.twilio.com/docs/api/rest/usage-records#list>`_ documentation.

  .. php:method:: getCategory($category)

    Return the single UsageRecord corresponding to this category of usage.
    Valid only for the `Records`, `Today`, `Yesterday`, `ThisMonth`,
    `LastMonth` and `AllTime` resources.

    :param string $category: The category to retrieve a usage record for. For a full list of valid categories, see the full `Usage Category documentation <http://www.twilio.com/docs/api/rest/usage-records#usage-all-categories>`_.
    :returns: :php:class:`Services_Twilio_Rest_UsageRecord` A single usage record

UsageTriggers
=============

.. php:class:: Services_Twilio_Rest_UsageTriggers

  For more information, including a list of filter parameters, see the `UsageTriggers List Resource <http://www.twilio.com/docs/api/rest/usage-triggers#list>`_ documentation.

  .. php:method:: create($category, $value, $url, $params = array())

    Create a new UsageTrigger.

    :param string $category: The category of usage to fire a trigger for. A full list of categories can be found in the `Usage Categories documentation <http://www.twilio.com/docs/api/rest/usage-records#usage-categories>`_.
    :param string $value: Fire the trigger when usage crosses this value.
    :param string $url: The URL to request when the trigger fires.
    :param array $params: Optional parameters for this trigger. A full list of parameters can be found in the `Usage Trigger documentation <http://www.twilio.com/docs/api/rest/usage-triggers#list-post-optional-parameters>`_.
    :returns: :php:class:`Services_Twilio_Rest_UsageTrigger` The created trigger.


********************
Instance Resources
********************

.. phpautoclass:: Services_Twilio_InstanceResource
    :filename: ../Services/Twilio/InstanceResource.php
    :members:

Below you will find a list of objects created by interacting with the Twilio
API, and the methods and properties that can be called on them. These are
derived from the :php:class:`ListResource <Services_Twilio_ListResource>` and
:php:class:`InstanceResource <Services_Twilio_InstanceResource>` above.


Account
========

.. php:class:: Services_Twilio_Rest_Account

   For more information, see the `Account Instance Resource <http://www.twilio.com/docs/api/rest/account#instance>`_ documentation.

   .. php:method:: update($params)

     Update the account

     The **$params** array is the same as in :php:meth:`Services_Twilio_Rest_Accounts::create`

   .. php:attr:: sid

      A 34 character string that uniquely identifies this account.

   .. php:attr:: date_created

      The date that this account was created, in GMT in RFC 2822 format

   .. php:attr:: date_updated

      The date that this account was last updated, in GMT in RFC 2822 format.

   .. php:attr:: friendly_name

      A human readable description of this account, up to 64 characters long. By default the FriendlyName is your email address.

   .. php:attr:: status

      The status of this account. Usually active, but can be suspended if you've been bad, or closed if you've been horrible.

   .. php:attr:: auth_token

      The authorization token for this account. This token should be kept a secret, so no sharing.

Application
===========

.. php:class:: Services_Twilio_Rest_Application

   For more information, see the `Application Instance Resource <http://www.twilio.com/docs/api/rest/applications#instance>`_ documentation.

   .. php:attr:: sid

      A 34 character string that uniquely idetifies this resource.

   .. php:attr:: date_created

      The date that this resource was created, given as GMT RFC 2822 format.

   .. php:attr:: date_updated

      The date that this resource was last updated, given as GMT RFC 2822 format.

   .. php:attr:: friendly_name

      A human readable descriptive text for this resource, up to 64 characters long. By default, the FriendlyName is a nicely formatted version of the phone number.

   .. php:attr:: account_sid

      The unique id of the Account responsible for this phone number.

   .. php:attr:: api_version

      Calls to this phone number will start a new TwiML session with this API version.

   .. php:attr:: voice_caller_id_lookup

      Look up the caller's caller-ID name from the CNAM database (additional charges apply). Either true or false.

   .. php:attr:: voice_url

      The URL Twilio will request when this phone number receives a call.

   .. php:attr:: voice_method

      The HTTP method Twilio will use when requesting the above Url. Either GET or POST.

   .. php:attr:: voice_fallback_url

      The URL that Twilio will request if an error occurs retrieving or executing the TwiML requested by Url.

   .. php:attr:: voice_fallback_method

      The HTTP method Twilio will use when requesting the VoiceFallbackUrl. Either GET or POST.

   .. php:attr:: status_callback

      The URL that Twilio will request to pass status parameters (such as call ended) to your application.

   .. php:attr:: status_callback_method

      The HTTP method Twilio will use to make requests to the StatusCallback URL. Either GET or POST.

   .. php:attr:: sms_url

      The URL Twilio will request when receiving an incoming SMS message to this number.

   .. php:attr:: sms_method

      The HTTP method Twilio will use when making requests to the SmsUrl. Either GET or POST.

   .. php:attr:: sms_fallback_url

      The URL that Twilio will request if an error occurs retrieving or executing the TwiML from SmsUrl.

   .. php:attr:: sms_fallback_method

      The HTTP method Twilio will use when requesting the above URL. Either GET or POST.

   .. php:attr:: uri

      The URI for this resource, relative to https://api.twilio.com.

AvailablePhoneNumber
========================

.. php:class:: Services_Twilio_Rest_AvailablePhoneNumber

   For more information, see the `AvailablePhoneNumber Instance Resource <http://www.twilio.com/docs/api/rest/available-phone-numbers#instance>`_ documentation.

   .. php:attr:: friendly_name

      A nicely-formatted version of the phone number.

   .. php:attr:: phone_number

      The phone number, in E.164 (i.e. "+1") format.

   .. php:attr:: lata

      The LATA of this phone number.

   .. php:attr:: rate_center

      The rate center of this phone number.

   .. php:attr:: latitude

      The latitude coordinate of this phone number.

   .. php:attr:: longitude

      The longitude coordinate of this phone number.

   .. php:attr:: region

      The two-letter state or province abbreviation of this phone number.

   .. php:attr:: postal_code

      The postal (zip) code of this phone number.

   .. php:attr:: iso_country

Call
====

.. phpautoclass:: Services_Twilio_Rest_Call
    :filename: ../Services/Twilio/Rest/Call.php
    :members:

CallerId
============

.. php:class:: Services_Twilio_Rest_OutgoingCallerId

   For more information, see the `OutgoingCallerId Instance Resource <http://www.twilio.com/docs/api/rest/outgoing-caller-ids#instance>`_ documentation.

   .. php:attr:: sid

      A 34 character string that uniquely identifies this resource.

   .. php:attr:: date_created

      The date that this resource was created, given in RFC 2822 format.

   .. php:attr:: date_updated

      The date that this resource was last updated, given in RFC 2822 format.

   .. php:attr:: friendly_name

      A human readable descriptive text for this resource, up to 64 characters long. By default, the FriendlyName is a nicely formatted version of the phone number.

   .. php:attr:: account_sid

      The unique id of the Account responsible for this Caller Id.

   .. php:attr:: phone_number

      The incoming phone number. Formatted with a '+' and country code e.g., +16175551212 (E.164 format).

   .. php:attr:: uri

      The URI for this resource, relative to https://api.twilio.com.

Conference
=============

.. php:class:: Services_Twilio_Rest_Conference

   For more information, see the `Conference Instance Resource <http://www.twilio.com/docs/api/rest/conference#instance>`_ documentation.

   .. php:attr:: sid

      A 34 character string that uniquely identifies this conference.

   .. php:attr:: friendly_name

      A user provided string that identifies this conference room.

   .. php:attr:: status

      A string representing the status of the conference. May be init, in-progress, or completed.

   .. php:attr:: date_created

      The date that this conference was created, given as GMT in RFC 2822 format.

   .. php:attr:: date_updated

      The date that this conference was last updated, given as GMT in RFC 2822 format.

   .. php:attr:: account_sid

      The unique id of the Account responsible for creating this conference.

   .. php:attr:: uri

      The URI for this resource, relative to https://api.twilio.com.

   .. php:attr:: participants

      The :php:class:`Services_Twilio_Rest_Participants` instance, listing people currently in this conference

CredentialListMapping
=========================

.. phpautoclass:: Services_Twilio_Rest_CredentialListMapping
    :filename: ../Services/Twilio/Rest/CredentialListMapping.php
    :members:


CredentialList
=================

.. phpautoclass:: Services_Twilio_Rest_CredentialList
    :filename: ../Services/Twilio/Rest/CredentialList.php
    :members:

Credential
==============

.. phpautoclass:: Services_Twilio_Rest_Credential
    :filename: ../Services/Twilio/Rest/Credential.php
    :members:

Domain
==========

.. phpautoclass:: Services_Twilio_Rest_Domain
    :filename: ../Services/Twilio/Rest/Domain.php
    :members:

IncomingPhoneNumber
===================

.. phpautoclass:: Services_Twilio_Rest_IncomingPhoneNumber
    :filename: ../Services/Twilio/Rest/IncomingPhoneNumber.php
    :members:

IpAccessControlListMapping
==============================

.. phpautoclass:: Services_Twilio_Rest_IpAccessControlListMapping
    :filename: ../Services/Twilio/Rest/IpAccessControlListMapping.php
    :members:

IpAccessControlList
=======================

.. phpautoclass:: Services_Twilio_Rest_IpAccessControlList
    :filename: ../Services/Twilio/Rest/IpAccessControlList.php
    :members:

IpAddress
==============
.. phpautoclass:: Services_Twilio_Rest_IpAddress
    :filename: ../Services/Twilio/Rest/IpAddress.php
    :members:


Notification
=============

.. php:class:: Services_Twilio_Rest_Notification

   For more information, see the `Notification Instance Resource <http://www.twilio.com/docs/api/rest/notification#instance>`_ documentation.

   .. php:attr:: sid

      A 34 character string that uniquely identifies this resource.

   .. php:attr:: date_created

      The date that this resource was created, given in RFC 2822 format.

   .. php:attr:: date_updated

      The date that this resource was last updated, given in RFC 2822 format.

   .. php:attr:: account_sid

      The unique id of the Account responsible for this notification.

   .. php:attr:: call_sid

      CallSid is the unique id of the call during which the notification was generated. Empty if the notification was generated by the REST API without regard to a specific phone call.

   .. php:attr:: api_version

      The version of the Twilio in use when this notification was generated.

   .. php:attr:: log

      An integer log level corresponding to the type of notification: 0 is ERROR, 1 is WARNING.

   .. php:attr:: error_code

      A unique error code for the error condition. You can lookup errors, with possible causes and solutions, in our `Error Dictionary <http://www.twilio.com/docs/errors/reference>`_.

   .. php:attr:: more_info

      A URL for more information about the error condition. The URL is a page in our `Error Dictionary <http://www.twilio.com/docs/errors/reference>`_.

   .. php:attr:: message_text

      The text of the notification.

   .. php:attr:: message_date

      The date the notification was actually generated, given in RFC 2822
      format. Due to buffering, this may be slightly different than the
      DateCreated date.

   .. php:attr:: request_url

      The URL of the resource that generated the notification. If the
      notification was generated during a phone call: This is the URL of the
      resource on YOUR SERVER that caused the notification. If the notification
      was generated by your use of the REST API: This is the URL of the REST
      resource you were attempting to request on Twilio's servers.

   .. php:attr:: request_method

    The HTTP method in use for the request that generated the notification. If
    the notification was generated during a phone call: The HTTP Method use to
    request the resource on your server. If the notification was generated by
    your use of the REST API: This is the HTTP method used in your request to
    the REST resource on Twilio's servers.

   .. php:attr:: request_variables

      The Twilio-generated HTTP GET or POST variables sent to your server. Alternatively, if the notification was generated by the REST API, this field will include any HTTP POST or PUT variables you sent to the REST API.

   .. php:attr:: response_headers

      The HTTP headers returned by your server.

   .. php:attr:: response_body

      The HTTP body returned by your server.

   .. php:attr:: uri

      The URI for this resource, relative to https://api.twilio.com

Media
=======

.. phpautoclass:: Services_Twilio_Rest_MediaInstance
    :filename: ../Services/Twilio/Rest/MediaInstance.php
    :members:

Member
=======

.. php:class:: Services_Twilio_Rest_Member

  For more information about available properties, see the `Member Instance Resource <http://www.twilio.com/docs/api/rest/member#instance>`_ documentation.

  .. php:method:: dequeue($url, $method = 'POST')

    Dequeue this member and immediately play the Twiml at the given ``$url``.

    :param string $url: The Twiml URL to play for this member, after dequeuing them
    :param string $method: The HTTP method to use when fetching the Twiml URL. Defaults to POST.
    :return: The dequeued member
    :rtype: :php:class:`Member <Services_Twilio_Rest_Member>` 


Participant
=============

.. php:class:: Services_Twilio_Rest_Participant

   For more information, see the `Participant Instance Resource <http://www.twilio.com/docs/api/rest/participant#instance>`_ documentation.

   .. php:attr:: call_sid

      A 34 character string that uniquely identifies the call that is connected to this conference

   .. php:attr:: conference_sid

      A 34 character string that identifies the conference this participant is in

   .. php:attr:: date_created

      The date that this resource was created, given in RFC 2822 format.

   .. php:attr:: date_updated

      The date that this resource was last updated, given in RFC 2822 format.

   .. php:attr:: account_sid

      The unique id of the Account that created this conference

   .. php:attr:: muted

      true if this participant is currently muted. false otherwise.

   .. php:attr:: start_conference_on_enter

      Was the startConferenceOnEnter attribute set on this participant (true or false)?

   .. php:attr:: end_conference_on_exit

      Was the endConferenceOnExit attribute set on this participant (true or false)?

   .. php:attr:: uri

      The URI for this resource, relative to https://api.twilio.com.

Queue
============

.. php:class:: Services_Twilio_Rest_Queue

  For more information about available properties of a queue, see the `Queue 
  Instance Resource <http://www.twilio.com/docs/api/rest/queue#instance>`_ 
  documentation. A Queue has one subresource, a list of 
  :php:class:`Services_Twilio_Rest_Members`.

Recording
=============

.. php:class:: Services_Twilio_Rest_Recording

   For more information, see the `Recording Instance Resource <http://www.twilio.com/docs/api/rest/recording#instance>`_ documentation.

   .. php:attr:: sid

      A 34 character string that uniquely identifies this resource.

   .. php:attr:: date_created

      The date that this resource was created, given in RFC 2822 format.

   .. php:attr:: date_updated

      The date that this resource was last updated, given in RFC 2822 format.

   .. php:attr:: account_sid

      The unique id of the Account responsible for this recording.

   .. php:attr:: call_sid

      The call during which the recording was made.

   .. php:attr:: duration

      The length of the recording, in seconds.

   .. php:attr:: api_version

      The version of the API in use during the recording.

   .. php:attr:: uri

      The URI for this resource, relative to https://api.twilio.com

   .. php:attr:: subresource_uris

      The list of subresources under this account

   .. php:attr:: formats

      A dictionary of the audio formats available for this recording

      .. code-block:: php

          array(
              'wav' => 'https://api.twilio.com/path/to/recording.wav',
              'mp3' => 'https://api.twilio.com/path/to/recording.mp3',
          )

Message
=======

.. phpautoclass:: Services_Twilio_Rest_Message
    :filename: ../Services/Twilio/Rest/Message.php
    :members:

SmsMessage
===========

.. php:class:: Services_Twilio_Rest_SmsMessage

   For more information, see the `SMS Message Instance Resource <http://www.twilio.com/docs/api/rest/sms#instance>`_ documentation.

   .. php:attr:: sid

      A 34 character string that uniquely identifies this resource.

   .. php:attr:: date_created

      The date that this resource was created, given in RFC 2822 format.

   .. php:attr:: date_updated

      The date that this resource was last updated, given in RFC 2822 format.

   .. php:attr:: date_sent

      The date that the SMS was sent, given in RFC 2822 format.

   .. php:attr:: account_sid

      The unique id of the Account that sent this SMS message.

   .. php:attr:: from

      The phone number that initiated the message in E.164 format. For incoming messages, this will be the remote phone. For outgoing messages, this will be one of your Twilio phone numbers.

   .. php:attr:: to

      The phone number that received the message in E.164 format. For incoming messages, this will be one of your Twilio phone numbers. For outgoing messages, this will be the remote phone.

   .. php:attr:: body

      The text body of the SMS message. Up to 160 characters long.

   .. php:attr:: status

      The status of this SMS message. Either queued, sending, sent, or failed.

   .. php:attr:: direction

    The direction of this SMS message. ``incoming`` for incoming messages,
    ``outbound-api`` for messages initiated via the REST API, ``outbound-call`` for
    messages initiated during a call or ``outbound-reply`` for messages initiated in
    response to an incoming SMS.

   .. php:attr:: price

      The amount billed for the message.

   .. php:attr:: api_version

      The version of the Twilio API used to process the SMS message.

   .. php:attr:: uri

      The URI for this resource, relative to https://api.twilio.com


Transcription
==================

.. php:class:: Services_Twilio_Rest_Transcription

   For more information, see the `Transcription Instance Resource <http://www.twilio.com/docs/api/rest/transcription#instance>`_ documentation.

   .. php:attr:: sid

      A 34 character string that uniquely identifies this resource.

   .. php:attr:: date_created

      The date that this resource was created, given in RFC 2822 format.

   .. php:attr:: date_updated

      The date that this resource was last updated, given in RFC 2822 format.

   .. php:attr:: account_sid

      The unique id of the Account responsible for this transcription.

   .. php:attr:: status

      A string representing the status of the transcription: ``in-progress``, ``completed`` or ``failed``.

   .. php:attr:: recording_sid

      The unique id of the Recording this Transcription was made of.

   .. php:attr:: duration

      The duration of the transcribed audio, in seconds.

   .. php:attr:: transcription_text

      The text content of the transcription.

   .. php:attr:: price

      The charge for this transcript in USD. Populated after the transcript is completed. Note, this value may not be immediately available.

   .. php:attr:: uri

      The URI for this resource, relative to https://api.twilio.com