Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
70 changes: 69 additions & 1 deletion lib/Api/TatraPayPlusAPIApi.php
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,9 @@ class TatraPayPlusAPIApi
'setLogo' => [
'application/json',
],
'loanPrecalculation' => [
'application/json',
],
];
/**
* @var object
Expand Down Expand Up @@ -106,7 +109,7 @@ public function __construct(
} else {
$this->client = $client;
}
$this->config = \Tatrapayplus\TatrapayplusApiClient\Configuration::getDefaultConfiguration($mode);
$this->config = new \Tatrapayplus\TatrapayplusApiClient\Configuration($mode);
}

/**
Expand Down Expand Up @@ -992,4 +995,69 @@ public function log(HttpResponse $response, array $additional_data = null): void
$this->logger->log($response, $additional_data);
}
}

/**
* Operation loanPrecalculation
*
* Calculate loan parameters from input
*
* @param \Tatrapayplus\TatrapayplusApiClient\Model\BasicCalculationRequest precalculation_request Request body (required)
*
* @return array of \Tatrapayplus\TatrapayplusApiClient\Model\BasicCalculationResponseItem, HTTP status code, HTTP response headers (array of strings)
*
* @throws InvalidArgumentException
* @throws ApiException on non-2xx response or if the response body is not in the expected format
*/
public function loanPrecalculation($precalculation_request)
{
$request = $this->loanPrecalculationRequest($precalculation_request);

return $this->processRequest($request, '\Tatrapayplus\TatrapayplusApiClient\Model\BasicCalculationResponseItem', '\Tatrapayplus\TatrapayplusApiClient\Model\Model400ErrorBody');
}

/**
* Create request for operation 'loanPrecalculation'
*
* @param \Tatrapayplus\TatrapayplusApiClient\Model\BasicCalculationRequest precalculation_request Request body (required)
*
* @return Request
*
* @throws InvalidArgumentException
*/
public function loanPrecalculationRequest($precalculation_request)
{
// verify the required parameter 'precalculation_request' is set
if ($precalculation_request === null || (is_array($precalculation_request) && count($precalculation_request) === 0)) {
throw new InvalidArgumentException('Missing the required parameter precalculation_request when calling loanPrecalculation');
}

$resourcePath = '/v1/payments/loans/precalculation';

$headers = $this->headerSelector->selectHeaders(
['application/json'],
self::contentTypes['loanPrecalculation'][0],
false
);

$httpBody = static::json_encode(ObjectSerializer::sanitizeForSerialization($precalculation_request));

// this endpoint requires OAuth (access token)
$headers = $this->addAuthHeader($headers);

$defaultHeaders = $this->getDefaultHeaders();

$headers = array_merge(
$defaultHeaders,
$headers
);

$operationHost = $this->config->getHost();

return new Request(
'PUT',
$operationHost . $resourcePath,
$headers,
$httpBody
);
}
}
3 changes: 3 additions & 0 deletions lib/CurlClient.php
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,9 @@ public function send(Request $request): HttpResponse
} elseif ($request->method === "PATCH") {
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "PATCH");
curl_setopt($ch, CURLOPT_POSTFIELDS, $request->httpBody);
} elseif ($request->method === "PUT") {
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "PUT");
curl_setopt($ch, CURLOPT_POSTFIELDS, $request->httpBody);
} else {
exit("Unsupported request type");
}
Expand Down
Loading