rippled
Loading...
Searching...
No Matches
OrderBookDB.h
1#pragma once
2
3#include <xrpl/ledger/AcceptedLedgerTx.h>
4#include <xrpl/ledger/BookListeners.h>
5#include <xrpl/ledger/ReadView.h>
6#include <xrpl/protocol/Book.h>
7#include <xrpl/protocol/Issue.h>
8#include <xrpl/protocol/MultiApiJson.h>
9#include <xrpl/protocol/UintTypes.h>
10
11#include <memory>
12#include <optional>
13#include <vector>
14
15namespace xrpl {
16
29{
30public:
31 virtual ~OrderBookDB() = default;
32
40 virtual void
42
47 virtual void
48 addOrderBook(Book const& book) = 0;
49
60 virtual std::vector<Book>
61 getBooksByTakerPays(Issue const& issue, std::optional<Domain> const& domain = std::nullopt) = 0;
62
69 virtual int
70 getBookSize(Issue const& issue, std::optional<Domain> const& domain = std::nullopt) = 0;
71
78 virtual bool
80
81 virtual void
84 AcceptedLedgerTx const& alTx,
85 MultiApiJson const& jvObj) = 0;
86
91};
92
93} // namespace xrpl
A transaction that is in a closed ledger.
Specifies an order book.
Definition Book.h:16
A currency issued by an account.
Definition Issue.h:13
Tracks order books in the ledger.
Definition OrderBookDB.h:29
virtual void processTxn(std::shared_ptr< ReadView const > const &ledger, AcceptedLedgerTx const &alTx, MultiApiJson const &jvObj)=0
virtual bool isBookToXRP(Issue const &issue, std::optional< Domain > domain=std::nullopt)=0
Check if an order book to XRP exists for the given issue.
virtual void addOrderBook(Book const &book)=0
Add an order book to track.
virtual std::vector< Book > getBooksByTakerPays(Issue const &issue, std::optional< Domain > const &domain=std::nullopt)=0
Get all order books that want a specific issue.
virtual BookListeners::pointer makeBookListeners(Book const &)=0
virtual void setup(std::shared_ptr< ReadView const > const &ledger)=0
Initialize or update the order book database with a new ledger.
virtual int getBookSize(Issue const &issue, std::optional< Domain > const &domain=std::nullopt)=0
Get the count of order books that want a specific issue.
virtual ~OrderBookDB()=default
virtual BookListeners::pointer getBookListeners(Book const &)=0
T is_same_v
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
Definition algorithm.h:5