mirror of
https://we.phorge.it/source/phorge.git
synced 2024-12-31 18:01:00 +01:00
203 lines
6.6 KiB
PHP
203 lines
6.6 KiB
PHP
<?php
|
|
|
|
/**
|
|
* @author Neuman Vong neuman@twilio.com
|
|
* @license http://creativecommons.org/licenses/MIT/ MIT
|
|
* @link http://pear.php.net/package/Services_Twilio
|
|
*/
|
|
|
|
/**
|
|
* Abstraction of a list resource from the Twilio API.
|
|
*
|
|
* The list resource implements the `IteratorAggregate
|
|
* <http://php.net/manual/en/class.iteratoraggregate.php>`_ and the `Countable
|
|
* <http://php.net/manual/en/class.countable.php>`_ interfaces.
|
|
*
|
|
*/
|
|
abstract class Services_Twilio_ListResource extends Services_Twilio_Resource
|
|
implements IteratorAggregate, Countable
|
|
{
|
|
|
|
public function __construct($client, $uri) {
|
|
$name = $this->getResourceName(true);
|
|
/*
|
|
* By default trim the 's' from the end of the list name to get the
|
|
* instance name (ex Accounts -> Account). This behavior can be
|
|
* overridden by child classes if the rule doesn't work.
|
|
*/
|
|
if (!isset($this->instance_name)) {
|
|
$this->instance_name = "Services_Twilio_Rest_" . rtrim($name, 's');
|
|
}
|
|
|
|
parent::__construct($client, $uri);
|
|
}
|
|
|
|
/**
|
|
* Gets a resource from this list.
|
|
*
|
|
* :param string $sid: The resource SID
|
|
* :return: The resource
|
|
* :rtype: :php:class:`InstanceResource <Services_Twilio_InstanceResource>`
|
|
*/
|
|
public function get($sid) {
|
|
$instance = new $this->instance_name(
|
|
$this->client, $this->uri . "/$sid"
|
|
);
|
|
// XXX check if this is actually a sid in all cases.
|
|
$instance->sid = $sid;
|
|
return $instance;
|
|
}
|
|
|
|
/**
|
|
* Construct an :php:class:`InstanceResource
|
|
* <Services_Twilio_InstanceResource>` with the specified params.
|
|
*
|
|
* :param array $params: usually a JSON HTTP response from the API
|
|
* :return: An instance with properties
|
|
* initialized to the values in the params array.
|
|
* :rtype: :php:class:`InstanceResource <Services_Twilio_InstanceResource>`
|
|
*/
|
|
public function getObjectFromJson($params, $idParam = "sid")
|
|
{
|
|
if (isset($params->{$idParam})) {
|
|
$uri = $this->uri . "/" . $params->{$idParam};
|
|
} else {
|
|
$uri = $this->uri;
|
|
}
|
|
return new $this->instance_name($this->client, $uri, $params);
|
|
}
|
|
|
|
/**
|
|
* Deletes a resource from this list.
|
|
*
|
|
* :param string $sid: The resource SID
|
|
* :rtype: null
|
|
*/
|
|
public function delete($sid, $params = array())
|
|
{
|
|
$this->client->deleteData($this->uri . '/' . $sid, $params);
|
|
}
|
|
|
|
/**
|
|
* Create a resource on the list and then return its representation as an
|
|
* InstanceResource.
|
|
*
|
|
* :param array $params: The parameters with which to create the resource
|
|
*
|
|
* :return: The created resource
|
|
* :rtype: :php:class:`InstanceResource <Services_Twilio_InstanceResource>`
|
|
*/
|
|
protected function _create($params)
|
|
{
|
|
$params = $this->client->createData($this->uri, $params);
|
|
/* Some methods like verified caller ID don't return sids. */
|
|
if (isset($params->sid)) {
|
|
$resource_uri = $this->uri . '/' . $params->sid;
|
|
} else {
|
|
$resource_uri = $this->uri;
|
|
}
|
|
return new $this->instance_name($this->client, $resource_uri, $params);
|
|
}
|
|
|
|
/**
|
|
* Returns a page of :php:class:`InstanceResources
|
|
* <Services_Twilio_InstanceResource>` from this list.
|
|
*
|
|
* :param int $page: The start page
|
|
* :param int $size: Number of items per page
|
|
* :param array $filters: Optional filters
|
|
* :param string $deep_paging_uri: if provided, the $page and $size
|
|
* parameters will be ignored and this URI will be requested directly.
|
|
*
|
|
* :return: A page of resources
|
|
* :rtype: :php:class:`Services_Twilio_Page`
|
|
*/
|
|
public function getPage(
|
|
$page = 0, $size = 50, $filters = array(), $deep_paging_uri = null
|
|
) {
|
|
$list_name = $this->getResourceName();
|
|
if ($deep_paging_uri !== null) {
|
|
$page = $this->client->retrieveData($deep_paging_uri, array(), true);
|
|
} else {
|
|
$page = $this->client->retrieveData($this->uri, array(
|
|
'Page' => $page,
|
|
'PageSize' => $size,
|
|
) + $filters);
|
|
}
|
|
|
|
/* create a new PHP object for each json obj in the api response. */
|
|
$page->$list_name = array_map(
|
|
array($this, 'getObjectFromJson'),
|
|
$page->$list_name
|
|
);
|
|
if (isset($page->next_page_uri)) {
|
|
$next_page_uri = $page->next_page_uri;
|
|
} else {
|
|
$next_page_uri = null;
|
|
}
|
|
return new Services_Twilio_Page($page, $list_name, $next_page_uri);
|
|
}
|
|
|
|
/**
|
|
* Get the total number of instances for this list.
|
|
*
|
|
* This will make one HTTP request to retrieve the total, every time this
|
|
* method is called.
|
|
*
|
|
* If the total is not set, or an Exception was thrown, returns 0
|
|
*
|
|
* :return: The total number of instance members
|
|
* :rtype: integer
|
|
*/
|
|
public function count() {
|
|
try {
|
|
$page = $this->getPage(0, 1);
|
|
return $page ? (int)$page->total : 0;
|
|
} catch (Exception $e) {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Returns an iterable list of
|
|
* :php:class:`instance resources <Services_Twilio_InstanceResource>`.
|
|
*
|
|
* :param int $page: The start page
|
|
* :param int $size: Number of items per page
|
|
* :param array $filters: Optional filters.
|
|
* The filter array can accept full datetimes when StartTime or DateCreated
|
|
* are used. Inequalities should be within the key portion of the array and
|
|
* multiple filter parameters can be combined for more specific searches.
|
|
*
|
|
* .. code-block:: php
|
|
*
|
|
* array('DateCreated>' => '2011-07-05 08:00:00', 'DateCreated<' => '2011-08-01')
|
|
*
|
|
* .. code-block:: php
|
|
*
|
|
* array('StartTime<' => '2011-07-05 08:00:00')
|
|
*
|
|
* :return: An iterator
|
|
* :rtype: :php:class:`Services_Twilio_AutoPagingIterator`
|
|
*/
|
|
public function getIterator(
|
|
$page = 0, $size = 50, $filters = array()
|
|
) {
|
|
return new Services_Twilio_AutoPagingIterator(
|
|
array($this, 'getPageGenerator'), $page, $size, $filters
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Retrieve a new page of API results, and update iterator parameters. This
|
|
* function is called by the paging iterator to retrieve a new page and
|
|
* shouldn't be called directly.
|
|
*/
|
|
public function getPageGenerator(
|
|
$page, $size, $filters = array(), $deep_paging_uri = null
|
|
) {
|
|
return $this->getPage($page, $size, $filters, $deep_paging_uri);
|
|
}
|
|
}
|
|
|