mirror of
https://we.phorge.it/source/phorge.git
synced 2024-12-24 14:30:56 +01:00
643c1c4a52
Summary: Ref T2787. This brings us up to date. Test Plan: `git clone` Reviewers: btrahan, chad Reviewed By: chad Subscribers: epriestley Maniphest Tasks: T2787 Differential Revision: https://secure.phabricator.com/D9916
90 lines
2.4 KiB
PHP
90 lines
2.4 KiB
PHP
<?php
|
|
|
|
abstract class Stripe_Util
|
|
{
|
|
/**
|
|
* Whether the provided array (or other) is a list rather than a dictionary.
|
|
*
|
|
* @param array|mixed $array
|
|
* @return boolean True if the given object is a list.
|
|
*/
|
|
public static function isList($array)
|
|
{
|
|
if (!is_array($array))
|
|
return false;
|
|
|
|
// TODO: generally incorrect, but it's correct given Stripe's response
|
|
foreach (array_keys($array) as $k) {
|
|
if (!is_numeric($k))
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Recursively converts the PHP Stripe object to an array.
|
|
*
|
|
* @param array $values The PHP Stripe object to convert.
|
|
* @return array
|
|
*/
|
|
public static function convertStripeObjectToArray($values)
|
|
{
|
|
$results = array();
|
|
foreach ($values as $k => $v) {
|
|
// FIXME: this is an encapsulation violation
|
|
if ($k[0] == '_') {
|
|
continue;
|
|
}
|
|
if ($v instanceof Stripe_Object) {
|
|
$results[$k] = $v->__toArray(true);
|
|
} else if (is_array($v)) {
|
|
$results[$k] = self::convertStripeObjectToArray($v);
|
|
} else {
|
|
$results[$k] = $v;
|
|
}
|
|
}
|
|
return $results;
|
|
}
|
|
|
|
/**
|
|
* Converts a response from the Stripe API to the corresponding PHP object.
|
|
*
|
|
* @param array $resp The response from the Stripe API.
|
|
* @param string $apiKey
|
|
* @return Stripe_Object|array
|
|
*/
|
|
public static function convertToStripeObject($resp, $apiKey)
|
|
{
|
|
$types = array(
|
|
'card' => 'Stripe_Card',
|
|
'charge' => 'Stripe_Charge',
|
|
'customer' => 'Stripe_Customer',
|
|
'list' => 'Stripe_List',
|
|
'invoice' => 'Stripe_Invoice',
|
|
'invoiceitem' => 'Stripe_InvoiceItem',
|
|
'event' => 'Stripe_Event',
|
|
'transfer' => 'Stripe_Transfer',
|
|
'plan' => 'Stripe_Plan',
|
|
'recipient' => 'Stripe_Recipient',
|
|
'refund' => 'Stripe_Refund',
|
|
'subscription' => 'Stripe_Subscription'
|
|
);
|
|
if (self::isList($resp)) {
|
|
$mapped = array();
|
|
foreach ($resp as $i)
|
|
array_push($mapped, self::convertToStripeObject($i, $apiKey));
|
|
return $mapped;
|
|
} else if (is_array($resp)) {
|
|
if (isset($resp['object'])
|
|
&& is_string($resp['object'])
|
|
&& isset($types[$resp['object']])) {
|
|
$class = $types[$resp['object']];
|
|
} else {
|
|
$class = 'Stripe_Object';
|
|
}
|
|
return Stripe_Object::scopedConstructFrom($class, $resp, $apiKey);
|
|
} else {
|
|
return $resp;
|
|
}
|
|
}
|
|
}
|