availability

Google Pay is currently available with our latest Android and JavaScript SDKs.

Creating transactions

Using card nonces

Include the Google Pay card nonce in the Transaction::sale() call on your server:

Collect device data from the client and include the $deviceDataFromTheClient in the transaction.

PHP
$result = $gateway->transaction()->sale([
  'amount' => '10.00',
  'paymentMethodNonce' => $nonceFromTheClient,
  'deviceData' => $deviceDataFromTheClient,
  'options' => [
    'submitForSettlement' => True
  ],
  'billing' => [
    'postalCode' => $postalCodeFromTheClient
  ]
]);
This code snippet now uses gateway instance methods instead of class-level methods. Learn more.
note

Google Pay cards are represented as Android Pay cards in our API to prevent breaking changes. For example, the response from a PaymentMethod::create() call with a card from Google Pay will include the AndroidPayCard response object.

Using PayPal nonces

PayPal nonces returned from the client will be a PayPalAccount type rather than an AndroidPayCard. To create a transaction with a PayPal nonce:

Collect device data from the client and include the $deviceDataFromTheClient in the transaction.

PHP
$result = $gateway->transaction()->sale([
    'amount' => $_POST['amount'],
    'paymentMethodNonce' => $_POST['payment_method_nonce'],
    'deviceData' => $_POST['device_data'],
    'orderId' => $_POST["Mapped to PayPal Invoice Number"],
    'options' => [
        'submitForSettlement' => True,
        'paypal' => [
            'customField' => $_POST["PayPal custom field"],
            'description' => $_POST["Description for PayPal email receipt"],
      ],
    ],
]);
if ($result->success) {
  print_r("Success ID: " . $result->transaction->id);
} else {
  print_r("Error Message: " . $result->message);
}
This code snippet now uses gateway instance methods instead of class-level methods. Learn more.
note

The merchant account used at transaction time must accept PayPal transactions.

Because creating a transaction with a PayPalAccount nonce from Google Pay is effectively the same as creating a transaction from your PayPal integration, they have the same settlement rules and options that typical PayPal transactions have.

When making a transaction with PayPalAccount nonce through Google Pay, the resulting transaction will have facilitatorDetails.oauthApplicationName set to Google.

Vaulting Google Pay

Google Pay cards can only be saved to your Vault for specific use cases; see the support article for details.

Vaulting of PayPal accounts from Google Pay is currently not supported. This means the options.storeInVault and options.storeInVaultOnSuccess options are not supported when creating a transaction.

If your use case is supported, you can store a customer's Google Pay card in your Vault in a few different ways:

Next Page: Testing and Go Live →