subscribe
The subscribe method requests periodic notifications from the server when certain events happen.
Request Format
An example of the request format:
{
  "id": "Example watch Bitstamp's hot wallet",
  "command": "subscribe",
  "accounts": ["rrpNnNLKrartuEqfJGpqyDwPj1AFPg9vn1"]
}The request includes the following parameters:
| Field | Type | Required? | Description | 
|---|---|---|---|
| streams | Array | No | Streams to subscribe to, as explained below. Each member of the array must be the string name of a stream. | 
| accounts | Array | No | Array with the unique addresses of accounts to monitor for validated transactions. The server sends a transactiontype message whenever a transaction affects at least one of these accounts. | 
| accounts_proposed | Array | No | Like accounts, but include transactions that are not yet finalized. | 
| books | Array | No | Order books to monitor for updates. Each member of the array must be a book object, as defined below. The server sends a transactiontype message whenever a transaction affects this account. | 
| url | String | Optional for Websocket; Required for JSON-RPC | (Admin only) URL where the server sends JSON-RPC callbacks for each event. | 
| url_username | String | No | Username to provide for basic authentication at the callback URL. | 
| url_password | String | No | Password to provide for basic authentication at the callback URL. | 
The following parameters are deprecated and may be removed without further notice: user, password, rt_accounts.
The streams parameter provides access to the following default streams of information:
| Stream Name | Message Type | Description | 
|---|---|---|
| book_changes | bookChanges | Sends order book changes whenever the consensus process declares a new validated ledger. | 
| consensus | consensusPhase | Sends a message whenever the server changes phase in the consensus cycle. | 
| ledger | ledgerClosed | Sends a message whenever the consensus process declares a new validated ledger. | 
| manifests | manifestReceived | Sends a message whenever the server receives an update to a validator's ephemeral signing key. | 
| peer_status | peerStatusChange | (Admin only) Information about connected peer rippledservers, especially with regards to the consensus process. | 
| transactions | transaction | Sends a message whenever a transaction is included in a closed ledger. | 
| transactions_proposed | transaction | Sends a message whenever a transaction is included in a closed ledger, as well as some transactions that have not yet been included in a validated ledger and may never be. Not all proposed transactions appear before validation. Note Even some transactions that don't succeed are included in validated ledgers, because they take the anti-spam transaction fee. | 
| server | serverStatus | Sends a message whenever the status of the rippledserver (for example, network connectivity) changes. | 
| validations | validationReceived | Sends a message whenever the server receives a validation message, regardless of if the server trusts the validator. (An individual rippleddeclares a ledger validated when the server receives validation messages from at least a quorum of trusted validators.) | 
Book Objects
Each member of the books array, if provided, is an object with the following fields:
| Field | Type | Required? | Description | 
|---|---|---|---|
| taker_gets | Object - Currency | Yes | Specification of which currency the account taking the offer would receive, as a currency object with no amount. | 
| taker_pays | Object - Currency | Yes | Specification of which currency the account taking the offer would pay, as a currency object with no amount. | 
| both | Boolean | No | If true, return both sides of the order book. The default isfalse. | 
| domain | String - Hash | No | The ledger entry ID of a permissioned domain. If provided, subscribe to the order books for the corresponding permissioned DEX instead of the open DEX. Requires the PermissionedDEX amendment. Loading... | 
| snapshot | Boolean | No | If true, return the current state of the order book once when you subscribe before sending updates. The default isfalse. | 
| taker | String - Address | No | The acount to use as a perspective for viewing offers. This affects the funding status and fees of offers. | 
Response Format
An example of a successful response:
{
  "id": "Example watch Bitstamp's hot wallet",
  "status": "success",
  "type": "response",
  "result": {}
}The response follows the standard format. The fields contained in the response vary depending on what subscriptions were included in the request.
- accountsand- accounts_proposed- No fields returned.
- Stream: server- Information about the server status, such asload_base(the current load level of the server),random(a randomly-generated value), and others, subject to change.
- Stream: transactions, Stream:transactions_proposed, Stream:validations, and Stream:consensus- No fields returned.
- Stream: ledger- Information about the ledgers on hand and current fee schedule. This includes the same fields as a ledger stream message, except that it omits thetypeandtxn_countfields.
- books- No fields returned by default. If- "snapshot": trueis set in the request, returns- offers(an array of offer definition objects defining the order book).
Possible Errors
- Any of the universal error types.
- invalidParams- One or more fields are specified incorrectly, or one or more required fields are missing.
- noPermission- The request included the- urlfield, but you are not connected as an admin.
- unknownStream- One or more the members of the- streamsfield of the request is not a valid stream name.
- malformedStream- The- streamsfield of the request is not formatted properly.
- malformedAccount- One of the addresses in the- accountsor- accounts_proposedfields of the request is not a properly-formatted XRP Ledger address. (Note:: You can subscribe to the stream of an address that does not yet have an entry in the global ledger to get a message when that address becomes funded.)
- srcCurMalformed- One or more- taker_payssub-fields of the- booksfield in the request is not formatted properly.
- dstAmtMalformed- One or more- taker_getssub-fields of the- booksfield in the request is not formatted properly.
- srcIsrMalformed- The- issuerfield of one or more- taker_payssub-fields of the- booksfield in the request is not valid.
- dstIsrMalformed- The- issuerfield of one or more- taker_getssub-fields of the- booksfield in the request is not valid.
- badMarket- One or more desired order books in the- booksfield does not exist; for example, offers to exchange a currency for itself.
When you subscribe to a particular stream, you receive periodic responses on that stream until you unsubscribe or close the WebSocket connection. The content of those responses depends on what you subscribed to. Here are some examples:
Ledger Stream
The ledger stream only sends ledgerClosed messages when the consensus process declares a new validated ledger. The message identifies the ledger and provides some information about its contents.
{
  "type": "ledgerClosed",
  "fee_base": 10,
  "fee_ref": 10,
  "ledger_hash": "687F604EF6B2F67319E8DCC8C66EF49D84D18A1E18F948421FC24D2C7C3DB464",
  "ledger_index": 7125358,
  "ledger_time": 455751310,
  "network_id": 1,
  "reserve_base": 20000000,
  "reserve_inc": 5000000,
  "txn_count": 7,
  "validated_ledgers": "32570-7125358"
}The fields from a ledger stream message are as follows:
| Field | Type | Description | 
|---|---|---|
| type | String | ledgerClosedindicates this is from the ledger stream | 
| fee_base | Number | The reference transaction cost as of this ledger version, in drops of XRP. If this ledger version includes a SetFee pseudo-transaction the new transaction cost applies starting with the following ledger version. | 
| fee_ref | Number | (May be omitted) The reference transaction cost in "fee units". If the XRPFees amendment is enabled, this field is permanently omitted as it will no longer be relevant. | 
| ledger_hash | String - Hash | The identifying hash of the ledger version that was closed. | 
| ledger_index | Number - Ledger Index | The ledger index of the ledger that was closed. | 
| ledger_time | Number | The time this ledger was closed, in seconds since the Ripple Epoch | 
| network_id | Number | The XRPL network of this stream. | 
| reserve_base | Number | The minimum reserve, in drops of XRP, that is required for an account. If this ledger version includes a SetFee pseudo-transaction the new base reserve applies starting with the following ledger version. | 
| reserve_inc | Number | The owner reserve for each object an account owns in the ledger, in drops of XRP. If the ledger includes a SetFee pseudo-transaction the new owner reserve applies after this ledger. | 
| txn_count | Number | Number of new transactions included in this ledger version. | 
| validated_ledgers | String | (May be omitted) Range of ledgers that the server has available. This may be a disjoint sequence such as 24900901-24900984,24901116-24901158. This field is not returned if the server is not connected to the network, or if it is connected but has not yet obtained a ledger from the network. | 
Validations Stream
The validations stream sends messages whenever it receives validation messages, also called validation votes, regardless of whether or not the validation message is from a trusted validator. The message looks like the following:
{
    "type": "validationReceived",
    "amendments":[
        "42426C4D4F1009EE67080A9B7965B44656D7714D104A72F9B4369F97ABF044EE",
        "4C97EBA926031A7CF7D7B36FDE3ED66DDA5421192D63DE53FFB46E43B9DC8373",
        "6781F8368C4771B83E8B821D88F580202BCB4228075297B19E4FDC5233F1EFDC",
        "C1B8D934087225F509BEB5A8EC24447854713EE447D277F69545ABFA0E0FD490",
        "DA1BD556B42D85EA9C84066D028D355B52416734D3283F85E216EA5DA6DB7E13"
    ],
    "base_fee":10,
    "flags":2147483649,
    "full":true,
    "ledger_hash":"EC02890710AAA2B71221B0D560CFB22D64317C07B7406B02959AD84BAD33E602",
    "ledger_index":"6",
    "load_fee":256000,
    "master_key": "nHUon2tpyJEHHYGmxqeGu37cvPYHzrMtUNQFVdCgGNvEkjmCpTqK",
    "network_id": 1,
    "reserve_base":20000000,
    "reserve_inc":5000000,
    "signature":"3045022100E199B55643F66BC6B37DBC5E185321CF952FD35D13D9E8001EB2564FFB94A07602201746C9A4F7A93647131A2DEB03B76F05E426EC67A5A27D77F4FF2603B9A528E6",
    "signing_time":515115322,
    "validation_public_key":"n94Gnc6svmaPPRHUAyyib1gQUov8sYbjLoEwUBYPH39qHZXuo8ZT"
}The fields from a validations stream message are as follows:
| Field | Type | Description | 
|---|---|---|
| type | String | The value validationReceivedindicates this is from the validations stream. | 
| amendments | Array of Strings | (May be omitted) The amendments this server wants to be added to the protocol. | 
| base_fee | Integer | (May be omitted) The unscaled transaction cost ( reference_feevalue) this server wants to set by Fee Voting. | 
| cookie | String - Number | (May be omitted) An arbitrary value chosen by the server at startup. If the same validation key pair signs validations with different cookies concurrently, that usually indicates that multiple servers are incorrectly configured to use the same validation key pair. | 
| flags | Number | Bit-mask of flags added to this validation message. The flag 0x80000000indicates that the validation signature is fully-canonical. The flag0x00000001indicates that this is a full validation; otherwise it's a partial validation. Partial validations are not meant to vote for any particular ledger. A partial validation indicates that the validator is still online but not keeping up with consensus. | 
| full | Boolean | If true, this is a full validation. Otherwise, this is a partial validation. Partial validations are not meant to vote for any particular ledger. A partial validation indicates that the validator is still online but not keeping up with consensus. | 
| ledger_hash | String | The identifying hash of the proposed ledger is being validated. | 
| ledger_index | String - Number | The Ledger Index of the proposed ledger. | 
| load_fee | Integer | (May be omitted) The local load-scaled transaction cost this validator is currently enforcing, in fee units. | 
| master_key | String | (May be omitted) The validator's master public key, if the validator is using a validator token, in the XRP Ledger's base58 format. (See also: Enable Validation on your rippledServer.) | 
| network_id | Number | The XRPL network of this stream. | 
| reserve_base | Integer | (May be omitted) The minimum reserve requirement ( account_reservevalue) this validator wants to set by Fee Voting. | 
| reserve_inc | Integer | (May be omitted) The increment in the reserve requirement ( owner_reservevalue) this validator wants to set by Fee Voting. | 
| server_version | String - Number | (May be omitted) An 64-bit integer that encodes the version number of the validating server. For example, "1745990410175512576". Only provided once every 256 ledgers. | 
| signature | String | The signature that the validator used to sign its vote for this ledger. | 
| signing_time | Number | When this validation vote was signed, in seconds since the Ripple Epoch. | 
| validated_hash | String | The unique hash of the proposed ledger this validation applies to. | 
| validation_public_key | String | The public key from the key-pair that the validator used to sign the message, in the XRP Ledger's base58 format. This identifies the validator sending the message and can also be used to verify the signature. If the validator is using a token, this is an ephemeral public key. | 
Transaction Streams
Many subscriptions result in messages about transactions, including the following:
- The transactionsstream
- The transactions_proposedstream
- accountssubscriptions
- accounts_proposedsubscriptions
- book(Order Book) subscriptions
The transactions_proposed stream, strictly speaking, is a superset of the transactions stream: it includes all validated transactions, as well as some suggested transactions that have not yet been included in a validated ledger and may never be. You can identify these "in-flight" transactions by their fields:
- The validatedfield is missing or has a value offalse.
- There is no metaormetadatafield.
- Instead of ledger_hashandledger_indexfields specifying in which ledger version the transactions were finalized, there is aledger_current_indexfield specifying in which ledger version they are currently proposed.
Otherwise, the messages from the transactions_proposed stream are the same as ones from the transactions stream.
Since the only thing that can modify an account or an order book is a transaction, the messages that are sent as a result of subscribing to particular accounts or books also take the form of transaction messages, the same as the ones in the transactions stream. The only difference is that you only receive messages for transactions that affect the accounts or order books you're watching.
The accounts_proposed subscription works the same way, except it also includes unconfirmed transactions, like the transactions_proposed stream, for the accounts you're watching.
{
  "close_time_iso": "2024-11-01T23:59:01Z",
  "engine_result": "tesSUCCESS",
  "engine_result_code": 0,
  "engine_result_message": "The transaction was applied. Only final in a validated ledger.",
  "hash": "6489E52A909208E371ACE82E19CAE59896C7F8BA40E7C36C5B8AA3C451914BED",
  "ledger_hash": "0B6F44849E6D702D0CFB447FDBD7B603C269E9EEECE9176882EF376E0C9DFF6A",
  "ledger_index": 1969852,
  "meta": {
    "AffectedNodes": [
      {
        "ModifiedNode": {
          "FinalFields": {
            "Account": "rH3PxjJPrrkvsATddBXkayjAyWR8xigaE8",
            "Balance": "39999964",
            "Flags": 0,
            "OwnerCount": 0,
            "Sequence": 1969812
          },
          "LedgerEntryType": "AccountRoot",
          "LedgerIndex": "EDE60B24659BCC06CCE1EA2804A4A202F1C88155CEAED9C140833C0C39100617",
          "PreviousFields": {
            "Balance": "59999976",
            "Sequence": 1969811
          },
          "PreviousTxnID": "1DBC93373D47794A684A5013178D0EBE10E6641D7C262BF20151B0E19156FF79",
          "PreviousTxnLgrSeq": 1969843
        }
      },
      {
        "ModifiedNode": {
          "FinalFields": {
            "Account": "rfdGuuVnq9juqWDV4W3LoLiNcW8g2hAXhN",
            "Balance": "160000000",
            "Flags": 0,
            "OwnerCount": 0,
            "Sequence": 1969810
          },
          "LedgerEntryType": "AccountRoot",
          "LedgerIndex": "F7D350FB54C5BBA734AE574EE6BF7A9294E11F9B75413972F98846AFC587C62C",
          "PreviousFields": {
            "Balance": "140000000"
          },
          "PreviousTxnID": "1DBC93373D47794A684A5013178D0EBE10E6641D7C262BF20151B0E19156FF79",
          "PreviousTxnLgrSeq": 1969843
        }
      }
    ],
    "TransactionIndex": 4,
    "TransactionResult": "tesSUCCESS",
    "delivered_amount": "20000000"
  },
  "status": "closed",
  "tx_json": {
    "Account": "rH3PxjJPrrkvsATddBXkayjAyWR8xigaE8",
    "DeliverMax": "20000000",
    "Destination": "rfdGuuVnq9juqWDV4W3LoLiNcW8g2hAXhN",
    "Fee": "12",
    "Flags": 0,
    "LastLedgerSequence": 1969870,
    "Sequence": 1969811,
    "SigningPubKey": "ED0761CDA5507784F6CEB445DE2343F861DD5EC7A869F75B08C7E8F29A947AD9FC",
    "TransactionType": "Payment",
    "TxnSignature": "20D5447ED7095BCCC3D42EA1955600D97D791811072E93D2A358AD9FB258C3A7F004974039D25708F5AE598C78F85B688DD586158F7E9C13AE0F30CC18E3390D",
    "date": 783820741
  },
  "type": "transaction",
  "validated": true
}Transaction stream messages have the following fields:
| Field | Type | Description | 
|---|---|---|
| close_time_iso | String | The ledger close time represented in ISO 8601 time format. | 
| type | String | transactionindicates this is the notification of a transaction, which could come from several possible streams. | 
| engine_result | String | String Transaction result code | 
| engine_result_code | Number | Numeric transaction response code, if applicable. | 
| engine_result_message | String | Human-readable explanation for the transaction response | 
| hash | String | The unique hash identifier of the transaction. | 
| ledger_current_index | Number - Ledger Index | (Unvalidated transactions only) The ledger index of the current in-progress ledger version for which this transaction is currently proposed. | 
| ledger_hash | String - Hash | (Validated transactions only) The identifying hash of the ledger version that includes this transaction | 
| ledger_index | Number - Ledger Index | (Validated transactions only) The ledger index of the ledger version that includes this transaction. | 
| meta | Object | (Validated transactions only) The transaction metadata, which shows the exact outcome of the transaction in detail. | 
| tx_json | Object | The definition of the transaction in JSON format. | 
| validated | Boolean | If true, this transaction is included in a validated ledger and its outcome is final. Responses from thetransactionstream should always be validated. | 
Peer Status Stream
The admin-only peer_status stream reports a large amount of information on the activities of other rippled servers to which this server is connected, in particular their status in the consensus process.
Example of a Peer Status stream message:
{
    "action": "CLOSING_LEDGER",
    "date": 508546525,
    "ledger_hash": "4D4CD9CD543F0C1EF023CC457F5BEFEA59EEF73E4552542D40E7C4FA08D3C320",
    "ledger_index": 18853106,
    "ledger_index_max": 18853106,
    "ledger_index_min": 18852082,
    "type": "peerStatusChange"
}Peer Status stream messages represent some event where the status of the peer rippled server changed. These messages are JSON objects with the following fields:
| Field | Value | Description | 
|---|---|---|
| type | String | peerStatusChangeindicates this comes from the Peer Status stream. | 
| action | String | The type of event that prompted this message. See Peer Status Events for possible values. | 
| date | Number | The time this event occurred, in seconds since the Ripple Epoch. | 
| ledger_hash | String | (May be omitted) The identifying Hash of a ledger version to which this message pertains. | 
| ledger_index | Number | (May be omitted) The Ledger Index of a ledger version to which this message pertains. | 
| ledger_index_max | Number | (May be omitted) The largest Ledger Index the peer has currently available. | 
| ledger_index_min | Number | (May be omitted) The smallest Ledger Index the peer has currently available. | 
Peer Status Events
The action field of a Peer Status stream message can have the following values:
| Value | Meaning | 
|---|---|
| CLOSING_LEDGER | The peer closed a ledger version with this Ledger Index, which usually means it is about to start consensus. | 
| ACCEPTED_LEDGER | The peer built this ledger version as the result of a consensus round. Note: This ledger is still not certain to become immutably validated. | 
| SWITCHED_LEDGER | The peer concluded it was not following the rest of the network and switched to a different ledger version. | 
| LOST_SYNC | The peer fell behind the rest of the network in tracking which ledger versions are validated and which are undergoing consensus. | 
Order Book Streams
When you subscribe to one or more order books with the books field, you get back any transactions that affect those order books.
Example order book stream message:
{
  "tx_json": {
    "Account": "rBTwLga3i2gz3doX6Gva3MgEV8ZCD8jjah",
    "Fee": "20",
    "Flags": 0,
    "LastLedgerSequence": 91826205,
    "OfferSequence": 156917168,
    "Sequence": 156917177,
    "SigningPubKey": "0253C1DFDCF898FE85F16B71CCE80A5739F7223D54CC9EBA4749616593470298C5",
    "TakerGets": "35992000000",
    "TakerPays": {
      "currency": "USD",
      "issuer": "rhub8VRN55s94qWKDv6jmDy1pUykJzF3wq",
      "value": "18570.025718376"
    },
    "TransactionType": "OfferCreate",
    "TxnSignature": "30440220520439D8DDB6B6D0E4EA1504873D780ADE524E3961E02A5DD84B8B4C456BA3240220533CF99250737C13FD376C18F6D64149332BA1FE6EA04895442247BD29952193",
    "date": 783819060,
    "owner_funds": "36054185999"
  },
  "meta": {
    "AffectedNodes": [
      {
        "ModifiedNode": {
          "FinalFields": {
            "Flags": 0,
            "IndexNext": "0",
            "IndexPrevious": "0",
            "Owner": "rBTwLga3i2gz3doX6Gva3MgEV8ZCD8jjah",
            "RootIndex": "0A2600D85F8309FE7F75A490C19613F1CE0C37483B856DB69B8140154C2335F3"
          },
          "LedgerEntryType": "DirectoryNode",
          "LedgerIndex": "0A2600D85F8309FE7F75A490C19613F1CE0C37483B856DB69B8140154C2335F3",
          "PreviousTxnID": "73BBE254DDC97EAD6ECB2D9F7A7EB13DBA1A5B816C2727548FCFBC41B40604EF",
          "PreviousTxnLgrSeq": 91826203
        }
      },
      {
        "ModifiedNode": {
          "FinalFields": {
            "Account": "rBTwLga3i2gz3doX6Gva3MgEV8ZCD8jjah",
            "Balance": "36092186059",
            "Flags": 0,
            "OwnerCount": 14,
            "Sequence": 156917178
          },
          "LedgerEntryType": "AccountRoot",
          "LedgerIndex": "1ED8DDFD80F275CB1CE7F18BB9D906655DE8029805D8B95FB9020B30425821EB",
          "PreviousFields": {
            "Balance": "36092186079",
            "Sequence": 156917177
          },
          "PreviousTxnID": "73BBE254DDC97EAD6ECB2D9F7A7EB13DBA1A5B816C2727548FCFBC41B40604EF",
          "PreviousTxnLgrSeq": 91826203
        }
      },
      {
        "CreatedNode": {
          "LedgerEntryType": "Offer",
          "LedgerIndex": "3B4D42B185D1FE4EBED70F7E35A8E8AEA39028FB6B16DCDFC175363EA38DED28",
          "NewFields": {
            "Account": "rBTwLga3i2gz3doX6Gva3MgEV8ZCD8jjah",
            "BookDirectory": "79C54A4EBD69AB2EADCE313042F36092BE432423CC6A4F784E125486AFA57980",
            "Sequence": 156917177,
            "TakerGets": "35992000000",
            "TakerPays": {
              "currency": "USD",
              "issuer": "rhub8VRN55s94qWKDv6jmDy1pUykJzF3wq",
              "value": "18570.025718376"
            }
          }
        }
      },
      {
        "DeletedNode": {
          "FinalFields": {
            "ExchangeRate": "4e12547b29376a80",
            "Flags": 0,
            "PreviousTxnID": "D4CB92E19CBADB14F82B0E0703B3F157338253EE1DD46DB91F6C98C93D01DA9C",
            "PreviousTxnLgrSeq": 91826201,
            "RootIndex": "79C54A4EBD69AB2EADCE313042F36092BE432423CC6A4F784E12547B29376A80",
            "TakerGetsCurrency": "0000000000000000000000000000000000000000",
            "TakerGetsIssuer": "0000000000000000000000000000000000000000",
            "TakerPaysCurrency": "0000000000000000000000005553440000000000",
            "TakerPaysIssuer": "2ADB0B3959D60A6E6991F729E1918B7163925230"
          },
          "LedgerEntryType": "DirectoryNode",
          "LedgerIndex": "79C54A4EBD69AB2EADCE313042F36092BE432423CC6A4F784E12547B29376A80"
        }
      },
      {
        "CreatedNode": {
          "LedgerEntryType": "DirectoryNode",
          "LedgerIndex": "79C54A4EBD69AB2EADCE313042F36092BE432423CC6A4F784E125486AFA57980",
          "NewFields": {
            "ExchangeRate": "4e125486afa57980",
            "RootIndex": "79C54A4EBD69AB2EADCE313042F36092BE432423CC6A4F784E125486AFA57980",
            "TakerPaysCurrency": "0000000000000000000000005553440000000000",
            "TakerPaysIssuer": "2ADB0B3959D60A6E6991F729E1918B7163925230"
          }
        }
      },
      {
        "DeletedNode": {
          "FinalFields": {
            "Account": "rBTwLga3i2gz3doX6Gva3MgEV8ZCD8jjah",
            "BookDirectory": "79C54A4EBD69AB2EADCE313042F36092BE432423CC6A4F784E12547B29376A80",
            "BookNode": "0",
            "Flags": 0,
            "OwnerNode": "0",
            "PreviousTxnID": "D4CB92E19CBADB14F82B0E0703B3F157338253EE1DD46DB91F6C98C93D01DA9C",
            "PreviousTxnLgrSeq": 91826201,
            "Sequence": 156917168,
            "TakerGets": "35992000000",
            "TakerPays": {
              "currency": "USD",
              "issuer": "rhub8VRN55s94qWKDv6jmDy1pUykJzF3wq",
              "value": "18569.847557976"
            }
          },
          "LedgerEntryType": "Offer",
          "LedgerIndex": "F72F9E5C9C81C6D2403C062365B34AA371D5D0BB13E1787622E936D0B8B4A499"
        }
      }
    ],
    "TransactionIndex": 23,
    "TransactionResult": "tesSUCCESS"
  },
  "type": "transaction",
  "validated": true,
  "status": "closed",
  "close_time_iso": "2024-11-01T23:31:00Z",
  "ledger_index": 91826203,
  "ledger_hash": "746D115326E08B884D7EA5F0E379272774F1B41443C000044D5DF97781E0601D",
  "hash": "2250BB2914AC7BC143AD62E7DD36F23A22F2BC50495FC29B36C6B0CA570BB4FA",
  "engine_result_code": 0,
  "engine_result": "tesSUCCESS",
  "engine_result_message": "The transaction was applied. Only final in a validated ledger."
}The format of an order book stream message is the same as that of transaction stream messages, except that OfferCreate transactions also contain the following field:
| Field | Value | Description | 
|---|---|---|
| transaction.owner_funds | String | Numeric amount of the TakerGetscurrency that theAccountsending this OfferCreate transaction has after executing this transaction. This does not check whether the currency amount is frozen.API v2 Renamed to tx_json.owner_funds. | 
Book Changes Stream
The book_changes stream sends bookChanges messages whenever a new ledger is validated. This message contains a summary of all changes to order books in the decentralized exchange that occurred in that ledger.
Example bookChanges message:
{
  "type": "bookChanges",
  "ledger_index": 88530525,
  "ledger_hash": "E2F24290E1714C842D34A1057E6D6B7327C7DDD310263AFBC67CA8EFED7A331B",
  "ledger_time": 771099232,
  "changes": [
    {
      "currency_a": "XRP_drops",
      "currency_b": "rKiCet8SdvWxPXnAgYarFUXMh1zCPz432Y/USD",
      "volume_a": "23020993",
      "volume_b": "11.51049687275246",
      "high": "1999999.935232603",
      "low": "1999999.935232603",
      "open": "1999999.935232603",
      "close": "1999999.935232603"
    },
    {
      "currency_a": "XRP_drops",
      "currency_b": "rRbiKwcueo6MchUpMFDce9XpDwHhRLPFo/43525950544F0000000000000000000000000000",
      "volume_a": "28062",
      "volume_b": "0.000643919229004",
      "high": "43580000.00000882",
      "low": "43580000.00000882",
      "open": "43580000.00000882",
      "close": "43580000.00000882"
    },
    {
      "currency_a": "XRP_drops",
      "currency_b": "rcEGREd8NmkKRE8GE424sksyt1tJVFZwu/5553444300000000000000000000000000000000",
      "volume_a": "147797392",
      "volume_b": "70.41143840513008",
      "high": "2099053.724049922",
      "low": "2099053.724049922",
      "open": "2099053.724049922",
      "close": "2099053.724049922"
    },
    {
      "currency_a": "XRP_drops",
      "currency_b": "rcRzGWq6Ng3jeYhqnmM4zcWcUh69hrQ8V/LTC",
      "volume_a": "350547165",
      "volume_b": "2.165759976556748",
      "high": "162573356.3100158",
      "low": "160134763.7403094",
      "open": "162573356.3100158",
      "close": "160134763.7403094"
    },
    {
      "currency_a": "XRP_drops",
      "currency_b": "rchGBxcD1A1C2tdxF6papQYZ8kjRKMYcL/BTC",
      "volume_a": "352373535",
      "volume_b": "0.00249291478138912",
      "high": "1413500174054660e-4",
      "low": "1413499999999996e-4",
      "open": "1413500174054660e-4",
      "close": "1413499999999996e-4"
    },
    {
      "currency_a": "XRP_drops",
      "currency_b": "rcvxE9PS9YBwxtGg1qNeewV6ZB3wGubZq/5553445400000000000000000000000000000000",
      "volume_a": "8768045",
      "volume_b": "4.193604075536",
      "high": "2090813.734932601",
      "low": "2090813.734932601",
      "open": "2090813.734932601",
      "close": "2090813.734932601"
    },
    {
      "currency_a": "XRP_drops",
      "currency_b": "rhub8VRN55s94qWKDv6jmDy1pUykJzF3wq/USD",
      "volume_a": "28113",
      "volume_b": "0.013405652999",
      "high": "2097100.380123005",
      "low": "2097100.380123005",
      "open": "2097100.380123005",
      "close": "2097100.380123005"
    },
    {
      "currency_a": "r3dVizzUAS3U29WKaaSALqkieytA2LCoRe/58434F5245000000000000000000000000000000",
      "currency_b": "rcoreNywaoz2ZCQ8Lg2EbSLnGuRBmun6D/434F524500000000000000000000000000000000",
      "volume_a": "75.626516003375",
      "volume_b": "63.022096669479",
      "high": "1.200000000000003",
      "low": "1.200000000000003",
      "open": "1.200000000000003",
      "close": "1.200000000000003"
    },
    {
      "currency_a": "rKiCet8SdvWxPXnAgYarFUXMh1zCPz432Y/CNY",
      "currency_b": "rKiCet8SdvWxPXnAgYarFUXMh1zCPz432Y/USD",
      "volume_a": "83.9115222024",
      "volume_b": "11.51049687275",
      "high": "7.290000000004561",
      "low": "7.290000000004561",
      "open": "7.290000000004561",
      "close": "7.290000000004561"
    },
    {
      "currency_a": "rcRzGWq6Ng3jeYhqnmM4zcWcUh69hrQ8V/LTC",
      "currency_b": "rchGBxcD1A1C2tdxF6papQYZ8kjRKMYcL/BTC",
      "volume_a": "0.64167647147626",
      "volume_b": "0.00073047551165797",
      "high": "878.4366638381051",
      "low": "878.4366638381051",
      "open": "878.4366638381051",
      "close": "878.4366638381051"
    },
    {
      "currency_a": "rhub8VRN55s94qWKDv6jmDy1pUykJzF3wq/USD",
      "currency_b": "rvYAfWj5gh67oV6fW32ZzP3Aw4Eubs59B/USD",
      "volume_a": "0.013432464305",
      "volume_b": "0.013566788948",
      "high": "0.9900990099046391",
      "low": "0.9900990099046391",
      "open": "0.9900990099046391",
      "close": "0.9900990099046391"
    }
  ]
}The fields from a Book Changes stream message are as follows:
| Field | Value | Description | 
|---|---|---|
| type | String | The value bookChangesindicates this is from the Book Changes stream. | 
| ledger_index | Ledger Index | The ledger index of the ledger with these changes. | 
| ledger_hash | Hash | The identifying hash of the ledger with these changes. | 
| ledger_time | Number | The official close time of the ledger with these changes, in seconds since the Ripple Epoch. | 
| changes | Array | List of Book Update Objects, containing one entry for each order book that was updated in this ledger version. The array is empty if no order books were updated. | 
Consensus Stream
The consensus stream sends consensusPhase messages when the consensus process changes phase. The message contains the new phase of consensus the server is in.
{
  "type": "consensusPhase",
  "consensus": "accepted"
}The fields from a consensus stream message are as follows:
| Field | Type | Description | 
|---|---|---|
| type | String | The value consensusPhaseindicates this is from the consensus stream | 
| consensus | String | The new consensus phase the server is in. Possible values are open,establish, andaccepted. |