2018-04-28 22:22:28 +02:00
|
|
|
//
|
2018-12-31 23:02:34 +01:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2019
|
2018-04-28 22:22:28 +02: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/actor/PromiseFuture.h"
|
|
|
|
|
|
|
|
#include "td/db/binlog/BinlogHelper.h"
|
|
|
|
|
|
|
|
#include "td/telegram/Global.h"
|
|
|
|
#include "td/telegram/TdDb.h"
|
|
|
|
|
2019-02-12 22:26:36 +01:00
|
|
|
#include "td/utils/common.h"
|
2018-04-28 22:22:28 +02:00
|
|
|
#include "td/utils/Status.h"
|
2019-08-14 02:13:34 +02:00
|
|
|
#include "td/utils/Time.h"
|
|
|
|
#include "td/utils/tl_helpers.h"
|
2018-04-28 22:22:28 +02:00
|
|
|
|
|
|
|
namespace td {
|
|
|
|
|
2019-04-13 19:07:02 +02:00
|
|
|
#define get_erase_logevent_promise(...) get_erase_logevent_promise_impl(__FILE__, __LINE__, __VA_ARGS__)
|
|
|
|
|
2019-09-08 02:10:09 +02:00
|
|
|
inline Promise<Unit> get_erase_logevent_promise_impl(const char *file, int line, uint64 logevent_id,
|
2019-04-13 19:07:02 +02:00
|
|
|
Promise<Unit> promise = Promise<Unit>()) {
|
2018-04-28 22:22:28 +02:00
|
|
|
if (logevent_id == 0) {
|
2018-05-07 19:20:20 +02:00
|
|
|
return promise;
|
2018-04-28 22:22:28 +02:00
|
|
|
}
|
|
|
|
|
2019-04-13 19:07:02 +02:00
|
|
|
return PromiseCreator::lambda([file, line, logevent_id, promise = std::move(promise)](Result<Unit> result) mutable {
|
2018-04-28 22:22:28 +02:00
|
|
|
if (!G()->close_flag()) {
|
2019-04-21 18:05:19 +02:00
|
|
|
binlog_erase(G()->get_td_db_impl(file, line)->get_binlog_impl(file, line), logevent_id);
|
2018-04-28 22:22:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
promise.set_result(std::move(result));
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2019-08-10 23:14:35 +02:00
|
|
|
template <class StorerT>
|
|
|
|
void store_time(double time_at, StorerT &storer) {
|
|
|
|
double server_time = storer.context()->server_time();
|
|
|
|
if (time_at == 0) {
|
|
|
|
store(-1.0, storer);
|
|
|
|
} else {
|
|
|
|
double time_left = max(time_at - Time::now(), 0.0);
|
|
|
|
store(time_left, storer);
|
|
|
|
store(server_time, storer);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
template <class ParserT>
|
|
|
|
void parse_time(double &time_at, ParserT &parser) {
|
|
|
|
double time_left;
|
|
|
|
parse(time_left, parser);
|
|
|
|
if (time_left < -0.1) {
|
|
|
|
time_at = 0;
|
|
|
|
} else {
|
|
|
|
double old_server_time;
|
|
|
|
parse(old_server_time, parser);
|
|
|
|
double passed_server_time = max(parser.context()->server_time() - old_server_time, 0.0);
|
|
|
|
time_left = max(time_left - passed_server_time, 0.0);
|
|
|
|
time_at = Time::now_cached() + time_left;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-04-28 22:22:28 +02:00
|
|
|
} // namespace td
|