CheckCash
Attempts to redeem a check to receive up to the amount authorized by the corresponding CheckCreate transaction. Only the Destination address of a check can cash it with a CheckCash transaction. Cashing a check this way is similar to executing a Payment initiated by the destination.
Since the funds for a check are not guaranteed, redeeming a check can fail because the sender does not have a high enough balance or because there is not enough liquidity to deliver the funds. If this happens, the check remains in the ledger and the destination can try to cash it again later, or for a different amount.
Requires the Checks amendment. Loading...
Example CheckCash JSON
{
    "Account": "rfkE1aSy9G8Upk4JssnwBxhEv5p4mn2KTy",
    "TransactionType": "CheckCash",
    "Amount": "100000000",
    "CheckID": "838766BA2B995C00744175F69A1B11E32C3DBC40E64801A4056FCBD657F57334",
    "Fee": "12"
}CheckCash Fields
In addition to the common fields, CheckCash transactions use the following fields:
| Field | JSON Type | Internal Type | Description | 
|---|---|---|---|
| CheckID | String | UInt256 | The ID of the Check ledger object to cash, as a 64-character hexadecimal string. | 
| Amount | Currency Amount | Amount | (Optional) Redeem the Check for exactly this amount, if possible. The currency must match that of the SendMaxof the corresponding CheckCreate transaction. You must provide either this field orDeliverMin. | 
| DeliverMin | Currency Amount | Amount | (Optional) Redeem the Check for at least this amount and for as much as possible. The currency must match that of the SendMaxof the corresponding CheckCreate transaction. You must provide either this field orAmount. | 
The transaction must include either Amount or DeliverMin, but not both.
Error Cases
- If the sender of the CheckCash transaction is not the Destinationof the check, the transaction fails with the result codetecNO_PERMISSION.
- If the Check identified by the CheckIDfield does not exist, the transaction fails with the resulttecNO_ENTRY.
- If the Check identified by the CheckIDfield has already expired, the transaction fails with the resulttecEXPIRED.
- If the destination of the Check has the RequireDestflag enabled but the Check, as created, does not have a destination tag, the transaction fails with the result codetecDST_TAG_NEEDED.
- If the transaction specifies both AmountandDeliverMin, or omits both, the transaction fails with the resulttemMALFORMED.
- If the AmountorDeliverMindoes not match the currency (and issuer, if not XRP) of the Check, the transaction fails with the resulttemBAD_CURRENCY.