Аутентификация 3‑D Secure

Общая информация

Обзор

Аутентификация пользователей с использованием протокола 3‑D Secure (Three-Domain Secure) предназначена для безопасного проведения интернет-оплат с использованием платёжных карт. Она может выполняться с применением различных способов проверки подлинности пользователей: например, через указание пользователем одноразового проверочного кода (One Time PIN, OTP), с помощью проверки отпечатка пальца пользователя на его мобильном устройстве или без каких-либо действий со стороны пользователя, на основе имеющейся информации о платеже и пользователе. При этом в разных случаях со стороны эмитентов могут поддерживаться различные способы проверки.

Прим.: В настоящее время как со стороны платёжных систем American Express, Mastercard и Visa, так и со стороны ecommpay поддерживается вторая версия протокола — 3‑D Secure 2. И представленная в этой статье информация относится к данной версии протокола.

В аутентификации 3‑D Secure задействуются три домена:

  • Домен эквайера. В рамках работы с платёжной платформой ecommpay к нему относятся веб-сервисы мерчантов, платёжная платформа и связанный с ней 3DS-сервер.
  • Домен совместимости. К нему относятся серверы каталогов (Directory Servers, DS) международных платёжных систем.
  • Домен эмитента. К нему относятся серверы управления доступом (Access Control Servers, ACS) эмитентов, а также страницы аутентификации, открываемые при обращениях к этим серверам.

Между этими доменами осуществляется обмен сообщениями, необходимыми для аутентификации пользователей. К таким сообщениям могут относиться запросы на проверку возможности проведения аутентификации (Verifying Enrolment Request, VEReq) и ответы на них (Verifying Enrolment Response, VERes), а также запросы на аутентификацию пользователя (Challenge Request, CReq) и ответы с информацией о результатах аутентификации (Challenge Response, CRes).

Следует учитывать, что информация о возможности аутентификации пользователя хранится на сервере управления доступом, и эту информацию можно получить только после отправки запроса на проведение платежа. Также со стороны веб-сервиса и платёжной платформы невозможно отслеживать действия пользователей на странице аутентификации — доступно только получение информации о результате аутентификации.

Варианты аутентификации

При работе с протоколом 3‑D Secure могут применяться два варианта аутентификации:

  • Аутентификация без участия пользователя (frictionless flow). В этом случае личность пользователя подтверждается исходя из информации, которой располагает эмитент.
  • Аутентификация с подтверждением пользователем своей личности (challenge flow). В этом случае подтверждение личности пользователя выполняется, например, с использованием одноразового кода или биометрических данных, если такая возможность поддерживается эмитентом.


Со стороны мерчанта выбрать требуемый вариант аутентификации нельзя — можно лишь указать предпочтение по такому выбору, но итоговое решение каждый раз принимается на стороне эмитента. Также, помимо указания предпочтений, в запросах на проведение платежей можно передавать ряд других необязательных параметров, применение которых может повышать вероятность выбора варианта аутентификации frictionless flow и, как следствие, способствовать повышению проходимости и улучшению пользовательского опыта. К базовому минимуму таких параметров можно отнести платёжный адрес пользователя (в параметрах объекта billing) и HTTP-заголовок User-Agent, полученный со стороны браузера (в параметре browser). Информация об этих и других параметрах представлена далее.

Особенности

Область применения

Выполнение аутентификации 3‑D Secure, как правило, обязательно для платежей с прямым использованием платёжных карт. Это связано с требованиями второй директивы о платёжных услугах (Payment Services Directive 2, PSD2), включающими в себя необходимость выполнения строгой аутентификации пользователя (Strong Customer Authentication, SCA) при проведении таких платежей.

К платежам, на которые не распространяются требования PSD2 к строгой аутентификации, относятся:

  • Оплаты с использованием платёжных карт не из Европейской экономической зоны.
  • Оплаты с использованием анонимных предоплаченных платёжных карт, например с использованием подарочной карты или виртуальной карты с предоплаченной стоимостью.
  • Оплаты категории Mail Order/Telephone Order (MO/TO).
  • Оплаты, инициируемые мерчантом (Merchant-initiated transactions, MIT); в платёжной платформе ecommpay к ним относятся регулярные оплаты и автооплаты (с типом платежа recurring), а также операции по изменению суммы предварительной блокировки (с типом операции incremental).
  • Оплаты с использованием большинства альтернативных платёжных методов.

В платёжной платформе поддерживается определение таких платежей, и аутентификация для них не выполняется.

Допустимые исключения

Среди тех платежей, на которые распространяются базовые требования к строгой аутентификации, директива PSD2 допускает наличие исключений (SCA Exemptions), при которых аутентификация может не выполняться по решениям эмитентов. Такими исключениями могут выступать платежи следующих категорий:

  • Платежи на незначительные суммы (Low value) — оплаты на суммы до 25 фунтов стерлингов (в пределах Великобритании) или 30 евро (в пределах Европейской экономической зоны), в случаях, когда с момента последней успешной аутентификации было проведено не более пяти платежей и общая сумма этих платежей не превышает 85 фунтов стерлингов или 100 евро соответственно.
  • Платежи с низким уровнем риска (Transaction Risk Analysis) — оплаты, проводимые эквайером, уровень мошенничества в платёжном трафике которого соответствует порогам, заданным в PSD2.
  • Платежи доверенным мерчантам (Trusted beneficiaries) — оплаты в пользу тех мерчантов, которые по инициативе или с согласия держателя карты занесены в список доверенных.
  • Безопасные корпоративные платежи (Corporate payments) — оплаты, инициируемые юридическими лицами с использованием процессов и протоколов, обеспечивающих высокий уровень защиты от мошенничества.

В платёжной платформе поддерживается работа с исключениями для платежей с использованием карт платёжных систем Mastercard и Visa в рамках первых двух категорий (на незначительные суммы и с низким уровнем риска).

Работа с допустимыми исключениями

Применение исключений может помочь снизить количество действий со стороны пользователя и положительно влиять на проходимость платежей. При этом ответственность за возможные мошеннические действия для таких платежей возлагается на мерчанта.

Если эта возможность подключена, соответствующие исключения применяются автоматически, кроме отдельных платежей, для которых со стороны мерчанта указано предпочтительное выполнение аутентификации. При этом следует учитывать, что в случае проведения платежа, который относится к исключениям, решение о необходимости аутентификации остаётся за эмитентом. С его стороны может быть направлен «мягкий отказ» (soft decline), означающий необходимость выполнения аутентификации. В случае получения такого отказа аутентификация для искомого платежа выполняется стандартно, без применения исключений, и, как правило, в варианте challenge flow. Кроме того, исключения не могут применяться при регистрации повторяемой оплаты — в этом случае выполнение аутентификации 3‑D Secure обязательно.

Информация о применённых исключениях передаётся в оповещениях о результатах платежей и отображается карточках платежей в интерфейсе Dashboard. По вопросам, касающимся подключения этой возможности, можно обращаться к курирующему менеджеру ecommpay.

Схемы работы

В платёжной платформе ecommpay аутентификация 3‑D Secure может выполняться при проведении карточных одностадийных и двухстадийных оплат, а также при проверках действительности платёжных карт. При этом может использоваться одна из двух схем выполнения аутентификации: базовая (proxy) или расширенная (native).

Базовая схема может требовать меньшего количества работ со стороны мерчанта, но при этом требует дополнительных перенаправлений пользователя, тогда как расширенная схема исключает такие перенаправления, но может требовать большего количества работ. Со стороны мерчанта можно выбрать любую из этих схем, однако рекомендуется использовать расширенную, так как она позволяет обеспечить лучший пользовательский опыт и может положительно влиять на проходимость платежей.

Перейти от использования базовой схемы к использованию расширенной можно в любое время, без дополнительных согласований со специалистами ecommpay. Для этого достаточно передать в запросе на проведение платежа параметры, обязательные для расширенной схемы. Эти параметры перечислены далее, в разделе Формат запросов на проведение платежей.

Пользовательские сценарии

В зависимости от используемой схемы, варианта аутентификации, выбранного эмитентом, и других факторов процесс аутентификации может выглядеть по-разному. Так, при аутентификации пользователю могут отображаться страница ожидания на стороне веб-сервиса или платформы и ACS-страница на стороне эмитента.

На примере расширенной схемы пользовательский сценарий может выглядеть следующим образом.

Схемы работы

Базовая схема

В платёжной платформе информирование мерчанта о необходимости аутентификации 3‑D Secure осуществляется через оповещения, при приёме которых, как обычно при работе с платформой, необходимо отправлять ответы.

В базовой схеме оповещения о необходимости аутентификации содержат объект acs, и в качестве реагирования на такие оповещения необходимо перенаправить пользователя на страницу эмитента, принять сведения о результате аутентификации и отправить эти сведения в запросе на продолжение платежа. Время ожидания в платформе такого запроса составляет, как правило, 30 минут и измеряется с момента выявления необходимости аутентификации и до получения запроса от веб-сервиса. Если время ожидания истекло и запрос не принят — платёж автоматически отклоняется.

После поступления в платёжную платформу информации о результате аутентификации проведение платежа продолжается. В случае, если подключено каскадное проведение платежей, может понадобиться принять одно или несколько дополнительных оповещений о необходимости аутентификации 3‑D Secure. Если полученное оповещение содержит параметр cascading_with_redirect со значением true, необходимо:

  • Отобразить пользователю страницу с сообщением об ошибке и получить его согласие на повторную аутентификацию.
  • Отреагировать на оповещение необходимым способом.

Информацию о каскадном проведении платежей можно получить в соответствующей статье или у специалистов технической поддержки ecommpay.

Рис. 6. Выполнение аутентификации 3‑D Secure по базовой схеме. Описание шагов
  1. В платёжной платформе выполняется обработка запроса и выявляется необходимость аутентификации 3‑D Secure.
  2. От платёжной платформы к 3DS‑серверу, связанному с платёжной платформой, передаётся запрос на проверку возможности аутентификации.
  3. На стороне 3DS‑сервера проверяется возможность аутентификации.
  4. От 3DS‑сервера к платёжной платформе направляются данные для перенаправления пользователя.
  5. От платёжной платформы к веб-сервису направляется оповещение с данными для перенаправления пользователя.
  6. От веб-сервиса к платёжной платформе направляется ответ о приёме данных.
  7. Со стороны веб-сервиса выполняется перенаправление пользователя на страницу ожидания платёжной платформы.
  8. Пользователю отображается страница ожидания платёжной платформы.
  9. Со стороны платёжной платформы выполняется открытие объекта iframe.
  10. С помощью объекта iframe выполняются сбор данных об устройстве пользователя и отправка этих данных к серверу управления доступом (Access Control Server) эмитента.
  11. От сервера управления доступом к платёжной платформе направляется уведомление о приёме этих данных.
  12. От платёжной платформы к 3DS-серверу передаётся запрос на аутентификацию пользователя.
  13. Запрос передаётся от 3DS‑сервера к серверу каталогов международной платёжной системы (Directory Server).
  14. Запрос передаётся от сервера каталогов к серверу управления доступом.
  15. На стороне эмитента выполняется аутентификация пользователя. При этом в случае выбора эмитентом варианта аутентификации frictionless flow от сервера управления доступом к платёжной платформе (через сервер каталогов и 3DS-сервер) передаётся информация о результате аутентификации и пользователь перенаправляется к веб-сервису, а в случае выбора варианта аутентификации challenge flow выполняются следующие шаги:
    • От сервера управления доступом к серверу каталогов и далее к 3DS-серверу и платёжной платформе передаются данные для перенаправления пользователя на страницу аутентификации (ACS URL).
    • Со стороны платёжной платформы выполняется перенаправление пользователя на страницу аутентификации.
    • Пользователю отображается страница аутентификации, после чего он осуществляет требуемые действия.
    • На стороне эмитента выполняется проверка подлинности пользователя.
    • От сервера управления доступом к серверу каталогов и далее к 3DS-серверу передаётся информация о результате проверки.
    • От 3DS‑сервера к серверу каталогов и далее к серверу управления доступом передаётся ответ о приёме этой информации.
    • От сервера управления доступом выполняется перенаправление пользователя на страницу ожидания платёжной платформы.
    • Пользователю отображается страница ожидания платёжной платформы.
    • Со стороны платёжной платформы выполняется перенаправление пользователя к веб-сервису с передачей данных о результате аутентификации.
    • Пользователю отображается страница ожидания веб-сервиса.
  16. От веб-сервиса на заданный URL ecommpay передаётся запрос на продолжение проведения платежа с учётом результата аутентификации.
  17. Запрос поступает в платёжную платформу.
  18. В платёжной платформе выполняется приём запроса с проверкой его корректности.
  19. От платёжной платформы к веб-сервису направляется ответ с информацией о получении запроса и его корректности.

Информация о форматах запросов и оповещений приведена далее; общая информация о работе с API — в разделе Организация взаимодействия.

Расширенная схема

В платёжной платформе информирование о необходимости аутентификации 3‑D Secure осуществляется через оповещения, при приёме которых необходимо отправлять ответы. Такое информирование не осуществляется только в тех случаях, когда со стороны эмитента принято решение об аутентификации пользователя без предоставления дополнительных сведений. В этих случаях со стороны веб-сервиса не требуется действий, отличных от стандартных при проведении платежа, а информация о результате аутентификации передаётся в итоговом оповещении.

При использовании расширенной схемы оповещение о необходимости аутентификации содержит объект iframe (в объекте threeds2). В качестве реагирования на это оповещение необходимо:

  1. Отобразить пользователю элемента iframe с использованием данных из оповещения.
  2. Принять от сервера управления доступом (ACS) эмитента уведомление о приёме данных и отправить в платёжную платформу запрос на инициирование аутентификации.
  3. В случае выбора эмитентом варианта аутентификации frictionless flow — принять информацию о результате аутентификации, а в случае выбора варианта аутентификации challenge flow выполнить следущие действия:
    • принять от платёжной платформы оповещение с объектом redirect (в объекте threeds2) и отправить ответ о приёме этого оповещения;
    • перенаправить пользователя на страницу аутентификации в течение 30 секунд после приёма оповещения;
    • принять от эмитента данных о результате аутентификации;
    • отправить в платформу запрос на продолжение проведение платежа с учётом результата аутентификации (3ds_result) в течение 30 минут после выявления необходимости аутентификации.

После поступления в платёжную платформу информации о результате аутентификации проведение платежа продолжается. В случае, если подключено каскадное проведение платежей, может понадобиться принять одно или несколько дополнительных оповещений с объектом redirect. Если такое оповещение содержит параметр cascading_with_redirect со значением true, необходимо:

  • Отобразить пользователю страницу с сообщением об ошибке и получить его согласие на повторную аутентификацию.
  • Отреагировать на оповещение необходимым способом.

Информацию о каскадном проведении платежей можно получить в соответствующей статье или у специалистов технической поддержки support@ecommpay.com.

Рис. 7. Выполнение аутентификации 3‑D Secure по расширенной схеме. Описание шагов
  1. В платёжной платформе выполняется обработка запроса и выявляется необходимость аутентификации 3‑D Secure.
  2. От платёжной платформы к 3DS‑серверу, связанному с платёжной платформой, передаётся запрос на проверку возможности аутентификации.
  3. На стороне 3DS‑сервера проверяется возможность аутентификации.
  4. От 3DS‑сервера к платёжной платформе направляются данные для формирования объекта iframe.
  5. От платёжной платформы к веб-сервису направляется оповещение с данными для формирования объекта iframe.
  6. От веб-сервиса к платёжной платформе направляется ответ о приёме данных.
  7. На стороне веб-сервиса выполняется открытие объекта iframe.
  8. С помощью объекта iframe выполняются сбор данных об устройстве пользователя и отправка этих данных к серверу управления доступом (Access Control Server) эмитента.
  9. От эмитента к веб-сервису передаётся уведомление о приёме данных.
  10. От веб-сервиса на заданный URL ecommpay передаётся запрос на инициирование аутентификации пользователя.
  11. Запрос поступает в платёжную платформу.
  12. В платёжной платформе выполняется приём запроса с проверкой его корректности.
  13. От платёжной платформы к веб-сервису направляется ответ с информацией о получении запроса и его корректности.
  14. От платёжной платформы к 3DS-серверу передаётся запрос на аутентификацию пользователя.
  15. Запрос передаётся от 3DS‑сервера к серверу каталогов международной платёжной системы (Directory Server).
  16. Запрос передаётся от сервера каталогов к серверу управления доступом.
  17. На стороне эмитента выполняется аутентификация пользователя. При этом в случае выбора эмитентом варианта аутентификации frictionless flow от сервера управления доступом к платёжной платформе (через сервер каталогов и 3DS-сервер) передаётся информация о результате аутентификации, а в случае выбора варианта аутентификации challenge flow выполняются следующие шаги:
    • От сервера управления доступом к серверу каталогов и далее к 3DS-серверу и платёжной платформе передаются данные для перенаправления пользователя на страницу аутентификации (ACS URL).
    • От платёжной платформы к веб-сервису направляется оповещения с данными для перенаправления.
    • Со стороны веб-сервиса выполняется перенаправление пользователя на страницу аутентификации.
    • Пользователю отображается страница аутентификации, после чего он осуществляет требуемые действия.
    • На стороне эмитента выполняется аутентификация пользователя.
    • От сервера контроля доступа к серверу каталогов и далее к 3DS-серверу передаётся информация о результате проверки.
    • От 3DS‑сервера к серверу каталогов и далее к серверу управления доступом передаётся ответ о приёме этой информации.
    • Со стороны сервера управления доступом выполняется перенаправление пользователя к веб-сервису с передачей данных о результате аутентификации.
    • Пользователю отображается страница ожидания веб-сервиса.
    • От веб-сервиса на заданный URL ecommpay передаётся запрос на продолжение проведения платежа с учётом результата аутентификации.
    • Запрос поступает в платёжную платформу.
    • В платёжной платформе выполняется приём запроса с проверкой его корректности.
    • От платёжной платформы к веб-сервису направляется ответ с информацией о получении запроса и его корректности.

Информация о форматах оповещений и запросов, используемых в этой схеме, приведена в разделе Форматы промежуточных сообщений для расширенной схемы; общая информация о работе с Gate API — в статье Организация взаимодействия.

Работа со сведениями об устройстве пользователя

Независимо от используемой схемы аутентификации (базовой или расширенной) в любых запросах на проведение платежей рекомендуется передавать ряд необязательных параметров, поскольку это может повышать вероятность выбора варианта аутентификации frictionless flow, который не требует участия пользователя. К числу таких параметров, наряду с перечисленными далее сведениями о пользователе и платеже, относятся сведения об устройстве и браузере пользователя:

  • Сведения об устройстве, определяемые на клиентской стороне веб-сервиса:
    • accept_header — значение HTTP-заголовка Accept;
    • accept_language_header — значение параметра Accept-Language, которое указывает предпочтения в языке локализации;
    • browser — значение HTTP-заголовка User-Agent;
    • ip_address — IP-адрес пользователя, актуальный для инициируемого платежа.
  • Сведения об устройстве, получаемые из запроса от используемого браузера к веб-сервису:
    • color_depth — глубина цвета используемого браузера, в битах на пиксель;
    • java_enabled — индикатор поддержки сценариев Java в используемом браузере;
    • js_enabled — индикатор поддержки сценариев JavaScript в используемом браузере;
    • language — код языка, выбранного для работы в используемом браузере;
    • screen_res — разрешение экрана используемого устройства, в пикселях и с символом x в качестве разделителя (например, 360x640);
    • timezone_name — название часового пояса, который актуален для используемого браузера (например, Europe/London);
    • timezone_offset — разница между временем для используемого браузера и UTC, в минутах (например, -120).
Рис. 8. Пример указания сведений об устройстве пользователя
    "customer": {
    "ip_address": "188.113.253.90",
    "browser": "Mozilla/5.0 (Linux; Android 14; SM-A155F Build/UP1A.231005.007; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/138.0.7204.67 Mobile Safari/537.36",
    "screen_res": "384x832",
    "language": "en_US",
    "accept_header": "*/*",
    "accept_language_header": "en-GB,en;q=0.8,fr;q=0.3",
    "color_depth": 24,
    "java_enabled": false,
    "js_enabled": true,
    "timezone_offset": "-110"
  }

Со стороны веб-сервиса сбор таких сведений можно организовать следующим образом.

  1. Определить сведения об устройстве пользователя в клиентской части веб-сервиса.
    Рис. 9. Пример кода на JavaScript для сбора сведений об устройстве пользователя
    function collectClientData() {
        return {
            // разрешение экрана устройства
            screen_res: `${screen.width}x${screen.height}`,
             
            // код языка, выбранного в браузере
            language: navigator.language,
             
            // глубина цвета браузера
            color_depth: screen.colorDepth,
             
            // индикатор поддержки сценариев Java в браузере
            java_enabled: navigator.javaEnabled(),
             
            // индикатор поддержки сценариев JavaScript в браузере
            js_enabled: true,
             
            // разница между временем для браузера и UTC
            timezone_offset: new Date().getTimezoneOffset().toString(),
        };
    }
  2. Отправить собранные сведения из клиентской в серверную часть веб-сервиса.
    Рис. 10. Пример кода на JavaScript для отправки собранных сведений в серверную часть веб-сервиса
    async function sendClientDataToServer(endpoint = '/api/collect-client-data') {
        try {
            const clientData = collectClientData();
              
            const response = await fetch(endpoint, {
                method: 'POST',
                headers: {
                    'Content-Type': 'application/json',
                    'Accept': '*/*'
                },
                body: JSON.stringify(clientData)
            });
              
            const result = await response.json();
            return result;
        } catch (error) {
            console.error('Ошибка отправки данных:', error);
            throw error;
        }
    }
  3. Дополнить эти сведения полученными из запроса от браузера пользователя к веб-сервису, а также другими необходимыми для отправки запроса параметрами в серверной части веб-сервиса, сформировать подпись и отправить запрос на рабочий URL ecommpay.
    Рис. 11. Пример кода на PHP для формирования запроса (с базовым набором параметров и сведениями об устройстве пользователя)
    interface CustomerData
    {
        public function getIpAddress(): ?string;
     
        public function getAcceptHeader(): ?string;
     
        public function getAcceptLanguageHeader(): ?string;
     
        public function getScreenRes(): ?string;
     
        public function getBrowser(): ?string;
     
        public function getLanguage(): ?string;
     
        public function getColorDepth(): ?int;
     
        public function getJavaEnabled(): ?bool;
     
        public function getJsEnabled(): ?bool;
     
        public function getTimezoneOffset(): ?string;
    }
     
    interface CardData
    {
        public function getPan();
     
        public function getYear();
     
        public function getMonth();
     
        public function getCardHolder();
     
        public function getCvv();
    }
     
    interface PaymentData
    {
        public function getPaymentId(): string;
     
        public function getAmount(): int;
     
        public function getCurrency(): string;
     
        public function getCardData(): CardData;
     
        public function getCustomerData(): CustomerData;
    }
     
    interface HttpClient
    {
        public function sendRequest(array $request): bool;
    }
     
    interface Signer
    {
        public function sign(array $params): string;
    }
     
    final class PaymentController
    {
        public function __construct(
            private Signer $signer,
            private HttpClient $httpClient,
            private int $projectId,
        ) {}
     
        public function processPayment(PaymentData $paymentData): void
        {
            $paymentRequest = [
                'general' => [
                    'project_id' => $this->projectId,
                    'payment_id' => $paymentData->getPaymentId(),
                ],
                'customer' => $this->prepareCustomerData($paymentData->getCustomerData()),
                'payment' => [
                    'amount' => $paymentData->getAmount(),
                    'currency' => $paymentData->getCurrency(),
                ],
                'card' => [
                    'pan' => $paymentData->getCardData()->getPan(),
                    'year' => $paymentData->getCardData()->getYear(),
                    'month' => $paymentData->getCardData()->getMonth(),
                    'card_holder' => $paymentData->getCardData()->getCardHolder(),
                    'cvv' => $paymentData->getCardData()->getCvv(),
                ],
            ];
     
            $paymentRequest['general']['signature'] = $this->signer->sign($paymentRequest);
     
            $this->httpClient->sendRequest($paymentRequest);
        }
     
        private function prepareCustomerData(CustomerData $customerData): array
        {
            return array_filter([
                'ip_address' => $customerData->getIpAddress(),
                'browser' => $customerData->getBrowser(),
                'screen_res' => $customerData->getScreenRes(),
                'language' => $customerData->getLanguage(),
                'accept_header' => $customerData->getAcceptHeader(),
                'accept_language_header' => $customerData->getAcceptLanguageHeader(),
                'color_depth' => $customerData->getColorDepth(),
                'java_enabled' => $customerData->getJavaEnabled(),
                'js_enabled' => $customerData->getJsEnabled(),
                'timezone_offset' => $customerData->getTimezoneOffset(),
            ]);
        }
    }
    Рис. 12. Пример кода на Go для формирования запроса (с базовым набором параметров и сведениями об устройстве пользователя)
    package main
     
    import "encoding/json"
     
    // CustomerData interface
    type CustomerData interface {
        GetIpAddress() *string
        GetAcceptHeader() *string
        GetAcceptLanguageHeader() *string
        GetScreenRes() *string
        GetBrowser() *string
        GetLanguage() *string
        GetColorDepth() *int
        GetJavaEnabled() *bool
        GetJsEnabled() *bool
        GetTimezoneOffset() *string
    }
     
    // CardData interface
    type CardData interface {
        GetPan() interface{}
        GetYear() interface{}
        GetMonth() interface{}
        GetCardHolder() interface{}
        GetCvv() interface{}
    }
     
    // PaymentData interface
    type PaymentData interface {
        GetPaymentId() string
        GetAmount() int
        GetCurrency() string
        GetCardData() CardData
        GetCustomerData() CustomerData
    }
     
    // HttpClient interface
    type HttpClient interface {
        SendRequest(request map[string]interface{}) bool
    }
     
    // Signer interface
    type Signer interface {
        Sign(params map[string]interface{}) string
    }
     
    // PaymentController struct
    type PaymentController struct {
        signer     Signer
        httpClient HttpClient
        projectId  int
    }
     
    // NewPaymentController constructor
    func NewPaymentController(signer Signer, httpClient HttpClient, projectId int) *PaymentController {
        return &PaymentController{
            signer:     signer,
            httpClient: httpClient,
            projectId:  projectId,
        }
    }
     
    // ProcessPayment processes the payment
    func (pc *PaymentController) ProcessPayment(paymentData PaymentData) {
        cardData := paymentData.GetCardData()
     
        paymentRequest := map[string]interface{}{
            "general": map[string]interface{}{
                "project_id": pc.projectId,
                "payment_id": paymentData.GetPaymentId(),
            },
            "customer": pc.prepareCustomerData(paymentData.GetCustomerData()),
            "payment": map[string]interface{}{
                "amount":   paymentData.GetAmount(),
                "currency": paymentData.GetCurrency(),
            },
            "card": map[string]interface{}{
                "pan":         cardData.GetPan(),
                "year":        cardData.GetYear(),
                "month":       cardData.GetMonth(),
                "card_holder": cardData.GetCardHolder(),
                "cvv":         cardData.GetCvv(),
            },
        }
     
        // Add signature
        general := paymentRequest["general"].(map[string]interface{})
        general["signature"] = pc.signer.Sign(paymentRequest)
     
        // Send request
        pc.httpClient.SendRequest(paymentRequest)
    }
     
    // prepareCustomerData filters and prepares customer data
    func (pc *PaymentController) prepareCustomerData(customerData CustomerData) map[string]interface{} {
        result := make(map[string]interface{})
     
        if v := customerData.GetIpAddress(); v != nil {
            result["ip_address"] = *v
        }
        if v := customerData.GetBrowser(); v != nil {
            result["browser"] = *v
        }
        if v := customerData.GetScreenRes(); v != nil {
            result["screen_res"] = *v
        }
        if v := customerData.GetLanguage(); v != nil {
            result["language"] = *v
        }
        if v := customerData.GetAcceptHeader(); v != nil {
            result["accept_header"] = *v
        }
        if v := customerData.GetAcceptLanguageHeader(); v != nil {
            result["accept_language_header"] = *v
        }
        if v := customerData.GetColorDepth(); v != nil {
            result["color_depth"] = *v
        }
        if v := customerData.GetJavaEnabled(); v != nil {
            result["java_enabled"] = *v
        }
        if v := customerData.GetJsEnabled(); v != nil {
            result["js_enabled"] = *v
        }
        if v := customerData.GetTimezoneOffset(); v != nil {
            result["timezone_offset"] = *v
        }
     
        return result
    }

Следует учитывать, что представленные здесь примеры кода для работы со сведениями об устройстве пользователя носят информативный характер и не допускают их использования в прямом виде («как есть») без проверки и доработки на соответствие всем актуальным требованиям на стороне веб-сервиса, включая требования PCI DSS.

Формат запросов на проведение платежей

Общая информация

Формат запросов на проведение платежей не влияет на возможность выполнения аутентификации 3‑D Secure и должен соответствовать описанному в статье Организация взаимодействия. При этом для каждого запроса может быть актуальным свой набор параметров:

  • в любом случае должны использоваться параметры, обязательные для соответствующего типа платежа (подробнее о них — в статьях о типах платежей);
  • в случае применения расширенной схемы аутентификации дополнительно должны использоваться параметры, перечисленные далее как обязательные;
  • в случае, когда предпочтителен вариант аутентификации frictionless flow (без участия пользователя), желательно передавать максимальное число параметров, которые перечислены далее как рекомендуемые;
  • дополнительно могут использоваться любые другие параметры из числа допустимых для конкретного типа платежа.

Обязательные параметры

При использовании базовой схемы аутентификации, как и в случае с проверкой платёжных инструментов, в набор обязательных параметров входят только те параметры, которые обязательны для соответствующего типа платежа. В случае с оплатами с использованием расширенной схемы аутентификации в число обязательных дополнительно включаются следующие объекты и параметры.

Параметр Описание

acs_return_url
object

Объект с адресами веб-сервиса 1

return_url
string

Адрес веб-сервиса для перенаправления пользователя после аутентификации, является обязательным при использовании расширенной схемы 1-11

3ds_notification_url
string

Адрес веб-сервиса для получения уведомления о том, что данные приняты сервером управления доступом. Является обязательным при использовании расширенной схемы 1-21

customer
object

Объект со сведениями о пользователе 2

ip_address
string

IP-адрес пользователя, актуальный для инициируемого платежа 2-12

screen_res
string

Разрешение экрана устройства пользователя, в пикселях и с символом x в качестве разделителя (например, 360x640) 2-22

email
string

Адрес электронной почты пользователя 2-32

phone
string

Номер телефона пользователя, может содержать только цифры, от четырёх до двадцати четырёх 2-42

card
object

Объект со сведениями о платёжной карте пользователя 3

card_holder
string

Имя держателя карты, в соответствии с указанным на карте 3-13

Рекомендуемые параметры

Независимо от используемой схемы аутентификации (базовой или расширенной) в любых запросах на проведение платежей рекомендуется передавать ряд необязательных параметров, перечисленных далее в этом подразделе — поскольку это может повышать вероятность выбора варианта аутентификации frictionless flow, который не требует участия пользователя. Со стороны веб-сервиса можно передавать как полный, так и неполный набор таких параметров, с учётом наличия соответствующей информации. К базовому минимуму параметров, влияющих на решение эмитента о варианте аутентификации, при этом можно отнести платёжный адрес пользователя и сведения о его устройстве и браузере.

Параметр Описание

customer
object

Объект со сведениями о пользователе 2

accept_header
string

Значение HTTP-заголовка Accept, полученного со стороны браузера пользователя 2-12

accept_language_header
string

Значение параметра Accept-Language, которое используется в HTTP-заголовках запросов от браузера пользователя к веб-сервису и указывает предпочтения в языке локализации. Представляет собой строку с перечислением кодов и уровней приоритетности (q-values) использования языков (например, en-GB,en;q=0.8,fr;q=0.3) 2-192

browser
string

Значение HTTP-заголовка User-Agent, полученного со стороны браузера пользователя 2-22

color_depth
integer

Глубина цвета браузера пользователя в битах на пиксель 2-32

java_enabled
boolean

Индикатор поддержки сценариев Java браузером пользователя 2-42

js_enabled
boolean

Индикатор поддержки сценариев JavaScript браузером пользователя 2-52

language
string

Код языка, установленного в браузере пользователя 2-62

screen_res
string

Разрешение экрана устройства пользователя, в пикселях и с символом x в качестве разделителя (например, 360x640) 2-72

timezone_name
string

Название часового пояса браузера пользователя (например, Europe/London) 2-82

timezone_offset
string

Разница между временем браузера пользователя и UTC, указывается в минутах (например, -120) 2-92

address_match
boolean

Указатель совпадения платёжного адреса пользователя с адресом доставки, указанным в объекте shipping.

Возможные значения:
  • Y — совпадает
  • N — не совпадает
2-102

home_phone
string

Номер домашнего телефона пользователя, может содержать только цифры, от четырёх до двадцати четырёх (например, 44991234567) 2-112

work_phone
string

Номер рабочего телефона пользователя, может содержать только цифры, от четырёх до двадцати четырёх (например, 44997654321) 2-122

account
object

Объект, содержащий информацию об учётной записи пользователя на стороне мерчанта 2-132

additional
string

Дополнительная информация об учётной записи пользователя, например её идентификатор; в произвольном формате с использованием до шестидесяти четырёх символов 2-13-12-13

activity_day
integer

Количество попыток проведения оплаты за последние 24 часа, не более трёх символов (999) 2-13-22-13

activity_year
integer

Количество попыток проведения оплаты за последние 365 дней, не более трёх символов (999) 2-13-32-13

age_indicator
string

Количество дней с момента создания учётной записи пользователя. Возможные значения:
  • 01 — платёж проводится без использования учётной записи
  • 02 — 0 дней (учётная запись создана в день проведения платежа)
  • 03 — менее 30 дней
  • 04 — от 30 до 60 дней
  • 05 — более 60 дней
2-13-42-13

auth_data
string

Дополнительная информация об аутентификации на стороне веб-сервиса в произвольном формате. Параметр может содержать не более 255 символов 2-13-52-13

auth_method
string

Указатель способа последней аутентификации пользователя на стороне веб-сервиса. Возможные значения:
  • 01 — доступ без аутентификации
  • 02 — аутентификация с использованием данных, сохранённых на стороне мерчанта
  • 03 — аутентификация с использованием Federated Identity (например, Google Account или Facebook)
  • 04 — аутентификация с использованием аутентификатора, соответствующего стандартам Fast IDentity Online (FIDO)
2-13-62-13

auth_time
string

Дата и время последней аутентификации пользователя на стороне веб-сервиса в формате ДД-ММ-ГГГГчч:мм 2-13-72-13

date
string

Дата создания учётной записи в формате ДД-ММ-ГГГГ 2-13-82-13

change_date
string

Дата последних изменений в учётной записи, за исключением изменения или сброса пароля, в формате ДД-ММ-ГГГГ 2-13-92-13

change_indicator
string

Количество дней с момента последних изменений в учётной записи, за исключением изменения или сброса пароля. Возможные значения:
  • 01 — 0 дней (изменения в день проведения платежа)
  • 02 — менее 30 дней
  • 03 — от 30 до 60 дней
  • 04 — более 60 дней
2-13-102-13

pass_change_date
string

Дата последнего изменения или сброса пароля в формате ДД-ММ-ГГГГ 2-13-112-13

pass_change_indicator
string

Количество дней с момента последнего изменения или сброса пароля. Возможные значения:
  • 01 — пароль не был изменён или сброшен
  • 02 — 0 дней (пароль был изменён или сброшен в день проведения платежа)
  • 03 — менее 30 дней
  • 04 — от 30 до 60 дней
  • 05 — более 60 дней
2-13-122-13

payment_age
string

Дата добавления платёжных данных карты в формате ДД-ММ-ГГГГ 2-13-132-13

payment_age_indicator
string

Количество дней с момента сохранения данных платёжной карты, используемой для проведения платежа, в учётной записи пользователя. Возможные значения:
  • 01 — платёж проводится без аутентификации в учётной записи
  • 02 — 0 дней (данные карты сохранены в день проведения платежа)
  • 03 — менее 30 дней
  • 04 — от 30 до 60 дней
  • 05 — более 60 дней
2-13-142-13

provision_attempts
integer

Количество попыток сохранения новых платёжных данных карты за последние 24 часа, не более трёх символов (999) 2-13-152-13

purchase_number
integer

Количество покупок, совершённых через эту учётную запись за последние 6 месяцев, не более четырёх символов (9999) 2-13-162-13

suspicious_activity
string

Индикатор подозрительной активности. Возможные значения:
  • 01 — без подозрений
  • 02 — с подозрительной активностью
2-13-172-13

email
string

Адрес электронной почты пользователя 2-142

phone
string

Номер телефона пользователя, может содержать только цифры, от четырёх до двадцати четырёх 2-152

billing
object

Объект с информацией о платёжном адресе пользователя 2-162

address
string

Улица платёжного адреса пользователя 2-16-12-16

city
string

Город платёжного адреса пользователя 2-16-22-16

country
string

Страна платёжного адреса пользователя в формате ISO 3166-1 alpha-2 2-16-32-16

postal
string

Почтовый индекс платёжного адреса пользователя 2-16-42-16

region_code
string

Код штата, провинции или региона страны в формате ISO 3166-2, например DEV для графства Девон.

При указании значения этого параметра также необходимо указать значение параметра billing_country

2-16-52-16

shipping
object

Объект, содержащий информацию о доставке 2-172

address
string

Адрес доставки, не более ста пятидесяти символов 2-17-12-17

address_usage
string

Дата первого использования адреса доставки, указанного в параметрах этого объекта, в формате ДД-ММ-ГГГГ 2-17-22-17

address_usage_indicator
string

Количество дней с момента первого использования адреса доставки, указанного в параметрах этого объекта. Возможные значения:
  • 01 — указанный адрес используется впервые
  • 02 — менее 30 дней назад
  • 03 — от 30 до 60 дней назад
  • 04 — более 60 дней назад
2-17-32-17

city
string

Название города доставки, не более пятидесяти символов 2-17-42-17

country
string

Код страны доставки в формате ISO 3166-1 alpha-2 (например, GB) 2-17-52-17

delivery_email
string

Адрес электронной почты в случае доставки на этот адрес. Может содержать не более 255 символов 2-17-62-17

delivery_time
string

Срок доставки. Возможные значения:
  • 01 — электронная доставка в день покупки
  • 02 — доставка в день покупки
  • 03 — доставка на следующий день после покупки
  • 04 — доставка более чем через один день после покупки
2-17-72-17

name_indicator
string

Индикатор совпадения имени пользователя с именем получателя. Возможные значения:
  • 01 — имена совпадают
  • 02 — имена не совпадают
2-17-82-17

postal
string

Почтовый индекс доставки, не более шестнадцати символов 2-17-92-17

region_code
string

Код штата, провинции или региона страны в формате ISO 3166-2, например DOR для графства Дорсет.

При указании значения этого параметра также необходимо указать значение параметра country в объекте shipping

2-17-102-17

type
string

Способ доставки, выбранный пользователем. Возможные значения:
  • 01 — доставка на платёжный адрес держателя карты
  • 02 — доставка на другой подтверждённый адрес
  • 03 — доставка на адрес, не совпадающий с платёжным и не являющийся подтверждённым
  • 04 — доставка в магазин
  • 05 — электронная доставка
  • 06 — без доставки (например, в случае покупки билетов на мероприятие)
  • 07 — другое
2-17-112-17

mpi_result
object

Объект со сведениями о предыдущей аутентификации пользователя 2-182

acs_operation_id
string

Идентификатор предыдущей операции пользователя на стороне эмитента, не более тридцати шести символов. В качестве этого идентификатора необходимо использовать значение, полученное в параметре acs_operation_id оповещения о результате проведения предыдущего платежа 2-18-12-18

authentication_flow
string

Указатель варианта предыдущего прохождения аутентификации пользователем, полученное в параметре authentication_flow оповещения о результате проведения предыдущего платежа.

Возможные значения:

  • 01 — frictionless flow
  • 02 — challenge flow
2-18-22-18

authentication_timestamp
string

Дата и время предыдущей успешной аутентификации пользователя. В качестве значения необходимо использовать данные, полученные в параметре mpi_timestamp оповещения о результате проведения предыдущего платежа 2-18-32-18

payment
object

Объект со сведениями о платеже 3

challenge_indicator
string

Указатель предпочтения по использованию варианта аутентификации challenge flow. Возможные значения:
  • 01 — без предпочтений
  • 02 — предпочтительно не использовать
  • 03 — предпочтительно использовать
  • 04 — обязательно использовать
  • 05 — не использовать, анализ рисков выполнен на стороне мерчанта
  • 06 — не использовать, применить сценарий Data Only
  • 07 — не использовать, Strong Customer Authentication уже выполнена иным способом
  • 08 — не использовать, мерчант включен в список доверенных для этого пользователя
  • 09 — обязательно использовать, предпочтительно предложить пользователю добавить мерчанта в список доверенных
3-13

challenge_window
string

Размер окна для открытия страницы аутентификации. Возможные значения:
  • 01 — 250 x 400 пикселей
  • 02 — 390 x 400 пикселей
  • 03 — 500 x 600 пикселей
  • 04 — 600 x 400 пикселей
  • 05 — полноэкранный режим
3-23

preorder_date
string

Планируемая дата поступления товара или услуги в формате ДД-ММ-ГГГГ 3-33

preorder_purchase
string

Индикатор предварительного заказа. Возможные значения:
  • 01 — не является предварительным заказом
  • 02 — является предварительным заказом
3-43

reorder
string

Индикатор первичной или повторной покупки данного товара или услуги пользователем. Возможные значения:
  • 01 — первичная покупка
  • 02 — повторная покупка
3-53

gift_card
object

Объект со сведениями об оплате предоплаченными или подарочными картами 3-63

amount
integer

Общая сумма оплаты предоплаченными или подарочными картами в минорных единицах валюты 3-6-13-6

currency
string

Код валюты оплаты предоплаченными или подарочными картами в формате ISO 4217 alpha-3 (например, GBP) 3-6-23-6

count
integer

Количество предоплаченных или подарочных карт, использованных для оплаты 3-6-33-6

Форматы промежуточных сообщений для базовой схемы

Формат оповещения о необходимости аутентификации

При использовании базовой схемы аутентификации от платёжной платформы к веб-сервису передаётся оповещение с данными для перенаправления пользователя. Оповещение передаётся в стандартном формате, описание которого представлено в разделе Работа с оповещениями.

Данные для перенаправления пользователя передаются в объекте acs. К таким данным относятся: сообщение CReq (в параметре pa_req) для направления запроса на прохождение аутентификации 3‑D Secure эмитенту, адрес страницы аутентификации (acs_url) и данные мерчанта в платёжной системе — Merchant Data (md).

Рис. 13. Пример данных для перенаправления
"acs":{  
  "pa_req":"inLgICAiYWNzVHIDAtMDAwMDAwMDAwNHv5hu", // Сообщение CReq
  "acs_url":"https://example.com/ACS", // Адрес страницы для перенаправления
  "md":"eyJwdXJjaGFzZV9vcGVyYXRpb25faWRfaWJ9" // Данные мерчанта в платёжной системе
}

Формат запроса на перенаправление

Для перенаправления пользователя на страницу аутентификации или страницу провайдера необходимо направить запрос на адрес, полученный в оповещении о необходимости аутентификации. Это должен быть POST-запрос со следующими объектами и параметрами:

  • action — адрес страницы, на которую необходимо перенаправить пользователя, полученный в параметре acs_url оповещения;
  • PaReq — сообщение CReq, полученное в параметре pa_req оповещения;
  • TermUrl — адрес для перенаправления пользователя к веб-сервису после аутентификации;
  • MD — данные мерчанта в международной платёжной системе (Merchant Data), полученные в параметре md оповещения.
Рис. 14. Пример HTML-формы с данными из объекта acs
<form id="3dsform" action="https://example.com/ACS" method="post" enctype="application/
x-www-form-urlencoded">
    <input type="hidden" name="PaReq" value="inLgICAiYWNzVHIDAtMDAwMDAwMDAwNHv5hu" />
    <input type="hidden" name="TermUrl" value="http://example.com/termurl" />
    <input type="hidden" name="MD" value="eyJwdXJjaGFzZV9vcGVyYXRpb25faWRfaWJ9" />
</form>
<script type="text/javascript">
    setTimeout(function() {
        document.getElementById("3dsform").submit();
    }, 1000);
</script>

Для удобства можно воспользоваться готовым примером — Пример HTML-формы, — заменив параметры на актуальные для платежа.

Формат уведомления о результате аутентификации

Данные о результате аутентификации передаются к веб-сервису в параметре pares.

Рис. 15. Пример данных об успешном прохождении аутентификации по базовой схеме
pares=eyJ4aWQiOiJNREF3TURBd01EQXdNREF5TkRBd01ERXhNVFU9IiwibWRTdGF0dXMiOjEsIm1kRXJyb3JNc2ciOiJBdXRoZW50aWNhdGVkIiwiZW5yb2xsbWVuU3RhdHVzIjpudWxsLCJhdXRoZW50aWNhdGlvblN0YXR1cyI6IlkiLCJjYXZ2IjoiUVVOVFJVMVZLMkI5UFV4MWFXRXBhMlJpTjJVPSIsImVjaSI6IjA1In0=
Рис. 16. Пример данных об ошибке при прохождении аутентификации по базовой схеме
pares=eyJ4aWQiOiJNREF3TURBd01EQXdNREF5TkRBd01ERXhNVFk9IiwibWRTdGF0dXMiOjAsIm1kRXJyb3JNc2ciOiJOb3QgYXV0aGVudGljYXRlZCIsImVucm9sbG1lblN0YXR1cyI6bnVsbCwiYXV0aGVudGljYXRpb25TdGF0dXMiOiJOIiwiY2F2diI6IiIsImVjaSI6IiJ9

Формат запроса на продолжение платежа

Для продолжения проведения платежа с учётом результата аутентификации необходимо отправить в платёжную платформу POST-запрос к конечной точке /v2/payment/card/3ds_result. В этом запросе должны использоваться следующие объекты и параметры:

  • general — объект, содержащий основные идентификационные сведения запроса:
    • project_id — идентификатор проекта, полученный от ecommpay при интеграции;
    • payment_id — идентификатор платежа, уникальный в рамках проекта;
    • signature — подпись к данным запроса, составленная после указания целевых параметров (подробнее — в разделе Работа с подписью к данным).
  • pares — сведения о результате аутентификации 3‑D Secure, полученные в уведомлении.

Таким образом, корректный запрос на продолжение проведения платежа с учётом результата аутентификации 3‑D Secure должен содержать идентификаторы проекта и платежа, подпись и данные о результате аутентификации.

Рис. 17. Пример набора данных в запросе на продолжение проведения платежа
{
   "general": {
   "project_id": 42,
   "payment_id": "456789",
   "signature": "v7KNMpfogAxwRIL9tVftZ1ZZ5D/aZAeb0VMdeR+CqGrNxYyilUwSm...=="
   },
   "pares": "ewogICJhY3NUcmFuc0lEIiA6ICJkYTIyNjY0Mi1hYzJhLTQ0N2ItYWFiYS1lNWI2Nzc2MjdmZmMi
LAogICJtZXNzYWdlVHlwZSIgOiAiQ1JlcyIsCiAgIm1lc3NhZ2VWZXJzaW9uIiA6ICIyLjEuMCIsCiAgInRocmVlR
FNTZXJ2ZXJUcmFuc0lEIiA6ICI5ZjE3OWM0My02NjA2LTU3YWUtODAwMC0wMDAwMDAwMDA3ZGQiLAogICJ0cmFuc1
N0YXR1cyIgOiAiWSIKfQ"
  // Сведения о результате аутентификации
}

Форматы промежуточных сообщений для расширенной схемы

Формат оповещения с данными для объекта iframe

При расширенной схеме аутентификации через Gate от платёжной платформы к веб-сервису могут передаваться оповещения с данными для формирования объекта iframe. Для этих оповещений используется стандартный формат, описание которого представлено в разделе Работа с оповещениями.

Оповещения с данными для формирования объекта iframe не передаются, если со стороны эмитента без использования данных об устройстве пользователя принято одно из следующих решений:

  • Выполнить проверку пользователя с перенаправлением на страницу аутентификации (вариант challenge flow). В этом случае со стороны веб-сервиса необходимо принять и обработать оповещение с данными для перенаправления (подробнее — ниже).
  • Аутентифицировать пользователя (вариант frictionless flow). В этом случае со стороны веб-сервиса необходимо принять и обработать оповещение о результате проведения платежа.

Следующий пример содержит данные для формирования объекта iframe. Эти данные необходимо использовать следующим образом: адрес из параметра url — в атрибуте action, а данные из других параметров — в тегах input.

Рис. 18. Пример данных для формирования объекта iframe
{ 
  "threeds2":{ 
    "iframe":{ 
      "url":"https://example.com",
      "params":{
        "3DSMethodData":"eyAidGhyZWVNrkthelJSUFQwaWZYMCUzQ",
        "threeDSMethodData":"eyAidGhjNjMGQ4YWU4LTA2u0wyWmtObGRdwR"
      }
    }
  }
}
Рис. 19. Пример разметки HTML-страницы для объекта iframe
<iframe id="tdsMmethodTgtFrame" name="tdsMmethodTgtFrame" style="width: 1px; height: 1px; 
display: none;" src="javascript:false;" xmlns="http://example.com/xhtml"> <!--.--> </iframe>
<form id="tdsMmethodForm" name="tdsMmethodForm" action="https://example.com" method="post" 
target="tdsMmethodTgtFrame" xmlns="http://example.com/xhtml">
    <input type="hidden" name="3DSMethodData" value="eyAidGhyZWVNrkthelJSUFQwaWZYMCUzQ"
    />
    <input type="hidden" name="threeDSMethodData" value="eyAidGhjNjMGQ4YWU4LTA2u0wyWmtObGRdwR"
    />
</form>
<script type="text/javascript" xmlns="http://example.com/xhtml">
    document.getElementById("tdsMmethodForm").submit();
</script>

Формат оповещения о необходимости аутентификации

При использовании расширенной схемы аутентификации через Gate от платёжной платформы к веб-сервису могут передаваться оповещения с данными для перенаправления пользователя на страницу аутентификации (ACS URL) эмитента. Оповещения передаются в стандартном формате, описание которого представлено в разделе Работа с оповещениями. Оповещения с данными для перенаправления пользователя на страницу аутентификации не передаются в случаях, если на стороне эмитента выбран вариант аутентификации frictionless flow. Вместо такого оповещения со стороны веб-сервиса необходимо принять и обработать оповещение о результате проведения платежа.

Следующий пример содержит данные для перенаправления пользователя на страницу аутентификации. Эти данные необходимо использовать следующим образом: адрес из параметра url — в атрибуте action, а данные из других параметров — в тегах input.

Рис. 20. Пример данных для перенаправления пользователя
{ 
  "threeds2":{ 
    "redirect":{ 
      "url":"https://example.com/ACS",
      "params":{
        "creq":"ewogICAiYWNzVHJhbnNJCIDAtMDAwMDAwMDAwN2Q5Ip9",
        "threeDSSessionData":"240000549"
      }
    }
  }
}
Рис. 21. Пример разметки HTML-страницы для перенаправления пользователя
<!DOCTYPE html SYSTEM "about:legacy-compat">
<html class="no-js" lang="en" xmlns="http://example.com/xhtml">
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <meta charset="utf-8" />
    <title>3D Secure Processing</title>
    <link href="https://example.com/mpi.css" rel="stylesheet" type="text/css" />
  </head>
  <body>
    <div id="main">
      <div id="content">
        <div id="order">
          <h2>3D Secure Processing</h2>
          <img src="https://example.com/preloader.gif" alt="Please wait.." /> <img src="https://
example.com/verifiedbyvisa.png" alt="Verified by VISA" />
          <div id="formdiv">
            <script type="text/javascript">
              function hideAndSubmitTimed(formid) { timer=setTimeout("hideAndSubmit('"+formid+"');",
100);} function hideAndSubmit(formid) { var formx=document.getElementById(formid); tif (formx!=null)
{ formx.style.visibility="hidden"; formx.submit(); } }
            </script>
            <div>
              <form id="webform0" name="red2ACSv2" method="POST" action="https://
example.com/ACS" accept_charset="UTF-8"> 
<input type="hidden" name="_charset_" value="UTF-8" /> 
<input type="hidden" name="creq" value="ewogICAiYWNzVHJhbnNJCIDAtMDAwMDAwMDAwN2Q5Ip9" /> 
<input type="hidden" name="threeDSSessionData" value="240000476" /> 
<input type="submit" name="submitBtn" value="Please click here to continue" /> 
              </form>
            </div>
          </div>
          <script type="text/javascript">
           thideAndSubmitTimed('webform0');
          </script>
          <noscript>
            <div align="center"> <b>Javascript is turned off or not supported!</b> <br/> </div>
          </noscript>
        </div>
      </div>
    </div>
  </body>
</html>

Формат уведомления о приёме данных об устройстве пользователя

При расширенной схеме аутентификации от сервера управления доступом (ACS) эмитента на URL веб-сервиса, указанный в запросе на проведение платежа (в параметре 3ds_notification_url), передаётся уведомление о приёме данных об устройстве пользователя. Это уведомление передаётся в формате эмитента.

Рис. 22. Пример идентификатора операции на стороне 3DS-сервера
threeDSServerTransID=3abd37b3-afa6-53cf-8000-000000006455

Формат запроса на инициирование аутентификации

При расширенной схеме аутентификации для инициирования аутентификации необходимо отправить в платёжную платформу POST-запрос к конечной точке /v2/payment/card/3ds_check_iframe. В запросе к этой конечной точке должны использоваться следующие объекты и параметры:

  • general — объект, содержащий основные идентификационные сведения запроса:
    • project_id — идентификатор проекта, полученный от ecommpay;
    • payment_id — идентификатор платежа, уникальный в рамках проекта;
    • signature — подпись к данным запроса, составленная после указания целевых параметров (подробнее — в разделе Работа с подписью к данным).
  • threeds_completion_indicator — указатель получения уведомления о приёме данных в течение десяти секунд после открытия объекта iframe. Необходимо передать значение true при получении уведомления и значение false при его отсутствии в заданный период.

Таким образом, корректный запрос на инициирование аутентификации 3‑D Secure должен содержать идентификаторы проекта и платежа и подпись.

Рис. 23. Пример набора данных в запросе на инициирование аутентификации
{ 
  "general":{ 
    "project_id":42,
    "payment_id":"456789",
    "signature":"v7KNMpfogAxwRIL9tVftZ1ZZ5D/aZAeb0VMdeR+CqGrNxYyilUwSm...=="
  },
  "threeds_completion_indicator":true
}

Формат уведомления о результате аутентификации

При использовании расширенной схемы аутентификации через Gate данные о результате аутентификации передаются к веб-сервису в формате эмитента. Эти данные передаются в параметре cres уведомления.

Рис. 24. Пример данных об успешном прохождении аутентификации по расширенной схеме
cres=ewogICJhY3NUcmFuc0lEIiA6ICJkYTIyNjY0Mi1hYzJhLTQ0N2ItYWFiYS1lNWI2Nzc2MjdmZmMiLAogICJtZXNzYWdlVHlwZSIgOiAiQ1JlcyIsCiAgIm1lc3NhZ2VWZXJzaW9uIiA6ICIyLjEuMCIsCiAgInRocmVlRFNTZXJ2ZXJUcmFuc0lEIiA6ICI5ZjE3OWM0My02NjA2LTU3YWUtODAwMC0wMDAwMDAwMDA3ZGQiLAogICJ0cmFuc1N0YXR1cyIgOiAiWSIKfQ&threeDSSessionData=240000554
Рис. 25. Пример данных об ошибке при прохождении аутентификации по расширенной схеме
cres=ewogICAiYWNzUmVmZXJlbmNlTnVtYmVyIiA6ICJBQ1NFbXUyIiwKICAgImFjc1RyYW5zSUQiIDog%0D%0AIjAwMDAwMDAwLTAwMDUtNWE1YS04MDAwLTAxNmQzZTI2ZWU2YyIsCiAgICJtZXNzYWdlVHlwZSIg%0D%0AOiAiQ1JlcyIsCiAgICJtZXNzYWdlVmVyc2lvbiIgOiAiMi4xLjAiLAogICAidGhyZWVEU1NlcnZl%0D%0AclRyYW5zSUQiIDogIjhiMjM0Y2ZmLTkzNjAtNTc5Yy04MDAwLTAwMDAwMDAwMDlhNiIsCiAgICJ0%0D%0AcmFuc1N0YXR1cyIgOiAiTiIKfQ==&threeDSSessionData=240000622

Формат запроса на продолжение платежа

При базовой и расширенной схемах аутентификации через Gate для продолжения проведения платежа с учётом результата аутентификации необходимо отправить в платёжную платформу POST-запрос к конечной точке /v2/payment/card/3ds_result. В этом запросе должны использоваться следующие объекты и параметры:

  • general — объект, содержащий основные идентификационные сведения запроса:
    • project_id — идентификатор проекта, полученный от ecommpay;
    • payment_id — идентификатор платежа, уникальный в рамках проекта;
    • signature — подпись к данным запроса, составленная после указания целевых параметров (подробнее — в разделе Работа с подписью к данным).
  • cres — данные о результате аутентификации 3‑D Secure, полученные в уведомлении от сервера управления доступом.

Таким образом, корректный запрос на продолжение проведения платежа с учётом результата аутентификации 3‑D Secure должен содержать идентификаторы проекта и платежа, подпись и данные о результате аутентификации.

Рис. 26. Пример набора данных в запросе на продолжение проведения платежа
{
   "general": {
   "project_id": 42,
   "payment_id": "456789",
   "signature": "v7KNMpfogAxwRIL9tVftZ1ZZ5D/aZAeb0VMdeR+CqGrNxYyilUwSm...=="
   },
   "cres": "ewogICJhY3NUcmFuc0lEIiA6ICJkYTIyNjY0Mi1hYzJhLTQ0N2ItYWFiYS1lNWI2Nzc2MjdmZmMi
LAogICJtZXNzYWdlVHlwZSIgOiAiQ1JlcyIsCiAgIm1lc3NhZ2VWZXJzaW9uIiA6ICIyLjEuMCIsCiAgInRocmVlR
FNTZXJ2ZXJUcmFuc0lEIiA6ICI5ZjE3OWM0My02NjA2LTU3YWUtODAwMC0wMDAwMDAwMDA3ZGQiLAogICJ0cmFuc1
N0YXR1cyIgOiAiWSIKfQ"
  // Данные о результате аутентификации
}

Формат оповещений о результатах платежей

Информация о результате платежа передаётся от платёжной платформы к веб-сервису в оповещении стандартного формата, описание которого представлено в разделе Работа с оповещениями.

В случае выполнения аутентификации 3‑D Secure при проведении платежа в объекте mpi_result оповещения дополнительно могут передаваться следующие параметры:

  • mpi_operation_id — идентификатор операции на стороне 3DS‑сервера;
  • ds_operation_id — идентификатор операции на стороне cервера каталогов международной платёжной системы;
  • acs_operation_id — идентификатор операции на стороне сервера управления доступом эмитента;
  • mpi_timestamp — дата и время аутентификации;
  • cardholder_info — информация об аутентификации, которую рекомендуется отобразить пользователю при уведомлении о результате проведения платежа;
  • authentication_flow — указатель использованного варианта аутентификации: 01 для frictionless flow или 02 для challenge flow.

По умолчанию эти параметры не передаются. Для того, чтобы получать их в оповещениях, необходимо обратиться в службу технической поддержки support@ecommpay.com.

В случае, если аутентификация не была выполнена в связи с применением исключения, в объекте operation оповещения дополнительно может передаваться параметр non_3ds_reason со значением tra, lve.

Рис. 27. Пример данных из оповещения о результате оплаты с аутентификацией 3‑D Secure
{  
  "account":{  
    "number":"431422******0056",
    "token":"f365bb1729f9b72fd9c09703a751c979f3becc679f29c3e35c91d18070d15654",
    "type":"visa",
    "card_holder":"JOHN SMITH",
    "id":45678,
    "expiry_month":"08",
    "expiry_year":"2025"
  },
  "customer":{  
    "id":"customer_12",
    "phone":"44991234567"
  },
  "payment":{  
    "date":"2019-01-11T13:02:42+0000",
    "id":"456789",
    "method":"card",
    "status":"success",
    "sum":{  
      "amount":400000,
      "currency":"USD"
    },
    "type":"purchase",
    "description":""
  },
  "project_id":42,
  "operation":{  
    "id":969000002636,
    "type":"sale",
    "status":"success",
    "date":"2019-01-11T13:02:42+0000",
    "created_date":"2019-01-11T13:01:45+0000",
    "request_id":"c6eed1eb14c629b4ef20b3b8086d...d04132c34b0088cbc0be4667c",
    "sum_initial":{  
      "amount":400000,
      "currency":"USD"
    },
    "sum_converted":{  
      "amount":400000,
      "currency":"USD"
    },
    "provider":{  
      "id":408,
      "payment_id":"330157196",
      "date":"2019-01-11T13:02:32+0000",
      "auth_code":"",
      "endpoint_id":"612266625"
    },
    "mpi_result":{
      "mpi_operation_id":"",
      // Идентификатор операции на стороне 3DS‑сервера
      "ds_operation_id":"",
      // Идентификатор операции на стороне сервера каталогов международной платёжной системы
      "acs_operation_id":"",
      // Идентификатор операции на стороне сервера управления доступом эмитента
      "mpi_timestamp":"YYYYMMDDHHMM",
      // Дата и время выполнения аутентификации
      "cardholder_info":"Additional authentication is needed for this transaction",
      // Информация об аутентификации, которую рекомендуется отобразить пользователю
      "authentication_flow":"02"
      // Информация о варианте аутентификации
    },
    "code":"0",
    "message":"Success",
    "eci":"07"
  },
  "signature":"v7KNMpfogAxwRIL9tVftZ1ZZ5D/aZAeb0VMdeR+CqGrNxYyilUwSm...=="
}