Gestionnaire de fichiers - Editer - /home/wwgoat/public_html/blog/wp-content/plugins/simple-membership/lib/braintree/lib/Braintree/ClientTokenGateway.php
Arrière
<?php namespace Braintree; use InvalidArgumentException; class ClientTokenGateway { /** * * @var Gateway */ private $_gateway; /** * * @var Configuration */ private $_config; /** * * @var Http */ private $_http; /** * * @param Gateway $gateway */ public function __construct($gateway) { $this->_gateway = $gateway; $this->_config = $gateway->config; $this->_config->assertHasAccessTokenOrKeys(); $this->_http = new Http($gateway->config); } public function generate($params=[]) { if (!array_key_exists("version", $params)) { $params["version"] = ClientToken::DEFAULT_VERSION; } $this->conditionallyVerifyKeys($params); $generateParams = ["client_token" => $params]; return $this->_doGenerate('/client_token', $generateParams); } /** * sends the generate request to the gateway * * @ignore * @param var $url * @param array $params * @return string */ public function _doGenerate($subPath, $params) { $fullPath = $this->_config->merchantPath() . $subPath; $response = $this->_http->post($fullPath, $params); return $this->_verifyGatewayResponse($response); } /** * * @param array $params * @throws InvalidArgumentException */ public function conditionallyVerifyKeys($params) { if (array_key_exists("customerId", $params)) { Util::verifyKeys($this->generateWithCustomerIdSignature(), $params); } else { Util::verifyKeys($this->generateWithoutCustomerIdSignature(), $params); } } /** * * @return mixed[] */ public function generateWithCustomerIdSignature() { return [ "version", "customerId", "proxyMerchantId", ["options" => ["makeDefault", "verifyCard", "failOnDuplicatePaymentMethod"]], "merchantAccountId"]; } /** * * @return string[] */ public function generateWithoutCustomerIdSignature() { return ["version", "proxyMerchantId", "merchantAccountId"]; } /** * generic method for validating incoming gateway responses * * If the request is successful, returns a client token string. * Otherwise, throws an InvalidArgumentException with the error * response from the Gateway or an HTTP status code exception. * * @ignore * @param array $response gateway response values * @return string client token * @throws InvalidArgumentException | HTTP status code exception */ private function _verifyGatewayResponse($response) { if (isset($response['clientToken'])) { return $response['clientToken']['value']; } elseif (isset($response['apiErrorResponse'])) { throw new InvalidArgumentException( $response['apiErrorResponse']['message'] ); } else { throw new Exception\Unexpected( "Expected clientToken or apiErrorResponse" ); } } } class_alias('Braintree\ClientTokenGateway', 'Braintree_ClientTokenGateway');
| ver. 1.4 |
Github
|
.
| PHP 8.0.30 | Génération de la page: 0.01 |
proxy
|
phpinfo
|
Réglages