2018-12-31 20:04:05 +01:00
|
|
|
//
|
2021-01-01 13:57:46 +01:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2021
|
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/telegram/DialogId.h"
|
2019-11-26 17:53:10 +01:00
|
|
|
#include "td/telegram/FullMessageId.h"
|
2018-12-31 20:04:05 +01:00
|
|
|
#include "td/telegram/MessageId.h"
|
2018-11-28 18:18:50 +01:00
|
|
|
#include "td/telegram/NotificationId.h"
|
2019-11-26 17:33:18 +01:00
|
|
|
#include "td/telegram/ServerMessageId.h"
|
2018-12-31 20:04:05 +01:00
|
|
|
|
|
|
|
#include "td/actor/PromiseFuture.h"
|
|
|
|
|
|
|
|
#include "td/utils/buffer.h"
|
|
|
|
#include "td/utils/common.h"
|
|
|
|
#include "td/utils/Status.h"
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
#include <utility>
|
|
|
|
|
|
|
|
namespace td {
|
2018-09-28 22:57:34 +02:00
|
|
|
|
2019-01-07 01:17:11 +01:00
|
|
|
class SqliteConnectionSafe;
|
|
|
|
class SqliteDb;
|
|
|
|
|
2018-12-31 20:04:05 +01:00
|
|
|
struct MessagesDbMessagesQuery {
|
|
|
|
DialogId dialog_id;
|
|
|
|
int32 index_mask{0};
|
|
|
|
MessageId from_message_id;
|
|
|
|
int32 offset{0};
|
|
|
|
int32 limit{100};
|
|
|
|
};
|
|
|
|
|
2021-10-01 11:55:12 +02:00
|
|
|
struct MessagesDbDialogMessage {
|
2021-10-01 14:23:38 +02:00
|
|
|
MessageId message_id;
|
2021-10-01 11:55:12 +02:00
|
|
|
BufferSlice data;
|
|
|
|
};
|
|
|
|
|
2018-12-31 20:04:05 +01:00
|
|
|
struct MessagesDbMessage {
|
|
|
|
DialogId dialog_id;
|
2021-10-01 14:23:38 +02:00
|
|
|
MessageId message_id;
|
2018-12-31 20:04:05 +01:00
|
|
|
BufferSlice data;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct MessagesDbFtsQuery {
|
|
|
|
string query;
|
|
|
|
DialogId dialog_id;
|
|
|
|
int32 index_mask{0};
|
|
|
|
int64 from_search_id{0};
|
|
|
|
int32 limit{100};
|
|
|
|
};
|
|
|
|
struct MessagesDbFtsResult {
|
2021-10-01 11:55:12 +02:00
|
|
|
vector<MessagesDbMessage> messages;
|
2018-12-31 20:04:05 +01:00
|
|
|
int64 next_search_id{1};
|
|
|
|
};
|
|
|
|
|
|
|
|
struct MessagesDbCallsQuery {
|
|
|
|
int32 index_mask{0};
|
|
|
|
int32 from_unique_message_id{0};
|
|
|
|
int32 limit{100};
|
|
|
|
};
|
|
|
|
struct MessagesDbCallsResult {
|
2021-10-01 11:55:12 +02:00
|
|
|
vector<MessagesDbMessage> messages;
|
2018-12-31 20:04:05 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
class MessagesDbSyncInterface {
|
|
|
|
public:
|
|
|
|
MessagesDbSyncInterface() = default;
|
|
|
|
MessagesDbSyncInterface(const MessagesDbSyncInterface &) = delete;
|
|
|
|
MessagesDbSyncInterface &operator=(const MessagesDbSyncInterface &) = delete;
|
|
|
|
virtual ~MessagesDbSyncInterface() = default;
|
|
|
|
|
|
|
|
virtual Status add_message(FullMessageId full_message_id, ServerMessageId unique_message_id, UserId sender_user_id,
|
|
|
|
int64 random_id, int32 ttl_expires_at, int32 index_mask, int64 search_id, string text,
|
2020-09-28 14:13:25 +02:00
|
|
|
NotificationId notification_id, MessageId top_thread_message_id, BufferSlice data) = 0;
|
2019-12-02 01:33:35 +01:00
|
|
|
virtual Status add_scheduled_message(FullMessageId full_message_id, BufferSlice data) = 0;
|
2018-12-31 20:04:05 +01:00
|
|
|
|
|
|
|
virtual Status delete_message(FullMessageId full_message_id) = 0;
|
|
|
|
virtual Status delete_all_dialog_messages(DialogId dialog_id, MessageId from_message_id) = 0;
|
|
|
|
virtual Status delete_dialog_messages_from_user(DialogId dialog_id, UserId sender_user_id) = 0;
|
|
|
|
|
2021-10-01 11:55:12 +02:00
|
|
|
virtual Result<MessagesDbDialogMessage> get_message(FullMessageId full_message_id) = 0;
|
2021-10-01 10:22:56 +02:00
|
|
|
virtual Result<MessagesDbMessage> get_message_by_unique_message_id(ServerMessageId unique_message_id) = 0;
|
2021-10-01 11:55:12 +02:00
|
|
|
virtual Result<MessagesDbDialogMessage> get_message_by_random_id(DialogId dialog_id, int64 random_id) = 0;
|
|
|
|
virtual Result<MessagesDbDialogMessage> get_dialog_message_by_date(DialogId dialog_id, MessageId first_message_id,
|
|
|
|
MessageId last_message_id, int32 date) = 0;
|
|
|
|
|
|
|
|
virtual Result<vector<MessagesDbDialogMessage>> get_messages(MessagesDbMessagesQuery query) = 0;
|
|
|
|
virtual Result<vector<MessagesDbDialogMessage>> get_scheduled_messages(DialogId dialog_id, int32 limit) = 0;
|
|
|
|
virtual Result<vector<MessagesDbDialogMessage>> get_messages_from_notification_id(DialogId dialog_id,
|
|
|
|
NotificationId from_notification_id,
|
|
|
|
int32 limit) = 0;
|
|
|
|
|
|
|
|
virtual Result<std::pair<vector<MessagesDbMessage>, int32>> get_expiring_messages(int32 expires_from,
|
|
|
|
int32 expires_till,
|
|
|
|
int32 limit) = 0;
|
2018-12-31 20:04:05 +01:00
|
|
|
virtual Result<MessagesDbCallsResult> get_calls(MessagesDbCallsQuery query) = 0;
|
|
|
|
virtual Result<MessagesDbFtsResult> get_messages_fts(MessagesDbFtsQuery query) = 0;
|
|
|
|
|
|
|
|
virtual Status begin_transaction() = 0;
|
|
|
|
virtual Status commit_transaction() = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
class MessagesDbSyncSafeInterface {
|
|
|
|
public:
|
|
|
|
MessagesDbSyncSafeInterface() = default;
|
|
|
|
MessagesDbSyncSafeInterface(const MessagesDbSyncSafeInterface &) = delete;
|
|
|
|
MessagesDbSyncSafeInterface &operator=(const MessagesDbSyncSafeInterface &) = delete;
|
|
|
|
virtual ~MessagesDbSyncSafeInterface() = default;
|
|
|
|
|
|
|
|
virtual MessagesDbSyncInterface &get() = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
class MessagesDbAsyncInterface {
|
|
|
|
public:
|
|
|
|
MessagesDbAsyncInterface() = default;
|
|
|
|
MessagesDbAsyncInterface(const MessagesDbAsyncInterface &) = delete;
|
|
|
|
MessagesDbAsyncInterface &operator=(const MessagesDbAsyncInterface &) = delete;
|
|
|
|
virtual ~MessagesDbAsyncInterface() = default;
|
|
|
|
|
|
|
|
virtual void add_message(FullMessageId full_message_id, ServerMessageId unique_message_id, UserId sender_user_id,
|
|
|
|
int64 random_id, int32 ttl_expires_at, int32 index_mask, int64 search_id, string text,
|
2020-09-28 14:13:25 +02:00
|
|
|
NotificationId notification_id, MessageId top_thread_message_id, BufferSlice data,
|
|
|
|
Promise<> promise) = 0;
|
2019-12-02 01:33:35 +01:00
|
|
|
virtual void add_scheduled_message(FullMessageId full_message_id, BufferSlice data, Promise<> promise) = 0;
|
2018-12-31 20:04:05 +01:00
|
|
|
|
|
|
|
virtual void delete_message(FullMessageId full_message_id, Promise<> promise) = 0;
|
|
|
|
virtual void delete_all_dialog_messages(DialogId dialog_id, MessageId from_message_id, Promise<> promise) = 0;
|
|
|
|
virtual void delete_dialog_messages_from_user(DialogId dialog_id, UserId sender_user_id, Promise<> promise) = 0;
|
|
|
|
|
2021-10-01 11:55:12 +02:00
|
|
|
virtual void get_message(FullMessageId full_message_id, Promise<MessagesDbDialogMessage> promise) = 0;
|
2018-12-31 20:04:05 +01:00
|
|
|
virtual void get_message_by_unique_message_id(ServerMessageId unique_message_id,
|
2021-10-01 10:22:56 +02:00
|
|
|
Promise<MessagesDbMessage> promise) = 0;
|
2021-10-01 11:55:12 +02:00
|
|
|
virtual void get_message_by_random_id(DialogId dialog_id, int64 random_id,
|
|
|
|
Promise<MessagesDbDialogMessage> promise) = 0;
|
2018-12-31 20:04:05 +01:00
|
|
|
virtual void get_dialog_message_by_date(DialogId dialog_id, MessageId first_message_id, MessageId last_message_id,
|
2021-10-01 11:55:12 +02:00
|
|
|
int32 date, Promise<MessagesDbDialogMessage> promise) = 0;
|
2018-12-31 20:04:05 +01:00
|
|
|
|
2021-10-01 11:55:12 +02:00
|
|
|
virtual void get_messages(MessagesDbMessagesQuery query, Promise<vector<MessagesDbDialogMessage>> promise) = 0;
|
|
|
|
virtual void get_scheduled_messages(DialogId dialog_id, int32 limit,
|
|
|
|
Promise<vector<MessagesDbDialogMessage>> promise) = 0;
|
2018-11-28 21:19:30 +01:00
|
|
|
virtual void get_messages_from_notification_id(DialogId dialog_id, NotificationId from_notification_id, int32 limit,
|
2021-10-01 11:55:12 +02:00
|
|
|
Promise<vector<MessagesDbDialogMessage>> promise) = 0;
|
2018-12-31 20:04:05 +01:00
|
|
|
|
2018-11-28 21:19:30 +01:00
|
|
|
virtual void get_calls(MessagesDbCallsQuery, Promise<MessagesDbCallsResult> promise) = 0;
|
2018-12-31 20:04:05 +01:00
|
|
|
virtual void get_messages_fts(MessagesDbFtsQuery query, Promise<MessagesDbFtsResult> promise) = 0;
|
|
|
|
|
2021-10-01 10:22:56 +02:00
|
|
|
virtual void get_expiring_messages(int32 expires_from, int32 expires_till, int32 limit,
|
2021-10-01 11:55:12 +02:00
|
|
|
Promise<std::pair<vector<MessagesDbMessage>, int32>> promise) = 0;
|
2018-12-31 20:04:05 +01:00
|
|
|
|
|
|
|
virtual void close(Promise<> promise) = 0;
|
|
|
|
virtual void force_flush() = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
Status init_messages_db(SqliteDb &db, int version) TD_WARN_UNUSED_RESULT;
|
|
|
|
Status drop_messages_db(SqliteDb &db, int version) TD_WARN_UNUSED_RESULT;
|
|
|
|
|
|
|
|
std::shared_ptr<MessagesDbSyncSafeInterface> create_messages_db_sync(
|
|
|
|
std::shared_ptr<SqliteConnectionSafe> sqlite_connection);
|
|
|
|
|
|
|
|
std::shared_ptr<MessagesDbAsyncInterface> create_messages_db_async(std::shared_ptr<MessagesDbSyncSafeInterface> sync_db,
|
|
|
|
int32 scheduler_id);
|
2018-09-28 22:57:34 +02:00
|
|
|
|
2018-07-18 03:30:29 +02:00
|
|
|
} // namespace td
|