mirror of
https://github.com/Karaka-Management/Resources.git
synced 2026-01-28 12:08:40 +00:00
174 lines
4.2 KiB
PHP
174 lines
4.2 KiB
PHP
<?php
|
|
|
|
namespace PayPal\Rest;
|
|
|
|
use PayPal\Core\PayPalConfigManager;
|
|
use PayPal\Core\PayPalCredentialManager;
|
|
|
|
/**
|
|
* Class ApiContext
|
|
*
|
|
* Call level parameters such as request id, credentials etc
|
|
*
|
|
* @package PayPal\Rest
|
|
*/
|
|
class ApiContext
|
|
{
|
|
|
|
/**
|
|
* Unique request id to be used for this call
|
|
* The user can either generate one as per application
|
|
* needs or let the SDK generate one
|
|
*
|
|
* @var null|string $requestId
|
|
*/
|
|
private $requestId;
|
|
|
|
/**
|
|
* This is a placeholder for holding credential for the request
|
|
* If the value is not set, it would get the value from @\PayPal\Core\PayPalCredentialManager
|
|
*
|
|
* @var \PayPal\Auth\OAuthTokenCredential
|
|
*/
|
|
private $credential;
|
|
|
|
|
|
/**
|
|
* Construct
|
|
*
|
|
* @param \PayPal\Auth\OAuthTokenCredential $credential
|
|
* @param string|null $requestId
|
|
*/
|
|
public function __construct($credential = null, $requestId = null)
|
|
{
|
|
$this->requestId = $requestId;
|
|
$this->credential = $credential;
|
|
}
|
|
|
|
/**
|
|
* Get Credential
|
|
*
|
|
* @return \PayPal\Auth\OAuthTokenCredential
|
|
*/
|
|
public function getCredential()
|
|
{
|
|
if ($this->credential == null) {
|
|
return PayPalCredentialManager::getInstance()->getCredentialObject();
|
|
}
|
|
return $this->credential;
|
|
}
|
|
|
|
public function getRequestHeaders()
|
|
{
|
|
$result = PayPalConfigManager::getInstance()->get('http.headers');
|
|
$headers = array();
|
|
foreach ($result as $header => $value) {
|
|
$headerName = ltrim($header, 'http.headers');
|
|
$headers[$headerName] = $value;
|
|
}
|
|
return $headers;
|
|
}
|
|
|
|
public function addRequestHeader($name, $value)
|
|
{
|
|
// Determine if the name already has a 'http.headers' prefix. If not, add one.
|
|
if (!(substr($name, 0, strlen('http.headers')) === 'http.headers')) {
|
|
$name = 'http.headers.' . $name;
|
|
}
|
|
PayPalConfigManager::getInstance()->addConfigs(array($name => $value));
|
|
}
|
|
|
|
/**
|
|
* Get Request ID
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getRequestId()
|
|
{
|
|
return $this->requestId;
|
|
}
|
|
|
|
/**
|
|
* Sets the request ID
|
|
*
|
|
* @param string $requestId the PayPal-Request-Id value to use
|
|
*/
|
|
public function setRequestId($requestId)
|
|
{
|
|
$this->requestId = $requestId;
|
|
}
|
|
|
|
/**
|
|
* Resets the requestId that can be used to set the PayPal-request-id
|
|
* header used for idempotency. In cases where you need to make multiple create calls
|
|
* using the same ApiContext object, you need to reset request Id.
|
|
* @deprecated Call setRequestId with a unique value.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function resetRequestId()
|
|
{
|
|
$this->requestId = $this->generateRequestId();
|
|
return $this->getRequestId();
|
|
}
|
|
|
|
/**
|
|
* Sets Config
|
|
*
|
|
* @param array $config SDK configuration parameters
|
|
*/
|
|
public function setConfig(array $config)
|
|
{
|
|
PayPalConfigManager::getInstance()->addConfigs($config);
|
|
}
|
|
|
|
/**
|
|
* Gets Configurations
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getConfig()
|
|
{
|
|
return PayPalConfigManager::getInstance()->getConfigHashmap();
|
|
}
|
|
|
|
/**
|
|
* Gets a specific configuration from key
|
|
*
|
|
* @param $searchKey
|
|
* @return mixed
|
|
*/
|
|
public function get($searchKey)
|
|
{
|
|
return PayPalConfigManager::getInstance()->get($searchKey);
|
|
}
|
|
|
|
/**
|
|
* Generates a unique per request id that
|
|
* can be used to set the PayPal-Request-Id header
|
|
* that is used for idempotency
|
|
* @deprecated
|
|
*
|
|
* @return string
|
|
*/
|
|
private function generateRequestId()
|
|
{
|
|
static $pid = -1;
|
|
static $addr = -1;
|
|
|
|
if ($pid == -1) {
|
|
$pid = getmypid();
|
|
}
|
|
|
|
if ($addr == -1) {
|
|
if (array_key_exists('SERVER_ADDR', $_SERVER)) {
|
|
$addr = ip2long($_SERVER['SERVER_ADDR']);
|
|
} else {
|
|
$addr = php_uname('n');
|
|
}
|
|
}
|
|
|
|
return $addr . $pid . $_SERVER['REQUEST_TIME'] . mt_rand(0, 0xffff);
|
|
}
|
|
}
|