Clio develop
The XRP Ledger API server.
Loading...
Searching...
No Matches
Monitor.hpp
1//------------------------------------------------------------------------------
2/*
3 This file is part of clio: https://github.com/XRPLF/clio
4 Copyright (c) 2025, the clio developers.
5
6 Permission to use, copy, modify, and distribute this software for any
7 purpose with or without fee is hereby granted, provided that the above
8 copyright notice and this permission notice appear in all copies.
9
10 THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11 WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12 MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13 ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14 WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15 ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16 OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17*/
18//==============================================================================
19
20#pragma once
21
22#include "data/BackendInterface.hpp"
24#include "etlng/MonitorInterface.hpp"
25#include "util/Mutex.hpp"
26#include "util/async/AnyExecutionContext.hpp"
27#include "util/async/AnyOperation.hpp"
28#include "util/async/AnyStrand.hpp"
29#include "util/log/Logger.hpp"
30
31#include <boost/signals2/connection.hpp>
32#include <xrpl/protocol/TxFormats.h>
33
34#include <atomic>
35#include <chrono>
36#include <cstddef>
37#include <cstdint>
38#include <memory>
39#include <optional>
40
41namespace etlng::impl {
42
43class Monitor : public MonitorInterface {
45 std::shared_ptr<BackendInterface> backend_;
46 std::shared_ptr<etl::NetworkValidatedLedgersInterface> validatedLedgers_;
47
48 std::atomic_uint32_t nextSequence_;
49 std::optional<util::async::AnyOperation<void>> repeatedTask_;
50 std::optional<boost::signals2::scoped_connection> subscription_; // network validated ledgers subscription
51
52 NewSequenceSignalType notificationChannel_;
53 DbStalledSignalType dbStalledChannel_;
54
55 struct UpdateData {
56 std::chrono::steady_clock::duration dbStalledReportDelay;
57 std::chrono::steady_clock::time_point lastDbCheckTime;
58 uint32_t lastSeenMaxSeqInDb = 0u;
59 };
60
61 util::Mutex<UpdateData> updateData_;
62
63 util::Logger log_{"ETL"};
64
65public:
66 Monitor(
68 std::shared_ptr<BackendInterface> backend,
69 std::shared_ptr<etl::NetworkValidatedLedgersInterface> validatedLedgers,
70 uint32_t startSequence,
71 std::chrono::steady_clock::duration dbStalledReportDelay
72 );
73 ~Monitor() override;
74
75 void
76 notifySequenceLoaded(uint32_t seq) override;
77
78 void
79 notifyWriteConflict(uint32_t seq) override;
80
81 void
82 run(std::chrono::steady_clock::duration repeatInterval) override;
83
84 void
85 stop() override;
86
87 boost::signals2::scoped_connection
88 subscribeToNewSequence(NewSequenceSignalType::slot_type const& subscriber) override;
89
90 boost::signals2::scoped_connection
91 subscribeToDbStalled(DbStalledSignalType::slot_type const& subscriber) override;
92
93private:
94 void
95 onNextSequence(uint32_t seq);
96
97 void
98 doWork();
99};
100
101} // namespace etlng::impl
An interface for the monitor service An implementation of this service is responsible for periodicall...
Definition MonitorInterface.hpp:36
Definition Monitor.hpp:43
boost::signals2::scoped_connection subscribeToDbStalled(DbStalledSignalType::slot_type const &subscriber) override
Allows clients to get notified when no database update is detected for a configured period.
Definition Monitor.cpp:117
void notifyWriteConflict(uint32_t seq) override
Notifies the monitor of a write conflict.
Definition Monitor.cpp:77
boost::signals2::scoped_connection subscribeToNewSequence(NewSequenceSignalType::slot_type const &subscriber) override
Allows clients to get notified when a new ledger becomes available in Clio's database.
Definition Monitor.cpp:111
void run(std::chrono::steady_clock::duration repeatInterval) override
Run the monitor service.
Definition Monitor.cpp:85
void stop() override
Stops the monitor service.
Definition Monitor.cpp:101
void notifySequenceLoaded(uint32_t seq) override
Allows the loading process to notify of a freshly committed ledger.
Definition Monitor.cpp:65
A simple thread-safe logger for the channel specified in the constructor.
Definition Logger.hpp:111
A container for data that is protected by a mutex. Inspired by Mutex in Rust.
Definition Mutex.hpp:96
A type-erased execution context.
Definition AnyExecutionContext.hpp:41
A type-erased execution context.
Definition AnyStrand.hpp:40