В случае, если карта покупателя участвует в программе 3dsecure, то в ответе на запрос к методам purchase или auth
будут присутствовать параметры для перехода на страницу банка, выпустивщего карту покупателя.
Последовательность операций
-
запрос
purchase -
переадресация покупателя на
acsUrlиз ответа со следующими параметрами-
PaReq- получено из запроса -
TermUrl-URLстраницы клиента, на которую будет возвращен покупатель после прохождения проверки -
MD- сгенерированные клиентом параметр, который будет передан обратно при возврате наTermUrl. Обычно используется идентификации покупателя
-
-
запрос
complete3dsс параметромpaRes, полученным при возврате наTermUrl.URLформируется с подстановкойoperationId, полученного в ответе на запросpurchase
Примеры запросов и ответов
Purchase
POST /card/1-1/operations/purchase HTTP/1.1
W1-Signature: tfKzlKLa5GNLTHyo4gZgSo5p2pRiiDsOfj1dKRWBkm28tiiXwqWui71Wz4Q77cE1sTlXWWwhPOH20x0fqmQJBhxf/f+b4qnAKR9T+vT0pbq9LipdfuyAMD9+Fqje4LZKpYlDMTCfxzZKBnWYNwAqQBxZ3zf7dsCyK87Hh7a7HmW1AClQ8Zy8XJNBQT39HUuEImllDB8KjGsvycSluR6snQrXb4u+GqlSuz5BVXEHpYtkziYBHlI2Pc2w7ZCQ/+LcdNuio086+hKLtmGKV9RDL8Zw1YuP/TCWuAdHagStF/qcW4hPSOwcybr7Dz2NV/JqFNSxF7R8j1R0a+eYHzbN+g==
Content-Type: application/json
Host: payment.payhub.pro
Content-Length: 764
{
"notification" : {
"url" : "http://127.0.0.1:8080/test/callback/default/",
"version" : 1
},
"externalId" : "ext#14-1770570543650",
"amount" : {
"amount" : 10.55,
"currency" : "USD"
},
"payer" : {
"paymentMethod" : {
"entity" : {
"pan" : "4916798373459761",
"expMonth" : 5,
"expYear" : 2030,
"cvv" : "444"
},
"type" : "CARD"
},
"info" : {
"phone" : "9001234567",
"email" : "no-reply@example.com",
"ip" : "127.0.0.1"
}
},
"merchantParameters" : {
"param1" : "anything you want for callback",
"param2" : null,
"param3" : null
},
"registerRecurring" : true,
"tds" : {
"notificationUrl" : "http://tds.notification.url:6789"
}
}
HTTP/1.1 200 OK
Vary: Origin
Vary: Access-Control-Request-Method
Vary: Access-Control-Request-Headers
Content-Type: application/json
Content-Length: 310
{
"operationId" : "1-1-a-608",
"status" : "WAITING_FOR_CONFIRMATION",
"type" : "PURCHASE",
"externalId" : "ext#14-1770570543650",
"params" : {
"acsUrl" : "http://testacs:9191/test/acs/3ds1",
"PaReq" : "good"
},
"actions" : {
"required" : [ {
"type" : "complete3ds"
} ]
}
}
Complete3ds
POST /card/1-1/operations/1-1-a-647/complete3ds HTTP/1.1
W1-Signature: Y5eNHqVoBSZMH4lxYWFeb9wXtW/2t1rst2H+VkYsupKVw7ZP0jcelrcYlzn9Lz/JRGD2ECy+M0dqa1KZ6qgiYYHmBQjlFN/8gDn7Kt55FT6PObnodwhveQAa3vheoabQWo00nS8sWrvVbKYkignXVdi0h+rA09DdAxx3w+KTY3XBvxYs/fqZXOvVm012wwWQq2/zIG9RooJCs1Kdx/dmeY1b1XGd69kpnW16guJqatP/1K98hH/9C9yMtYL0eiMgJGGp9f09XT2s/wig/rfj4BfFW/2PXYLcBHOtnlX2gIRQNBxqbAi/WdX1f/1OHjc8HpoIAK2UjZOL0EUG7N807g==
Content-Type: application/json
Host: payment.payhub.pro
Content-Length: 26
{
"paRes" : "verified"
}
HTTP/1.1 200 OK
Vary: Origin
Vary: Access-Control-Request-Method
Vary: Access-Control-Request-Headers
Content-Type: application/json
Content-Length: 183
{
"operationId" : "1-1-a-647",
"status" : "SUCCEEDED",
"type" : "PURCHASE",
"externalId" : "ext#62-1770570573296",
"params" : { },
"actions" : {
"required" : [ ]
}
}
Уведомление клиента со стороны Payhub (Callback)
POST /test/emptycallback HTTP/1.1
W1-Signature: tGKwJT3xbqyL0z0BzEsSfN34OAksuCyfWUoeQnsCK1GVdbq/JquNYKdL7M5/pZggkwSLykJHWnr0dSPWHDL0LzNwQx63Nu0nSQp7lFWwcj5hfZ/ZHHwXS+gFAyYnaCWAi5ovpzohoq/5RMUH0fuvwIEPRXFJEZ5WYKE9Kg9OMhCMdRjJ+vGdN7o7hKtrjIMA4qyY7Wp+GGhKbwLMTDwBgpLrsSCHIN3+n4QsYdur4t/8E4n9B431+ZZUtqMakcP+qBtp/gidu5TFOsd8sbpLfeDQogwXoC8nPJyQe1kSwPsC31nqbnj1RXDkTtbrFTMIOFsjMGEBN2HzqyxzlzBH9A==
Content-Type: application/json
Host: payment.payhub.pro
Content-Length: 895
{
"id" : "1-1-a-608",
"type" : "PURCHASE",
"externalId" : "ext#14-1770570543650",
"successful" : true,
"amount" : {
"amount" : 10.55,
"currency" : "USD"
},
"baseAmount" : {
"amount" : 10.55,
"currency" : "USD"
},
"registeredMethods" : [ {
"entity" : {
"id" : "1-3"
},
"type" : "RECURRING_TOKEN"
}, {
"entity" : {
"id" : "payoutToken-491679-something-9761"
},
"type" : "PAYOUT_TOKEN"
} ],
"merchantParameters" : {
"param1" : "anything you want for callback",
"param2" : null,
"param3" : null
},
"status" : "SUCCEEDED",
"transactions" : [ {
"type" : "PURCHASE",
"status" : "SUCCEEDED"
}, {
"type" : "COMPLETE3DS",
"status" : "SUCCEEDED"
} ],
"payer" : {
"paymentMethod" : {
"entity" : {
"pan" : "491679XXXXXX9761"
},
"type" : "MASKED_CARD"
}
}
}
HTTP/1.1 404 Not Found
Vary: Origin
Vary: Access-Control-Request-Method
Vary: Access-Control-Request-Headers