tdlight/tddb/td/db/binlog/ConcurrentBinlog.h

73 lines
2.2 KiB
C
Raw Permalink Normal View History

//
2024-01-01 01:07:21 +01:00
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2024
//
// 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/Binlog.h"
#include "td/db/binlog/BinlogInterface.h"
#include "td/db/DbKey.h"
2021-09-18 23:47:05 +02:00
#include "td/actor/actor.h"
#include "td/utils/buffer.h"
#include "td/utils/common.h"
2022-06-27 12:30:18 +02:00
#include "td/utils/Promise.h"
#include "td/utils/Slice.h"
#include "td/utils/Status.h"
#include <atomic>
#include <functional>
namespace td {
namespace detail {
class BinlogActor;
} // namespace detail
class ConcurrentBinlog final : public BinlogInterface {
public:
using Callback = std::function<void(const BinlogEvent &)>;
Result<BinlogInfo> init(string path, const Callback &callback, DbKey db_key = DbKey::empty(),
DbKey old_db_key = DbKey::empty(), int scheduler_id = -1) TD_WARN_UNUSED_RESULT;
ConcurrentBinlog();
explicit ConcurrentBinlog(unique_ptr<Binlog> binlog, int scheduler_id = -1);
ConcurrentBinlog(const ConcurrentBinlog &) = delete;
ConcurrentBinlog &operator=(const ConcurrentBinlog &) = delete;
ConcurrentBinlog(ConcurrentBinlog &&) = delete;
ConcurrentBinlog &operator=(ConcurrentBinlog &&) = delete;
2021-07-03 22:51:36 +02:00
~ConcurrentBinlog() final;
2024-02-02 13:09:17 +01:00
void force_sync(Promise<> promise, const char *source) final;
2021-07-03 22:51:36 +02:00
void force_flush() final;
void change_key(DbKey db_key, Promise<> promise) final;
2023-01-16 10:47:37 +01:00
uint64 next_event_id() final {
return last_event_id_.fetch_add(1, std::memory_order_relaxed);
}
2023-01-16 10:47:37 +01:00
uint64 next_event_id(int32 shift) final {
return last_event_id_.fetch_add(shift, std::memory_order_relaxed);
}
CSlice get_path() const {
return path_;
}
uint64 erase_batch(vector<uint64> event_ids) final;
private:
void init_impl(unique_ptr<Binlog> binlog, int scheduler_id);
2021-07-03 22:51:36 +02:00
void close_impl(Promise<> promise) final;
void close_and_destroy_impl(Promise<> promise) final;
2023-01-16 10:47:37 +01:00
void add_raw_event_impl(uint64 event_id, BufferSlice &&raw_event, Promise<> promise, BinlogDebugInfo info) final;
ActorOwn<detail::BinlogActor> binlog_actor_;
string path_;
2023-01-16 10:47:37 +01:00
std::atomic<uint64> last_event_id_{0};
};
} // namespace td