Retrieve payment methods and currencies
Last updated: 23-Aug-2022
Rate this article:
Overview
Use the getVendorPaymentMethodCurrencies SOAP API 6.0 call to get the list of available payment methods with currencies and countries. The result can be filtered by PaymentMethod and CountryCode.
Request parameters
Parameter name | Type | Required/Optional | Description |
---|---|---|---|
CountryCode | String | Optional | Country code. |
PaymentMethod | String | Optional | Payment method. |
sessionID | String | Required | Output of the Login method. |
Request example
<?php
declare(strict_types=1);
class Configuration
{
public const MERCHANT_CODE = '';
public const MERCHANT_KEY = '';
public const URL = 'http://api.2checkout.com/soap/6.0';
public const ACTION = 'getVendorPaymentMethodCurrencies';
public const ADDITIONAL_OPTIONS = null;
//array or JSON
public const PAYLOAD = <<<JSON
["WIRE", "FR"]
JSON;
}
class Client
{
public function call(
string $url = Configuration::URL,
$payload = Configuration::PAYLOAD,
string $action = Configuration::ACTION
): ?object
{
if (is_array($payload)) {
$payload = json_encode($payload);
}
if (!empty($payload)) {
// SoapClient works with objects(StdClass)
$payload = json_decode($payload);
}
$soapClient = $this->getClient($url);
$sessionId = $this->getSession($soapClient);
//$args = array_filter([$sessionId, $payload]);
$args = array_merge([$sessionId], $payload);
return $soapClient->$action(...$args);
}
public function getClient(string $url): SoapClient
{
return new SoapClient(
$url . '?wsdl',
[
'location' => $url,
'cache_wsdl' => WSDL_CACHE_NONE,
]
);
}
public function getSession(SoapClient $client)
{
$date = gmdate('Y-m-d H:i:s');
$merchantCode = Configuration::MERCHANT_CODE;
$key = Configuration::MERCHANT_KEY;
$string = strlen($merchantCode) . $merchantCode . strlen($date) . $date;
$hash = hash_hmac('md5', $string, $key);
// $client->__setCookie('XDEBUG_SESSION', 'PHPSTORM');
return $client->login($merchantCode, $date, $hash);
}
}
try {
$client = new Client();
var_dump($client->call());
} catch (Exception $ex) {
var_dump($ex);
}
Response example
[
{
"Currencies": [
"EUR",
"GBP",
"RON",
"USD"
],
"Countries": [
"RO",
"RU",
"RW",
"LC",
"WS",
"SM",
"ST",
"SA",
],
"BusinessCompany": "AVANGATE_BV",
"HasRenewal": false,
"PaymentType": "wire",
"PaymentMethod": "WIRE",
"AutofillSettings": null
}
]
Related articles
Rate this article: