Мерчант будет получать на Callback Url уведомления с финальным ответом, содержащим статус транзакции.
На основе этих уведомлений Мерчант должен предоставлять услугу/товар покупателю.
Callback Url - обязательная настройка для каждого проекта открытого в maibmerchants, но можно отправить и в запросе при инициации платежа (параметр callbackUrl).
Чтобы получать уведомления, убедитесь, что ваш сервер разрешает доступ для maib ecomm (IP: 91.250.245.70 / 91.250.245.71).
Уведомление считается обработанной Мерчантом, если в ответ получен HTTP 200 OK статус. Иначе maib ecomm будет повторять попытки переотправки уведомления через такие интервалы времени: 10, 60, 300, 600, 3600, 43200, 86400 секунд.
Уведомления отправляются в виде запросов HTTPS POST с данными в формате JSON.
Пример получения уведомлений по Callback URL (PHP)
Сравните сгенерированную подпись со значением параметра signature из уведомлении, и если они совпадают, подпись будет считаться действительной (полученные данные целостные и подлинные).
Пример проверки подписи (PHP)
<?php
$key = "8508706b-3454-4733-8295-56e617c4abcf"; //Signature Key from Project settings
$json = file_get_contents('php://input');
$data = json_decode($json, true);
if (isset($data['signature'])) {
$data_result = $data['result']; // Data from "result" object
function sortByKeyRecursive(array $array) {
ksort($array, SORT_STRING);
foreach ($array as $key => $value) {
if (is_array($value)) {
$array[$key] = sortByKeyRecursive($value);
}
}
return $array;
}
function implodeRecursive($separator, $array) {
$result = '';
foreach ($array as $item) {
$result .= (is_array($item) ? implodeRecursive($separator, $item) : (string)$item) . $separator;
}
return substr($result, 0, -1);
}
$sortedDataByKeys = sortByKeyRecursive($data_result); //Sort an array by key recursively
$sortedDataByKeys[] = $key; //Add Signature Key to the end of data array
$signString = implodeRecursive(':', $sortedDataByKeys); // Implode array recursively
$sign = base64_encode(hash('sha256', $signString, true)); // Generate signature
if ($sign === $data['signature']) // Compare the generated signature with the received signature on Callback URL
{
echo "Signature is valid!"; // Signature is valid, process the data
} else {
echo "Signature is invalid!"; // Signature is invalid, reject the request
}
}