/** * Initializes resources (i.e. registers them with Resource::_registry). Note * that if you add a Resource then you must initialize it here. * * @internal */ private static function initializeResources() { if (self::$initialized) { return; } \infiniteLabs\BalancedPayments\Resource::init(); \infiniteLabs\BalancedPayments\APIKey::init(); \infiniteLabs\BalancedPayments\Marketplace::init(); \infiniteLabs\BalancedPayments\Credit::init(); \infiniteLabs\BalancedPayments\Debit::init(); \infiniteLabs\BalancedPayments\Refund::init(); \infiniteLabs\BalancedPayments\Reversal::init(); \infiniteLabs\BalancedPayments\Card::init(); \infiniteLabs\BalancedPayments\BankAccount::init(); \infiniteLabs\BalancedPayments\BankAccountVerification::init(); \infiniteLabs\BalancedPayments\CardHold::init(); \infiniteLabs\BalancedPayments\Callback::init(); \infiniteLabs\BalancedPayments\Event::init(); \infiniteLabs\BalancedPayments\Customer::init(); \infiniteLabs\BalancedPayments\Order::init(); \infiniteLabs\BalancedPayments\Dispute::init(); self::$initialized = true; }
/** * Create a buyer account. * * @param string email_address Optional email address. There can only be one account with this email address. * @param string card_href Href referencing a card to associate with the account. * @param array[string]string meta Optional metadata to associate with the account. * @param string name Optional name of the account. * * @return \infiniteLabs\BalancedPayments\Customer */ public function createBuyer($email_address, $card_href, $meta = null, $name = null) { $customer = $this->customers->create(array('email' => $email_address, 'meta' => $meta, 'name' => $name)); $card = Card::get($card_href); $card->associateToCustomer($customer); return $customer; }