Вход Регистрация
Файл: sngine-v2.8/Script/includes/libs/Stripe/lib/Account.php
Строк: 653
<?php

namespace Stripe;

/**
 * This is an object representing a Stripe account. You can retrieve it to see
 * properties on the account like its current e-mail address or if the account is
 * enabled yet to make live charges.
 *
 * Some properties, marked below, are available only to platforms that want to <a
 * href="https://stripe.com/docs/connect/accounts">create and manage Express or
 * Custom accounts</a>.
 *
 * @property string $id Unique identifier for the object.
 * @property string $object String representing the object's type. Objects of the same type share the same value.
 * @property null|StripeStripeObject $business_profile Business information about the account.
 * @property null|string $business_type The business type.
 * @property StripeStripeObject $capabilities
 * @property bool $charges_enabled Whether the account can create live charges.
 * @property StripeStripeObject $company
 * @property string $country The account's country.
 * @property int $created Time at which the object was created. Measured in seconds since the Unix epoch.
 * @property string $default_currency Three-letter ISO currency code representing the default currency for the account. This must be a currency that <a href="https://stripe.com/docs/payouts">Stripe supports in the account's country</a>.
 * @property bool $details_submitted Whether account details have been submitted. Standard accounts cannot receive payouts before this is true.
 * @property null|string $email The primary user's email address.
 * @property StripeCollection $external_accounts External accounts (bank accounts and debit cards) currently attached to this account
 * @property StripePerson $individual <p>This is an object representing a person associated with a Stripe account.</p><p>Related guide: <a href="https://stripe.com/docs/connect/identity-verification-api#person-information">Handling Identity Verification with the API</a>.</p>
 * @property StripeStripeObject $metadata Set of key-value pairs that you can attach to an object. This can be useful for storing additional information about the object in a structured format.
 * @property bool $payouts_enabled Whether Stripe can send payouts to this account.
 * @property StripeStripeObject $requirements
 * @property null|StripeStripeObject $settings Options for customizing how the account functions within Stripe.
 * @property StripeStripeObject $tos_acceptance
 * @property string $type The Stripe account type. Can be <code>standard</code>, <code>express</code>, or <code>custom</code>.
 */
class Account extends ApiResource
{
    const 
OBJECT_NAME 'account';

    use 
ApiOperationsAll;
    use 
ApiOperationsCreate;
    use 
ApiOperationsDelete;
    use 
ApiOperationsNestedResource;
    use 
ApiOperationsUpdate;

    const 
BUSINESS_TYPE_COMPANY 'company';
    const 
BUSINESS_TYPE_GOVERNMENT_ENTITY 'government_entity';
    const 
BUSINESS_TYPE_INDIVIDUAL 'individual';
    const 
BUSINESS_TYPE_NON_PROFIT 'non_profit';

    const 
CAPABILITY_CARD_PAYMENTS 'card_payments';
    const 
CAPABILITY_LEGACY_PAYMENTS 'legacy_payments';
    const 
CAPABILITY_PLATFORM_PAYMENTS 'platform_payments';
    const 
CAPABILITY_TRANSFERS 'transfers';

    const 
CAPABILITY_STATUS_ACTIVE 'active';
    const 
CAPABILITY_STATUS_INACTIVE 'inactive';
    const 
CAPABILITY_STATUS_PENDING 'pending';

    const 
TYPE_CUSTOM 'custom';
    const 
TYPE_EXPRESS 'express';
    const 
TYPE_STANDARD 'standard';

    use 
ApiOperationsRetrieve {
        
retrieve as protected _retrieve;
    }

    public static function 
getSavedNestedResources()
    {
        static 
$savedNestedResources null;
        if (
null === $savedNestedResources) {
            
$savedNestedResources = new UtilSet([
                
'external_account',
                
'bank_account',
            ]);
        }

        return 
$savedNestedResources;
    }

    public function 
instanceUrl()
    {
        if (
null === $this['id']) {
            return 
'/v1/account';
        }

        return 
parent::instanceUrl();
    }

    public function 
serializeParameters($force false)
    {
        
$update parent::serializeParameters($force);
        if (isset(
$this->_values['legal_entity'])) {
            
$entity $this['legal_entity'];
            if (isset(
$entity->_values['additional_owners'])) {
                
$owners $entity['additional_owners'];
                
$entityUpdate = isset($update['legal_entity']) ? $update['legal_entity'] : [];
                
$entityUpdate['additional_owners'] = $this->serializeAdditionalOwners($entity$owners);
                
$update['legal_entity'] = $entityUpdate;
            }
        }
        if (isset(
$this->_values['individual'])) {
            
$individual $this['individual'];
            if ((
$individual instanceof Person) && !isset($update['individual'])) {
                
$update['individual'] = $individual->serializeParameters($force);
            }
        }

        return 
$update;
    }

    private function 
serializeAdditionalOwners($legalEntity$additionalOwners)
    {
        if (isset(
$legalEntity->_originalValues['additional_owners'])) {
            
$originalValue $legalEntity->_originalValues['additional_owners'];
        } else {
            
$originalValue = [];
        }
        if ((
$originalValue) && (count($originalValue) > count($additionalOwners))) {
            throw new 
ExceptionInvalidArgumentException(
                
'You cannot delete an item from an array, you must instead set a new array'
            
);
        }

        
$updateArr = [];
        foreach (
$additionalOwners as $i => $v) {
            
$update = ($v instanceof StripeObject) ? $v->serializeParameters() : $v;

            if (
$update !== []) {
                if (!
$originalValue ||
                    !
array_key_exists($i$originalValue) ||
                    (
$update !== $legalEntity->serializeParamsValue($originalValue[$i], nullfalsetrue))) {
                    
$updateArr[$i] = $update;
                }
            }
        }

        return 
$updateArr;
    }

    
/**
     * @param null|array|string $id the ID of the account to retrieve, or an
     *     options array containing an `id` key
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripeAccount
     */
    
public static function retrieve($id null$opts null)
    {
        if (!
$opts && is_string($id) && 'sk_' === substr($id03)) {
            
$opts $id;
            
$id null;
        }

        return 
self::_retrieve($id$opts);
    }

    
/**
     * @param null|array $clientId
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripeStripeObject object containing the response from the API
     */
    
public function deauthorize($clientId null$opts null)
    {
        
$params = [
            
'client_id' => $clientId,
            
'stripe_user_id' => $this->id,
        ];

        return 
OAuth::deauthorize($params$opts);
    }

    
/**
     * @param null|array $params
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripeCollection the list of persons
     */
    
public function persons($params null$opts null)
    {
        
$url $this->instanceUrl() . '/persons';
        list(
$response$opts) = $this->_request('get'$url$params$opts);
        
$obj UtilUtil::convertToStripeObject($response$opts);
        
$obj->setLastResponse($response);

        return 
$obj;
    }

    
/**
     * @param null|array $params
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return Account the rejected account
     */
    
public function reject($params null$opts null)
    {
        
$url $this->instanceUrl() . '/reject';
        list(
$response$opts) = $this->_request('post'$url$params$opts);
        
$this->refreshFrom($response$opts);

        return 
$this;
    }

    
/*
     * Capabilities methods
     * We can not add the capabilities() method today as the Account object already has a
     * capabilities property which is a hash and not the sub-list of capabilities.
     */

    
const PATH_CAPABILITIES '/capabilities';

    
/**
     * @param string $id the ID of the account on which to retrieve the capabilities
     * @param null|array $params
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripeCollection the list of capabilities
     */
    
public static function allCapabilities($id$params null$opts null)
    {
        return 
self::_allNestedResources($id, static::PATH_CAPABILITIES$params$opts);
    }

    
/**
     * @param string $id the ID of the account to which the capability belongs
     * @param string $capabilityId the ID of the capability to retrieve
     * @param null|array $params
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripeCapability
     */
    
public static function retrieveCapability($id$capabilityId$params null$opts null)
    {
        return 
self::_retrieveNestedResource($id, static::PATH_CAPABILITIES$capabilityId$params$opts);
    }

    
/**
     * @param string $id the ID of the account to which the capability belongs
     * @param string $capabilityId the ID of the capability to update
     * @param null|array $params
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripeCapability
     */
    
public static function updateCapability($id$capabilityId$params null$opts null)
    {
        return 
self::_updateNestedResource($id, static::PATH_CAPABILITIES$capabilityId$params$opts);
    }

    const 
PATH_EXTERNAL_ACCOUNTS '/external_accounts';

    
/**
     * @param string $id the ID of the account on which to retrieve the external accounts
     * @param null|array $params
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripeCollection the list of external accounts (BankAccount or Card)
     */
    
public static function allExternalAccounts($id$params null$opts null)
    {
        return 
self::_allNestedResources($id, static::PATH_EXTERNAL_ACCOUNTS$params$opts);
    }

    
/**
     * @param string $id the ID of the account on which to create the external account
     * @param null|array $params
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripeBankAccount|StripeCard
     */
    
public static function createExternalAccount($id$params null$opts null)
    {
        return 
self::_createNestedResource($id, static::PATH_EXTERNAL_ACCOUNTS$params$opts);
    }

    
/**
     * @param string $id the ID of the account to which the external account belongs
     * @param string $externalAccountId the ID of the external account to delete
     * @param null|array $params
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripeBankAccount|StripeCard
     */
    
public static function deleteExternalAccount($id$externalAccountId$params null$opts null)
    {
        return 
self::_deleteNestedResource($id, static::PATH_EXTERNAL_ACCOUNTS$externalAccountId$params$opts);
    }

    
/**
     * @param string $id the ID of the account to which the external account belongs
     * @param string $externalAccountId the ID of the external account to retrieve
     * @param null|array $params
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripeBankAccount|StripeCard
     */
    
public static function retrieveExternalAccount($id$externalAccountId$params null$opts null)
    {
        return 
self::_retrieveNestedResource($id, static::PATH_EXTERNAL_ACCOUNTS$externalAccountId$params$opts);
    }

    
/**
     * @param string $id the ID of the account to which the external account belongs
     * @param string $externalAccountId the ID of the external account to update
     * @param null|array $params
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripeBankAccount|StripeCard
     */
    
public static function updateExternalAccount($id$externalAccountId$params null$opts null)
    {
        return 
self::_updateNestedResource($id, static::PATH_EXTERNAL_ACCOUNTS$externalAccountId$params$opts);
    }

    const 
PATH_LOGIN_LINKS '/login_links';

    
/**
     * @param string $id the ID of the account on which to create the login link
     * @param null|array $params
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripeLoginLink
     */
    
public static function createLoginLink($id$params null$opts null)
    {
        return 
self::_createNestedResource($id, static::PATH_LOGIN_LINKS$params$opts);
    }

    const 
PATH_PERSONS '/persons';

    
/**
     * @param string $id the ID of the account on which to retrieve the persons
     * @param null|array $params
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripeCollection the list of persons
     */
    
public static function allPersons($id$params null$opts null)
    {
        return 
self::_allNestedResources($id, static::PATH_PERSONS$params$opts);
    }

    
/**
     * @param string $id the ID of the account on which to create the person
     * @param null|array $params
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripePerson
     */
    
public static function createPerson($id$params null$opts null)
    {
        return 
self::_createNestedResource($id, static::PATH_PERSONS$params$opts);
    }

    
/**
     * @param string $id the ID of the account to which the person belongs
     * @param string $personId the ID of the person to delete
     * @param null|array $params
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripePerson
     */
    
public static function deletePerson($id$personId$params null$opts null)
    {
        return 
self::_deleteNestedResource($id, static::PATH_PERSONS$personId$params$opts);
    }

    
/**
     * @param string $id the ID of the account to which the person belongs
     * @param string $personId the ID of the person to retrieve
     * @param null|array $params
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripePerson
     */
    
public static function retrievePerson($id$personId$params null$opts null)
    {
        return 
self::_retrieveNestedResource($id, static::PATH_PERSONS$personId$params$opts);
    }

    
/**
     * @param string $id the ID of the account to which the person belongs
     * @param string $personId the ID of the person to update
     * @param null|array $params
     * @param null|array|string $opts
     *
     * @throws StripeExceptionApiErrorException if the request fails
     *
     * @return StripePerson
     */
    
public static function updatePerson($id$personId$params null$opts null)
    {
        return 
self::_updateNestedResource($id, static::PATH_PERSONS$personId$params$opts);
    }
}
Онлайн: 0
Реклама