apiKey = $key; $this->headers = $headers; } /** * Unpacks an options array and merges it into the existing RequestOptions * object. * @param array|string|null $options a key => value array * * @return RequestOptions */ public function merge($options) { $other_options = self::parse($options); if ($other_options->apiKey === null) { $other_options->apiKey = $this->apiKey; } $other_options->headers = array_merge($this->headers, $other_options->headers); return $other_options; } /** * Unpacks an options array into an RequestOptions object * @param array|string|null $options a key => value array * * @return RequestOptions */ public static function parse($options) { if ($options instanceof self) { return $options; } if (is_null($options)) { return new RequestOptions(null, array()); } if (is_string($options)) { return new RequestOptions($options, array()); } if (is_array($options)) { $headers = array(); $key = null; if (array_key_exists('api_key', $options)) { $key = $options['api_key']; } if (array_key_exists('idempotency_key', $options)) { $headers['Idempotency-Key'] = $options['idempotency_key']; } if (array_key_exists('stripe_account', $options)) { $headers['Stripe-Account'] = $options['stripe_account']; } if (array_key_exists('stripe_version', $options)) { $headers['Stripe-Version'] = $options['stripe_version']; } return new RequestOptions($key, $headers); } $message = 'The second argument to Stripe API method calls is an ' . 'optional per-request apiKey, which must be a string, or ' . 'per-request options, which must be an array. (HINT: you can set ' . 'a global apiKey by "Stripe::setApiKey()")'; throw new Error\Api($message); } }