Google Pay
Overview
Introduction
Google Pay is a payment method which allows to process payments in different currencies by using Google Pay services in different regions. This method supports one-time and credential-on-file purchases, refunds, payment card verification and payouts.
This article provides information about working with the Google Pay method: general insights are presented in the Overview section, while information about the actions required to process payments and perform other actions is presented in the sections that follow.
General information
Payment method type | digital wallet payments |
---|---|
Payment instruments | payments cards |
Countries and regions | the list is available at the link |
Payment currencies | all currencies supported by American Express, Mastercard and Visa payment systems in supported regions |
Currency conversion | on the ecommpay side |
One-time purchases | + |
Credential-on-file purchases | + |
Full refunds | + |
Partial refunds | + |
Payouts | + |
Card verification | + |
Chargebacks | + |
Special considerations |
|
Obtaining access to the payment method and access fee | refer to your ecommpay key account manager, additional information available in the ecommpay shop |
Interaction diagram
Payment processing by using the Google Pay payment method requires merchant's web service, oone of ecommpay interfaces, and the ecommpay payment platform, as well as the Google Pay and the issuer bank services.
Operations support
Various platform interfaces can be used to process payments and perform operations using the Google Pay method. Purchases can be processed by using Payment Page, Gate and Dashboard (using payment links), refunds and payouts—by using Gate and Dashboard.
Processing scenarios
To perform a purchases by using the Google Pay method, a customer needs to register a payment card in Google Payapp at one of the supported devices first. Then to perform a purchase, it is required to request the tokenized card details from the Google Pay service by using Google Pay API. When processing a purchase by using Payment Page, ecommpay establishes all interactions with the Google Pay service, when processing a purchase by using Gate, interaction with the Google Pay service is on the merchant web service side. To perform a refund, you need to receive a request from a customer and notify the customer about the result of the refund via the web service. To process a payout, you need to notify the customer via the web service.
Scenarios for performing operations via the main interfaces of the payment platform correspond to those presented in the diagrams. Similarly, when additional features (such as payment links) are used, scenarios for performing operations also correspond to the specifics of those features.
One-time purchases by using Payment Page
General information
To process a purchase through Payment Page by using the Google Pay method, the merchant's web service is required to send a request with all required parameters and signature to the ecommpay URL and receive a callback with the result. The full sequence and special aspects of purchase processing are provided below.
Information about the formats of requests and callbacks used for processing payments by using the Google Pay method via Payment Page is presented further in this section; general information about working with the Payment Page API is presented in Interaction concepts.
Request format
There are several things you need to consider when sending purchase requests by using the Google Pay method:
- The following parameters required for any payment must be specified:
project_id
—project identifier obtained from ecommpay during integrationpayment_id
—payment identifier unique within the projectpayment_currency
—payment currency code in the ISO-4217 alpha-3 formatpayment_amount
—payment amount in the smallest currency unitcustomer_id
—customer identifier unique within the project
- The following parameters required for any payment must be specified:
project_id
,payment_id
,payment_currency
,payment_amount
,customer_id
. - You can choose the way of displaying the
Google Pay
button on Payment Page. There are several ways:- Displaying the
Google Pay
button on the page for entering card details. The customer must first select the Bank cards method on the page for selection a payment method among other payment methods. This option is set by default. - Displaying the
Google Pay
button on the page for selection a payment method among other payment methods. To set this option, contact ecommpay technical support. - Displaying the
Google Pay
button on the page for entering card details by passing the page for the payment method selection. The customer does not need to select the Bank cards method. To set this option, pass the codecard
in theforce_payment_method
parameter. - Displaying only the
Google Pay
button on Payment Page. To set this option, pass the codegoogle_pay_host
in theforce_payment_method
parameter.
- Displaying the
- Additionally, any other parameters available for working with Payment Page can be used (details).
- After all target parameters are specified, generate a signature (details).
Thus, a correct request for opening the payment form using the Google Pay method must contain the project identifier, basic payment information (identifier, amount, and currency code), customer identifier and signature.
Callback format
In the Google Pay method, the callbacks that deliver purchase results use the standard format described in Callbacks.
Note that unlike other payment methods, in the Google Pay method, callbacks containing information about purchases processed with the inclusion of the 3‑D Secure authentication procedure contain the ECI indicator code in the operation.eci
parameter (details); also in this case the service code of the payment method is specified as card
in the payment.method
parameter. At the same time callbacks containing information about purchases processed without the inclusion of the 3‑D Secure authentication procedure do not contain the ECI indicator code and the service code can be specified as card
or etoken-google
.
The callbacks containing information about processed purchases include the token of the card in the token
parameter of the account
object. When the service code of the method is specified as etoken-google
the token can be only used for initiating payouts, and when the code is card
the token can be used for initiating both purchases and payouts.
The following is the example of a callback with an information about a 1,000.00 USD
purchase made in the 688
project by using 431422******0056
payment card without 3‑D Secure authentication.
The following is the example of a callback with an information about a 1,000.00 USD
purchase made in the 688
project by using 431422******0056
payment card with 3‑D Secure authentication.
The following is the example of a callback for a declined purchase with 3‑D Secure authentication.
Useful links
The following articles can be useful when implementing purchases via Payment Page:
- Interaction concepts—about the interaction with the payment platform by using Payment Page.
- Signature generation and verification—about the procedure of generating and verifying signatures in requests and callbacks.
- Payment models and statuses—about the types, processing models, and possible statuses of supported payments and operations.
- One-time one-step purchase—about processing of one-time one-step purchases by using Payment Page.
- Information of operations performing—about error and response codes that are used in the payment platform to record information about performing of operations.
One-time purchases by using Gate
General information
In order to process purchases by using the Google Pay method via Gate, the merchant must adhere to the Google Pay API Acceptable Use Policy and accept the terms defined in the Google Pay API Terms of Service. At the same time, the web service is required to the following:
- Perform the necessary setup required by Google and follow the integration checklist
- Apply for the registration in Google service and receive the Google merchant ID
- Fill in the Google Pay API integration support request form and take the next steps in accordance with the communications from Google. It may be necessary to provide additional integration information to Google
You should also keep in mind that payments using the Google Pay method can be processed in accordance with two scenarios:
- via the Google Pay app (when installed on the customer's compatible device)
- without using the Google Pay app, like a typical card payment (when the app is not installed on the customer's device or the device is not compatible with it).
In the first case, the purchase is processed without 3‑D Secure authentication, and in the second case, it can be carried out both with and without the authentication. To resolve such situations on the web service side, it is necessary to configure a response to callbacks with information about customer redirection and support the two possible scenarios.
When processing a purchase in the Google Pay method without 3‑D Secure authentication, the merchant web service is required to do the following:
- Integrate the
Google Pay
button following the Google Pay brand guidelines and implement the receiving of the token of customer card from Google Pay. - Send a request to Google Pay service for payment form or app opening with the list of saved cards that are available to a customer.
- Send a request to Google Pay service for receiving the token of the card selected by a customer.
- Send a request with all the required parameters and signature to the ecommpay URL.
- Receive the final callback with the payment result from the payment platform.
When processing a purchase in the Google Pay method with 3‑D Secure, the merchant web service is required to do the following:
- Integrate the
Google Pay
button following the Google Pay brand guidelines and implement the receiving of the token of customer card from Google Pay. - Send a request to Google Pay service for payment form or app opening with the list of saved cards that are available to a customer.
- Send a request to Google Pay service for receiving the token of the card selected by a customer.
- Send a request with all the required parameters and signature to the ecommpay URL.
- Get the callback from the platform with data to redirect the customer to the authentication page.
- Redirect the customer to the authentication page to pass 3‑D Secure.
- Send the payment completion request with the result of authentication to the payment platform.
- Receive the final callback with the payment result from the payment platform.
The full sequence and special aspects of purchase processing are provided below.
Information about the formats of requests and callbacks used for processing payments by using the Google Pay method via Gate is presented further in this section. General information about working with the Gate API is presented in Interaction concepts.
Request format
There are several things you need to consider when sending requests for starting the payment session by using the Google Pay method:
- To initiate each purchase, send a separate POST request to one of the following endpoints:
- /v2/payment/googlepay/sale for one-step purchases
- /v2/payment/googlepay/auth for two-step purchases
- Each request must include the following objects and parameters:
- Object
general
—general purchase information:project_id
—project identifier obtained from ecommpay during integrationpayment_id
—payment identifier unique within the projectsignature
—request signature generated after all required parameters are specified (details—in the Signature generation and verification) (details)
- Object
payment
—payment information:amount
—payment amount in the smallest currency unitcurrency
—payment currency code in the ISO-4217 alpha-3 format
- Object
customer
—customer information:id
—customer identifier unique within the projectip_address
—customer IP address relevant for the initiated payment
- Object
etoken
— information about token that represents card details received from the Google Pay service:token
—token with card encrypted details
- Object
- Other mandatory parameters may be required. It depends on the tokenization type that is used in a request to the Google Pay service. For information about what type of tokenization you need to perform purchase in a project, contact ecommpay technical support.
To use
PAYMENT_GATEWAY
tokenization type, customer email is required to specify in theemail
parameter of thecustomer
object.To use
DIRECT
tokenization type, the following parameters must be specified in theetoken
object:google_merchant_id
—merchant ID in the Google Pay servicegoogle_tokenization_type
—theDIRECT
tokenization type
- Additionally, any other parameters included in the specification can be used.
Thus, a correct purchase request by using the Google Pay method with the PAYMENT_GATEWAY
tokenization type must contain the project identifier, basic payment information (identifier, amount, and currency code), customer identifier, IP address and email, as well as signature.
Thus, a correct purchase request by using the Google Pay method with the DIRECT
tokenization type must contain the project identifier, basic payment information (identifier, amount, and currency code), customer identifier and IP address, mechant ID and tokenization type, as well as signature.
Payment completion request format
There are several things you must consider when using payment completion requests in the Google Pay method:
- To complete each purchase, send a separate POST request to the /v2/payment/card/3ds_result endpoint.
- Each request must include the following objects and parameters:
- Object
general
—general purchase information:project_id
—project identifier obtained from ecommpay during integrationpayment_id
—payment identifier unique within the projectsignature
—request signature generated after all required parameters are specified (details—in the Signature generation and verification) (details)
- One of the following parameters:
pares
—the 3‑D Secure authentication result you obtain from the payment platformcres
—the 3‑D Secure authentication result you obtain from the Access Control Server
- Object
Thus, a correct payment completion request by using the Google Pay method must contain the project and payment identifiers, authentication result, as well as signature.
Two-step purchase debiting request format
There are several things you need to consider when sending debiting requests by using the Google Pay method:
- To initiate each debiting, send a separate POST request to one of the following endpoints:
- /v2/payment/googlepay/capture—when the service code of the method is specified as
etoken-google
in the callback containing information about authorisation hold - /v2/payment/card/capture—when the service code of the method is specified as
card
in the callback containing information about authorisation hold
- /v2/payment/googlepay/capture—when the service code of the method is specified as
- Each request must include the following objects and parameters:
- Object
general
—general purchase information:project_id
—project identifier obtained from ecommpay during integrationpayment_id
—payment identifier unique within the projectsignature
—request signature generated after all required parameters are specified (details—in the Signature generation and verification) (details)
- Object
payment
—payment information:amount
—payment amount in the smallest currency unitcurrency
—payment currency code in the ISO-4217 alpha-3 format
- Object
- The amount and currency must match the values in the authorisation request.
- Additionally, any other parameters included in the specification can be used.
Thus, a correct purchase request by using the Google Pay method must contain the project identifier, basic payment information (identifier, amount, and currency code), as well as signature.
Two-step purchase cancellation request format
There are several things you need to consider when sending purchase cancellation requests by using the Google Pay method:
- To initiate each cancellation, send a separate POST request to one of the following endpoints:
- /v2/payment/googlepay/cancel—when the service code of the method is specified as
etoken-google
in the callback containing information about authorisation hold - /v2/payment/card/cancel—when the service code of the method is specified as
card
in the callback containing information about authorisation hold
- /v2/payment/googlepay/cancel—when the service code of the method is specified as
- Each request must include the following objects and parameters:
- Object
general
—general purchase information:project_id
—project identifier obtained from ecommpay during integrationpayment_id
—payment identifier unique within the projectsignature
—request signature generated after all required parameters are specified (details—in the Signature generation and verification) (details)
- Object
- Additionally, any other parameters included in the specification can be used.
Thus, a correct purchase request by using the Google Pay method must contain the project and payment identifiers, as well as signature.
Callback format
In the Google Pay method, the callbacks that deliver purchase results use the standard format described in Callbacks.
Note that unlike other payment methods, in the Google Pay method, callbacks containing information about purchases processed with the inclusion of the 3‑D Secure authentication procedure contain the ECI indicator code in the operation.eci
parameter (details); also in this case the service code of the payment method is specified as card
in the payment.method
parameter. At the same time callbacks containing information about purchases processed without the inclusion of the 3‑D Secure authentication procedure do not contain the ECI indicator code and the service code can be specified as card
or etoken-google
.
The callbacks containing information about processed purchases include the token of the card in the token
parameter of the account
object. When the service code of the method is specified as etoken-google
the token can be only used for initiating payouts, and when the code is card
the token can be used for initiating both purchases and payouts.
The following is the example of a callback with an information about a 1,000.00 USD
purchase made in the 688
project by using 431422******0056
payment card without 3‑D Secure authentication.
The following is the example of a callback with an information about a 1,000.00 USD
purchase made in the 688
project by using 431422******0056
payment card with 3‑D Secure authentication.
The following is the example of a callback for a purchase declined due to insufficient funds on card.
Useful links
The following articles can be useful when implementing purchases via Gate:
- Interaction concepts—about the interaction with the payment platform by using Gate.
- Signature generation and verification—about the procedure of generating and verifying signatures in requests and callbacks.
- Payment models and statuses—about the types, processing models, and possible statuses of supported payments and operations.
- One-time one-step purchase—about processing of one-time one-step purchases by using Payment Page.
- Information of operations performing—about error and response codes that are used in the payment platform to record information about performing of operations.
COF purchases by using Payment Page
General information
The Google Pay payment method provides the ability to perform COF purchases—regular on-demand payments. For more information about COF purchases, see On-demand COF purchase.
Registration of a COF purchases is also available by using Payment Page. For registration the web service must send a request containing the required parameters and signature, as well as data for registering a COF purchase in the recurring
object, to the ecommpay URL and accept a callback with the result. In the callback about registering a COF purchase, you will get its ID, which you need to use to make or cancel regular payments via Gate. For more information, see the section COF purchases by using Gate.
Information about the formats of requests and callbacks used for processing payments by using the Google Pay method via Payment Page is presented further in this section; general information about working with the Payment Page API is presented in Interaction concepts.
Request format
There are several things you need to consider when creating requests to open a payment form for registering COF purchases by using the Google Pay method:
- The following parameters required for any payment must be specified:
project_id
—project identifier obtained from ecommpay during integrationpayment_id
—payment identifier unique within the projectpayment_currency
—payment currency code in the ISO-4217 alpha-3 formatpayment_amount
—payment amount in the smallest currency unitcustomer_id
—customer identifier unique within the project
- The following parameters required for any payment must be specified:
project_id
,payment_id
,payment_currency
,payment_amount
,customer_id
. - To register a COF purchase, you must specify a
recurring
object containing the registration attribute and the necessary information. To register regular payments, the request must contain information about the frequency, amount, and beginning and end time of regular payments. The full list of parameters that can be passed in therecurring
object is shown in the COF purchase registration section. - If you need to have payment form displayed with the Google Pay method selected, set the
force_payment_method
parameter to:google_pay_host
—to open Payment Page with pre-selected payment method Google Paycard
—for the ability of payment by using either a payment card or Google Pay. In this case customer can chose the payment method on Payment Page
- Additionally, any other parameters available for working with Payment Page can be used (details).
- After all target parameters are specified, generate a signature (details).
Thus, a correct request for opening the payment form using the Google Pay method must contain the project identifier, basic payment information (identifier, amount, and currency code), customer identifier and signature.
Callback format
The Google Pay method uses the standard format for callbacks to deliver COF purchase registration results. For more information, see Callbacks.
Note that unlike other payment methods, in the Google Pay method, callbacks containing information about purchases processed with the inclusion of the 3‑D Secure authentication procedure contain the ECI indicator code in the operation.eci
parameter (details); also in this case the service code of the payment method is specified as card
in the payment.method
parameter. At the same time callbacks containing information about purchases processed without the inclusion of the 3‑D Secure authentication procedure do not contain the ECI indicator code and the service code can be specified as card
or etoken-google
.
The callbacks containing information about processed purchases include the token of the card in the token
parameter of the account
object. When the service code of the method is specified as etoken-google
the token can be only used for initiating payouts, and when the code is card
the token can be used for initiating both purchases and payouts.
The following is the example of a callback with an information about a COF purchase registration made by a customer in the 208
project.
Useful links
The following articles can be useful when implementing purchases via Payment Page:
- Interaction concepts—about the interaction with the payment platform by using Payment Page.
- Signature generation and verification—about the procedure of generating and verifying signatures in requests and callbacks.
- Payment models and statuses—about the types, processing models, and possible statuses of supported payments and operations.
- Information of operations performing—about error and response codes that are used in the payment platform to record information about performing of operations.
COF purchases by using Gate
General information
The Google Pay payment method provides the ability to perform COF purchases—regular on-demand payments. For more information about COF purchases, see On-demand COF purchase.
Information about the formats of requests and callbacks used for processing payments by using the Google Pay method via Gate is presented further in this section. General information about working with the Gate API is presented in Interaction concepts.
COF purchase registration
To register a COF purchase by using Gate, the merchant is required to send a request for purchase with all the required parameters (including the register
parameter of the recurring
object, set to the value true
) to the ecommpay URL and get the callback with the payment result from the payment platform. To register a regular payment the request should also contain information about the frequency, amount, start and end dates of regular payments. The COF purchase registration callback contains its identifier, which can be used to process or cancel regular payments.
For more information about purchase processing by using Gate, see One-time purchases by using Gate.
Format of requests for registration of COF purchases
There are several things you need to consider when sending requests for registering COF purchases by using the Google Pay method:
- To register each COF purchase, send a separate POST request to one of the following endpoints /v2/payment/googlepay/sale or /v2/payment/googlepay/auth.
- The following objects and parameters must be specified in the request:
- Object
general
—general purchase information:project_id
—project identifier obtained from ecommpay during integrationpayment_id
—payment identifier unique within the projectsignature
—request signature generated after all required parameters are specified (details—in the Signature generation and verification) (details)
- Object
payment
—payment information:amount
—payment amount in the smallest currency unitcurrency
—payment currency code in the ISO-4217 alpha-3 format
- Object
customer
—customer information:id
—customer identifier unique within the projectip_address
—customer IP address relevant for the initiated payment
- Object
recurring
—COF purchase information:register
—payment registration as a COF purchasetype
—type of the COF purchase:R
(for Regular payment),C
(for OneClick payment), orU
(for Autopayment), for more information, refer to Overviewscheduled_payment_id
—identifier assigned to the payment within which scheduled debits are performed; it must differ from the identifier of the payment made to register a COF purchase and must be unique within the projectstart_date
—the start date of regular payments, in theDD-MM-YYYY
format (must be at least one day later than the date of registration)amount
—amount of debitingperiod
—regular payment performing periodinterval
— regular payment performing intervaltime
—regular payment performing time in thehh:mm:ss (UTC0)
format
- Object
- Additionally, any other parameters included in the specification can be used.
Thus, a correct COF purchase registration request by using the Google Pay method must contain the project identifier, basic payment information (identifier, amount, and currency code), customer identifier and IP address, the registration parameter and the conditions for regular payments, as well as signature.
Format of requests for COF purchase processing
After the payment is registered, the funds are debited according to the specified regular payment conditions. You initiate COF purchase by sending a recurring
request to the payment platform.
There are several things you must consider when processing COF purchases performing by using the Google Pay method:
- To process each COF purchase, send a separate POST request to one of the following endpoints:
- /v2/payment/googlepay/recurring—when the service code of the method is specified as
etoken-google
in the callback containing information about a registered COF purchase - /v2/payment/card/recurring—when the service code of the method is specified as
card
in the callback containing information about a registered COF purchase
- /v2/payment/googlepay/recurring—when the service code of the method is specified as
- The following objects and parameters must be specified in the request:
- Object
general
—general purchase information:project_id
—project identifier obtained from ecommpay during integrationpayment_id
—payment identifier unique within the projectsignature
—request signature generated after all required parameters are specified (details—in the Signature generation and verification) (details)
- Object
payment
—payment information:amount
—payment amount in the smallest currency unitcurrency
—payment currency code in the ISO-4217 alpha-3 format
- Object
customer
—customer information:id
—customer identifier unique within the projectip_address
—customer IP address relevant for the initiated payment
- Object
recurring
—COF purchase information:id
—registered COF purchase identifier
- Object
- Additionally, any other parameters included in the specification can be used.
Thus, a correct purchase request by using the Google Pay method must contain the project identifier, basic payment information (identifier, amount, and currency code), customer identifier and IP address, COF purchase identifier, as well as signature.
Format of request for cancellation of COF purchases
Until the expiration date of COF purchases performing, you can cancel it. Also, to change the conditions of COF purchases, you must cancel it and send a request to register a new one.
There are several things you must consider when cancelling COF purchases by using the Google Pay method:
- To cancel each purchase, send a separate POST request to one of the following endpoints:
-
/v2/payment/googlepay/recurring/cancel—when the service code of the method is specified as
etoken-google
in the callback containing information about a registered COF purchase - /v2/payment/card/recurring/cancel—when the service code of the method is specified as
card
in the callback containing information about a registered COF purchase
-
/v2/payment/googlepay/recurring/cancel—when the service code of the method is specified as
- Each request must include the following objects and parameters:
- Object
general
—general purchase information:project_id
—project identifier obtained from ecommpay during integrationpayment_id
—payment identifier unique within the projectsignature
—request signature generated after all required parameters are specified (details—in the Signature generation and verification) (details)
- Object
recurring
—COF purchase information:id
—registered COF purchase identifier
- Object
- Additionally, any other parameters included in the specification can be used.
Thus, a correct purchase request by using the Google Pay method must contain the project, payment and COF purchase identifiers, as well as signature.
Callback format
The standard format for callbacks is used to deliver the results of actions with COF purchases. For more information, see Callbacks.
The following is the example of a callback with an information about a COF purchase registration for a customer in the 208
project. The title of the payment method is specified as etoken-google
in the payment.method
parameter.
The following is the example of a callback after COF purchase cancellation.
The following is the example of a callback with an information about a declined registration of a COF purchase.
Useful links
The following articles can be useful when implementing purchases via Gate:
- Interaction concepts—about the interaction with the payment platform by using Gate.
- Signature generation and verification—about the procedure of generating and verifying signatures in requests and callbacks.
- Payment models and statuses—about the types, processing models, and possible statuses of supported payments and operations.
- Information of operations performing—about error and response codes that are used in the payment platform to record information about performing of operations.
Refunds by using Gate
General information
To perform a refund through Gate by using the Google Pay method, send a request with all required parameters and signature to the ecommpay URL and receive a callback with the result. The full sequence and special aspects of refund performing are provided below.
Information about the formats of requests and callbacks used for performing refunds by using the Google Pay method via Gate is presented further in this section. General information about working with the Gate API is presented in Interaction concepts.
Request format
There are several things you need to consider when sending refund requests by using the Google Pay method:
- To initiate each refund, send a separate POST request to one of the following endpoints:
- /v2/payment/googlepay/refund—when the service code of the method is specified as
etoken-google
in the callback containing information about a registered COF purchase - /v2/payment/card/refund—when the service code of the method is specified as
card
in the callback containing information about a registered COF purchase
- /v2/payment/googlepay/refund—when the service code of the method is specified as
- The following objects and parameters must be specified in any request:
- Object
general
—general refund information:project_id
—project identifier obtained from ecommpay during integrationpayment_id
—identifier of the payment that needs to be refundedpayment identifiersignature
—request signature generated after all required parameters are specified (details—in the Signature generation and verification)
- Object
payment
—refund information:description
—refund description or commentamount
—refund amount in the smallest currency unit (required for a partial refund)currency
—refund currency code in the ISO-4217 alpha-3 format (required for a partial refund)
- Object
customer
—customer information:ip_address
—customer IP address relevant for the initiated refund
- Object
- Additionally, any other parameters included in the specification can be used.
Thus, a correct refund request by using the Google Pay method must contain the project and payment identifiers, description of the refund, the customer IP address, signature, and, if necessary, currency code and refund amount.
Callback format
The Google Pay method uses the standard format for callbacks to deliver refund results. For more information, see Callbacks.
The following is the example of a callback with an information about a 30,00 USD
refund for the customer account 541333******0019
in the 208
project.
The service code of the payment method can be specified as etoken-google
or card
, depending on the purchase for which the refund is processed.
The following is the example of a callback with information about a declined refund.
Useful links
The following articles can be useful when implementing refunds via Gate:
- Interaction concepts—about the interaction with the payment platform by using Gate.
- Signature generation and verification—about the procedure of generating and verifying signatures in requests and callbacks.
- Payment models and statuses—about the types, processing models, and possible statuses of supported payments and operations.
- Purchase refunds—about performing of refunds by using Gate.
- Information of operations performing—about error and response codes that are used in the payment platform to record information about performing of operations.
Payouts by using Gate
General information
To process a payout through Gate by using the Google Pay method, send a request with all required parameters and signature to the ecommpay URL and receive a callback with the result. The full sequence and special aspects of payout processing are provided below.
Information about the formats of requests and callbacks used for processing payouts by using the Google Pay method via Gate is presented further in this section. General information about working with the Gate API is presented in Interaction concepts.
Request format
There are several things you need to consider when sending payout requests by using the Google Pay method:
- To initiate each payout send a separate POST request to the /v2/payment/card/payout/token endpoint.
- Each request must include the following objects and parameters:
- Object
general
—general payout information:project_id
—project identifier obtained from ecommpay during integrationpayment_id
—payment identifier unique within the projectsignature
—request signature generated after all required parameters are specified (details—in the Signature generation and verification) details
- Object
payment
—payment information:amount
—payout amount in the smallest currency unitcurrency
—payout currency code in the ISO-4217 alpha-3 format
- Object
customer
—customer information:id
—customer identifier unique within the projectfirst_name
—customer first namemiddle_name
—customer middle name or patronymiclast_name
—customer last nameip_address
—customer IP address relevant for the initiated payout
- Object
card
—card information:card_holder
—full name of the cardholder
token
—token of the card received from ecommpay in the parameter included in a callback with information about a processed purchase.
- Object
- In the case of a payout to Visa card issued in Canada, the request must contain the
recipient
object with the payout recipient's address data: - In the case of a payout processed as part of the Visa Money Transfer program to a card issued in Brazil or Qatar, the request must contain the sender's phone number in the
phone
parameter of thesender
object. - In the case of a payout that originates from a physical person and that is processed as part of the programs supported for the Mastercard MoneySend service, the request must contain the information about the payout recipient's name in the
first_name
andlast_name
parameters of therecipient
object and the information about the payout sender in thesender
object:- number of the sender's payment instrument—
pan
for the sender's card orwallet_id
for the sender's electronic wallet first_name
—sender's first namelast_name
—sender's last nameaddress
—sender's addresscity
—sender's cityzip
—sender's postal codecountry
—sender's country code in ISO 3166-1 alpha-2- if the specified country code is CA or US, also pass the
state
parameter that provides information about the sender's state, province, or any other region
- number of the sender's payment instrument—
- Additionally, any other parameters included in the specification can be used.
Thus, a correct payout request by using the Google Pay method must contain the project identifier, basic payment information (identifier, amount, and currency code), customer information, full name of the card holder, as well as token and signature.
Callback format
The Google Pay method uses the standard format for callbacks to deliver payout results. For more information, see Callbacks.
The following is the example of a callback with information about a 1.00 EUR
payout made in the 123
project.
The following is the example of a callback with information about a declined payout.
Useful links
The following articles can be useful when implementing payouts via Gate:
- Interaction concepts—about the interaction with the payment platform by using Gate.
- Signature generation and verification—about the procedure of generating and verifying signatures in requests and callbacks.
- Payment models and statuses—about the types, processing models, and possible statuses of supported payments and operations.
- Payouts—about processing of payouts by using Gate.
- Information of operations performing—about error and response codes that are used in the payment platform to record information about performing of operations.
Payouts by using Dashboard
When working with Dashboard, you can process payouts by using the Google Pay method using batch requests. Each batch can contain one or more payout requests.
To process a number of payouts, prepare and upload a file with information about all target payouts, send a batch request, and verify that the payouts have been processed.
Use a CSV file structured according to the requirements presented in the Mass payments data section. The payout parameters must comply with the requirements (you do not have to generate a signature because it is specified by Dashboard).
More information about processing payouts by using Dashboard is presented in a separate section.
Payment card verification
General information
To perform a payment card verification through the Google Pay method, merchant's web service sends a request with all the required parameters and signature to ecommpay URL, and receives a callback with the result. Payment card verification processing for this method is the same as standard processing sequence which is provided in the section Payment instrument verification.
Format of request for payment card verification
There are several things you need to consider when sending payment card verification requests by using the Google Pay method:
- To initiate each verification, send a separate POST request to the /v2/payment/googlepay/account_verification endpoint.
- Each request must include the following objects and parameters:
- Object
general
—general purchase information:project_id
—project identifier obtained from ecommpay during integrationpayment_id
—payment identifier unique within the projectsignature
—request signature generated after all required parameters are specified (details—in the Signature generation and verification) (details)
- Object
payment
—payment information:amount
—payment amount in the smallest currency unitcurrency
—payment currency code in the ISO-4217 alpha-3 format
- Object
customer
—customer information:id
—customer identifier unique within the projectip_address
—customer IP address relevant for the initiated payment
etoken
—token received from the Google Pay information:token
—token received from the Google Pay after customer identification
- Object
- The payment amount must be zero.
- Additionally, any other parameters included in the specification can be used.
Thus, a correct purchase request by using the Google Pay method must contain the project identifier, basic payment information (identifier, amount, and currency code), customer identifier and IP address, Google Pay token information, as well as signature.
Callback format
The Google Pay method uses the standard format for callbacks to deliver results. For more information, see Payment instrument verification.
Useful links
The following articles can be useful when implementing purchases via Gate:
- Interaction concepts—about the interaction with the payment platform by using Gate.
- Signature generation and verification—about the procedure of generating and verifying signatures in requests and callbacks.
- Payment models and statuses—about the types, processing models, and possible statuses of supported payments and operations.
- One-time one-step purchase—about processing of one-time one-step purchases by using Payment Page.
- Information of operations performing—about error and response codes that are used in the payment platform to record information about performing of operations.
Testing
General information
For the Google Pay method, it is possible to test one-step and two-step purchases by using Payment Page and Gate, as well as payment card verification by using Gate. To enable and disable testing, as well getting assistance with setting up a test project, refer to ecommpay technical support.
When performing a test payment, take into account that you must specify the identifier of the test project in the requests, and the interfaces of the payment forms emulator of Payment Page and the 3‑D Secure 2 authentication page may differ from the production environment. At the same time to process a test payment it is necessary to use verified payment cards previously registered in the Google Pay service. This does not influence the processing of real payments by using such cards, but allows to perform full-fledged testing. In order to test purchases by using Gate it is necessary to prepare the web-service for interaction with the Google service (more information is presented in the section One-time purchases by using Gate).
Statuses of test payment and operations
The final status of test payments and operations is determined by the amount specified in the request.
Test one-step and two-step purchases:
1000
amount to get thesuccess
status2000
,5000
or10001
amount to get thedecline
status
Test payment card verification:
0
amount to get thesuccess
status- any other amount to get the
decline
status
One-step purchases by using Payment Page
To perform a test one-step purchase by using Payment Page, do the following:
- Send a correct test request for Payment Page opening to the payment platform.
- If the
card
orgoogle_pay_host
method was not specified in the request—select the method on the emulator page. - If the authentication page is displayed pass the 3‑D Secure 2 authentication.
- Receive the final callback with information about the payment result.
More information about processing purchases by using the Google Pay method via Payment Page is provided in the One-time purchases by using Payment Page section.
One-step purchases by using Gate
To perform a test one-step purchase by using Gate, do the following:
- Send a correct test request for purchase to the payment platform.
- If you receive the callback with the 3‑D Secure 2 authentication redirection data:
- Perform the redirection and pass the 3‑D Secure 2 authentication.
- Send the payment completion request. It is required to use the cres parameter and specify the following value in the request:
ewogICAiYWNzUmVmZXJlbmNlTnVtYmVyIiA6ICJBQ1NFbXUyIiwKICAgImFjc1RyYW5zSUQiIDogIjAwMDAwMDAwLTAwMDUtNWE1YS04MDAwLTAxNmRiNjMzNzZlYiIsCiAgICJtZXNzYWdlVHlwZSIgOiAiQ1JlcyIsCiAgICJtZXNzYWdlVmVyc2lvbiIgOiAiMi4xLjAiLAogICAidGhyZWVEU1NlcnZlclRyYW5zSUQiIDogIjZmMmM3OGFkLTFjOWMtNTI2ZC04MDAwLTAwMDAwMDAwMTA2YiIsCiAgICJ0cmFuc1N0YXR1cyIgOiAiWSIKfQ
- Receive the final callback with information about the payment result.
More information about processing purchases by using the Google Pay method via Gate is provided in the One-time purchases by using Gate section.
One-step purchases by performing authorization hold via Payment Page and capture or cancellation via Gate
To perform a test one-step purchase by performing authorization hold via Payment Page and capture or cancellation via Gate, do the following:
- Send a correct test request for Payment Page opening to the payment platform.
- If the
card
orgoogle_pay_host
method was not specified in the request—select the method on the emulator page. - If the authentication page is displayed pass the 3‑D Secure 2 authentication.
- Accept a callback with information about successful authorization hold.
- Send a capture or cancellation request.
- Receive the final callback with information about the result.
More information about processing purchases by using the Google Pay method via Gate is provided in the One-time purchases by using Payment Page and One-time purchases by using Gate sections.
One-step purchases by performing authorization hold and capture or cancellation via Gate
To perform a test one-step purchase by performing authorization hold and capture or cancellation via Gate, do the following:
- Send a correct test request for Payment Page opening to the payment platform.
- If you receive the callback with the 3‑D Secure 2 authentication redirection data:
- Perform the redirection and pass the 3‑D Secure 2 authentication.
- Send the payment completion request. It is required to use the cres parameter and specify the following value in the request:
ewogICAiYWNzUmVmZXJlbmNlTnVtYmVyIiA6ICJBQ1NFbXUyIiwKICAgImFjc1RyYW5zSUQiIDogIjAwMDAwMDAwLTAwMDUtNWE1YS04MDAwLTAxNmRiNjMzNzZlYiIsCiAgICJtZXNzYWdlVHlwZSIgOiAiQ1JlcyIsCiAgICJtZXNzYWdlVmVyc2lvbiIgOiAiMi4xLjAiLAogICAidGhyZWVEU1NlcnZlclRyYW5zSUQiIDogIjZmMmM3OGFkLTFjOWMtNTI2ZC04MDAwLTAwMDAwMDAwMTA2YiIsCiAgICJ0cmFuc1N0YXR1cyIgOiAiWSIKfQ
- Accept a callback with information about successful authorization hold.
- Send a capture or cancellation request.
- Receive the final callback with information about the result.
More information about processing purchases by using the Google Pay method via Gate is provided in the One-time purchases by using Gate section.
Payment card verification by using Gate
To process a test payment card verification by using Gate, send a valid test request for a verification to the payment platform and receive a final callback with information about the verification result. More information about performing payment card verification by using the Google Pay method via Gate is provided in the Payment card verification section.
Analysis of payments results
To analyse information about payments made with the Google Pay method and other methods, you can use:
- Dashboard interface toolkit with various lists and analytic panels.
- Reports in CSV file format, available via the Reports section (one-time and periodically).
- Data in JSON format, sent by program requests to a specified URL available by using the Data API interface.
If you have any questions, refer to the documentation (Dashboard and Using Data API) and ecommpay technical support.