Class PaymentSummary
java.lang.Object
com.broadleafcommerce.orderoperation.domain.payment.PaymentSummary
- All Implemented Interfaces:
Serializable
The domain that summarizes the current state of transactions against the payment.
- Author:
- Dima Myroniuk (dmyroniuk)
- See Also:
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionprotected boolean
boolean
com.broadleafcommerce.order.common.domain.Address
getAddress
(String addressType) Gathers one of the payment's relatedaddresses
by typeThe collection of related addresses that may include billing or shipping addressesjavax.money.MonetaryAmount
The payment's adjustments (a.k.a discounts) total, usually excluding shipping/fulfillment discounts.javax.money.MonetaryAmount
The amount for which this payment is allotted.javax.money.MonetaryAmount
The total authorized amount for capture.javax.money.MonetaryAmount
Determines the amount that can be authorized for this payment summaryjavax.money.MonetaryAmount
Determines the amount that can be authorized and captured for this payment summaryjavax.money.MonetaryAmount
Determines the amount that can be captured for this payment summaryjavax.money.MonetaryAmount
Determines the amount that can be refunded for this payment summaryjavax.money.MonetaryAmount
Determines the amount that can be reverse-authorized for this payment summaryjavax.money.MonetaryAmount
The total amount that is currently captured.javax.money.MonetaryAmount
The total detached credit amount.javax.money.MonetaryAmount
The total refunded amount.General use map to capture any additional attributes needed for this Paymentcom.broadleafcommerce.order.common.domain.Address
javax.money.MonetaryAmount
The total amount sent to the payment gateway for capture, and is waiting for a response about the transaction result.javax.money.CurrencyUnit
The currency gathered fromgetAmount()
General use map to capture any display properties for this Paymentjavax.money.MonetaryAmount
The payment's total fulfillment costThe gateway used to process this payment.getName()
The name of this payment.The id of the entity that owns this payment.Describes the owning entity of the payment.The id of this payment.javax.money.MonetaryAmount
The total amount sent to the payment gateway for refund, and is waiting for a response about the transaction result.javax.money.MonetaryAmount
The total amount sent to the payment gateway for reverse authorize, and is waiting for a response about the transaction result.javax.money.MonetaryAmount
The payment's total usually excluding adjustments, tax, and shipping.javax.money.MonetaryAmount
The payment's total tax costjavax.money.MonetaryAmount
The total amount ever captured, as opposed to the current snapshot of the captured amount represented ingetAmountCaptured()
.getType()
The type of this payment like Credit Card or Gift Card.The version of this payment.int
hashCode()
boolean
Determines if the payment summary is fully authorizedboolean
Determines if the payment summary is fully capturedboolean
Indicates that the payment transaction has been flagged for manual review by fraud checks.boolean
Determines if the payment summary is partially capturedboolean
Whether a portion of an authorization transaction can be reversed, or if the full authorization transaction must be reversed.boolean
Declares if the reverse authorize for this functionality only allows reversing the full non-captured amount.boolean
Whether or not the underlying payment method can only be used once.void
setAddressByType
(Map<String, com.broadleafcommerce.order.common.domain.Address> addressByType) The collection of related addresses that may include billing or shipping addressesvoid
setAdjustmentsTotal
(javax.money.MonetaryAmount adjustmentsTotal) The payment's adjustments (a.k.a discounts) total, usually excluding shipping/fulfillment discounts.void
setAmount
(javax.money.MonetaryAmount amount) The amount for which this payment is allotted.void
setAmountAuthorized
(javax.money.MonetaryAmount amountAuthorized) The total authorized amount for capture.void
setAmountAvailableForAuthorize
(javax.money.MonetaryAmount amountAvailableForAuthorize) Determines the amount that can be authorized for this payment summaryvoid
setAmountAvailableForAuthorizeAndCapture
(javax.money.MonetaryAmount amountAvailableForAuthorizeAndCapture) Determines the amount that can be authorized and captured for this payment summaryvoid
setAmountAvailableForCapture
(javax.money.MonetaryAmount amountAvailableForCapture) Determines the amount that can be captured for this payment summaryvoid
setAmountAvailableForRefund
(javax.money.MonetaryAmount amountAvailableForRefund) Determines the amount that can be refunded for this payment summaryvoid
setAmountAvailableForReverseAuthorization
(javax.money.MonetaryAmount amountAvailableForReverseAuthorization) Determines the amount that can be reverse-authorized for this payment summaryvoid
setAmountCaptured
(javax.money.MonetaryAmount amountCaptured) The total amount that is currently captured.void
setAmountCredited
(javax.money.MonetaryAmount amountCredited) The total detached credit amount.void
setAmountRefunded
(javax.money.MonetaryAmount amountRefunded) The total refunded amount.void
setAttributes
(Map<String, String> attributes) General use map to capture any additional attributes needed for this Paymentvoid
setCaptureAmountAwaitingResult
(javax.money.MonetaryAmount captureAmountAwaitingResult) The total amount sent to the payment gateway for capture, and is waiting for a response about the transaction result.void
setDisplayAttributes
(Map<String, String> displayAttributes) General use map to capture any display properties for this Paymentvoid
setFulfillmentTotal
(javax.money.MonetaryAmount fulfillmentTotal) The payment's total fulfillment costvoid
setFullyAuthorized
(boolean fullyAuthorized) Determines if the payment summary is fully authorizedvoid
setFullyCaptured
(boolean fullyCaptured) Determines if the payment summary is fully capturedvoid
setGatewayType
(String gatewayType) The gateway used to process this payment.void
setHasTransactionFlaggedForManualReview
(boolean hasTransactionFlaggedForManualReview) Indicates that the payment transaction has been flagged for manual review by fraud checks.void
The name of this payment.void
setOwningEntityId
(String owningEntityId) The id of the entity that owns this payment.void
setOwningEntityType
(String owningEntityType) Describes the owning entity of the payment.void
setPartiallyCaptured
(boolean partiallyCaptured) Determines if the payment summary is partially capturedvoid
setPartialReverseAuthSupported
(boolean partialReverseAuthSupported) Whether a portion of an authorization transaction can be reversed, or if the full authorization transaction must be reversed.void
setPaymentId
(String paymentId) The id of this payment.void
setRefundAmountAwaitingResult
(javax.money.MonetaryAmount refundAmountAwaitingResult) The total amount sent to the payment gateway for refund, and is waiting for a response about the transaction result.void
setReverseAuthorizeAmountAwaitingResult
(javax.money.MonetaryAmount reverseAuthorizeAmountAwaitingResult) The total amount sent to the payment gateway for reverse authorize, and is waiting for a response about the transaction result.void
setReverseAuthRemainder
(boolean reverseAuthRemainder) Declares if the reverse authorize for this functionality only allows reversing the full non-captured amount.void
setSingleUsePaymentMethod
(boolean isSingleUsePaymentMethod) Whether or not the underlying payment method can only be used once.void
setSubtotal
(javax.money.MonetaryAmount subtotal) The payment's total usually excluding adjustments, tax, and shipping.void
setTaxTotal
(javax.money.MonetaryAmount taxTotal) The payment's total tax costvoid
setTotalEverCaptured
(javax.money.MonetaryAmount totalEverCaptured) The total amount ever captured, as opposed to the current snapshot of the captured amount represented ingetAmountCaptured()
.void
The type of this payment like Credit Card or Gift Card.void
setVersion
(Integer version) The version of this payment.toString()
-
Constructor Details
-
PaymentSummary
public PaymentSummary()
-
-
Method Details
-
getAddress
Gathers one of the payment's relatedaddresses
by type- Returns:
- The payment's related address identified by type
-
getBillingAddress
@Nullable public com.broadleafcommerce.order.common.domain.Address getBillingAddress() -
getCurrency
@Nullable public javax.money.CurrencyUnit getCurrency()The currency gathered fromgetAmount()
- Returns:
- The currency gathered from the amount
-
getPaymentId
The id of this payment.- Returns:
- The id of this payment.
-
getName
The name of this payment. This name is typically something like "Visa ending in 1234".- Returns:
- The name of this payment.
-
getType
The type of this payment like Credit Card or Gift Card.- Returns:
- The type of this payment like Credit Card or Gift Card.
-
getGatewayType
The gateway used to process this payment. Only a SINGLE payment gateway can modify transactions on a particular payment.- Returns:
- The gateway used to process this payment.
-
getOwningEntityType
Describes the owning entity of the payment. For example, the payment could have originated with a cart or a subscription, therefore this value might be CART or SUBSCRIPTION.- Returns:
- The type describing the owning entity of the payment
-
getOwningEntityId
The id of the entity that owns this payment. For example, this may be a cart id, or a subscription billing cycle id.- Returns:
- The id of the entity that owns this payment.
-
getAddressByType
The collection of related addresses that may include billing or shipping addresses- Returns:
- The collection of related addresses
-
getAttributes
General use map to capture any additional attributes needed for this Payment- Returns:
- General use map to capture any additional attributes needed for this Payment
-
getDisplayAttributes
General use map to capture any display properties for this Payment- Returns:
- General use map to capture any display properties for this Payment
-
isSingleUsePaymentMethod
public boolean isSingleUsePaymentMethod()Whether or not the underlying payment method can only be used once. In most cases, we're managing a single-use token that represents a credit card. This flag is especially important for managing payments with successful transactions. In those cases, the token has already been used and cannot be reused. If we need modify the payment's amount, then we may actually need to archive the existing payment, and create a new payment, with a new underlying token. Additionally, this flag is helpful when needing to re-authorize an expired authorization transaction. In that case, if the payment represents a single-use payment method, then the re-authorization may not be possible, and you'll need to seek an alternative form of payment.- Returns:
- Whether or not the underlying payment method can only be used once
-
getAmount
public javax.money.MonetaryAmount getAmount()The amount for which this payment is allotted. The summation of all of thepayments
for a particular cart should equal the cart's total. If specified, the amount details (subtotal
,adjustmentsTotal
,fulfillmentTotal
, &taxTotal
) should sum together to equal this amount.- Returns:
- The amount for which this payment is allotted.
-
getSubtotal
public 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.
-
getAdjustmentsTotal
public 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.
-
getFulfillmentTotal
public javax.money.MonetaryAmount getFulfillmentTotal()The payment's total fulfillment cost- Returns:
- The payment's total fulfillment cost
-
getTaxTotal
public javax.money.MonetaryAmount getTaxTotal()The payment's total tax cost- Returns:
- The payment's total tax cost
-
getAmountAuthorized
public javax.money.MonetaryAmount getAmountAuthorized()The total authorized amount for capture. This value is calculated as "total authorized - total reverse-authed".- Returns:
- the total authorized amount for capture
-
getAmountCaptured
public javax.money.MonetaryAmount getAmountCaptured()The total amount that is currently captured. This value is calculated as "total captured - total refunded".- Returns:
- The total amount that is currently captured
-
getTotalEverCaptured
public javax.money.MonetaryAmount getTotalEverCaptured()The total amount ever captured, as opposed to the current snapshot of the captured amount represented ingetAmountCaptured()
.- Returns:
- The total amount ever captured
-
getAmountRefunded
public javax.money.MonetaryAmount getAmountRefunded()The total refunded amount.- Returns:
- the total refunded amount
-
getAmountCredited
public javax.money.MonetaryAmount getAmountCredited()The total detached credit amount.- Returns:
- the total detached credit amount
-
getCaptureAmountAwaitingResult
public javax.money.MonetaryAmount getCaptureAmountAwaitingResult()The total amount sent to the payment gateway for capture, and is waiting for a response about the transaction result.This value should only be present for payment gateways that support asynchronous transaction executions.
- Returns:
- the total amount sent to the payment gateway for capture and is waiting for a response about the transaction result
-
getReverseAuthorizeAmountAwaitingResult
public javax.money.MonetaryAmount getReverseAuthorizeAmountAwaitingResult()The total amount sent to the payment gateway for reverse authorize, and is waiting for a response about the transaction result.This value should only be present for payment gateways that support asynchronous transaction executions.
- Returns:
- the total amount sent to the payment gateway for reverse authorize and is waiting for a response about the transaction result
-
getRefundAmountAwaitingResult
public javax.money.MonetaryAmount getRefundAmountAwaitingResult()The total amount sent to the payment gateway for refund, and is waiting for a response about the transaction result.This value should only be present for payment gateways that support asynchronous transaction executions.
- Returns:
- the total amount sent to the payment gateway for refund and is waiting for a response about the transaction result
-
getVersion
The version of this payment. Used for checking that the requested version of the payment is up-to-date before saving changes. Required for any request which results in an update being made to the payment. This should never be manually incremented/decremented. -
isPartialReverseAuthSupported
public boolean isPartialReverseAuthSupported()Whether a portion of an authorization transaction can be reversed, or if the full authorization transaction must be reversed.- Returns:
- Whether a portion of an authorization transaction can be reversed.
-
isReverseAuthRemainder
public boolean isReverseAuthRemainder()Declares if the reverse authorize for this functionality only allows reversing the full non-captured amount.- Returns:
- Declares if the reverse authorize for this functionality only allows reversing the full non-captured amount.
-
isHasTransactionFlaggedForManualReview
public boolean isHasTransactionFlaggedForManualReview()Indicates that the payment transaction has been flagged for manual review by fraud checks.- Returns:
- true if the transaction has been flagged for manual review
-
getAmountAvailableForAuthorize
public javax.money.MonetaryAmount getAmountAvailableForAuthorize()Determines the amount that can be authorized for this payment summary- Returns:
- The amount that is available for authorize
-
getAmountAvailableForCapture
public javax.money.MonetaryAmount getAmountAvailableForCapture()Determines the amount that can be captured for this payment summary- Returns:
- The amount that is available for capture
-
getAmountAvailableForAuthorizeAndCapture
public javax.money.MonetaryAmount getAmountAvailableForAuthorizeAndCapture()Determines the amount that can be authorized and captured for this payment summary- Returns:
- The amount that is available for authorize and capture
-
getAmountAvailableForReverseAuthorization
public javax.money.MonetaryAmount getAmountAvailableForReverseAuthorization()Determines the amount that can be reverse-authorized for this payment summary- Returns:
- The amount that is available for reverse-authorized
-
getAmountAvailableForRefund
public javax.money.MonetaryAmount getAmountAvailableForRefund()Determines the amount that can be refunded for this payment summary- Returns:
- The amount that is available for refund
-
isFullyAuthorized
public boolean isFullyAuthorized()Determines if the payment summary is fully authorized- Returns:
- true if the payment summary has authorized the full amount, false otherwise
-
isFullyCaptured
public boolean isFullyCaptured()Determines if the payment summary is fully captured- Returns:
- true if the payment summary has captured the full amount, false otherwise
-
isPartiallyCaptured
public boolean isPartiallyCaptured()Determines if the payment summary is partially captured- Returns:
- true if the payment summary has started to capture an amount (smaller than the full amount), false otherwise
-
setPaymentId
The id of this payment.- Parameters:
id
- The id of this payment.
-
setName
The name of this payment. This name is typically something like "Visa ending in 1234".- Parameters:
name
- The name of this payment.
-
setType
The type of this payment like Credit Card or Gift Card.- Parameters:
type
- The type of this payment like Credit Card or Gift Card.
-
setGatewayType
The gateway used to process this payment. Only a SINGLE payment gateway can modify transactions on a particular payment.- Parameters:
gatewayType
- The gateway used to process this payment.
-
setOwningEntityType
Describes the owning entity of the payment. For example, the payment could have originated with a cart or a subscription, therefore this value might be CART or SUBSCRIPTION.- Parameters:
owningEntityType
- The type describing the owning entity of the payment
-
setOwningEntityId
The id of the entity that owns this payment. For example, this may be a cart id, or a subscription billing cycle id.- Parameters:
owningEntityId
- The id of the entity that owns this payment.
-
setAddressByType
public void setAddressByType(Map<String, com.broadleafcommerce.order.common.domain.Address> addressByType) The collection of related addresses that may include billing or shipping addresses- Parameters:
addressByType
- The collection of related addresses
-
setAttributes
General use map to capture any additional attributes needed for this Payment- Parameters:
attributes
- General use map to capture any additional attributes needed for this Payment
-
setDisplayAttributes
General use map to capture any display properties for this Payment- Parameters:
displayAttributes
- General use map to capture any display properties for this Payment
-
setSingleUsePaymentMethod
public void setSingleUsePaymentMethod(boolean isSingleUsePaymentMethod) Whether or not the underlying payment method can only be used once. In most cases, we're managing a single-use token that represents a credit card. This flag is especially important for managing payments with successful transactions. In those cases, the token has already been used and cannot be reused. If we need modify the payment's amount, then we may actually need to archive the existing payment, and create a new payment, with a new underlying token. Additionally, this flag is helpful when needing to re-authorize an expired authorization transaction. In that case, if the payment represents a single-use payment method, then the re-authorization may not be possible, and you'll need to seek an alternative form of payment.- Parameters:
isSingleUsePaymentMethod
- Whether or not the underlying payment method can only be used once
-
setAmount
public void setAmount(javax.money.MonetaryAmount amount) The amount for which this payment is allotted. The summation of all of thepayments
for a particular cart should equal the cart's total. If specified, the amount details (subtotal
,adjustmentsTotal
,fulfillmentTotal
, &taxTotal
) should sum together to equal this amount.- Parameters:
amount
- The amount for which this payment is allotted.
-
setSubtotal
public void setSubtotal(javax.money.MonetaryAmount subtotal) The payment's total usually excluding adjustments, tax, and shipping. -
setAdjustmentsTotal
public void setAdjustmentsTotal(javax.money.MonetaryAmount adjustmentsTotal) The payment's adjustments (a.k.a discounts) total, usually excluding shipping/fulfillment discounts. -
setFulfillmentTotal
public void setFulfillmentTotal(javax.money.MonetaryAmount fulfillmentTotal) The payment's total fulfillment cost -
setTaxTotal
public void setTaxTotal(javax.money.MonetaryAmount taxTotal) The payment's total tax cost -
setAmountAuthorized
public void setAmountAuthorized(javax.money.MonetaryAmount amountAuthorized) The total authorized amount for capture. This value is calculated as "total authorized - total reverse-authed".- Parameters:
amountAuthorized
- the total authorized amount for capture
-
setAmountCaptured
public void setAmountCaptured(javax.money.MonetaryAmount amountCaptured) The total amount that is currently captured. This value is calculated as "total captured - total refunded".- Parameters:
amountCaptured
- The total amount that is currently captured
-
setTotalEverCaptured
public void setTotalEverCaptured(javax.money.MonetaryAmount totalEverCaptured) The total amount ever captured, as opposed to the current snapshot of the captured amount represented ingetAmountCaptured()
.- Parameters:
totalEverCaptured
- The total amount ever captured
-
setAmountRefunded
public void setAmountRefunded(javax.money.MonetaryAmount amountRefunded) The total refunded amount.- Parameters:
amountRefunded
- the total refunded amount
-
setAmountCredited
public void setAmountCredited(javax.money.MonetaryAmount amountCredited) The total detached credit amount.- Parameters:
amountCredited
- the total detached credit amount
-
setCaptureAmountAwaitingResult
public void setCaptureAmountAwaitingResult(javax.money.MonetaryAmount captureAmountAwaitingResult) The total amount sent to the payment gateway for capture, and is waiting for a response about the transaction result.This value should only be present for payment gateways that support asynchronous transaction executions.
- Parameters:
captureAmountAwaitingResult
- the total amount sent to the payment gateway for capture and is waiting for a response about the transaction result
-
setReverseAuthorizeAmountAwaitingResult
public void setReverseAuthorizeAmountAwaitingResult(javax.money.MonetaryAmount reverseAuthorizeAmountAwaitingResult) The total amount sent to the payment gateway for reverse authorize, and is waiting for a response about the transaction result.This value should only be present for payment gateways that support asynchronous transaction executions.
- Parameters:
reverseAuthorizeAmountAwaitingResult
- the total amount sent to the payment gateway for reverse authorize and is waiting for a response about the transaction result
-
setRefundAmountAwaitingResult
public void setRefundAmountAwaitingResult(javax.money.MonetaryAmount refundAmountAwaitingResult) The total amount sent to the payment gateway for refund, and is waiting for a response about the transaction result.This value should only be present for payment gateways that support asynchronous transaction executions.
- Parameters:
refundAmountAwaitingResult
- the total amount sent to the payment gateway for refund and is waiting for a response about the transaction result
-
setVersion
The version of this payment. Used for checking that the requested version of the payment is up-to-date before saving changes. Required for any request which results in an update being made to the payment. This should never be manually incremented/decremented. -
setPartialReverseAuthSupported
public void setPartialReverseAuthSupported(boolean partialReverseAuthSupported) Whether a portion of an authorization transaction can be reversed, or if the full authorization transaction must be reversed.- Parameters:
partialReverseAuthSupported
- Whether a portion of an authorization transaction can be reversed.
-
setReverseAuthRemainder
public void setReverseAuthRemainder(boolean reverseAuthRemainder) Declares if the reverse authorize for this functionality only allows reversing the full non-captured amount.- Parameters:
reverseAuthRemainder
- Declares if the reverse authorize for this functionality only allows reversing the full non-captured amount.
-
setHasTransactionFlaggedForManualReview
public void setHasTransactionFlaggedForManualReview(boolean hasTransactionFlaggedForManualReview) Indicates that the payment transaction has been flagged for manual review by fraud checks.- Parameters:
hasTransactionFlaggedForManualReview
- whether the transaction has been marked for manual review
-
setAmountAvailableForAuthorize
public void setAmountAvailableForAuthorize(javax.money.MonetaryAmount amountAvailableForAuthorize) Determines the amount that can be authorized for this payment summary -
setAmountAvailableForCapture
public void setAmountAvailableForCapture(javax.money.MonetaryAmount amountAvailableForCapture) Determines the amount that can be captured for this payment summary -
setAmountAvailableForAuthorizeAndCapture
public void setAmountAvailableForAuthorizeAndCapture(javax.money.MonetaryAmount amountAvailableForAuthorizeAndCapture) Determines the amount that can be authorized and captured for this payment summary -
setAmountAvailableForReverseAuthorization
public void setAmountAvailableForReverseAuthorization(javax.money.MonetaryAmount amountAvailableForReverseAuthorization) Determines the amount that can be reverse-authorized for this payment summary -
setAmountAvailableForRefund
public void setAmountAvailableForRefund(javax.money.MonetaryAmount amountAvailableForRefund) Determines the amount that can be refunded for this payment summary -
setFullyAuthorized
public void setFullyAuthorized(boolean fullyAuthorized) Determines if the payment summary is fully authorized -
setFullyCaptured
public void setFullyCaptured(boolean fullyCaptured) Determines if the payment summary is fully captured -
setPartiallyCaptured
public void setPartiallyCaptured(boolean partiallyCaptured) Determines if the payment summary is partially captured -
equals
-
canEqual
-
hashCode
public int hashCode() -
toString
-