3#include <xrpl/core/ServiceRegistry.h>
4#include <xrpl/ledger/AcceptedLedgerTx.h>
5#include <xrpl/ledger/BookListeners.h>
6#include <xrpl/ledger/OrderBookDB.h>
7#include <xrpl/protocol/MultiApiJson.h>
8#include <xrpl/protocol/UintTypes.h>
A generic endpoint for log messages.
A transaction that is in a closed ledger.
A currency issued by an account.
hardened_hash_map< std::pair< Issue, Domain >, hardened_hash_set< Issue > > domainBooks_
void addOrderBook(Book const &book) override
Add an order book to track.
BookListeners::pointer makeBookListeners(Book const &) override
BookListeners::pointer getBookListeners(Book const &) override
BookToListenersMap mListeners
int getBookSize(Issue const &issue, std::optional< Domain > const &domain=std::nullopt) override
Get the count of order books that want a specific issue.
hash_set< Issue > xrpBooks_
bool isBookToXRP(Issue const &issue, std::optional< Domain > domain=std::nullopt) override
Check if an order book to XRP exists for the given issue.
void setup(std::shared_ptr< ReadView const > const &ledger) override
Initialize or update the order book database with a new ledger.
hash_set< std::pair< Issue, Domain > > xrpDomainBooks_
hardened_hash_map< Issue, hardened_hash_set< Issue > > allBooks_
std::atomic< std::uint32_t > seq_
void processTxn(std::shared_ptr< ReadView const > const &ledger, AcceptedLedgerTx const &alTx, MultiApiJson const &jvObj) override
std::vector< Book > getBooksByTakerPays(Issue const &issue, std::optional< Domain > const &domain=std::nullopt) override
Get all order books that want a specific issue.
void update(std::shared_ptr< ReadView const > const &ledger)
ServiceRegistry & registry_
std::recursive_mutex mLock
Tracks order books in the ledger.
Service registry for dependency injection.
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
std::unique_ptr< OrderBookDB > make_OrderBookDB(ServiceRegistry ®istry, OrderBookDBConfig const &config)
Create an OrderBookDB instance.
Configuration for OrderBookDB.