2018-12-31 20:04:05 +01:00
|
|
|
//
|
2022-12-31 22:28:08 +01:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2023
|
2018-12-31 20:04:05 +01:00
|
|
|
//
|
|
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
//
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "td/db/binlog/BinlogEvent.h"
|
|
|
|
#include "td/db/DbKey.h"
|
|
|
|
|
|
|
|
#include "td/utils/buffer.h"
|
|
|
|
#include "td/utils/common.h"
|
2022-06-27 12:30:18 +02:00
|
|
|
#include "td/utils/Promise.h"
|
2020-06-11 15:43:26 +02:00
|
|
|
#include "td/utils/StorerBase.h"
|
2018-12-31 20:04:05 +01:00
|
|
|
|
|
|
|
namespace td {
|
2019-01-06 20:59:17 +01:00
|
|
|
|
2018-12-31 20:04:05 +01:00
|
|
|
class BinlogInterface {
|
|
|
|
public:
|
|
|
|
BinlogInterface() = default;
|
|
|
|
BinlogInterface(const BinlogInterface &) = delete;
|
|
|
|
BinlogInterface &operator=(const BinlogInterface &) = delete;
|
|
|
|
BinlogInterface(BinlogInterface &&) = delete;
|
|
|
|
BinlogInterface &operator=(BinlogInterface &&) = delete;
|
|
|
|
virtual ~BinlogInterface() = default;
|
|
|
|
|
|
|
|
void close(Promise<> promise = {}) {
|
|
|
|
close_impl(std::move(promise));
|
|
|
|
}
|
|
|
|
void close_and_destroy(Promise<> promise = {}) {
|
|
|
|
close_and_destroy_impl(std::move(promise));
|
|
|
|
}
|
2023-01-16 10:47:37 +01:00
|
|
|
void add_raw_event(BinlogDebugInfo info, uint64 event_id, BufferSlice &&raw_event, Promise<> promise = Promise<>()) {
|
|
|
|
add_raw_event_impl(event_id, std::move(raw_event), std::move(promise), info);
|
2018-06-28 17:12:20 +02:00
|
|
|
}
|
2023-01-16 10:47:37 +01:00
|
|
|
void add_raw_event(uint64 event_id, BufferSlice &&raw_event, Promise<> promise = Promise<>()) {
|
|
|
|
add_raw_event_impl(event_id, std::move(raw_event), std::move(promise), {});
|
2018-12-31 20:04:05 +01:00
|
|
|
}
|
|
|
|
void lazy_sync(Promise<> promise = Promise<>()) {
|
2023-01-16 10:47:37 +01:00
|
|
|
add_raw_event_impl(next_event_id(), BufferSlice(), std::move(promise), {});
|
2018-12-31 20:04:05 +01:00
|
|
|
}
|
2020-06-11 01:25:50 +02:00
|
|
|
|
|
|
|
uint64 add(int32 type, const Storer &storer, Promise<> promise = Promise<>()) {
|
2023-01-16 10:47:37 +01:00
|
|
|
auto event_id = next_event_id();
|
|
|
|
add_raw_event_impl(event_id, BinlogEvent::create_raw(event_id, type, 0, storer), std::move(promise), {});
|
|
|
|
return event_id;
|
2020-06-11 01:25:50 +02:00
|
|
|
}
|
|
|
|
|
2023-01-16 10:47:37 +01:00
|
|
|
uint64 rewrite(uint64 event_id, int32 type, const Storer &storer, Promise<> promise = Promise<>()) {
|
|
|
|
auto seq_no = next_event_id();
|
|
|
|
add_raw_event_impl(seq_no, BinlogEvent::create_raw(event_id, type, BinlogEvent::Flags::Rewrite, storer),
|
2020-06-11 01:25:50 +02:00
|
|
|
std::move(promise), {});
|
|
|
|
return seq_no;
|
|
|
|
}
|
|
|
|
|
2023-01-16 10:47:37 +01:00
|
|
|
uint64 erase(uint64 event_id, Promise<> promise = Promise<>()) {
|
|
|
|
auto seq_no = next_event_id();
|
|
|
|
add_raw_event_impl(
|
|
|
|
seq_no,
|
|
|
|
BinlogEvent::create_raw(event_id, BinlogEvent::ServiceTypes::Empty, BinlogEvent::Flags::Rewrite, EmptyStorer()),
|
|
|
|
std::move(promise), {});
|
2020-06-11 01:25:50 +02:00
|
|
|
return seq_no;
|
|
|
|
}
|
|
|
|
|
2018-12-31 20:04:05 +01:00
|
|
|
virtual void force_sync(Promise<> promise) = 0;
|
|
|
|
virtual void force_flush() = 0;
|
2021-10-18 18:26:14 +02:00
|
|
|
virtual void change_key(DbKey db_key, Promise<> promise) = 0;
|
2018-12-31 20:04:05 +01:00
|
|
|
|
2023-01-16 10:47:37 +01:00
|
|
|
virtual uint64 next_event_id() = 0;
|
|
|
|
virtual uint64 next_event_id(int32 shift) = 0;
|
2018-12-31 20:04:05 +01:00
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual void close_impl(Promise<> promise) = 0;
|
|
|
|
virtual void close_and_destroy_impl(Promise<> promise) = 0;
|
2023-01-16 10:47:37 +01:00
|
|
|
virtual void add_raw_event_impl(uint64 seq_no, BufferSlice &&raw_event, Promise<> promise, BinlogDebugInfo info) = 0;
|
2018-12-31 20:04:05 +01:00
|
|
|
};
|
2019-01-06 20:59:17 +01:00
|
|
|
|
2018-12-31 20:04:05 +01:00
|
|
|
} // namespace td
|