Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F101274437
Util.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Fri, Feb 7, 09:44
Size
2 KB
Mime Type
text/x-php
Expires
Sun, Feb 9, 09:44 (2 d)
Engine
blob
Format
Raw Data
Handle
24128493
Attached To
rPH Phabricator
Util.php
View Options
<?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
;
}
}
}
Event Timeline
Log In to Comment