- HTTP request
- Request body
- Response body
- CaptureResult
- CaptureResultCode
- CaptureResultNotificationResponse
- CaptureResultNotificationResultCode
Notify Google of the result of a capture after an asynchronousCapture method call has been made.
The captureResult value is idempotent for this captureRequestId, so its value cannot be changed by a subsequent call to this method.
If the endpoint encounters an error while processing the request, the endpoint will return HTTP 4xx or 5xx and the HTTP body will either be of type ErrorResponse or contain a generic error (e.g. a message similar to "There was an error. Please try again later.").
The generic error is used in situations where an ErrorResponse with a clear description could be used to help an attacker understand the payment integrator account identifier of other integrators. In these situations, where either the signing key doesn't match, the payment integrator identifier was not found, or the encryption key was unknown, this method will return a generic error. If the request signature could be verified, additional information regarding the error will be returned in an ErrorResponse.
An example request looks like:
{
  "requestHeader": {
    "protocolVersion": {
      "major": 1,
      "minor": 1,
      "revision": 0
    },
    "requestId": "KcgwSKrV76eVNDUbsZ4UA3",
    "requestTimestamp": "1481852928293"
  },
  "paymentIntegratorAccountId": "InvisiCashUSA_USD",
  "captureRequestId": "awNaC510cefae3IJdNEvW2",
  "captureResult": {
    "captureResultCode": "SUCCESS"
  },
  "payerInfo": {
    "payerTaxInfo": {
      "brazil": {
        "cnpj": "66818021000127"
      }
    },
    "payerBankAccountIdentifier": {
      "brazilBankAccount": {
        "bankCode": "12345678",
        "branchCode": "1234567890",
        "accountNumber": "1234567890123456"
      }
    }
  }
}
An example response looks like:
{
  "responseHeader": {
    "responseTimestamp": "1481852928324"
  },
  "result": "SUCCESS"
}
HTTP request
POST https://vgw.googleapis.com/gsp/refundable-one-time-payment-code-v1/captureResultNotification/:PIAID
Request body
The request body contains data with the following structure:
| JSON representation | 
|---|
| { "requestHeader": { object (RequestHeader) }, "paymentIntegratorAccountId": string, "paymentIntegratorTransactionId": string, "captureRequestId": string, "captureResult": { object ( | 
| Fields | |
|---|---|
| requestHeader | 
 REQUIRED: Common header for all requests. | 
| paymentIntegratorAccountId | 
 REQUIRED: Payment integrator account identifier on which the capture occurred. | 
| paymentIntegratorTransactionId | 
 OPTIONAL: This identifier is specific to the integrator and is generated by the integrator. This is the identifier by which the integrator knows this transaction. For convenience, this identifier is included when the payment integrator requests  | 
| captureRequestId | 
 REQUIRED: A unique identifier for this transaction. This is the  This is a string with a max length of 100 characters and contains only the characters "a-z", "A-Z", "0-9", ":", "-", and "_". | 
| captureResult | 
 REQUIRED: Result of this capture. | 
| payerInfo | 
 OPTIONAL: Details about the person making the payment. This may include tax information, bank account details, etc. Providing this information enhances our ability to detect and prevent fraudulent activity by adding Risk checks, making the payment system more secure for one-time payment code FOPs. If this information is not provided, the payment system will still function normally but may not be as secure. | 
| Union field end_to_end_network_identifier. OPTIONAL: Identifier specific for a newwork.end_to_end_network_identifiercan be only one of the following: | |
| pixEndToEndId | 
 This ID is created by Banco Central do Brasil (BCB) for the Brazilian instant payment ecosystem (Pix). This ID is used to identify the operation on a transaction, either a payment or a refund. | 
Response body
This method supports multiple return types. For additional information about what 4XX or 5XX HTTP status code to return with an ErrorResponse, consult the ErrorResponse object and HTTP status codes documentation.
| Possible response messages | |
|---|---|
| HTTP 200 Status | 
 | 
| HTTP 4XX / 5XX Status | 
 | 
CaptureResult
Information about the final result of a capture.
| JSON representation | 
|---|
| { "captureResultCode": enum ( | 
| Fields | |
|---|---|
| captureResultCode | 
 REQUIRED: Result code of this capture. | 
| rawResult | 
 OPTIONAL: Raw result of this capture. Used to help inform Google's risk engine and analytics. In decline code–mapping situations, data is sometimes lost. The integrator can choose to give Google a raw code. For example, a credit card gateway (the integrator) may use this field to communicate to Google the exact decline code that was received from the VISA network. In that case, the  This value is required if the  | 
| Union field FailureDetail. OPTIONAL: Details related to the capture failure.FailureDetailcan be only one of the following: | |
| transactionMaxLimit | 
 If  This amount is micros of the same  | 
| transactionMinLimit | 
 If  This amount is micros of the same  | 
| currentBalance | 
 If Result is  This value must be in the same currency as the  | 
CaptureResultCode
Result codes for a capture.
| Enums | |
|---|---|
| UNKNOWN_RESULT | Do not ever set this default value! | 
| SUCCESS | Capture successful. | 
| CHARGE_UNDER_TRANSACTION_LIMIT | Requested capture amount does not meet the integrator's minimum per-transaction amount. If this code is used, populate the transactionMinLimitfield with the minimum transaction amount for user messaging purposes. | 
| CHARGE_EXCEEDS_TRANSACTION_LIMIT | Requested capture amount exceeds the integrator's maximum per-transaction limit. If this code is used, populate the transactionMaxLimitfield with the transaction limit for user messaging purposes. | 
| CHARGE_EXCEEDS_DAILY_LIMIT | User's account cannot be used for purchases right now as it has exceeded its daily limit. | 
| CHARGE_EXCEEDS_MONTHLY_LIMIT | User's account cannot be used for purchases right now as it has exceeded its monthly limit. | 
| INSUFFICIENT_FUNDS | This account does not have sufficient funds to guarantee this capture. | 
| SUSPECTED_FRAUD | The integrator has reason to suspect that this transaction is fraudulent. | 
| ACCOUNT_CLOSED | User's account held with the integrator has been closed. This return value will cause the user's instrument to be closed with Google. The user will be forced to add a new instrument. | 
| ACCOUNT_CLOSED_ACCOUNT_TAKEN_OVER | User's account with the integrator has been closed, suspected account take over. This return value will cause the user's instrument to be closed with Google. The user will be forced to add a new instrument. | 
| ACCOUNT_CLOSED_FRAUD | User's account held with the integrator has been closed because of fraud. This return value will cause the user's instrument to be closed with Google. The user will be forced to add a new instrument. | 
| ACCOUNT_ON_HOLD | User's account is on hold. | 
| OTP_NOT_MATCHED | OTP did not match what the integrator sent. | 
| OTP_ALREADY_USED | OTP was already used. | 
| CAPTURE_REQUEST_EXPIRED | It took too long for the integrator to capture the user's funds. Google will treat this decline as a final state, so the integrator must ensure that the user's funds do not get captured later or that the user gets automatically refunded if the capture ended up succeeding. | 
| INVALID_PIN | The user supplied an invalid PIN. | 
| OS_LOCK_FAILED | This payment flow requires an OS lock challenge and the user failed to unlock the device. | 
| PIN_ENTRY_ATTEMPTS_EXHAUSTED | This payment flow requires user PIN entry. The user failed PIN entry enough times that they ran out of retries. | 
| USER_EXITED_PAYMENT_FLOW | User canceled the whole payment attempt (either at the OS lock or at the PIN entry screen). | 
| MONTHLY_FREQUENCY_LIMIT_EXCEEDED | User's account cannot be used for purchases right now as it has exceeded its monthly transaction attempt limit. | 
| DECLINED_BY_ISSUER | This decline code should never be used in steady-state. It is meant as a temporary catch-all code to use when the integrator encounters an unknown decline code from the underlying issuer of the user's instrument. This result code can be used while the integrator determines a more appropriate result code to use or negotiates the addition of a new result code to this specification. Importantly, this decline code is very much a real decline. It is a permanent decline as far as Google is concerned. If the integrator returns this, it is up to them to track down what the issuer's code really means and refund the user if it turns out the code actually meant  If this decline code is used for the same underlying decline code for more than a certain number of days, Google will treat it as a bug and track it accordingly with respect to any contractual penalties around fixing bugs. | 
| GOOGLE_PAYMENT_TOKEN_INVALIDATED_BY_USER | The account is active, but the GPT has been invalidated by the user on the integrator's side. Returning this value will cause the user's instrument to be closed with Google. The user will be forced to add a new instrument by going through the association flow again. | 
| PAYMENT_CANCELLED_BY_THE_USER | The user cancelled the payment on the issuer app or interface. | 
| ENROLLMENT_CANCELLED_BY_THE_USER | The user cancelled the mandate enrollment on the issuer app or interface. | 
CaptureResultNotificationResponse
Response object for the captureResultNotification method.
| JSON representation | 
|---|
| {
  "responseHeader": {
    object (ResponseHeader)
  },
  "result": enum ( | 
| Fields | |
|---|---|
| responseHeader | 
 REQUIRED: Common header for all responses. | 
| result | 
 REQUIRED: Result of this capture. | 
CaptureResultNotificationResultCode
Result codes for the captureResultNotification method.
| Enums | |
|---|---|
| UNKNOWN_RESULT | Do not ever set this default value! | 
| SUCCESS | Capture result notification was successfully processed. |