Transaction Object
Learn more about how the Lithic platform uses transactions to inform you about activity taking place on your cards.
A transaction
object is created when a payment or payment-related event takes place on a card. Examples of events triggering the creation of a transaction
object are an authorization to make a purchase at a store and a credit authorization requested by a merchant to issue a refund.
The transaction object updates whenever new events take place that modify the transaction. An example of this is when a merchant clears an outstanding purchase authorization.
Our Transaction Flow guide contains detailed examples of scenarios in which a transaction
object is created or updated.
Check out our Simulating Transactions guide to get started with simulating card transactions in our sandbox environment.
How to View Transactions
Lithic provides the following API endpoints to view card transactions in transaction
object form:
Transaction Events
To properly interpret the transaction
object and the underlying card activity that it represents, it is important to understand the various events that can either trigger the creation of an object or append to an existing object's events
array to signal a new lifecycle event.
Transaction events can generally be separated along two dimensions: financial vs. non-financial messages, and requests vs. advice.
Non-financial | Financial | |
---|---|---|
Request | A message that requires a response but does not move money (e.g. authorization). | A message that requires a response and moves money (e.g. financial authorization). |
Advice | An informational message that does not move money (e.g. auth advice). | An informational message that moves money (e.g. clearing). |
Financial messages prompt movement of funds between accounts (e.g. a clearing message that prompts a withdrawal of funds from a card program's bank account), while non-financial messages do not prompt movement of funds (e.g. an authorization request that induces a hold on funds but doesn’t trigger a payment to the merchant until the transaction settles).
On the other axis, requests are messages that require a response (i.e., approval or decline) from Lithic, while advice messages only require an acknowledgment of receipt from Lithic.
Event Type | Description | Financial or Non-financial | Request or Advice |
---|---|---|---|
Authorization | A dual-message authorization request from a merchant has taken place on the card. If approved, a subsequent clearing is typically expected. | Non-financial | Request |
Financial Authorization | A single-message authorization request from a merchant has taken place on the card, and no subsequent clearing is expected. | Financial | Request |
Credit Authorization | A dual-message credit or refund authorization request from a merchant has taken place on the card. If approved, a subsequent clearing is normally expected. | Non-financial | Request |
Financial Credit Authorization | A single-message credit or refund authorization request from a merchant has taken place on the card, and no subsequent clearing is expected. | Financial | Request |
Authorization Advice | An advice message indicating either that the authorized amount of a previous authorization has been modified or that an authorization was declined upstream on your behalf (most typically by the network). | Non-financial | Advice |
Credit Authorization Advice | An advice message indicating that a credit authorization was approved upstream on your behalf (most typically by the network). | Non-financial | Advice |
Authorization Reversal | An advice message indicating that an authorization was reversed by the merchant. Typical causes of this are that an authorization approval was not received in time or the issuer sent back an Address Verification Service (AVS) mismatch result. | Non-financial | Advice |
Clearing | An advice message indicating either that a merchant has captured the transaction and money has moved, or that a financial authorization was declined upstream on your behalf (most typically by the network). | Financial | Advice |
Return | An advice message indicating that a refund has been processed on the transaction, and money has moved. | Financial | Advice |
Return Reversal | An advice message indicating that a refund has been reversed. A primary motive for this is a merchant needing to reverse an incorrectly issued refund. | Financial | Advice |
Balance Inquiry | A request from a merchant for the card's balance. This is most often seen when a cardholder requests to see their balance via an ATM. | Non-financial | Request |
Transaction Amounts
The transaction
object contains various amount fields indicating how much the transaction has been authorized and settled for, across any currencies involved. These can be found in the amounts
object, which specifies the amounts, currencies, and conversion rates utilized during the transaction. All amounts include any acquirer fees and display in the smallest unit of their corresponding currencies.
The pending amount referred to below represents the total amount authorized that is currently pending completion by the merchant/acquirer. This may change over the course of a transaction lifecycle, depending on which events take place. Events impacting the pending amount are:
- Non-financial requests. When Lithic approves this type of request, the amount the merchant is authorized to transact on then increases in magnitude. Examples: Authorization and Credit Authorization.
- Non-financial advices. These increase or decrease the amount the merchant is authorized to transact on, without Lithic's approval. Examples: Authorization Advice and Authorization Reversal.
- Financial events settling an existing non-financial request or advice. Such events reduce the remaining amount that the merchant can transact on. Examples: Clearing (following an Authorization) and Return (following a Credit Authorization).
How should you use the pending amount?
Pending debit transactions and pending credit transactions differ in how Lithic treats them. The pending amount in both cases indicates the current expectation of funds settling in one direction or the other – merchant to cardholder, or vice versa. However, a pending debit transaction also results in a temporary reduction, or hold, of the cardholder's spending power by the pending amount, to ensure the cardholder does not spend beyond what is permitted. If the transaction settles, this reduction becomes permanent to a full or partial extent, depending on how much has settled; otherwise the reduction is eventually reversed. A pending credit transaction, on the other hand, does not increase the cardholder's spending power. This increase only occurs once the transaction settles and the expectation of funds has been realized, to prevent situations where the credit authorization gets reversed and the cardholder has overspent as a result of the anticipated funds never arriving.
Due to this difference, the pending amount of a debit transaction equates to the actual hold placed on the cardholder's spending power. This materializes as a decrease in the available balance to spend (for a debit or prepaid card program) or a decrease in the available credit (for a credit card program). The pending amount is also summed into the total spend controlled by any spend limits. Meanwhile, the pending amount of a credit transaction has no impact, except to signal that the cardholder may receive funds from the merchant. Customers integrating Lithic with their own or a third-party ledger are strongly encouraged to treat the pending amount as described above.
The settled amount referred to below represents the total amount of the transaction that has settled. This may change over the course of a transaction lifecycle. Financial events impact the settled amount, while non-financial events do not.
Note, balance inquiries do not affect any amounts, because these are purely informational requests from the merchant.
A transaction may span multiple currencies during its lifecycle, by authorizing in one currency and settling in another. To capture this, Lithic displays amounts in the following types of currencies:
- The cardholder billing currency is the currency the card is issued in and the currency the cardholder is typically billed in.
- The merchant currency, also known as the transaction currency, is the currency used by the merchant/acquirer when submitting the transaction to the network.
- The settlement currency is the currency that settlement (actual funds movement) takes place in.
How do the amounts in these currencies relate to each other?
- In each event, the merchant specifies the desired amount in its default currency; this is called the merchant amount, or transaction amount.
- If the cardholder billing currency differs from the merchant currency, the card network converts the merchant amount to the cardholder billing currency to yield the cardholder billing amount. The network pins the exchange rate at the time of the first event in the transaction and reuses it for any subsequent events in this transaction. Applying a fixed exchange rate across all stages of the transaction provides a consistent experience to the cardholder, by ensuring that the pending amount displayed on the cardholder's account matches the final amount in the statement issued to the cardholder.
- If the event is financial and the settlement currency differs from the merchant currency, then the card network converts the merchant amount to the settlement currency. The conversion rate used here is not pinned, meaning the network will apply the live exchange rate to any subsequent financial event in this transaction (see our guide to Multiple Completion). The settlement amount output by this conversion represents how much will actually settle between the issuer and the network for this particular event. Due to fluctuating conversion rates and network fees, this will deviate from the cardholder billing amount.
Lithic exposes all of these amounts, as well as the conversion rates used, to give customers transparency into how much their transactions are pending or settling for at each stage. Customers may use the cardholder billing amount to bill cardholders, but should keep in mind that actual funds movement occurs in the settlement amount. Lithic utilizes the settlement amount when updating balances within our ledger.
Let's look at an example illustrating the concepts above. A person with a card issued in Canada makes a 100 AUD purchase at a store in Sydney. Assume this takes place as a dual-message system transaction. The merchant sends an authorization request to the card network with a merchant amount of 100 AUD, and the network pins and uses the current conversion rate of 1 AUD to 0.9159 CAD to calculate a cardholder billing amount of 91.59 CAD. Lithic receives and approves this authorization request. The next day, the merchant submits a clearing of 100 AUD to settle the transaction. The network uses the pinned rate to calculate a cardholder billing amount of 91.59 CAD. Suppose settlement takes place in CAD; then the network uses the live conversion rate of 1 AUD to 0.9160 CAD to calculate a settlement amount of 91.60 CAD. The settlement amount differs from the cardholder billing amount by 0.01 CAD.
Below describes the amount fields in the transaction
object, along with the events that can affect them. These are negative for a debit transaction and positive for a credit transaction. A full outline of the amounts
object can be found here.
Field | Description | Impacting Events |
---|---|---|
amounts.cardholder.amount | The estimated settled amount of the transaction in the cardholder billing currency. | Financial Authorization, Financial Credit Authorization, Clearing, Return, Return Reversal |
amounts.hold.amount | The pending amount of the transaction in the anticipated settlement currency. | Authorization, Credit Authorization, Authorization Advice, Credit Authorization Advice, Authorization Reversal, Clearing, Return |
amounts.merchant.amount | The settled amount of the transaction in the merchant currency. | Financial Authorization, Financial Credit Authorization, Clearing, Return, Return Reversal |
amounts.settlement.amount | The settled amount of the transaction in the settlement currency. | Financial Authorization, Financial Credit Authorization, Clearing, Return, Return Reversal |
Deprecated Transaction Amount Fields
The transaction
object also contains the following fields that are deprecated and will be removed in the future. Lithic will provide advance notice to customers at such time that this occurs.
The authorization amount referred to below represents the total amount requested by the merchant. This may change over the course of a transaction lifecycle, depending on which events take place. Events impacting the authorization amount are:
- Requests, both financial and non-financial, as they signal the merchant's intent to transact for a given amount. Examples: Authorization and Financial Credit Authorization.
- Non-financial advices. These events modify the requested transaction amount. Examples: Authorization Advice and Authorization Reversal.
- Financial advices reversing an existing financial request or advice. Such events unwind, either partially or entirely, the prior funds movement as well as the merchant's intent to trigger this movement. The latter is done to signal that the merchant should reauthorize for the desired amount if it wants to reattempt the funds movement. Examples: Return (following a Clearing) and Return Reversal (following a Return).
All amounts include any acquirer fees and display in the smallest unit of their corresponding currencies.
Field | Description | Impacting Events |
---|---|---|
amount | When the transaction is pending, this represents the authorization amount of the transaction in the anticipated settlement currency. This field represents the settled amount in the settlement currency once the transaction has settled. | All events, except for Balance Inquiry |
authorization_amount | The authorization amount of the transaction in the anticipated settlement currency. | Authorization, Financial Authorization, Credit Authorization, Financial Credit Authorization, Authorization Advice, Credit Authorization Advice, Authorization Reversal, Return, Return Reversal |
merchant_amount | Analogous to the amount , but in the merchant currency. | All events, except for Balance Inquiry |
merchant_authorization_amount | Analogous to the authorization_amount , but in the merchant currency. | Authorization, Financial Authorization, Credit Authorization, Financial Credit Authorization, Authorization Advice, Credit Authorization Advice, Authorization Reversal, Return, Return Reversal |
settled_amount | The settled amount of the transaction in the settlement currency. | Financial Authorization, Financial Credit Authorization, Clearing, Return, Return Reversal |
Transaction Event Amounts
Each event in the transaction
object's events
array also contains fields detailing, in multiple currency types, the amount requested by the merchant/acquirer, independent of whether the event is approved or declined. These can be found in the event's amounts
object, which lists the amounts, currencies, and conversion rates involved. A full outline of the amounts
object can be found here.
Field | Description |
---|---|
amounts.cardholder.amount | Amount of the event in the cardholder billing currency. |
amounts.merchant.amount | Amount of the event in the merchant currency. |
amounts.settlement.amount | Amount of the event, if it is financial, in the settlement currency. Non-financial events do not contain this amount because they do not move funds. |
Deprecated Transaction Event Amount Fields
The transaction
event also contains the following fields that are deprecated and will be removed in the future. Lithic will provide advance notice to customers at such time that this occurs.
Field | Description |
---|---|
amount | Amount of the event in the settlement currency. |
Enumerations
Transaction Status
The following outlines the possible values for the status
within the transaction
object.
Value | Description |
---|---|
DECLINED | The transaction was declined |
EXPIRED | The authorization validity window (which dictates how long the merchant has to clear or settle the transaction) has passed. Lithic has automatically expired the authorization |
PENDING | Authorization is pending completion from the merchant |
SETTLED | The transaction is complete |
VOIDED | The merchant has voided the previously pending authorization |
Transaction Result and Transaction Event Result
The following outlines the possible values for the transaction-level result
and event-level result
.
ACCOUNT_STATE_TRANSACTION_FAIL | Contact [email protected] |
APPROVED | Successful transaction |
AUTH_RULE_ALLOWED_COUNTRY | Transaction was declined because the merchant's country is not contained in the set of allowed MCCs configured via Auth Rules |
AUTH_RULE_ALLOWED_MCC | Transaction was declined because the merchant's merchant category code (MCC) is not contained in the set of allowed MCCs configured via Auth Rules |
AUTH_RULE_BLOCKED_COUNTRY | Transaction was declined because the merchant's country is contained in the set of blocked countries configured via Auth Rules |
AUTH_RULE_BLOCKED_MCC | Transaction was declined because the merchant's merchant category code (MCC) is contained in the set of blocked MCCs configured via Auth Rules |
BANK_CONNECTION_ERROR | Please reconnect a funding source |
BANK_NOT_VERIFIED | Please confirm the funding source |
CARD_PAUSED | Transaction was declined because either the card program responded to ASA request with a response of CARD_PAUSED or the card’s state was PAUSED at the time of authorization |
CARD_CLOSED | Transaction was declined because either the card program responded to ASA request with a response of CARD_CLOSED or the card’s state was CLOSED at the time of authorization |
DECLINED | Transaction was declined for a reason not captured by the other listed reasons |
DO_NOT_HONOR_ADVICE | Transaction was declined due to a decision made by the acquirer or the card network. This is primarily occurs when transaction processing takes a long time on the Lithic side, due to either the customer's ASA responder or the Lithic platform taking too long to respond. An advice with this result typically follows a declined authorization or an approved and voided authorization. On occasion, it may also follow a financial authorization. |
FRAUD_ADVICE | Transaction declined due to risk-related reasons |
IGNORED_TTL_EXPIRY | Authorization could not be processed by the Lithic platform in time |
INACTIVE_ACCOUNT | Contact [email protected] |
INCORRECT_PIN | PIN verification failed. This may occur for several reasons, including a PIN entered incorrectly by the cardholder or a PIN transaction attempted while the PIN is blocked due to consecutive incorrect attempts. In rare cases, this result can be triggered if the merchant sends through bad PIN data, even if the cardholder was not prompted to enter a PIN during the transaction. |
INSUFFICIENT_FUNDS | Transaction was declined because the card's available balance was insufficient to cover the authorization amount. |
INSUFFICIENT_FUNDS_PRELOAD | Result given when client responds to ASA request with INSUFFICIENT_FUNDS . See ASA Response Result |
INVALID_CARD_DETAILS | Incorrect CVV or expiry date |
INVALID_TRANSACTION | Transaction type (for example, inter-account transfer) cannot be processed |
MERCHANT_BLACKLIST | This merchant is disallowed on the platform |
ORIGINAL_NOT_FOUND | Merchant submitted a reversal without a corresponding original |
PREVIOUSLY_COMPLETED | A duplicate message from the network was received on a transaction that has already been completed or cleared |
SINGLE_USE_RECHARGED | Single-use card attempted multiple times |
SWITCH_INOPERATIVE_ADVICE | Network error, re-attempt the transaction |
UNAUTHORIZED_MERCHANT | Merchant locked card attempted at different merchant. |
UNKNOWN | Transaction was declined for an unspecified reason |
UNKNOWN_HOST_TIMEOUT | Network error, re-attempt the transaction |
USER_TRANSACTION_LIMIT | User-set spend limit exceeded |
Transaction Event Detailed Results
The following outlines the possible values composing the transaction event-level detailed_results
array.
Enum values only relevant for authorization-based events (i.e., may appear associated with event types AUTHORIZATION
, FINANCIAL_AUTHORIZATION
, CREDIT_AUTHORIZATION
, FINANCIAL_CREDIT_AUTHORIZATION
, BALANCE_INQUIRY
):
ACCOUNT_DAILY_SPEND_LIMIT_EXCEEDED | Authorization was declined because authorization amount exceeds the account’s available daily spend limit |
ACCOUNT_DELINQUENT | Transaction was declined because the account is in delinquency |
ACCOUNT_INACTIVE | Either the card program responded to ASA request with a response of ACCOUNT_INACTIVE or the account object is not in a transactable state (e.g., PAUSED or CLOSED ) |
ACCOUNT_LIFETIME_SPEND_LIMIT_EXCEEDED | Authorization was declined because authorization amount exceeds the account’s available lifetime spend limit |
ACCOUNT_MONTHLY_SPEND_LIMIT_EXCEEDED | Authorization was declined because authorization amount exceeds the account’s available monthly spend limit |
ADDRESS_INCORRECT | Authorization was declined because card program responded to ASA request with a response of AVS_INVALID |
AUTH_RULE_ALLOWED_COUNTRY | Authorization was declined because the merchant’s country is not contained in the set of allowed countries configured via Auth Rules |
AUTH_RULE_ALLOWED_MCC | Authorization was declined because the merchant’s merchant category code (MCC) is not contained in the set of allowed MCCs configured via Auth Rules |
AUTH_RULE_BLOCKED_COUNTRY | Authorization was declined because the merchant's country is contained in the set of blocked countries configured via Auth Rules |
AUTH_RULE_BLOCKED_MCC | Authorization was declined because the merchant's merchant category code (MCC) is contained in the set of blocked countries configured via Auth Rules |
CARD_CLOSED | Authorization was declined because either the card program responded to ASA request with a response of CARD_CLOSED or the card’s state was CLOSED at the time of authorization |
CARD_EXPIRY_DATE_INCORRECT | Authorization was declined because the expiry date provided was incorrect |
CARD_NOT_ACTIVATED | Authorization was declined because card is in a PENDING_FULFILLMENT or a PENDING_ACTIVATION state. |
CARD_PAUSED | Authorization was declined because either the card program responded to ASA request with response of CARD_PAUSED or the card’s state was PAUSED at the time of authorization |
CARD_PIN_INCORRECT | Authorization was declined because the provided PIN was incorrect |
CARD_SECURITY_CODE_INCORRECT | Authorization was declined because the provided security code was incorrect. Excessive occurrences of incorrect security codes on the same card may be an indicator of cardholder confusion or fraud. |
CARD_SPEND_LIMIT_EXCEEDED | Authorization was declined because either the authorization amount exceeds the card’s available spend limit or the card program responded to ASA request with response of VELOCITY_EXCEEDED |
CUSTOM_ASA_RESULT | Authorization was declined because the card program responded to ASA request with a decline reason not contained in the predefined set |
CUSTOMER_ASA_TIMEOUT | Authorization was declined because the card program’s ASA responder timed out and did not provide an approve or decline reason within the allotted time |
DRIVER_NUMBER_INVALID | Authorization was declined because transaction had an invalid driver number |
VEHICLE_NUMBER_INVALID | Authorization was declined because transaction had an invalid vehicle number |
LITHIC_SYSTEM_ERROR | Authorization was declined because of a Lithic system error, and transaction should be re-attempted |
LITHIC_SYSTEM_RATE_LIMIT | Authorization was declined because of a rate limit applied by the Lithic system (most typically when a surge in authorization volume takes place) |
MALFORMED_ASA_RESPONSE | Authorization was declined because the card program’s response to the ASA request did not conform to the specified response structure |
MERCHANT_LOCKED_CARD_ATTEMPTED_ELSEWHERE | Authorization was declined because the merchant-locked card was attempted at a different merchant than the one it is locked to |
MERCHANT_NOT_PERMITTED | Authorization was declined because transactions with the merchant are not permitted on the Lithic platform |
PIN_BLOCKED | Authorization was declined because the card's PIN_STATUS is currently BLOCKED due to excessive consecutive incorrect PIN attempts. To unblock a card's PIN, see the Managing Cards guide here. |
PROGRAM_CARD_SPEND_LIMIT_EXCEEDED | Authorization was declined because the authorization amount exceeds the card’s permitted spend amount (as determined at the program-level) |
PROGRAM_SUSPENDED | Authorization was declined because the program is suspended |
PROGRAM_USAGE_RESTRICTION | Authorization was declined because the transaction violates the program’s terms of use (e.g., transacting at prohibited MCCs) |
SINGLE_USE_CARD_REATTEMPTED | Authorization was declined because the card used is a single use card that has already been used |
UNAUTHORIZED_MERCHANT | Authorization was declined because the card program responded to ASA request with response of UNAUTHORIZED_MERCHANT |
Enum values only relevant for advices (i.e., may appear associated with event types AUTHORIZATION_ADVICE
, CREDIT_AUTHORIZATION_ADVICE
, AUTHORIZATION_REVERSAL
, AUTHORIZATION_EXPIRY
, CLEARING
, RETURN
, RETURN_REVERSAL
):
CARD_RESTRICTED | Network declined the authorization and populated the advice message with a response code indicating “restricted card” |
CONTACT_CARD_ISSUER | Network declined the authorization and populated the advice message with a response code indicating “contact card issuer” |
DO_NOT_HONOR | Network declined the authorization and populated the advice message with a response code indicating “do not honor” |
FORMAT_ERROR | Network declined the authorization and populated the advice message with a response code indicating “format error”. This indicates that the acquirer’s message had a format error, causing an on-behalf decline and subsequent advice message. |
MERCHANT_INVALID | Network declined the authorization and populated the advice message with a response code indicating “invalid merchant” |
OVER_REVERSAL_ATTEMPTED | The merchant attempted to reverse the authorized amount, but the reversal would have caused the transaction amount to go negative |
REVERSAL_UNMATCHED | The merchant attempted to reverse a prior authorization or settlement, but the original event was not found and therefore the reversal is not matched |
TRANSACTION_NOT_PERMITTED_TO_ACQUIRER_OR_TERMINAL | Network declined the authorization and populated the advice message with a response code indicating “transaction not permitted to acquirer/terminal” |
TRANSACTION_NOT_PERMITTED_TO_ISSUER_OR_CARDHOLDER | Network declined the authorization and populated the advice message with a response code indicating “transaction not permitted to issuer/cardholder” |
TRANSACTION_PREVIOUSLY_COMPLETED | The merchant attempted to reverse a prior authorization, but the authorization was already successfully cleared or reversed, and this reversal is considered a duplicate |
Enum values only relevant for both authorization-based events and advices:
APPROVED | Either the authorization was approved or the network populated the advice message with a response code indicating "success". |
CARD_CRYPTOGRAM_VALIDATION_FAILURE | Either Lithic declined the authorization because the card’s cryptogram could not be validated, or the network declined the authorization and populated the advice message with a response code indicating “cryptographic failure” |
CARD_EXPIRED | Either Lithic declined the authorization because the card has an expiry date that has passed, or the network declined the authorization and populated the advice message with a response code indicating “expired card” |
CARD_INVALID | Either Lithic declined the authorization because the card details entered are not recognized (e.g., card was just created and has not yet been propagated across Lithic’s system to support an authorization) or the network declined the authorization and populated the advice message with a response code indicating “invalid card number” |
DECLINED | Either Lithic declined the authorization for a reason not captured elsewhere in the set of enums, or the network declined the authorization and populated the advice message with a response code not captured elsewhere in the set of enums |
INSUFFICIENT_FUNDS | Either Lithic declined the authorization because the associated financial account had an insufficient available balance to cover the authorization amount, the card program responded to ASA request with a response of INSUFFICIENT_FUNDS , or the network declined the authorization and populated the advice message with a response code indicating “insufficient funds/over credit limit) |
SECURITY_VIOLATION | Either Lithic declined the authorization because a security violation occurred (e.g., required card security details were not provided) or the network declined the authorization and populated the advice message with a response code indicating “security violation” |
TRANSACTION_INVALID | Either Lithic declined the authorization because the attempted transaction type is not supported, or the network declined the authorization and populated the advice message with a response code indicating “invalid transaction” |
Updated about 2 hours ago