![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/job-board.corals.io/Corals/modules/Payment/Braintree/lib/Braintree/ |
<?php namespace Braintree; use finfo; /** * Braintree HTTP Client * processes Http requests using curl */ class Http { protected $_config; private $_useClientCredentials = false; public function __construct($config) { $this->_config = $config; } public function delete($path, $params = null) { $response = $this->_doRequest('DELETE', $path, $this->_buildXml($params)); $responseCode = $response['status']; if ($responseCode === 200 || $responseCode === 204) { return true; } else if ($responseCode === 422) { return Xml::buildArrayFromXml($response['body']); } else { Util::throwStatusCodeException($response['status']); } } public function get($path) { $response = $this->_doRequest('GET', $path); if ($response['status'] === 200) { return Xml::buildArrayFromXml($response['body']); } else { Util::throwStatusCodeException($response['status']); } } public function post($path, $params = null) { $response = $this->_doRequest('POST', $path, $this->_buildXml($params)); $responseCode = $response['status']; if ($responseCode === 200 || $responseCode === 201 || $responseCode === 422 || $responseCode == 400) { return Xml::buildArrayFromXml($response['body']); } else { Util::throwStatusCodeException($responseCode); } } public function postMultipart($path, $params, $file) { $response = $this->_doRequest('POST', $path, $params, $file); $responseCode = $response['status']; if ($responseCode === 200 || $responseCode === 201 || $responseCode === 422 || $responseCode == 400) { return Xml::buildArrayFromXml($response['body']); } else { Util::throwStatusCodeException($responseCode); } } public function put($path, $params = null) { $response = $this->_doRequest('PUT', $path, $this->_buildXml($params)); $responseCode = $response['status']; if ($responseCode === 200 || $responseCode === 201 || $responseCode === 422 || $responseCode == 400) { return Xml::buildArrayFromXml($response['body']); } else { Util::throwStatusCodeException($responseCode); } } private function _buildXml($params) { return empty($params) ? null : Xml::buildXmlFromArray($params); } private function _getHeaders() { return [ 'Accept: application/xml', ]; } private function _getAuthorization() { if ($this->_useClientCredentials) { return [ 'user' => $this->_config->getClientId(), 'password' => $this->_config->getClientSecret(), ]; } else if ($this->_config->isAccessToken()) { return [ 'token' => $this->_config->getAccessToken(), ]; } else { return [ 'user' => $this->_config->getPublicKey(), 'password' => $this->_config->getPrivateKey(), ]; } } public function useClientCredentials() { $this->_useClientCredentials = true; } private function _doRequest($httpVerb, $path, $requestBody = null, $file = null) { return $this->_doUrlRequest($httpVerb, $this->_config->baseUrl() . $path, $requestBody, $file); } public function _doUrlRequest($httpVerb, $url, $requestBody = null, $file = null) { $curl = curl_init(); curl_setopt($curl, CURLOPT_TIMEOUT, $this->_config->timeout()); curl_setopt($curl, CURLOPT_CUSTOMREQUEST, $httpVerb); curl_setopt($curl, CURLOPT_URL, $url); if ($this->_config->acceptGzipEncoding()) { curl_setopt($curl, CURLOPT_ENCODING, 'gzip'); } if ($this->_config->sslVersion()) { curl_setopt($curl, CURLOPT_SSLVERSION, $this->_config->sslVersion()); } $headers = $this->_getHeaders($curl); $headers[] = 'User-Agent: Braintree PHP Library ' . Version::get(); $headers[] = 'X-ApiVersion: ' . Configuration::API_VERSION; $authorization = $this->_getAuthorization(); if (isset($authorization['user'])) { curl_setopt($curl, CURLOPT_HTTPAUTH, CURLAUTH_BASIC); curl_setopt($curl, CURLOPT_USERPWD, $authorization['user'] . ':' . $authorization['password']); } else if (isset($authorization['token'])) { $headers[] = 'Authorization: Bearer ' . $authorization['token']; } if ($this->_config->sslOn()) { curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true); curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 2); curl_setopt($curl, CURLOPT_CAINFO, $this->getCaFile()); } if (!empty($file)) { $boundary = "---------------------" . md5(mt_rand() . microtime()); $headers[] = "Content-Type: multipart/form-data; boundary={$boundary}"; $this->prepareMultipart($curl, $requestBody, $file, $boundary); } else if (!empty($requestBody)) { $headers[] = 'Content-Type: application/xml'; curl_setopt($curl, CURLOPT_POSTFIELDS, $requestBody); } if ($this->_config->isUsingProxy()) { $proxyHost = $this->_config->getProxyHost(); $proxyPort = $this->_config->getProxyPort(); $proxyType = $this->_config->getProxyType(); $proxyUser = $this->_config->getProxyUser(); $proxyPwd = $this->_config->getProxyPassword(); curl_setopt($curl, CURLOPT_PROXY, $proxyHost . ':' . $proxyPort); if (!empty($proxyType)) { curl_setopt($curl, CURLOPT_PROXYTYPE, $proxyType); } if ($this->_config->isAuthenticatedProxy()) { curl_setopt($curl, CURLOPT_PROXYUSERPWD, $proxyUser . ':' . $proxyPwd); } } curl_setopt($curl, CURLOPT_HTTPHEADER, $headers); curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); $response = curl_exec($curl); $httpStatus = curl_getinfo($curl, CURLINFO_HTTP_CODE); $error_code = curl_errno($curl); $error = curl_error($curl); if ($error_code == 28 && $httpStatus == 0) { throw new Exception\Timeout(); } curl_close($curl); if ($this->_config->sslOn()) { if ($httpStatus == 0) { throw new Exception\SSLCertificate($error, $error_code); } } else if ($error_code) { throw new Exception\Connection($error, $error_code); } return ['status' => $httpStatus, 'body' => $response]; } function prepareMultipart($ch, $requestBody, $file, $boundary) { $disallow = ["\0", "\"", "\r", "\n"]; $fileInfo = new finfo(FILEINFO_MIME_TYPE); $filePath = stream_get_meta_data($file)['uri']; $data = file_get_contents($filePath); $mimeType = $fileInfo->buffer($data); // build normal parameters foreach ($requestBody as $k => $v) { $k = str_replace($disallow, "_", $k); $body[] = implode("\r\n", [ "Content-Disposition: form-data; name=\"{$k}\"", "", filter_var($v), ]); } // build file parameter $filePath = call_user_func("end", explode(DIRECTORY_SEPARATOR, $filePath)); $filePath = str_replace($disallow, "_", $filePath); $body[] = implode("\r\n", [ "Content-Disposition: form-data; name=\"file\"; filename=\"{$filePath}\"", "Content-Type: {$mimeType}", "", $data, ]); // add boundary for each parameters array_walk($body, function (&$part) use ($boundary) { $part = "--{$boundary}\r\n{$part}"; }); // add final boundary $body[] = "--{$boundary}--"; $body[] = ""; // set options return curl_setopt_array($ch, [ CURLOPT_POST => true, CURLOPT_POSTFIELDS => implode("\r\n", $body) ]); } private function getCaFile() { static $memo; if ($memo === null) { $caFile = $this->_config->caFile(); if (substr($caFile, 0, 7) !== 'phar://') { return $caFile; } $extractedCaFile = sys_get_temp_dir() . '/api_braintreegateway_com.ca.crt'; if (!file_exists($extractedCaFile) || sha1_file($extractedCaFile) != sha1_file($caFile)) { if (!copy($caFile, $extractedCaFile)) { throw new Exception\SSLCaFileNotFound(); } } $memo = $extractedCaFile; } return $memo; } } class_alias('Braintree\Http', 'Braintree_Http');