Class TransactionExecutionDetail
- All Implemented Interfaces:
- Serializable
- Author:
- Chris Kittrell (ckittrell)
- See Also:
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected booleanbooleanjavax.money.MonetaryAmountThe payment's adjustments (a.k.a discounts) total, usually excluding shipping/fulfillment discounts.Map of specific attributes that have been gathered from the raw response.The timestamp when this transaction response was recordedThe type of transaction failure (hard vs soft failure)The type of transaction failurejavax.money.MonetaryAmountThe payment's total fulfillment costThe response code provided by the payment gateway which may represent a success or failureMessage describing the result of the transactionThe id of the parent payment transaction.javax.money.MonetaryAmountThe payment's total usually excluding adjustments, tax, and shipping.javax.money.MonetaryAmountThe payment's total tax costThe gateway-provided url where the customer must verify that they are in fact the owner of the payment method.javax.money.MonetaryAmountThe transaction amount that was executed against thePaymentSummary.The id of the executed transaction.The transaction id known by the payment gateway.The status of the transaction.inthashCode()booleanIndicates that the payment transaction has been flagged for manual review via fraud checks.booleanTells if this transaction has an indeterminate result.voidsetAdjustmentsTotal(javax.money.MonetaryAmount adjustmentsTotal) The payment's adjustments (a.k.a discounts) total, usually excluding shipping/fulfillment discounts.voidsetAttributes(Map<String, String> attributes) Map of specific attributes that have been gathered from the raw response.voidsetDateRecorded(Instant dateRecorded) The timestamp when this transaction response was recordedvoidsetDeclineType(String declineType) The type of transaction failure (hard vs soft failure)voidsetFailureType(String failureType) The type of transaction failurevoidsetFlaggedForManualReview(boolean flaggedForManualReview) Indicates that the payment transaction has been flagged for manual review via fraud checks.voidsetFulfillmentTotal(javax.money.MonetaryAmount fulfillmentTotal) The payment's total fulfillment costvoidsetGatewayResponseCode(String gatewayResponseCode) The response code provided by the payment gateway which may represent a success or failurevoidsetIndeterminateResult(boolean indeterminateResult) Tells if this transaction has an indeterminate result.voidsetMessage(String message) Message describing the result of the transactionvoidsetParentTransactionId(String parentTransactionId) The id of the parent payment transaction.voidsetSubtotal(javax.money.MonetaryAmount subtotal) The payment's total usually excluding adjustments, tax, and shipping.voidsetTaxTotal(javax.money.MonetaryAmount taxTotal) The payment's total tax costvoidsetThreeDSecureVerificationUrl(String threeDSecureVerificationUrl) The gateway-provided url where the customer must verify that they are in fact the owner of the payment method.voidsetTransactionAmount(javax.money.MonetaryAmount transactionAmount) The transaction amount that was executed against thePaymentSummary.voidsetTransactionId(String transactionId) The id of the executed transaction.voidsetTransactionReferenceId(String transactionReferenceId) The transaction id known by the payment gateway.voidsetTransactionStatus(String transactionStatus) The status of the transaction.toString()booleanWhether this transaction was successful based ongetTransactionStatus().
- 
Constructor Details- 
TransactionExecutionDetailpublic TransactionExecutionDetail()
 
- 
- 
Method Details- 
wasSuccessfulpublic boolean wasSuccessful()Whether this transaction was successful based ongetTransactionStatus().- Returns:
- Whether or not this transaction was successful.
- See Also:
 
- 
getTransactionIdThe id of the executed transaction.- Returns:
- The id of the executed transaction.
 
- 
getParentTransactionIdThe id of the parent payment transaction. Necessary for operations on a payment that require something to have happened beforehand. For instance, an authorize transaction would not have a parent but a capture must have an authorize parent transaction and a refund must have a capture parent transaction. The full set of expected parent-child transaction relationships are as follows:- Child Transaction -> Parent Transaction
- Reverse Authorize -> Authorize
- Capture -> Authorize
- Refund -> Capture
- Refund -> AuthorizeAndCapture
 - Returns:
- The id of the parent payment transaction.
 
- 
getTransactionReferenceIdThe transaction id known by the payment gateway. This reference can be used to link the request to the gateway's record of the transaction in the case that the calling application does not receive a response from the gateway.- Returns:
- The transaction id known by the payment gateway
 
- 
getTransactionStatusThe status of the transaction.- Returns:
- The status of the transaction.
- See Also:
 
- 
getFailureTypeThe type of transaction failure- Returns:
- The type of transaction failure
 
- 
getDeclineTypeThe type of transaction failure (hard vs soft failure)- Returns:
- The type of transaction failure (hard vs soft failure)
 
- 
isFlaggedForManualReviewpublic boolean isFlaggedForManualReview()Indicates that the payment transaction has been flagged for manual review via fraud checks.- Returns:
- true if the transaction has been flagged for manual review
 
- 
getThreeDSecureVerificationUrlThe gateway-provided url where the customer must verify that they are in fact the owner of the payment method. The customer is typically redirected to this location, but the page can also be rendered within an iframe if this is supported by the gateway.- Returns:
- The gateway-provided url where the customer must verify that they are in fact the owner of the payment method.
 
- 
isIndeterminateResultpublic boolean isIndeterminateResult()Tells if this transaction has an indeterminate result.Having an indeterminate result means that the true outcome of the transaction is not known. For example, if a transaction is sent to the payment processor but a network error occurred, it is not known to us whether the user was actually charged or not (thus, the result is indeterminate). Transactions should be marked as indeterminate when sending to the payment processor, and then unmarked once a response is received, understood, and recorded. This means that a transaction in an indeterminate result state is expected during the sending to processor phase. However, if the transaction remains in that state for an excessive amount of time, something likely went wrong and the transaction will need to be reconciled. If the transaction changes from the sending to processor status but remains indeterminate, the transaction will also require reconciliation in that scenario. Some situations which may lead to an indeterminate result: - A transaction is sent to the processor, but a network error prevents us from receiving the response
- A transaction is sent to the processor, but the processor returns an unexpected error (e.g. 500 internal server error)
- A transaction is sent to the processor and a response is received, but cannot be recorded because Cart Services is down
- A transaction is sent to the processor and a response is received, but cannot be recorded because the database is down
 
- 
getDateRecordedThe timestamp when this transaction response was recorded- Returns:
- The timestamp when this transaction response was recorded
 
- 
getGatewayResponseCodeThe response code provided by the payment gateway which may represent a success or failure- Returns:
- The response code provided by the payment gateway which may represent a success or failure
 
- 
getMessageMessage describing the result of the transaction- Returns:
- Message describing the result of the transaction
 
- 
getTransactionAmountpublic javax.money.MonetaryAmount getTransactionAmount()The transaction amount that was executed against thePaymentSummary.- Returns:
- The transaction amount that was executed against the PaymentSummary.
 
- 
getSubtotalpublic javax.money.MonetaryAmount getSubtotal()The payment's total usually excluding adjustments, tax, and shipping.- Returns:
- The payment's total usually excluding adjustments, tax, and shipping.
 
- 
getAdjustmentsTotalpublic javax.money.MonetaryAmount getAdjustmentsTotal()The payment's adjustments (a.k.a discounts) total, usually excluding shipping/fulfillment discounts.- Returns:
- The payment's adjustments (a.k.a discounts) total, usually excluding shipping/fulfillment discounts.
 
- 
getFulfillmentTotalpublic javax.money.MonetaryAmount getFulfillmentTotal()The payment's total fulfillment cost- Returns:
- The payment's total fulfillment cost
 
- 
getTaxTotalpublic javax.money.MonetaryAmount getTaxTotal()The payment's total tax cost- Returns:
- The payment's total tax cost
 
- 
getAttributesMap of specific attributes that have been gathered from the raw response. This should be used for data points that are to be used programmatically. For example, a gateway-specific transaction id that can be used to capture or refund the transaction.- Returns:
- Map of specific fields that have been gathered from the raw response
 
- 
setTransactionIdThe id of the executed transaction.- Parameters:
- transactionId- The id of the executed transaction.
 
- 
setParentTransactionIdThe id of the parent payment transaction. Necessary for operations on a payment that require something to have happened beforehand. For instance, an authorize transaction would not have a parent but a capture must have an authorize parent transaction and a refund must have a capture parent transaction. The full set of expected parent-child transaction relationships are as follows:- Child Transaction -> Parent Transaction
- Reverse Authorize -> Authorize
- Capture -> Authorize
- Refund -> Capture
- Refund -> AuthorizeAndCapture
 - Parameters:
- parentTransactionId- The id of the parent payment transaction.
 
- 
setTransactionReferenceIdThe transaction id known by the payment gateway. This reference can be used to link the request to the gateway's record of the transaction in the case that the calling application does not receive a response from the gateway.- Parameters:
- transactionReferenceId- The transaction id known by the payment gateway
 
- 
setTransactionStatusThe status of the transaction.- Parameters:
- status- The status of the transaction.
- See Also:
 
- 
setFailureTypeThe type of transaction failure- Parameters:
- failureType- The type of transaction failure
 
- 
setDeclineTypeThe type of transaction failure (hard vs soft failure)- Parameters:
- failureType- The type of transaction failure (hard vs soft failure)
 
- 
setFlaggedForManualReviewpublic void setFlaggedForManualReview(boolean flaggedForManualReview) Indicates that the payment transaction has been flagged for manual review via fraud checks.- Parameters:
- flaggedForManualReview- whether the transaction has been marked for manual review
 
- 
setThreeDSecureVerificationUrlThe gateway-provided url where the customer must verify that they are in fact the owner of the payment method. The customer is typically redirected to this location, but the page can also be rendered within an iframe if this is supported by the gateway.- Parameters:
- threeDSecureVerificationUrl- The gateway-provided url where the customer must verify that they are in fact the owner of the payment method.
 
- 
setIndeterminateResultpublic void setIndeterminateResult(boolean indeterminateResult) Tells if this transaction has an indeterminate result.Having an indeterminate result means that the true outcome of the transaction is not known. For example, if a transaction is sent to the payment processor but a network error occurred, it is not known to us whether the user was actually charged or not (thus, the result is indeterminate). Transactions should be marked as indeterminate when sending to the payment processor, and then unmarked once a response is received, understood, and recorded. This means that a transaction in an indeterminate result state is expected during the sending to processor phase. However, if the transaction remains in that state for an excessive amount of time, something likely went wrong and the transaction will need to be reconciled. If the transaction changes from the sending to processor status but remains indeterminate, the transaction will also require reconciliation in that scenario. Some situations which may lead to an indeterminate result: - A transaction is sent to the processor, but a network error prevents us from receiving the response
- A transaction is sent to the processor, but the processor returns an unexpected error (e.g. 500 internal server error)
- A transaction is sent to the processor and a response is received, but cannot be recorded because Cart Services is down
- A transaction is sent to the processor and a response is received, but cannot be recorded because the database is down
 
- 
setDateRecordedThe timestamp when this transaction response was recorded- Parameters:
- dateRecorded- The timestamp when this transaction response was recorded
 
- 
setGatewayResponseCodeThe response code provided by the payment gateway which may represent a success or failure- Parameters:
- gatewayResponseCode- The response code provided by the payment gateway which may represent a success or failure
 
- 
setMessageMessage describing the result of the transaction- Parameters:
- message- Message describing the result of the transaction
 
- 
setTransactionAmountpublic void setTransactionAmount(javax.money.MonetaryAmount transactionAmount) The transaction amount that was executed against thePaymentSummary.- Parameters:
- transactionAmount- The transaction amount that was executed against the- PaymentSummary.
 
- 
setSubtotalpublic void setSubtotal(javax.money.MonetaryAmount subtotal) The payment's total usually excluding adjustments, tax, and shipping.
- 
setAdjustmentsTotalpublic void setAdjustmentsTotal(javax.money.MonetaryAmount adjustmentsTotal) The payment's adjustments (a.k.a discounts) total, usually excluding shipping/fulfillment discounts.
- 
setFulfillmentTotalpublic void setFulfillmentTotal(javax.money.MonetaryAmount fulfillmentTotal) The payment's total fulfillment cost
- 
setTaxTotalpublic void setTaxTotal(javax.money.MonetaryAmount taxTotal) The payment's total tax cost
- 
setAttributesMap of specific attributes that have been gathered from the raw response. This should be used for data points that are to be used programmatically. For example, a gateway-specific transaction id that can be used to capture or refund the transaction.- Parameters:
- attributes- Map of specific fields that have been gathered from the raw response
 
- 
equals
- 
canEqual
- 
hashCodepublic int hashCode()
- 
toString
 
-