AI-generated Key Takeaways
- 
          This document outlines the Error Response object structure and its components, including ResponseHeader, errorDescription, paymentIntegratorErrorIdentifier, and errorResponseResult. 
- 
          The errorResponseResult field further details various error codes like invalidApiVersion, invalidPayloadSignature, and others, each with their specific meaning and HTTP code advice. 
- 
          Each error code is described with its JSON representation and relevant fields, such as requestVersion and expectedVersion for invalidApiVersion, or invalidFieldName for invalidFieldValue. 
- 
          Some error codes, like InvalidPayloadSignature, IdempotencyViolation, and others, currently have no fields but may be expanded in the future. 
- 
          This comprehensive structure aims to provide clear and detailed error information for debugging and support purposes during payment integration processes. 
- JSON representation
- ErrorResponseResult
- InvalidApiVersion
- InvalidPayloadSignature
- InvalidPayloadEncryption
- RequestTimestampOutOfRange
- InvalidIdentifier
- IdempotencyViolation
- InvalidFieldValue
- MissingRequiredField
- PreconditionViolation
- UserActionInProgress
- InvalidDecryptedRequest
- Forbidden
Error Response object for all methods.
| JSON representation | 
|---|
| { "responseHeader": { object ( | 
| Fields | |
|---|---|
| responseHeader | 
 REQUIRED: Common header for all responses. | 
| errorDescription | 
 OPTIONAL: Provide a description of this status for support reps to debug errors. Note that this is never shown to users. It can contain descriptive, non-sensitive text used for debugging. Note that some values for errorResponseCode should be accompanied by additional detail in this field. Warning: Do not include any tokens in this message unless they are defined as public. | 
| paymentIntegratorErrorIdentifier | 
 OPTIONAL: This identifier is specific to the integrator and is generated by the integrator. It is used for debugging purposes only in order to identify this call. This is the identifier that the integrator knows this call by. | 
| errorResponseResult | 
 OPTIONAL: A code that captures the type of error that occurred. | 
ErrorResponseResult
Error Codes
| JSON representation | 
|---|
| { // Union field | 
| Fields | |
|---|---|
| Union field result. OPTIONAL: The type of error that occurred.resultcan be only one of the following: | |
| invalidApiVersion | 
 Used if the request's API version is unsupported. Advised HTTP Code: 400 | 
| invalidPayloadSignature | 
 Used if the signature of the payload is to an unknown or inactive key. Advised HTTP Code: 401 | 
| invalidPayloadEncryption | 
 Used if the encryption of the payload is to an unknown or inactive key. Advised HTTP Code: 400 | 
| requestTimestampOutOfRange | 
 Used if the requestTimestamp is not ± 60s of now. Advised HTTP Code: 400 | 
| invalidIdentifier | 
 Used if an identifier sent in the request was invalid or unknown. This may include PIAID, captureRequestId, Google Payment Token, etc. Advised HTTP Code: 404 | 
| idempotencyViolation | 
 Used if the request violates the idempotency requirements for the request. Advised HTTP Code: 412 | 
| invalidFieldValue | 
 Used if the request contains a value for a field that isn't in the set of supported values. Advised HTTP Code: 400 | 
| missingRequiredField | 
 Used if a field that is required is unset in the request. Advised HTTP Code: 400 | 
| preconditionViolation | 
 Used if a constraint on the operation is violated (e.g. when a request for a refund amount exceeds the amount remaining on the transaction). Advised HTTP Code: 400 | 
| userActionInProgress | 
 Used if the request cannot be processed at this time because it would interrupt an in-process user action which effectively acts as a system lock. This code must not be used to indicate failures due to implementation-specific internal concurrency errors. Advised HTTP Code: 423 | 
| invalidDecryptedRequest | 
 Used if the request payload could be decrypted, but the resulting message could not be parsed. Advised HTTP Code: 400 | 
| forbidden | 
 Access to the requested resource is forbidden. Advised Http Code: 403 | 
InvalidApiVersion
Used if the request's API version is unsupported.
| JSON representation | 
|---|
| { "requestVersion": { object ( | 
| Fields | |
|---|---|
| requestVersion | 
 REQUIRED: The invalid version that was specified on the request. | 
| expectedVersion | 
 REQUIRED: The expected version. | 
InvalidPayloadSignature
This type has no fields.
This message is intentionally empty right now. New fields could be added in the future.
InvalidPayloadEncryption
This type has no fields.
This message is intentionally empty right now. New fields could be added in the future.
RequestTimestampOutOfRange
Used if the requestTimestamp is not ± 60s of now.
| JSON representation | 
|---|
| { "requestTimestamp": { object ( | 
| Fields | |
|---|---|
| requestTimestamp | 
 REQUIRED: The timestamp provided in the request | 
| serverTimestampAtReceipt | 
 REQUIRED: The server time at receipt, used for comparison | 
InvalidIdentifier
Used if an identifier sent in the request was invalid or unknown. This may include PIAID, captureRequestId, Google Payment Token, etc.
| JSON representation | 
|---|
| { "invalidIdentifierType": string } | 
| Fields | |
|---|---|
| invalidIdentifierType | 
 REQUIRED: The type of identifier that was invalid, e.g. PIAID, captureRequestId, etc. | 
IdempotencyViolation
This type has no fields.
This message is intentionally empty right now. New fields could be added in the future.
InvalidFieldValue
Used if the request contains a value for a field that isn't in the set of supported values.
| JSON representation | 
|---|
| { "invalidFieldName": string } | 
| Fields | |
|---|---|
| invalidFieldName | 
 REQUIRED: The name of the field that was found to be invalid. | 
MissingRequiredField
Used if a field that is required is unset in the request.
| JSON representation | 
|---|
| { "missingFieldNames": [ string ] } | 
| Fields | |
|---|---|
| missingFieldNames[] | 
 REQUIRED: The names of the missing fields. | 
PreconditionViolation
This type has no fields.
This message is intentionally empty right now. New fields could be added in the future.
UserActionInProgress
This type has no fields.
This message is intentionally empty right now. New fields could be added in the future.
InvalidDecryptedRequest
This type has no fields.
This message is intentionally empty right now. New fields could be added in the future.
Forbidden
This type has no fields.
This message is intentionally empty right now. New fields could be added in the future.