AI-generated Key Takeaways
- 
          This documentation outlines the Error Response object structure and its components, including responseHeader,errorDescription,paymentIntegratorErrorIdentifier, anderrorResponseResult.
- 
          ErrorResponseResultfurther categorizes errors using specific result codes likeinvalidApiVersion,invalidPayloadSignature,invalidPayloadEncryption, and more, each with a suggested HTTP code.
- 
          Several error codes have their own dedicated objects for providing additional context, such as InvalidApiVersion, which includesrequestVersionandexpectedVersion, while others likeInvalidPayloadSignaturehave no additional fields.
- 
          Each error code is designed to offer detailed information for debugging and troubleshooting, including the type of error, potential causes, and suggested HTTP response codes. 
- 
          Error descriptions are provided for support representatives, but are not displayed to users and should not contain sensitive information. 
- 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.