Use MessagesDbMessage instead of std::pair.
This commit is contained in:
parent
37a10fad57
commit
314035a129
@ -462,7 +462,7 @@ class MessagesDbImpl final : public MessagesDbSyncInterface {
|
||||
return BufferSlice(stmt.view_blob(0));
|
||||
}
|
||||
|
||||
Result<std::pair<DialogId, BufferSlice>> get_message_by_unique_message_id(ServerMessageId unique_message_id) final {
|
||||
Result<MessagesDbMessage> get_message_by_unique_message_id(ServerMessageId unique_message_id) final {
|
||||
if (!unique_message_id.is_valid()) {
|
||||
return Status::Error("Invalid unique_message_id");
|
||||
}
|
||||
@ -475,7 +475,7 @@ class MessagesDbImpl final : public MessagesDbSyncInterface {
|
||||
return Status::Error("Not found");
|
||||
}
|
||||
DialogId dialog_id(get_message_by_unique_message_id_stmt_.view_int64(0));
|
||||
return std::make_pair(dialog_id, BufferSlice(get_message_by_unique_message_id_stmt_.view_blob(1)));
|
||||
return MessagesDbMessage{dialog_id, BufferSlice(get_message_by_unique_message_id_stmt_.view_blob(1))};
|
||||
}
|
||||
|
||||
Result<BufferSlice> get_message_by_random_id(DialogId dialog_id, int64 random_id) final {
|
||||
@ -554,15 +554,14 @@ class MessagesDbImpl final : public MessagesDbSyncInterface {
|
||||
return Status::Error("Not found");
|
||||
}
|
||||
|
||||
Result<std::pair<std::vector<std::pair<DialogId, BufferSlice>>, int32>> get_expiring_messages(int32 expires_from,
|
||||
int32 expires_till,
|
||||
int32 limit) final {
|
||||
Result<std::pair<std::vector<MessagesDbMessage>, int32>> get_expiring_messages(int32 expires_from, int32 expires_till,
|
||||
int32 limit) final {
|
||||
SCOPE_EXIT {
|
||||
get_expiring_messages_stmt_.reset();
|
||||
get_expiring_messages_helper_stmt_.reset();
|
||||
};
|
||||
|
||||
std::vector<std::pair<DialogId, BufferSlice>> messages;
|
||||
std::vector<MessagesDbMessage> messages;
|
||||
// load messages
|
||||
if (expires_from <= expires_till) {
|
||||
get_expiring_messages_stmt_.bind_int32(1, expires_from).ensure();
|
||||
@ -572,7 +571,7 @@ class MessagesDbImpl final : public MessagesDbSyncInterface {
|
||||
while (get_expiring_messages_stmt_.has_row()) {
|
||||
DialogId dialog_id(get_expiring_messages_stmt_.view_int64(0));
|
||||
BufferSlice data(get_expiring_messages_stmt_.view_blob(1));
|
||||
messages.emplace_back(dialog_id, std::move(data));
|
||||
messages.push_back(MessagesDbMessage{dialog_id, std::move(data)});
|
||||
get_expiring_messages_stmt_.step().ensure();
|
||||
}
|
||||
}
|
||||
@ -973,8 +972,7 @@ class MessagesDbAsync final : public MessagesDbAsyncInterface {
|
||||
void get_message(FullMessageId full_message_id, Promise<BufferSlice> promise) final {
|
||||
send_closure_later(impl_, &Impl::get_message, full_message_id, std::move(promise));
|
||||
}
|
||||
void get_message_by_unique_message_id(ServerMessageId unique_message_id,
|
||||
Promise<std::pair<DialogId, BufferSlice>> promise) final {
|
||||
void get_message_by_unique_message_id(ServerMessageId unique_message_id, Promise<MessagesDbMessage> promise) final {
|
||||
send_closure_later(impl_, &Impl::get_message_by_unique_message_id, unique_message_id, std::move(promise));
|
||||
}
|
||||
void get_message_by_random_id(DialogId dialog_id, int64 random_id, Promise<BufferSlice> promise) final {
|
||||
@ -1004,7 +1002,7 @@ class MessagesDbAsync final : public MessagesDbAsyncInterface {
|
||||
send_closure_later(impl_, &Impl::get_messages_fts, std::move(query), std::move(promise));
|
||||
}
|
||||
void get_expiring_messages(int32 expires_from, int32 expires_till, int32 limit,
|
||||
Promise<std::pair<std::vector<std::pair<DialogId, BufferSlice>>, int32>> promise) final {
|
||||
Promise<std::pair<std::vector<MessagesDbMessage>, int32>> promise) final {
|
||||
send_closure_later(impl_, &Impl::get_expiring_messages, expires_from, expires_till, limit, std::move(promise));
|
||||
}
|
||||
|
||||
@ -1063,8 +1061,7 @@ class MessagesDbAsync final : public MessagesDbAsyncInterface {
|
||||
add_read_query();
|
||||
promise.set_result(sync_db_->get_message(full_message_id));
|
||||
}
|
||||
void get_message_by_unique_message_id(ServerMessageId unique_message_id,
|
||||
Promise<std::pair<DialogId, BufferSlice>> promise) {
|
||||
void get_message_by_unique_message_id(ServerMessageId unique_message_id, Promise<MessagesDbMessage> promise) {
|
||||
add_read_query();
|
||||
promise.set_result(sync_db_->get_message_by_unique_message_id(unique_message_id));
|
||||
}
|
||||
@ -1100,7 +1097,7 @@ class MessagesDbAsync final : public MessagesDbAsyncInterface {
|
||||
promise.set_result(sync_db_->get_messages_fts(std::move(query)));
|
||||
}
|
||||
void get_expiring_messages(int32 expires_from, int32 expires_till, int32 limit,
|
||||
Promise<std::pair<std::vector<std::pair<DialogId, BufferSlice>>, int32>> promise) {
|
||||
Promise<std::pair<std::vector<MessagesDbMessage>, int32>> promise) {
|
||||
add_read_query();
|
||||
promise.set_result(sync_db_->get_expiring_messages(expires_from, expires_till, limit));
|
||||
}
|
||||
|
@ -77,8 +77,7 @@ class MessagesDbSyncInterface {
|
||||
virtual Status delete_dialog_messages_from_user(DialogId dialog_id, UserId sender_user_id) = 0;
|
||||
|
||||
virtual Result<BufferSlice> get_message(FullMessageId full_message_id) = 0;
|
||||
virtual Result<std::pair<DialogId, BufferSlice>> get_message_by_unique_message_id(
|
||||
ServerMessageId unique_message_id) = 0;
|
||||
virtual Result<MessagesDbMessage> get_message_by_unique_message_id(ServerMessageId unique_message_id) = 0;
|
||||
virtual Result<BufferSlice> get_message_by_random_id(DialogId dialog_id, int64 random_id) = 0;
|
||||
virtual Result<BufferSlice> get_dialog_message_by_date(DialogId dialog_id, MessageId first_message_id,
|
||||
MessageId last_message_id, int32 date) = 0;
|
||||
@ -89,8 +88,9 @@ class MessagesDbSyncInterface {
|
||||
NotificationId from_notification_id,
|
||||
int32 limit) = 0;
|
||||
|
||||
virtual Result<std::pair<std::vector<std::pair<DialogId, BufferSlice>>, int32>> get_expiring_messages(
|
||||
int32 expires_from, int32 expires_till, int32 limit) = 0;
|
||||
virtual Result<std::pair<std::vector<MessagesDbMessage>, int32>> get_expiring_messages(int32 expires_from,
|
||||
int32 expires_till,
|
||||
int32 limit) = 0;
|
||||
virtual Result<MessagesDbCallsResult> get_calls(MessagesDbCallsQuery query) = 0;
|
||||
virtual Result<MessagesDbFtsResult> get_messages_fts(MessagesDbFtsQuery query) = 0;
|
||||
|
||||
@ -127,7 +127,7 @@ class MessagesDbAsyncInterface {
|
||||
|
||||
virtual void get_message(FullMessageId full_message_id, Promise<BufferSlice> promise) = 0;
|
||||
virtual void get_message_by_unique_message_id(ServerMessageId unique_message_id,
|
||||
Promise<std::pair<DialogId, BufferSlice>> promise) = 0;
|
||||
Promise<MessagesDbMessage> promise) = 0;
|
||||
virtual void get_message_by_random_id(DialogId dialog_id, int64 random_id, Promise<BufferSlice> promise) = 0;
|
||||
virtual void get_dialog_message_by_date(DialogId dialog_id, MessageId first_message_id, MessageId last_message_id,
|
||||
int32 date, Promise<BufferSlice> promise) = 0;
|
||||
@ -140,9 +140,8 @@ class MessagesDbAsyncInterface {
|
||||
virtual void get_calls(MessagesDbCallsQuery, Promise<MessagesDbCallsResult> promise) = 0;
|
||||
virtual void get_messages_fts(MessagesDbFtsQuery query, Promise<MessagesDbFtsResult> promise) = 0;
|
||||
|
||||
virtual void get_expiring_messages(
|
||||
int32 expires_from, int32 expires_till, int32 limit,
|
||||
Promise<std::pair<std::vector<std::pair<DialogId, BufferSlice>>, int32>> promise) = 0;
|
||||
virtual void get_expiring_messages(int32 expires_from, int32 expires_till, int32 limit,
|
||||
Promise<std::pair<std::vector<MessagesDbMessage>, int32>> promise) = 0;
|
||||
|
||||
virtual void close(Promise<> promise) = 0;
|
||||
virtual void force_flush() = 0;
|
||||
|
@ -12638,13 +12638,12 @@ void MessagesManager::ttl_db_loop(double server_now) {
|
||||
G()->td_db()->get_messages_db_async()->get_expiring_messages(
|
||||
ttl_db_expires_from_, ttl_db_expires_till_, limit,
|
||||
PromiseCreator::lambda(
|
||||
[actor_id = actor_id(this)](Result<std::pair<std::vector<std::pair<DialogId, BufferSlice>>, int32>> result) {
|
||||
[actor_id = actor_id(this)](Result<std::pair<std::vector<MessagesDbMessage>, int32>> result) {
|
||||
send_closure(actor_id, &MessagesManager::ttl_db_on_result, std::move(result), false);
|
||||
}));
|
||||
}
|
||||
|
||||
void MessagesManager::ttl_db_on_result(Result<std::pair<std::vector<std::pair<DialogId, BufferSlice>>, int32>> r_result,
|
||||
bool dummy) {
|
||||
void MessagesManager::ttl_db_on_result(Result<std::pair<std::vector<MessagesDbMessage>, int32>> r_result, bool dummy) {
|
||||
if (G()->close_flag()) {
|
||||
return;
|
||||
}
|
||||
@ -12657,8 +12656,9 @@ void MessagesManager::ttl_db_on_result(Result<std::pair<std::vector<std::pair<Di
|
||||
LOG(INFO) << "Receive ttl_db query result " << tag("new expires_till", ttl_db_expires_till_)
|
||||
<< tag("got messages", result.first.size());
|
||||
for (auto &dialog_message : result.first) {
|
||||
on_get_message_from_database(dialog_message.first, get_dialog_force(dialog_message.first, "ttl_db_on_result"),
|
||||
dialog_message.second, false, "ttl_db_on_result");
|
||||
on_get_message_from_database(dialog_message.dialog_id,
|
||||
get_dialog_force(dialog_message.dialog_id, "ttl_db_on_result"), dialog_message.data,
|
||||
false, "ttl_db_on_result");
|
||||
}
|
||||
ttl_db_loop(G()->server_time());
|
||||
}
|
||||
@ -16260,7 +16260,8 @@ vector<DialogId> MessagesManager::search_public_dialogs(const string &query, Pro
|
||||
|
||||
auto d = get_dialog(dialog_id);
|
||||
if (d == nullptr || d->order != DEFAULT_ORDER ||
|
||||
(dialog_id.get_type() == DialogType::User && td_->contacts_manager_->is_user_contact(dialog_id.get_user_id()))) {
|
||||
(dialog_id.get_type() == DialogType::User &&
|
||||
td_->contacts_manager_->is_user_contact(dialog_id.get_user_id()))) {
|
||||
continue;
|
||||
}
|
||||
|
||||
@ -34062,9 +34063,9 @@ MessagesManager::Dialog *MessagesManager::get_dialog_by_message_id(MessageId mes
|
||||
auto r_value =
|
||||
G()->td_db()->get_messages_db_sync()->get_message_by_unique_message_id(message_id.get_server_message_id());
|
||||
if (r_value.is_ok()) {
|
||||
DialogId dialog_id(r_value.ok().first);
|
||||
auto dialog_id = r_value.ok().dialog_id;
|
||||
Message *m = on_get_message_from_database(dialog_id, get_dialog_force(dialog_id, "get_dialog_by_message_id"),
|
||||
r_value.ok().second, false, "get_dialog_by_message_id");
|
||||
r_value.ok().data, false, "get_dialog_by_message_id");
|
||||
if (m != nullptr) {
|
||||
CHECK(m->message_id == message_id);
|
||||
LOG_CHECK(message_id_to_dialog_id_[message_id] == dialog_id)
|
||||
|
@ -2735,7 +2735,7 @@ class MessagesManager final : public Actor {
|
||||
|
||||
void ttl_db_loop_start(double server_now);
|
||||
void ttl_db_loop(double server_now);
|
||||
void ttl_db_on_result(Result<std::pair<std::vector<std::pair<DialogId, BufferSlice>>, int32>> r_result, bool dummy);
|
||||
void ttl_db_on_result(Result<std::pair<std::vector<MessagesDbMessage>, int32>> r_result, bool dummy);
|
||||
|
||||
void on_get_message_link_dialog(MessageLinkInfo &&info, Promise<MessageLinkInfo> &&promise);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user