2012-04-04 16:09:29 -07:00
|
|
|
<?php
|
|
|
|
|
|
|
|
class Stripe_Customer extends Stripe_ApiResource
|
|
|
|
{
|
2014-07-13 09:19:07 -07:00
|
|
|
/**
|
|
|
|
* @param string $id The ID of the customer to retrieve.
|
|
|
|
* @param string|null $apiKey
|
|
|
|
*
|
|
|
|
* @return Stripe_Customer
|
|
|
|
*/
|
2012-04-04 16:09:29 -07:00
|
|
|
public static function retrieve($id, $apiKey=null)
|
|
|
|
{
|
|
|
|
$class = get_class();
|
|
|
|
return self::_scopedRetrieve($class, $id, $apiKey);
|
|
|
|
}
|
|
|
|
|
2014-07-13 09:19:07 -07:00
|
|
|
/**
|
|
|
|
* @param array|null $params
|
|
|
|
* @param string|null $apiKey
|
|
|
|
*
|
|
|
|
* @return array An array of Stripe_Customers.
|
|
|
|
*/
|
2012-04-04 16:09:29 -07:00
|
|
|
public static function all($params=null, $apiKey=null)
|
|
|
|
{
|
|
|
|
$class = get_class();
|
|
|
|
return self::_scopedAll($class, $params, $apiKey);
|
|
|
|
}
|
|
|
|
|
2014-07-13 09:19:07 -07:00
|
|
|
/**
|
|
|
|
* @param array|null $params
|
|
|
|
* @param string|null $apiKey
|
|
|
|
*
|
|
|
|
* @return Stripe_Customer The created customer.
|
|
|
|
*/
|
2012-04-04 16:09:29 -07:00
|
|
|
public static function create($params=null, $apiKey=null)
|
|
|
|
{
|
|
|
|
$class = get_class();
|
|
|
|
return self::_scopedCreate($class, $params, $apiKey);
|
|
|
|
}
|
|
|
|
|
2014-07-13 09:19:07 -07:00
|
|
|
/**
|
|
|
|
* @returns Stripe_Customer The saved customer.
|
|
|
|
*/
|
2012-04-04 16:09:29 -07:00
|
|
|
public function save()
|
|
|
|
{
|
|
|
|
$class = get_class();
|
|
|
|
return self::_scopedSave($class);
|
|
|
|
}
|
|
|
|
|
2014-07-13 09:19:07 -07:00
|
|
|
/**
|
|
|
|
* @param array|null $params
|
|
|
|
*
|
|
|
|
* @returns Stripe_Customer The deleted customer.
|
|
|
|
*/
|
2012-04-04 16:09:29 -07:00
|
|
|
public function delete($params=null)
|
|
|
|
{
|
|
|
|
$class = get_class();
|
|
|
|
return self::_scopedDelete($class, $params);
|
|
|
|
}
|
|
|
|
|
2014-07-13 09:19:07 -07:00
|
|
|
/**
|
|
|
|
* @param array|null $params
|
|
|
|
*
|
|
|
|
* @returns Stripe_InvoiceItem The resulting invoice item.
|
|
|
|
*/
|
2012-04-04 16:09:29 -07:00
|
|
|
public function addInvoiceItem($params=null)
|
|
|
|
{
|
|
|
|
if (!$params)
|
|
|
|
$params = array();
|
|
|
|
$params['customer'] = $this->id;
|
|
|
|
$ii = Stripe_InvoiceItem::create($params, $this->_apiKey);
|
|
|
|
return $ii;
|
|
|
|
}
|
|
|
|
|
2014-07-13 09:19:07 -07:00
|
|
|
/**
|
|
|
|
* @param array|null $params
|
|
|
|
*
|
|
|
|
* @returns array An array of the customer's Stripe_Invoices.
|
|
|
|
*/
|
2012-04-04 16:09:29 -07:00
|
|
|
public function invoices($params=null)
|
|
|
|
{
|
|
|
|
if (!$params)
|
|
|
|
$params = array();
|
|
|
|
$params['customer'] = $this->id;
|
|
|
|
$invoices = Stripe_Invoice::all($params, $this->_apiKey);
|
|
|
|
return $invoices;
|
|
|
|
}
|
|
|
|
|
2014-07-13 09:19:07 -07:00
|
|
|
/**
|
|
|
|
* @param array|null $params
|
|
|
|
*
|
|
|
|
* @returns array An array of the customer's Stripe_InvoiceItems.
|
|
|
|
*/
|
2012-04-04 16:09:29 -07:00
|
|
|
public function invoiceItems($params=null)
|
|
|
|
{
|
|
|
|
if (!$params)
|
|
|
|
$params = array();
|
|
|
|
$params['customer'] = $this->id;
|
|
|
|
$iis = Stripe_InvoiceItem::all($params, $this->_apiKey);
|
|
|
|
return $iis;
|
|
|
|
}
|
|
|
|
|
2014-07-13 09:19:07 -07:00
|
|
|
/**
|
|
|
|
* @param array|null $params
|
|
|
|
*
|
|
|
|
* @returns array An array of the customer's Stripe_Charges.
|
|
|
|
*/
|
2012-04-04 16:09:29 -07:00
|
|
|
public function charges($params=null)
|
|
|
|
{
|
|
|
|
if (!$params)
|
|
|
|
$params = array();
|
|
|
|
$params['customer'] = $this->id;
|
|
|
|
$charges = Stripe_Charge::all($params, $this->_apiKey);
|
|
|
|
return $charges;
|
|
|
|
}
|
|
|
|
|
2014-07-13 09:19:07 -07:00
|
|
|
/**
|
|
|
|
* @param array|null $params
|
|
|
|
*
|
|
|
|
* @returns Stripe_Subscription The updated subscription.
|
|
|
|
*/
|
2012-04-04 16:09:29 -07:00
|
|
|
public function updateSubscription($params=null)
|
|
|
|
{
|
|
|
|
$requestor = new Stripe_ApiRequestor($this->_apiKey);
|
|
|
|
$url = $this->instanceUrl() . '/subscription';
|
|
|
|
list($response, $apiKey) = $requestor->request('post', $url, $params);
|
|
|
|
$this->refreshFrom(array('subscription' => $response), $apiKey, true);
|
|
|
|
return $this->subscription;
|
|
|
|
}
|
|
|
|
|
2014-07-13 09:19:07 -07:00
|
|
|
/**
|
|
|
|
* @param array|null $params
|
|
|
|
*
|
|
|
|
* @returns Stripe_Subscription The cancelled subscription.
|
|
|
|
*/
|
2012-04-04 16:09:29 -07:00
|
|
|
public function cancelSubscription($params=null)
|
|
|
|
{
|
|
|
|
$requestor = new Stripe_ApiRequestor($this->_apiKey);
|
|
|
|
$url = $this->instanceUrl() . '/subscription';
|
|
|
|
list($response, $apiKey) = $requestor->request('delete', $url, $params);
|
|
|
|
$this->refreshFrom(array('subscription' => $response), $apiKey, true);
|
|
|
|
return $this->subscription;
|
|
|
|
}
|
2014-07-13 09:19:07 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param array|null $params
|
|
|
|
*
|
|
|
|
* @returns Stripe_Customer The updated customer.
|
|
|
|
*/
|
|
|
|
public function deleteDiscount()
|
|
|
|
{
|
|
|
|
$requestor = new Stripe_ApiRequestor($this->_apiKey);
|
|
|
|
$url = $this->instanceUrl() . '/discount';
|
|
|
|
list($response, $apiKey) = $requestor->request('delete', $url);
|
|
|
|
$this->refreshFrom(array('discount' => null), $apiKey, true);
|
|
|
|
}
|
2012-04-04 16:09:29 -07:00
|
|
|
}
|