summaryrefslogtreecommitdiff
path: root/protocols/Telegram/tdlib/td/td/telegram/Dependencies.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'protocols/Telegram/tdlib/td/td/telegram/Dependencies.cpp')
-rw-r--r--protocols/Telegram/tdlib/td/td/telegram/Dependencies.cpp57
1 files changed, 40 insertions, 17 deletions
diff --git a/protocols/Telegram/tdlib/td/td/telegram/Dependencies.cpp b/protocols/Telegram/tdlib/td/td/telegram/Dependencies.cpp
index 91e544179e..bbd43b05c0 100644
--- a/protocols/Telegram/tdlib/td/td/telegram/Dependencies.cpp
+++ b/protocols/Telegram/tdlib/td/td/telegram/Dependencies.cpp
@@ -1,14 +1,16 @@
//
-// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2023
+// 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)
//
#include "td/telegram/Dependencies.h"
-#include "td/telegram/ContactsManager.h"
-#include "td/telegram/MessagesManager.h"
+#include "td/telegram/ChatManager.h"
+#include "td/telegram/DialogManager.h"
+#include "td/telegram/StoryManager.h"
#include "td/telegram/Td.h"
+#include "td/telegram/UserManager.h"
#include "td/telegram/WebPagesManager.h"
#include "td/utils/common.h"
@@ -46,6 +48,13 @@ void Dependencies::add(WebPageId web_page_id) {
}
}
+void Dependencies::add(StoryFullId story_full_id) {
+ if (story_full_id.is_valid()) {
+ add_dialog_and_dependencies(story_full_id.get_dialog_id());
+ story_full_ids.insert(story_full_id);
+ }
+}
+
void Dependencies::add_dialog_and_dependencies(DialogId dialog_id) {
if (dialog_id.is_valid() && dialog_ids.insert(dialog_id).second) {
add_dialog_dependencies(dialog_id);
@@ -81,47 +90,61 @@ void Dependencies::add_message_sender_dependencies(DialogId dialog_id) {
}
}
-bool Dependencies::resolve_force(Td *td, const char *source) const {
+bool Dependencies::resolve_force(Td *td, const char *source, bool ignore_errors) const {
bool success = true;
for (auto user_id : user_ids) {
- if (!td->contacts_manager_->have_user_force(user_id)) {
- LOG(ERROR) << "Can't find " << user_id << " from " << source;
+ if (!td->user_manager_->have_user_force(user_id, source)) {
+ if (!ignore_errors) {
+ LOG(ERROR) << "Can't find " << user_id << " from " << source;
+ }
success = false;
}
}
for (auto chat_id : chat_ids) {
- if (!td->contacts_manager_->have_chat_force(chat_id)) {
- LOG(ERROR) << "Can't find " << chat_id << " from " << source;
+ if (!td->chat_manager_->have_chat_force(chat_id, source)) {
+ if (!ignore_errors) {
+ LOG(ERROR) << "Can't find " << chat_id << " from " << source;
+ }
success = false;
}
}
for (auto channel_id : channel_ids) {
- if (!td->contacts_manager_->have_channel_force(channel_id)) {
- if (td->contacts_manager_->have_min_channel(channel_id)) {
+ if (!td->chat_manager_->have_channel_force(channel_id, source)) {
+ if (td->chat_manager_->have_min_channel(channel_id)) {
LOG(INFO) << "Can't find " << channel_id << " from " << source << ", but have it as a min-channel";
continue;
}
- LOG(ERROR) << "Can't find " << channel_id << " from " << source;
+ if (!ignore_errors) {
+ LOG(ERROR) << "Can't find " << channel_id << " from " << source;
+ }
success = false;
}
}
for (auto secret_chat_id : secret_chat_ids) {
- if (!td->contacts_manager_->have_secret_chat_force(secret_chat_id)) {
- LOG(ERROR) << "Can't find " << secret_chat_id << " from " << source;
+ if (!td->user_manager_->have_secret_chat_force(secret_chat_id, source)) {
+ if (!ignore_errors) {
+ LOG(ERROR) << "Can't find " << secret_chat_id << " from " << source;
+ }
success = false;
}
}
for (auto dialog_id : dialog_ids) {
- if (!td->messages_manager_->have_dialog_force(dialog_id, source)) {
- LOG(ERROR) << "Can't find " << dialog_id << " from " << source;
- td->messages_manager_->force_create_dialog(dialog_id, "resolve_dependencies_force", true);
+ if (!td->dialog_manager_->have_dialog_force(dialog_id, source)) {
+ if (!ignore_errors) {
+ LOG(ERROR) << "Can't find " << dialog_id << " from " << source;
+ }
+ td->dialog_manager_->force_create_dialog(dialog_id, source, true);
success = false;
}
}
for (auto web_page_id : web_page_ids) {
if (!td->web_pages_manager_->have_web_page_force(web_page_id)) {
LOG(INFO) << "Can't find " << web_page_id << " from " << source;
- success = false;
+ }
+ }
+ for (auto story_full_id : story_full_ids) {
+ if (!td->story_manager_->have_story_force(story_full_id)) {
+ LOG(INFO) << "Can't find " << story_full_id << " from " << source;
}
}
return success;