/** * Creates an Simplify_Customer object * @param array $hash a map of parameters; valid keys are:<dl style="padding-left:10px;"> * <dt><tt>card.addressCity</tt></dt> <dd>City of the cardholder. </dd> * <dt><tt>card.addressCountry</tt></dt> <dd>Country code (ISO-3166-1-alpha-2 code) of residence of the cardholder. </dd> * <dt><tt>card.addressLine1</tt></dt> <dd>Address of the cardholder </dd> * <dt><tt>card.addressLine2</tt></dt> <dd>Address of the cardholder if needed. </dd> * <dt><tt>card.addressState</tt></dt> <dd>State code (USPS code) of residence of the cardholder. </dd> * <dt><tt>card.addressZip</tt></dt> <dd>Postal code of the cardholder. </dd> * <dt><tt>card.cvc</tt></dt> <dd>CVC security code of the card. This is the code on the back of the card. Example: 123 </dd> * <dt><tt>card.expMonth</tt></dt> <dd>Expiration month of the card. Format is MM. Example: January = 01 <strong>required </strong></dd> * <dt><tt>card.expYear</tt></dt> <dd>Expiration year of the card. Format is YY. Example: 2013 = 13 <strong>required </strong></dd> * <dt><tt>card.name</tt></dt> <dd>Name as appears on the card. </dd> * <dt><tt>card.number</tt></dt> <dd>Card number as it appears on the card. <strong>required </strong></dd> * <dt><tt>email</tt></dt> <dd>Email address of the customer <strong>required </strong></dd> * <dt><tt>name</tt></dt> <dd>Customer name <strong>required </strong></dd> * <dt><tt>reference</tt></dt> <dd>Reference field for external applications use. </dd> * <dt><tt>subscriptions.amount</tt></dt> <dd>Amount of payment in minor units. Example: 1000 = 10.00 </dd> * <dt><tt>subscriptions.coupon</tt></dt> <dd>Coupon associated with the subscription for the customer. </dd> * <dt><tt>subscriptions.currency</tt></dt> <dd>Currency code (ISO-4217). Must match the currency associated with your account. <strong>default:USD</strong></dd> * <dt><tt>subscriptions.customer</tt></dt> <dd>The customer ID to create the subscription for. Do not supply this when creating a customer. </dd> * <dt><tt>subscriptions.frequency</tt></dt> <dd>Frequency of payment for the plan. Example: Monthly </dd> * <dt><tt>subscriptions.name</tt></dt> <dd>Name describing subscription </dd> * <dt><tt>subscriptions.plan</tt></dt> <dd>The plan ID that the subscription should be created from. </dd> * <dt><tt>subscriptions.quantity</tt></dt> <dd>Quantity of the plan for the subscription. </dd></dl> * @param string publicKey Public key. If null, the value of static Simplify::$publicKey will be used * @param string privateKey Private key. If null, the value of static Simplify::$privateKey will be used * @return Customer a Customer object. */ public static function createCustomer($hash, $publicKey = null, $privateKey = null) { $instance = new Simplify_Customer(); $instance->setAll($hash); $object = Simplify_PaymentsApi::createObject($instance, $publicKey, $privateKey); return $object; }
/** * Creates an Simplify_Customer object * @param array $hash a map of parameters; valid keys are:<dl style="padding-left:10px;"> * <dt><tt>card.addressCity</tt></dt> <dd>City of the cardholder. <strong>required </strong></dd> * <dt><tt>card.addressCountry</tt></dt> <dd>Country code (ISO-3166-1-alpha-2 code) of residence of the cardholder. <strong>required </strong></dd> * <dt><tt>card.addressLine1</tt></dt> <dd>Address of the cardholder <strong>required </strong></dd> * <dt><tt>card.addressLine2</tt></dt> <dd>Address of the cardholder if needed. <strong>required </strong></dd> * <dt><tt>card.addressState</tt></dt> <dd>State code (USPS code) of residence of the cardholder. <strong>required </strong></dd> * <dt><tt>card.addressZip</tt></dt> <dd>Postal code of the cardholder. The postal code size is between 5 and 9 in length and only contain numbers or letters. <strong>required </strong></dd> * <dt><tt>card.cvc</tt></dt> <dd>CVC security code of the card. This is the code on the back of the card. Example: 123 <strong>required </strong></dd> * <dt><tt>card.expMonth</tt></dt> <dd>Expiration month of the card. Format is MM. Example: January = 01 <strong>required </strong></dd> * <dt><tt>card.expYear</tt></dt> <dd>Expiration year of the card. Format is YY. Example: 2013 = 13 <strong>required </strong></dd> * <dt><tt>card.id</tt></dt> <dd>ID of card. Unused during customer create. </dd> * <dt><tt>card.name</tt></dt> <dd>Name as appears on the card. <strong>required </strong></dd> * <dt><tt>card.number</tt></dt> <dd>Card number as it appears on the card. [max length: 19, min length: 13] </dd> * <dt><tt>email</tt></dt> <dd>Email address of the customer <strong>required </strong></dd> * <dt><tt>name</tt></dt> <dd>Customer name [min length: 2] <strong>required </strong></dd> * <dt><tt>reference</tt></dt> <dd>Reference field for external applications use. </dd> * <dt><tt>subscriptions.amount</tt></dt> <dd>Amount of payment in the smallest unit of your currency. Example: 100 = $1.00USD </dd> * <dt><tt>subscriptions.billingCycle</tt></dt> <dd>How the plan is billed to the customer. Values must be AUTO (indefinitely until the customer cancels) or FIXED (a fixed number of billing cycles). [default: AUTO] </dd> * <dt><tt>subscriptions.billingCycleLimit</tt></dt> <dd>The number of fixed billing cycles for a plan. Only used if the billingCycle parameter is set to FIXED. Example: 4 </dd> * <dt><tt>subscriptions.coupon</tt></dt> <dd>Coupon associated with the subscription for the customer. </dd> * <dt><tt>subscriptions.currency</tt></dt> <dd>Currency code (ISO-4217). Must match the currency associated with your account. [default: USD] </dd> * <dt><tt>subscriptions.customer</tt></dt> <dd>The customer ID to create the subscription for. Do not supply this when creating a customer. </dd> * <dt><tt>subscriptions.frequency</tt></dt> <dd>Frequency of payment for the plan. Used in conjunction with frequencyPeriod. Valid values are "DAILY", "WEEKLY", "MONTHLY" and "YEARLY". </dd> * <dt><tt>subscriptions.frequencyPeriod</tt></dt> <dd>Period of frequency of payment for the plan. Example: if the frequency is weekly, and periodFrequency is 2, then the subscription is billed bi-weekly. </dd> * <dt><tt>subscriptions.name</tt></dt> <dd>Name describing subscription </dd> * <dt><tt>subscriptions.plan</tt></dt> <dd>The plan ID that the subscription should be created from. </dd> * <dt><tt>subscriptions.quantity</tt></dt> <dd>Quantity of the plan for the subscription. [min value: 1] </dd> * <dt><tt>subscriptions.renewalReminderLeadDays</tt></dt> <dd>If set, how many days before the next billing cycle that a renewal reminder is sent to the customer. If null, then no emails are sent. Minimum value is 7 if set. </dd> * <dt><tt>token</tt></dt> <dd>If specified, card associated with card token will be used </dd></dl> * @param $authentication - information used for the API call. If no value is passed the global keys Simplify::public_key and Simplify::private_key are used. <i>For backwards compatibility the public and private keys may be passed instead of the authentication object.<i/> * @return Customer a Customer object. */ public static function createCustomer($hash, $authentication = null) { $args = func_get_args(); $authentication = Simplify_PaymentsApi::buildAuthenticationObject($authentication, $args, 2); $instance = new Simplify_Customer(); $instance->setAll($hash); $object = Simplify_PaymentsApi::createObject($instance, $authentication); return $object; }