Add ContactsManager::get_current_state.

GitOrigin-RevId: 108cab6899368e264684aab79d488384be968e48
This commit is contained in:
levlam 2018-09-20 21:37:35 +03:00
parent b2f9a33832
commit f8894dbff9
3 changed files with 44 additions and 11 deletions

View File

@ -6305,7 +6305,7 @@ void ContactsManager::update_channel_full(ChannelFull *channel_full, ChannelId c
send_closure( send_closure(
G()->td(), &Td::send_update, G()->td(), &Td::send_update,
make_tl_object<td_api::updateSupergroupFullInfo>(get_supergroup_id_object(channel_id, "update_channel_full"), make_tl_object<td_api::updateSupergroupFullInfo>(get_supergroup_id_object(channel_id, "update_channel_full"),
get_channel_full_info_object(channel_full))); get_supergroup_full_info_object(channel_full)));
} }
} }
@ -9677,11 +9677,11 @@ tl_object_ptr<td_api::supergroup> ContactsManager::get_supergroup_object(Channel
channel->is_verified, channel->restriction_reason); channel->is_verified, channel->restriction_reason);
} }
tl_object_ptr<td_api::supergroupFullInfo> ContactsManager::get_channel_full_info_object(ChannelId channel_id) const { tl_object_ptr<td_api::supergroupFullInfo> ContactsManager::get_supergroup_full_info_object(ChannelId channel_id) const {
return get_channel_full_info_object(get_channel_full(channel_id)); return get_supergroup_full_info_object(get_channel_full(channel_id));
} }
tl_object_ptr<td_api::supergroupFullInfo> ContactsManager::get_channel_full_info_object( tl_object_ptr<td_api::supergroupFullInfo> ContactsManager::get_supergroup_full_info_object(
const ChannelFull *channel_full) const { const ChannelFull *channel_full) const {
CHECK(channel_full != nullptr); CHECK(channel_full != nullptr);
return make_tl_object<td_api::supergroupFullInfo>( return make_tl_object<td_api::supergroupFullInfo>(
@ -9689,7 +9689,7 @@ tl_object_ptr<td_api::supergroupFullInfo> ContactsManager::get_channel_full_info
channel_full->restricted_count, channel_full->banned_count, channel_full->can_get_participants, channel_full->restricted_count, channel_full->banned_count, channel_full->can_get_participants,
channel_full->can_set_username, channel_full->can_set_sticker_set, channel_full->is_all_history_available, channel_full->can_set_username, channel_full->can_set_sticker_set, channel_full->is_all_history_available,
channel_full->sticker_set_id, channel_full->invite_link, channel_full->pinned_message_id.get(), channel_full->sticker_set_id, channel_full->invite_link, channel_full->pinned_message_id.get(),
get_basic_group_id_object(channel_full->migrated_from_chat_id, "get_channel_full_info_object"), get_basic_group_id_object(channel_full->migrated_from_chat_id, "get_supergroup_full_info_object"),
channel_full->migrated_from_max_message_id.get()); channel_full->migrated_from_max_message_id.get());
} }
@ -9859,4 +9859,35 @@ UserId ContactsManager::get_support_user(Promise<Unit> &&promise) {
return UserId(); return UserId();
} }
void ContactsManager::get_current_state(vector<td_api::object_ptr<td_api::Update>> &updates) {
for (auto &it : users_) {
updates.push_back(td_api::make_object<td_api::updateUser>(get_user_object(it.first, &it.second)));
}
for (auto &it : channels_) {
updates.push_back(td_api::make_object<td_api::updateSupergroup>(get_supergroup_object(it.first, &it.second)));
}
for (auto &it : chats_) { // chat object can contain channel_id, so it must be sent after channels
updates.push_back(td_api::make_object<td_api::updateBasicGroup>(get_basic_group_object(it.first, &it.second)));
}
for (auto &it : secret_chats_) { // secret chat object contains user_id, so it must be sent after users
updates.push_back(td_api::make_object<td_api::updateSecretChat>(get_secret_chat_object(it.first, &it.second)));
}
for (auto &it : users_full_) {
if (!it.second.is_inited) {
continue;
}
updates.push_back(td_api::make_object<td_api::updateUserFullInfo>(get_user_id_object(it.first, "get_current_state"),
get_user_full_info_object(it.first, &it.second)));
}
for (auto &it : channels_full_) {
updates.push_back(td_api::make_object<td_api::updateSupergroupFullInfo>(
get_supergroup_id_object(it.first, "get_current_state"), get_supergroup_full_info_object(&it.second)));
}
for (auto &it : chats_full_) {
updates.push_back(td_api::make_object<td_api::updateBasicGroupFullInfo>(
get_basic_group_id_object(it.first, "get_current_state"), get_basic_group_full_info_object(&it.second)));
}
}
} // namespace td } // namespace td

View File

@ -413,7 +413,7 @@ class ContactsManager : public Actor {
tl_object_ptr<td_api::supergroup> get_supergroup_object(ChannelId channel_id) const; tl_object_ptr<td_api::supergroup> get_supergroup_object(ChannelId channel_id) const;
tl_object_ptr<td_api::supergroupFullInfo> get_channel_full_info_object(ChannelId channel_id) const; tl_object_ptr<td_api::supergroupFullInfo> get_supergroup_full_info_object(ChannelId channel_id) const;
int32 get_secret_chat_id_object(SecretChatId secret_chat_id, const char *source) const; int32 get_secret_chat_id_object(SecretChatId secret_chat_id, const char *source) const;
@ -433,6 +433,8 @@ class ContactsManager : public Actor {
UserId get_support_user(Promise<Unit> &&promise); UserId get_support_user(Promise<Unit> &&promise);
void get_current_state(vector<td_api::object_ptr<td_api::Update>> &updates);
private: private:
enum class LinkState : uint8 { Unknown, None, KnowsPhoneNumber, Contact }; enum class LinkState : uint8 { Unknown, None, KnowsPhoneNumber, Contact };
@ -986,7 +988,7 @@ class ContactsManager : public Actor {
tl_object_ptr<td_api::supergroup> get_supergroup_object(ChannelId channel_id, const Channel *channel) const; tl_object_ptr<td_api::supergroup> get_supergroup_object(ChannelId channel_id, const Channel *channel) const;
tl_object_ptr<td_api::supergroupFullInfo> get_channel_full_info_object(const ChannelFull *channel_full) const; tl_object_ptr<td_api::supergroupFullInfo> get_supergroup_full_info_object(const ChannelFull *channel_full) const;
static tl_object_ptr<td_api::SecretChatState> get_secret_chat_state_object(SecretChatState state); static tl_object_ptr<td_api::SecretChatState> get_secret_chat_state_object(SecretChatState state);

View File

@ -846,7 +846,7 @@ class GetSupergroupFullInfoRequest : public RequestActor<> {
} }
void do_send_result() override { void do_send_result() override {
send_result(td->contacts_manager_->get_channel_full_info_object(channel_id_)); send_result(td->contacts_manager_->get_supergroup_full_info_object(channel_id_));
} }
public: public:
@ -4587,19 +4587,19 @@ void Td::on_request(uint64 id, const td_api::getCurrentState &request) {
updates.push_back(td_api::make_object<td_api::updateConnectionState>(get_connection_state_object(connection_state_))); updates.push_back(td_api::make_object<td_api::updateConnectionState>(get_connection_state_object(connection_state_)));
contacts_manager_->get_current_state(updates);
/* /*
// TODO // TODO
updateUnreadMessageCount { updateUnreadMessageCount {
updateUnreadChatCount { updateUnreadChatCount {
updateScopeNotificationSettings { updateScopeNotificationSettings {
updateScopeNotificationSettings { updateScopeNotificationSettings {
updateUser {
updateSecretChat {
updateNewChat { updateNewChat {
updateChatLastMessage { updateChatLastMessage {
*/ */
// send response synchronously to prevent "Request aborted" // send response synchronously to prevent "Request aborted" or other changes of the current state
send_result(id, td_api::make_object<td_api::updates>(std::move(updates))); send_result(id, td_api::make_object<td_api::updates>(std::move(updates)));
} }