Merge remote-tracking branch 'td/master'
This commit is contained in:
commit
9f3e26dea6
@ -3004,13 +3004,13 @@ class GetChannelAdministratorsQuery final : public Td::ResultHandler {
|
|||||||
administrators.reserve(participants->participants_.size());
|
administrators.reserve(participants->participants_.size());
|
||||||
for (auto &participant : participants->participants_) {
|
for (auto &participant : participants->participants_) {
|
||||||
DialogParticipant dialog_participant(std::move(participant));
|
DialogParticipant dialog_participant(std::move(participant));
|
||||||
if (!dialog_participant.is_valid() || !dialog_participant.status.is_administrator() ||
|
if (!dialog_participant.is_valid() || !dialog_participant.status_.is_administrator() ||
|
||||||
dialog_participant.dialog_id.get_type() != DialogType::User) {
|
dialog_participant.dialog_id_.get_type() != DialogType::User) {
|
||||||
LOG(ERROR) << "Receive " << dialog_participant << " as an administrator of " << channel_id_;
|
LOG(ERROR) << "Receive " << dialog_participant << " as an administrator of " << channel_id_;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
administrators.emplace_back(dialog_participant.dialog_id.get_user_id(), dialog_participant.status.get_rank(),
|
administrators.emplace_back(dialog_participant.dialog_id_.get_user_id(),
|
||||||
dialog_participant.status.is_creator());
|
dialog_participant.status_.get_rank(), dialog_participant.status_.is_creator());
|
||||||
}
|
}
|
||||||
|
|
||||||
td->contacts_manager_->on_update_channel_administrator_count(channel_id_,
|
td->contacts_manager_->on_update_channel_administrator_count(channel_id_,
|
||||||
@ -6915,7 +6915,7 @@ void ContactsManager::set_channel_participant_status(ChannelId channel_id, Dialo
|
|||||||
}
|
}
|
||||||
|
|
||||||
send_closure(actor_id, &ContactsManager::set_channel_participant_status_impl, channel_id, participant_dialog_id,
|
send_closure(actor_id, &ContactsManager::set_channel_participant_status_impl, channel_id, participant_dialog_id,
|
||||||
std::move(status), r_dialog_participant.ok().status, std::move(promise));
|
std::move(status), r_dialog_participant.ok().status_, std::move(promise));
|
||||||
});
|
});
|
||||||
|
|
||||||
td_->create_handler<GetChannelParticipantQuery>(std::move(on_result_promise))
|
td_->create_handler<GetChannelParticipantQuery>(std::move(on_result_promise))
|
||||||
@ -7436,17 +7436,17 @@ void ContactsManager::delete_chat_participant(ChatId chat_id, UserId user_id, bo
|
|||||||
TODO
|
TODO
|
||||||
if (c->everyone_is_administrator) {
|
if (c->everyone_is_administrator) {
|
||||||
// if all are administrators, only invited by me participants can be deleted
|
// if all are administrators, only invited by me participants can be deleted
|
||||||
if (participant->inviter_user_id != my_id) {
|
if (participant->inviter_user_id_ != my_id) {
|
||||||
return promise.set_error(Status::Error(400, "Need to be inviter of a user to kick it from a basic group"));
|
return promise.set_error(Status::Error(400, "Need to be inviter of a user to kick it from a basic group"));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// otherwise, only creator can kick administrators
|
// otherwise, only creator can kick administrators
|
||||||
if (participant->status.is_administrator()) {
|
if (participant->status_.is_administrator()) {
|
||||||
return promise.set_error(
|
return promise.set_error(
|
||||||
Status::Error(400, "Only the creator of a basic group can kick group administrators"));
|
Status::Error(400, "Only the creator of a basic group can kick group administrators"));
|
||||||
}
|
}
|
||||||
// regular users can be kicked by administrators and their inviters
|
// regular users can be kicked by administrators and their inviters
|
||||||
if (!my_status.is_administrator() && participant->inviter_user_id != my_id) {
|
if (!my_status.is_administrator() && participant->inviter_user_id_ != my_id) {
|
||||||
return promise.set_error(Status::Error(400, "Need to be inviter of a user to kick it from a basic group"));
|
return promise.set_error(Status::Error(400, "Need to be inviter of a user to kick it from a basic group"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -9447,8 +9447,8 @@ void ContactsManager::on_load_chat_full_from_database(ChatId chat_id, string val
|
|||||||
dependencies.chat_ids.insert(chat_id);
|
dependencies.chat_ids.insert(chat_id);
|
||||||
dependencies.user_ids.insert(chat_full->creator_user_id);
|
dependencies.user_ids.insert(chat_full->creator_user_id);
|
||||||
for (auto &participant : chat_full->participants) {
|
for (auto &participant : chat_full->participants) {
|
||||||
add_message_sender_dependencies(dependencies, participant.dialog_id);
|
add_message_sender_dependencies(dependencies, participant.dialog_id_);
|
||||||
dependencies.user_ids.insert(participant.inviter_user_id);
|
dependencies.user_ids.insert(participant.inviter_user_id_);
|
||||||
}
|
}
|
||||||
dependencies.user_ids.insert(chat_full->invite_link.get_creator_user_id());
|
dependencies.user_ids.insert(chat_full->invite_link.get_creator_user_id());
|
||||||
if (!resolve_dependencies_force(td_, dependencies, "on_load_chat_full_from_database")) {
|
if (!resolve_dependencies_force(td_, dependencies, "on_load_chat_full_from_database")) {
|
||||||
@ -10011,12 +10011,12 @@ void ContactsManager::update_chat_full(ChatFull *chat_full, ChatId chat_id, cons
|
|||||||
vector<DialogAdministrator> administrators;
|
vector<DialogAdministrator> administrators;
|
||||||
vector<UserId> bot_user_ids;
|
vector<UserId> bot_user_ids;
|
||||||
for (const auto &participant : chat_full->participants) {
|
for (const auto &participant : chat_full->participants) {
|
||||||
if (participant.status.is_administrator() && participant.dialog_id.get_type() == DialogType::User) {
|
if (participant.status_.is_administrator() && participant.dialog_id_.get_type() == DialogType::User) {
|
||||||
administrators.emplace_back(participant.dialog_id.get_user_id(), participant.status.get_rank(),
|
administrators.emplace_back(participant.dialog_id_.get_user_id(), participant.status_.get_rank(),
|
||||||
participant.status.is_creator());
|
participant.status_.is_creator());
|
||||||
}
|
}
|
||||||
if (participant.dialog_id.get_type() == DialogType::User) {
|
if (participant.dialog_id_.get_type() == DialogType::User) {
|
||||||
auto user_id = participant.dialog_id.get_user_id();
|
auto user_id = participant.dialog_id_.get_user_id();
|
||||||
if (is_user_bot(user_id)) {
|
if (is_user_bot(user_id)) {
|
||||||
bot_user_ids.push_back(user_id);
|
bot_user_ids.push_back(user_id);
|
||||||
}
|
}
|
||||||
@ -10361,7 +10361,7 @@ vector<BotCommands> ContactsManager::get_bot_commands(vector<tl_object_ptr<teleg
|
|||||||
if (participants != nullptr) {
|
if (participants != nullptr) {
|
||||||
bool is_participant = false;
|
bool is_participant = false;
|
||||||
for (auto &participant : *participants) {
|
for (auto &participant : *participants) {
|
||||||
if (participant.dialog_id == DialogId(user_id)) {
|
if (participant.dialog_id_ == DialogId(user_id)) {
|
||||||
is_participant = true;
|
is_participant = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -11479,10 +11479,10 @@ void ContactsManager::update_dialog_online_member_count(const vector<DialogParti
|
|||||||
int32 online_member_count = 0;
|
int32 online_member_count = 0;
|
||||||
int32 time = G()->unix_time();
|
int32 time = G()->unix_time();
|
||||||
for (const auto &participant : participants) {
|
for (const auto &participant : participants) {
|
||||||
if (participant.dialog_id.get_type() != DialogType::User) {
|
if (participant.dialog_id_.get_type() != DialogType::User) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
auto user_id = participant.dialog_id.get_user_id();
|
auto user_id = participant.dialog_id_.get_user_id();
|
||||||
auto u = get_user(user_id);
|
auto u = get_user(user_id);
|
||||||
if (u != nullptr && !u->is_deleted && !u->is_bot) {
|
if (u != nullptr && !u->is_deleted && !u->is_bot) {
|
||||||
if (get_user_was_online(u, user_id) > time) {
|
if (get_user_was_online(u, user_id) > time) {
|
||||||
@ -11548,18 +11548,18 @@ void ContactsManager::on_get_chat_participants(tl_object_ptr<telegram_api::ChatP
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG_IF(ERROR, !td_->messages_manager_->have_dialog_info(dialog_participant.dialog_id))
|
LOG_IF(ERROR, !td_->messages_manager_->have_dialog_info(dialog_participant.dialog_id_))
|
||||||
<< "Have no information about " << dialog_participant.dialog_id << " as a member of " << chat_id;
|
<< "Have no information about " << dialog_participant.dialog_id_ << " as a member of " << chat_id;
|
||||||
LOG_IF(ERROR, !have_user(dialog_participant.inviter_user_id))
|
LOG_IF(ERROR, !have_user(dialog_participant.inviter_user_id_))
|
||||||
<< "Have no information about " << dialog_participant.inviter_user_id << " as a member of " << chat_id;
|
<< "Have no information about " << dialog_participant.inviter_user_id_ << " as a member of " << chat_id;
|
||||||
if (dialog_participant.joined_date < c->date) {
|
if (dialog_participant.joined_date_ < c->date) {
|
||||||
LOG_IF(ERROR, dialog_participant.joined_date < c->date - 30 && c->date >= 1486000000)
|
LOG_IF(ERROR, dialog_participant.joined_date_ < c->date - 30 && c->date >= 1486000000)
|
||||||
<< "Wrong join date = " << dialog_participant.joined_date << " for " << dialog_participant.dialog_id
|
<< "Wrong join date = " << dialog_participant.joined_date_ << " for " << dialog_participant.dialog_id_
|
||||||
<< ", " << chat_id << " was created at " << c->date;
|
<< ", " << chat_id << " was created at " << c->date;
|
||||||
dialog_participant.joined_date = c->date;
|
dialog_participant.joined_date_ = c->date;
|
||||||
}
|
}
|
||||||
if (dialog_participant.status.is_creator() && dialog_participant.dialog_id.get_type() == DialogType::User) {
|
if (dialog_participant.status_.is_creator() && dialog_participant.dialog_id_.get_type() == DialogType::User) {
|
||||||
new_creator_user_id = dialog_participant.dialog_id.get_user_id();
|
new_creator_user_id = dialog_participant.dialog_id_.get_user_id();
|
||||||
}
|
}
|
||||||
new_participants.push_back(std::move(dialog_participant));
|
new_participants.push_back(std::move(dialog_participant));
|
||||||
}
|
}
|
||||||
@ -11595,7 +11595,7 @@ const DialogParticipant *ContactsManager::get_chat_participant(ChatId chat_id, U
|
|||||||
|
|
||||||
const DialogParticipant *ContactsManager::get_chat_full_participant(const ChatFull *chat_full, DialogId dialog_id) {
|
const DialogParticipant *ContactsManager::get_chat_full_participant(const ChatFull *chat_full, DialogId dialog_id) {
|
||||||
for (const auto &dialog_participant : chat_full->participants) {
|
for (const auto &dialog_participant : chat_full->participants) {
|
||||||
if (dialog_participant.dialog_id == dialog_id) {
|
if (dialog_participant.dialog_id_ == dialog_id) {
|
||||||
return &dialog_participant;
|
return &dialog_participant;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -11604,7 +11604,7 @@ const DialogParticipant *ContactsManager::get_chat_full_participant(const ChatFu
|
|||||||
|
|
||||||
tl_object_ptr<td_api::chatMember> ContactsManager::get_chat_member_object(
|
tl_object_ptr<td_api::chatMember> ContactsManager::get_chat_member_object(
|
||||||
const DialogParticipant &dialog_participant) const {
|
const DialogParticipant &dialog_participant) const {
|
||||||
DialogId dialog_id = dialog_participant.dialog_id;
|
DialogId dialog_id = dialog_participant.dialog_id_;
|
||||||
UserId participant_user_id;
|
UserId participant_user_id;
|
||||||
if (dialog_id.get_type() == DialogType::User) {
|
if (dialog_id.get_type() == DialogType::User) {
|
||||||
participant_user_id = dialog_id.get_user_id();
|
participant_user_id = dialog_id.get_user_id();
|
||||||
@ -11613,8 +11613,8 @@ tl_object_ptr<td_api::chatMember> ContactsManager::get_chat_member_object(
|
|||||||
}
|
}
|
||||||
return td_api::make_object<td_api::chatMember>(
|
return td_api::make_object<td_api::chatMember>(
|
||||||
td_->messages_manager_->get_message_sender_object_const(dialog_id, "get_chat_member_object"),
|
td_->messages_manager_->get_message_sender_object_const(dialog_id, "get_chat_member_object"),
|
||||||
get_user_id_object(dialog_participant.inviter_user_id, "chatMember.inviter_user_id"),
|
get_user_id_object(dialog_participant.inviter_user_id_, "chatMember.inviter_user_id"),
|
||||||
dialog_participant.joined_date, dialog_participant.status.get_chat_member_status_object());
|
dialog_participant.joined_date_, dialog_participant.status_.get_chat_member_status_object());
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ContactsManager::on_get_channel_error(ChannelId channel_id, const Status &status, const string &source) {
|
bool ContactsManager::on_get_channel_error(ChannelId channel_id, const Status &status, const string &source) {
|
||||||
@ -11710,15 +11710,15 @@ void ContactsManager::on_get_channel_participants(
|
|||||||
result.emplace_back(std::move(participant_ptr));
|
result.emplace_back(std::move(participant_ptr));
|
||||||
const auto &participant = result.back();
|
const auto &participant = result.back();
|
||||||
UserId participant_user_id;
|
UserId participant_user_id;
|
||||||
if (participant.dialog_id.get_type() == DialogType::User) {
|
if (participant.dialog_id_.get_type() == DialogType::User) {
|
||||||
participant_user_id = participant.dialog_id.get_user_id();
|
participant_user_id = participant.dialog_id_.get_user_id();
|
||||||
}
|
}
|
||||||
if (!participant.is_valid() || (filter.is_bots() && !is_user_bot(participant_user_id)) ||
|
if (!participant.is_valid() || (filter.is_bots() && !is_user_bot(participant_user_id)) ||
|
||||||
(filter.is_administrators() && !participant.status.is_administrator()) ||
|
(filter.is_administrators() && !participant.status_.is_administrator()) ||
|
||||||
((filter.is_recent() || filter.is_contacts() || filter.is_search()) && !participant.status.is_member()) ||
|
((filter.is_recent() || filter.is_contacts() || filter.is_search()) && !participant.status_.is_member()) ||
|
||||||
(filter.is_contacts() && !is_user_contact(participant_user_id)) ||
|
(filter.is_contacts() && !is_user_contact(participant_user_id)) ||
|
||||||
(filter.is_restricted() && !participant.status.is_restricted()) ||
|
(filter.is_restricted() && !participant.status_.is_restricted()) ||
|
||||||
(filter.is_banned() && !participant.status.is_banned())) {
|
(filter.is_banned() && !participant.status_.is_banned())) {
|
||||||
bool skip_error = ((filter.is_administrators() || filter.is_bots()) && is_user_deleted(participant_user_id)) ||
|
bool skip_error = ((filter.is_administrators() || filter.is_bots()) && is_user_deleted(participant_user_id)) ||
|
||||||
(filter.is_contacts() && participant_user_id == get_my_id());
|
(filter.is_contacts() && participant_user_id == get_my_id());
|
||||||
if (!skip_error) {
|
if (!skip_error) {
|
||||||
@ -11750,11 +11750,11 @@ void ContactsManager::on_get_channel_participants(
|
|||||||
{
|
{
|
||||||
if (filter.is_recent()) {
|
if (filter.is_recent()) {
|
||||||
for (const auto &participant : result) {
|
for (const auto &participant : result) {
|
||||||
if (participant.dialog_id.get_type() == DialogType::User) {
|
if (participant.dialog_id_.get_type() == DialogType::User) {
|
||||||
auto participant_user_id = participant.dialog_id.get_user_id();
|
auto participant_user_id = participant.dialog_id_.get_user_id();
|
||||||
if (participant.status.is_administrator()) {
|
if (participant.status_.is_administrator()) {
|
||||||
administrators.emplace_back(participant_user_id, participant.status.get_rank(),
|
administrators.emplace_back(participant_user_id, participant.status_.get_rank(),
|
||||||
participant.status.is_creator());
|
participant.status_.is_creator());
|
||||||
}
|
}
|
||||||
if (is_user_bot(participant_user_id)) {
|
if (is_user_bot(participant_user_id)) {
|
||||||
bot_user_ids.push_back(participant_user_id);
|
bot_user_ids.push_back(participant_user_id);
|
||||||
@ -11769,15 +11769,15 @@ void ContactsManager::on_get_channel_participants(
|
|||||||
}
|
}
|
||||||
} else if (filter.is_administrators()) {
|
} else if (filter.is_administrators()) {
|
||||||
for (const auto &participant : result) {
|
for (const auto &participant : result) {
|
||||||
if (participant.dialog_id.get_type() == DialogType::User) {
|
if (participant.dialog_id_.get_type() == DialogType::User) {
|
||||||
administrators.emplace_back(participant.dialog_id.get_user_id(), participant.status.get_rank(),
|
administrators.emplace_back(participant.dialog_id_.get_user_id(), participant.status_.get_rank(),
|
||||||
participant.status.is_creator());
|
participant.status_.is_creator());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (filter.is_bots()) {
|
} else if (filter.is_bots()) {
|
||||||
bot_user_ids = transform(result, [](const DialogParticipant &participant) {
|
bot_user_ids = transform(result, [](const DialogParticipant &participant) {
|
||||||
CHECK(participant.dialog_id.get_type() == DialogType::User);
|
CHECK(participant.dialog_id_.get_type() == DialogType::User);
|
||||||
return participant.dialog_id.get_user_id();
|
return participant.dialog_id_.get_user_id();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -11827,7 +11827,7 @@ void ContactsManager::on_get_channel_participants(
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!additional_query.empty()) {
|
if (!additional_query.empty()) {
|
||||||
auto dialog_ids = transform(result, [](const DialogParticipant &participant) { return participant.dialog_id; });
|
auto dialog_ids = transform(result, [](const DialogParticipant &participant) { return participant.dialog_id_; });
|
||||||
std::pair<int32, vector<DialogId>> result_dialog_ids =
|
std::pair<int32, vector<DialogId>> result_dialog_ids =
|
||||||
search_among_dialogs(dialog_ids, additional_query, additional_limit);
|
search_among_dialogs(dialog_ids, additional_query, additional_limit);
|
||||||
|
|
||||||
@ -11837,8 +11837,8 @@ void ContactsManager::on_get_channel_participants(
|
|||||||
auto all_participants = std::move(result);
|
auto all_participants = std::move(result);
|
||||||
result.clear();
|
result.clear();
|
||||||
for (auto &participant : all_participants) {
|
for (auto &participant : all_participants) {
|
||||||
if (result_dialog_ids_set.count(participant.dialog_id)) {
|
if (result_dialog_ids_set.count(participant.dialog_id_)) {
|
||||||
result_dialog_ids_set.erase(participant.dialog_id);
|
result_dialog_ids_set.erase(participant.dialog_id_);
|
||||||
result.push_back(std::move(participant));
|
result.push_back(std::move(participant));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -11862,7 +11862,7 @@ void ContactsManager::add_channel_participant_to_cache(ChannelId channel_id,
|
|||||||
if (participants.participants_.empty()) {
|
if (participants.participants_.empty()) {
|
||||||
channel_participant_cache_timeout_.set_timeout_in(channel_id.get(), CHANNEL_PARTICIPANT_CACHE_TIME);
|
channel_participant_cache_timeout_.set_timeout_in(channel_id.get(), CHANNEL_PARTICIPANT_CACHE_TIME);
|
||||||
}
|
}
|
||||||
auto &participant_info = participants.participants_[dialog_participant.dialog_id];
|
auto &participant_info = participants.participants_[dialog_participant.dialog_id_];
|
||||||
if (participant_info.last_access_date_ > 0 && !allow_replace) {
|
if (participant_info.last_access_date_ > 0 && !allow_replace) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -11881,7 +11881,7 @@ const DialogParticipant *ContactsManager::get_channel_participant_from_cache(Cha
|
|||||||
CHECK(!participants.empty());
|
CHECK(!participants.empty());
|
||||||
auto it = participants.find(participant_dialog_id);
|
auto it = participants.find(participant_dialog_id);
|
||||||
if (it != participants.end()) {
|
if (it != participants.end()) {
|
||||||
it->second.participant_.status.update_restrictions();
|
it->second.participant_.status_.update_restrictions();
|
||||||
it->second.last_access_date_ = G()->unix_time();
|
it->second.last_access_date_ = G()->unix_time();
|
||||||
return &it->second.participant_;
|
return &it->second.participant_;
|
||||||
}
|
}
|
||||||
@ -11919,7 +11919,7 @@ void ContactsManager::speculative_add_channel_participants(ChannelId channel_id,
|
|||||||
auto &participants = it->second;
|
auto &participants = it->second;
|
||||||
bool is_found = false;
|
bool is_found = false;
|
||||||
for (auto &participant : participants) {
|
for (auto &participant : participants) {
|
||||||
if (participant.dialog_id == DialogId(user_id)) {
|
if (participant.dialog_id_ == DialogId(user_id)) {
|
||||||
is_found = true;
|
is_found = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -11961,7 +11961,7 @@ void ContactsManager::speculative_delete_channel_participant(ChannelId channel_i
|
|||||||
if (it != cached_channel_participants_.end()) {
|
if (it != cached_channel_participants_.end()) {
|
||||||
auto &participants = it->second;
|
auto &participants = it->second;
|
||||||
for (size_t i = 0; i < participants.size(); i++) {
|
for (size_t i = 0; i < participants.size(); i++) {
|
||||||
if (participants[i].dialog_id == DialogId(deleted_user_id)) {
|
if (participants[i].dialog_id_ == DialogId(deleted_user_id)) {
|
||||||
participants.erase(participants.begin() + i);
|
participants.erase(participants.begin() + i);
|
||||||
update_channel_online_member_count(channel_id, false);
|
update_channel_online_member_count(channel_id, false);
|
||||||
break;
|
break;
|
||||||
@ -12076,12 +12076,12 @@ void ContactsManager::speculative_add_channel_user(ChannelId channel_id, UserId
|
|||||||
auto &participants = it->second;
|
auto &participants = it->second;
|
||||||
bool is_found = false;
|
bool is_found = false;
|
||||||
for (size_t i = 0; i < participants.size(); i++) {
|
for (size_t i = 0; i < participants.size(); i++) {
|
||||||
if (participants[i].dialog_id == DialogId(user_id)) {
|
if (participants[i].dialog_id_ == DialogId(user_id)) {
|
||||||
if (!new_status.is_member()) {
|
if (!new_status.is_member()) {
|
||||||
participants.erase(participants.begin() + i);
|
participants.erase(participants.begin() + i);
|
||||||
update_channel_online_member_count(channel_id, false);
|
update_channel_online_member_count(channel_id, false);
|
||||||
} else {
|
} else {
|
||||||
participants[i].status = new_status;
|
participants[i].status_ = new_status;
|
||||||
}
|
}
|
||||||
is_found = true;
|
is_found = true;
|
||||||
break;
|
break;
|
||||||
@ -12658,12 +12658,12 @@ void ContactsManager::on_update_chat_add_user(ChatId chat_id, UserId inviter_use
|
|||||||
}
|
}
|
||||||
if (on_update_chat_full_participants_short(chat_full, chat_id, version)) {
|
if (on_update_chat_full_participants_short(chat_full, chat_id, version)) {
|
||||||
for (auto &participant : chat_full->participants) {
|
for (auto &participant : chat_full->participants) {
|
||||||
if (participant.dialog_id == DialogId(user_id)) {
|
if (participant.dialog_id_ == DialogId(user_id)) {
|
||||||
if (participant.inviter_user_id != inviter_user_id) {
|
if (participant.inviter_user_id_ != inviter_user_id) {
|
||||||
LOG(ERROR) << user_id << " was readded to " << chat_id << " by " << inviter_user_id
|
LOG(ERROR) << user_id << " was readded to " << chat_id << " by " << inviter_user_id
|
||||||
<< ", previously invited by " << participant.inviter_user_id;
|
<< ", previously invited by " << participant.inviter_user_id_;
|
||||||
participant.inviter_user_id = inviter_user_id;
|
participant.inviter_user_id_ = inviter_user_id;
|
||||||
participant.joined_date = date;
|
participant.joined_date_ = date;
|
||||||
repair_chat_participants(chat_id);
|
repair_chat_participants(chat_id);
|
||||||
} else {
|
} else {
|
||||||
// Possible if update comes twice
|
// Possible if update comes twice
|
||||||
@ -12747,8 +12747,8 @@ void ContactsManager::on_update_chat_edit_administrator(ChatId chat_id, UserId u
|
|||||||
if (chat_full != nullptr) {
|
if (chat_full != nullptr) {
|
||||||
if (chat_full->version + 1 == version) {
|
if (chat_full->version + 1 == version) {
|
||||||
for (auto &participant : chat_full->participants) {
|
for (auto &participant : chat_full->participants) {
|
||||||
if (participant.dialog_id == DialogId(user_id)) {
|
if (participant.dialog_id_ == DialogId(user_id)) {
|
||||||
participant.status = std::move(status);
|
participant.status_ = std::move(status);
|
||||||
chat_full->is_changed = true;
|
chat_full->is_changed = true;
|
||||||
update_chat_full(chat_full, chat_id, "on_update_chat_edit_administrator");
|
update_chat_full(chat_full, chat_id, "on_update_chat_edit_administrator");
|
||||||
return;
|
return;
|
||||||
@ -12798,7 +12798,7 @@ void ContactsManager::on_update_chat_delete_user(ChatId chat_id, UserId user_id,
|
|||||||
}
|
}
|
||||||
if (on_update_chat_full_participants_short(chat_full, chat_id, version)) {
|
if (on_update_chat_full_participants_short(chat_full, chat_id, version)) {
|
||||||
for (size_t i = 0; i < chat_full->participants.size(); i++) {
|
for (size_t i = 0; i < chat_full->participants.size(); i++) {
|
||||||
if (chat_full->participants[i].dialog_id == DialogId(user_id)) {
|
if (chat_full->participants[i].dialog_id_ == DialogId(user_id)) {
|
||||||
chat_full->participants[i] = chat_full->participants.back();
|
chat_full->participants[i] = chat_full->participants.back();
|
||||||
chat_full->participants.resize(chat_full->participants.size() - 1);
|
chat_full->participants.resize(chat_full->participants.size() - 1);
|
||||||
chat_full->is_changed = true;
|
chat_full->is_changed = true;
|
||||||
@ -13428,7 +13428,7 @@ void ContactsManager::on_update_bot_stopped(UserId user_id, int32 date, bool is_
|
|||||||
DialogParticipant old_dialog_participant(DialogId(get_my_id()), user_id, date, DialogParticipantStatus::Banned(0));
|
DialogParticipant old_dialog_participant(DialogId(get_my_id()), user_id, date, DialogParticipantStatus::Banned(0));
|
||||||
DialogParticipant new_dialog_participant(DialogId(get_my_id()), user_id, date, DialogParticipantStatus::Member());
|
DialogParticipant new_dialog_participant(DialogId(get_my_id()), user_id, date, DialogParticipantStatus::Member());
|
||||||
if (is_stopped) {
|
if (is_stopped) {
|
||||||
std::swap(old_dialog_participant.status, new_dialog_participant.status);
|
std::swap(old_dialog_participant.status_, new_dialog_participant.status_);
|
||||||
}
|
}
|
||||||
|
|
||||||
send_update_chat_member(DialogId(user_id), user_id, date, DialogInviteLink(), old_dialog_participant,
|
send_update_chat_member(DialogId(user_id), user_id, date, DialogInviteLink(), old_dialog_participant,
|
||||||
@ -13461,21 +13461,21 @@ void ContactsManager::on_update_chat_participant(ChatId chat_id, UserId user_id,
|
|||||||
if (old_participant != nullptr) {
|
if (old_participant != nullptr) {
|
||||||
old_dialog_participant = DialogParticipant(std::move(old_participant), c->date, c->status.is_creator());
|
old_dialog_participant = DialogParticipant(std::move(old_participant), c->date, c->status.is_creator());
|
||||||
if (new_participant == nullptr) {
|
if (new_participant == nullptr) {
|
||||||
new_dialog_participant = DialogParticipant::left(old_dialog_participant.dialog_id);
|
new_dialog_participant = DialogParticipant::left(old_dialog_participant.dialog_id_);
|
||||||
} else {
|
} else {
|
||||||
new_dialog_participant = DialogParticipant(std::move(new_participant), c->date, c->status.is_creator());
|
new_dialog_participant = DialogParticipant(std::move(new_participant), c->date, c->status.is_creator());
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
new_dialog_participant = DialogParticipant(std::move(new_participant), c->date, c->status.is_creator());
|
new_dialog_participant = DialogParticipant(std::move(new_participant), c->date, c->status.is_creator());
|
||||||
old_dialog_participant = DialogParticipant::left(new_dialog_participant.dialog_id);
|
old_dialog_participant = DialogParticipant::left(new_dialog_participant.dialog_id_);
|
||||||
}
|
}
|
||||||
if (old_dialog_participant.dialog_id != new_dialog_participant.dialog_id || !old_dialog_participant.is_valid() ||
|
if (old_dialog_participant.dialog_id_ != new_dialog_participant.dialog_id_ || !old_dialog_participant.is_valid() ||
|
||||||
!new_dialog_participant.is_valid()) {
|
!new_dialog_participant.is_valid()) {
|
||||||
LOG(ERROR) << "Receive wrong updateChatParticipant: " << old_dialog_participant << " -> " << new_dialog_participant;
|
LOG(ERROR) << "Receive wrong updateChatParticipant: " << old_dialog_participant << " -> " << new_dialog_participant;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (new_dialog_participant.dialog_id == DialogId(get_my_id()) &&
|
if (new_dialog_participant.dialog_id_ == DialogId(get_my_id()) &&
|
||||||
new_dialog_participant.status != get_chat_status(chat_id) && false) {
|
new_dialog_participant.status_ != get_chat_status(chat_id) && false) {
|
||||||
LOG(ERROR) << "Have status " << get_chat_status(chat_id) << " after receiving updateChatParticipant in " << chat_id
|
LOG(ERROR) << "Have status " << get_chat_status(chat_id) << " after receiving updateChatParticipant in " << chat_id
|
||||||
<< " by " << user_id << " at " << date << " from " << old_dialog_participant << " to "
|
<< " by " << user_id << " at " << date << " from " << old_dialog_participant << " to "
|
||||||
<< new_dialog_participant;
|
<< new_dialog_participant;
|
||||||
@ -13505,29 +13505,29 @@ void ContactsManager::on_update_channel_participant(ChannelId channel_id, UserId
|
|||||||
if (old_participant != nullptr) {
|
if (old_participant != nullptr) {
|
||||||
old_dialog_participant = DialogParticipant(std::move(old_participant));
|
old_dialog_participant = DialogParticipant(std::move(old_participant));
|
||||||
if (new_participant == nullptr) {
|
if (new_participant == nullptr) {
|
||||||
new_dialog_participant = DialogParticipant::left(old_dialog_participant.dialog_id);
|
new_dialog_participant = DialogParticipant::left(old_dialog_participant.dialog_id_);
|
||||||
} else {
|
} else {
|
||||||
new_dialog_participant = DialogParticipant(std::move(new_participant));
|
new_dialog_participant = DialogParticipant(std::move(new_participant));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
new_dialog_participant = DialogParticipant(std::move(new_participant));
|
new_dialog_participant = DialogParticipant(std::move(new_participant));
|
||||||
old_dialog_participant = DialogParticipant::left(new_dialog_participant.dialog_id);
|
old_dialog_participant = DialogParticipant::left(new_dialog_participant.dialog_id_);
|
||||||
}
|
}
|
||||||
if (old_dialog_participant.dialog_id != new_dialog_participant.dialog_id || !old_dialog_participant.is_valid() ||
|
if (old_dialog_participant.dialog_id_ != new_dialog_participant.dialog_id_ || !old_dialog_participant.is_valid() ||
|
||||||
!new_dialog_participant.is_valid()) {
|
!new_dialog_participant.is_valid()) {
|
||||||
LOG(ERROR) << "Receive wrong updateChannelParticipant: " << old_dialog_participant << " -> "
|
LOG(ERROR) << "Receive wrong updateChannelParticipant: " << old_dialog_participant << " -> "
|
||||||
<< new_dialog_participant;
|
<< new_dialog_participant;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (old_dialog_participant.dialog_id == DialogId(get_my_id()) && old_dialog_participant.status.is_administrator() &&
|
if (old_dialog_participant.dialog_id_ == DialogId(get_my_id()) && old_dialog_participant.status_.is_administrator() &&
|
||||||
!new_dialog_participant.status.is_administrator()) {
|
!new_dialog_participant.status_.is_administrator()) {
|
||||||
channel_participants_.erase(channel_id);
|
channel_participants_.erase(channel_id);
|
||||||
} else if (have_channel_participant_cache(channel_id)) {
|
} else if (have_channel_participant_cache(channel_id)) {
|
||||||
add_channel_participant_to_cache(channel_id, new_dialog_participant, true);
|
add_channel_participant_to_cache(channel_id, new_dialog_participant, true);
|
||||||
}
|
}
|
||||||
if (new_dialog_participant.dialog_id == DialogId(get_my_id()) &&
|
if (new_dialog_participant.dialog_id_ == DialogId(get_my_id()) &&
|
||||||
new_dialog_participant.status != get_channel_status(channel_id) && false) {
|
new_dialog_participant.status_ != get_channel_status(channel_id) && false) {
|
||||||
LOG(ERROR) << "Have status " << get_channel_status(channel_id) << " after receiving updateChannelParticipant in "
|
LOG(ERROR) << "Have status " << get_channel_status(channel_id) << " after receiving updateChannelParticipant in "
|
||||||
<< channel_id << " by " << user_id << " at " << date << " from " << old_dialog_participant << " to "
|
<< channel_id << " by " << user_id << " at " << date << " from " << old_dialog_participant << " to "
|
||||||
<< new_dialog_participant;
|
<< new_dialog_participant;
|
||||||
@ -14757,7 +14757,7 @@ void ContactsManager::finish_get_dialog_participant(DialogParticipant &&dialog_p
|
|||||||
Promise<td_api::object_ptr<td_api::chatMember>> &&promise) {
|
Promise<td_api::object_ptr<td_api::chatMember>> &&promise) {
|
||||||
TRY_STATUS_PROMISE(promise, G()->close_status());
|
TRY_STATUS_PROMISE(promise, G()->close_status());
|
||||||
|
|
||||||
auto participant_dialog_id = dialog_participant.dialog_id;
|
auto participant_dialog_id = dialog_participant.dialog_id_;
|
||||||
bool is_user = participant_dialog_id.get_type() == DialogType::User;
|
bool is_user = participant_dialog_id.get_type() == DialogType::User;
|
||||||
if ((is_user && !have_user(participant_dialog_id.get_user_id())) ||
|
if ((is_user && !have_user(participant_dialog_id.get_user_id())) ||
|
||||||
(!is_user && !td_->messages_manager_->have_dialog(participant_dialog_id))) {
|
(!is_user && !td_->messages_manager_->have_dialog(participant_dialog_id))) {
|
||||||
@ -14941,7 +14941,7 @@ void ContactsManager::do_search_chat_participants(ChatId chat_id, const string &
|
|||||||
vector<DialogId> dialog_ids;
|
vector<DialogId> dialog_ids;
|
||||||
for (const auto &participant : chat_full->participants) {
|
for (const auto &participant : chat_full->participants) {
|
||||||
if (filter.is_dialog_participant_suitable(td_, participant)) {
|
if (filter.is_dialog_participant_suitable(td_, participant)) {
|
||||||
dialog_ids.push_back(participant.dialog_id);
|
dialog_ids.push_back(participant.dialog_id_);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -14983,9 +14983,9 @@ void ContactsManager::finish_get_channel_participant(ChannelId channel_id, Dialo
|
|||||||
Promise<DialogParticipant> &&promise) {
|
Promise<DialogParticipant> &&promise) {
|
||||||
TRY_STATUS_PROMISE(promise, G()->close_status());
|
TRY_STATUS_PROMISE(promise, G()->close_status());
|
||||||
|
|
||||||
LOG(INFO) << "Receive a member " << dialog_participant.dialog_id << " of a channel " << channel_id;
|
LOG(INFO) << "Receive a member " << dialog_participant.dialog_id_ << " of a channel " << channel_id;
|
||||||
|
|
||||||
dialog_participant.status.update_restrictions();
|
dialog_participant.status_.update_restrictions();
|
||||||
if (have_channel_participant_cache(channel_id)) {
|
if (have_channel_participant_cache(channel_id)) {
|
||||||
add_channel_participant_to_cache(channel_id, dialog_participant, false);
|
add_channel_participant_to_cache(channel_id, dialog_participant, false);
|
||||||
}
|
}
|
||||||
|
@ -656,14 +656,14 @@ RestrictedRights get_restricted_rights(const td_api::object_ptr<td_api::chatPerm
|
|||||||
|
|
||||||
DialogParticipant::DialogParticipant(DialogId dialog_id, UserId inviter_user_id, int32 joined_date,
|
DialogParticipant::DialogParticipant(DialogId dialog_id, UserId inviter_user_id, int32 joined_date,
|
||||||
DialogParticipantStatus status)
|
DialogParticipantStatus status)
|
||||||
: dialog_id(dialog_id), inviter_user_id(inviter_user_id), joined_date(joined_date), status(std::move(status)) {
|
: dialog_id_(dialog_id), inviter_user_id_(inviter_user_id), joined_date_(joined_date), status_(std::move(status)) {
|
||||||
if (!inviter_user_id.is_valid() && inviter_user_id != UserId()) {
|
if (!inviter_user_id_.is_valid() && inviter_user_id_ != UserId()) {
|
||||||
LOG(ERROR) << "Receive inviter " << inviter_user_id;
|
LOG(ERROR) << "Receive inviter " << inviter_user_id_;
|
||||||
this->inviter_user_id = UserId();
|
inviter_user_id_ = UserId();
|
||||||
}
|
}
|
||||||
if (joined_date < 0) {
|
if (joined_date_ < 0) {
|
||||||
LOG(ERROR) << "Receive date " << joined_date;
|
LOG(ERROR) << "Receive date " << joined_date_;
|
||||||
this->joined_date = 0;
|
joined_date_ = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -743,18 +743,18 @@ DialogParticipant::DialogParticipant(tl_object_ptr<telegram_api::ChannelParticip
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool DialogParticipant::is_valid() const {
|
bool DialogParticipant::is_valid() const {
|
||||||
if (!dialog_id.is_valid() || joined_date < 0) {
|
if (!dialog_id_.is_valid() || joined_date_ < 0) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (status.is_restricted() || status.is_banned() || (status.is_administrator() && !status.is_creator())) {
|
if (status_.is_restricted() || status_.is_banned() || (status_.is_administrator() && !status_.is_creator())) {
|
||||||
return inviter_user_id.is_valid();
|
return inviter_user_id_.is_valid();
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
StringBuilder &operator<<(StringBuilder &string_builder, const DialogParticipant &dialog_participant) {
|
StringBuilder &operator<<(StringBuilder &string_builder, const DialogParticipant &dialog_participant) {
|
||||||
return string_builder << '[' << dialog_participant.dialog_id << " invited by " << dialog_participant.inviter_user_id
|
return string_builder << '[' << dialog_participant.dialog_id_ << " invited by " << dialog_participant.inviter_user_id_
|
||||||
<< " at " << dialog_participant.joined_date << " with status " << dialog_participant.status
|
<< " at " << dialog_participant.joined_date_ << " with status " << dialog_participant.status_
|
||||||
<< ']';
|
<< ']';
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -979,21 +979,21 @@ bool DialogParticipantsFilter::is_dialog_participant_suitable(const Td *td,
|
|||||||
const DialogParticipant &participant) const {
|
const DialogParticipant &participant) const {
|
||||||
switch (type_) {
|
switch (type_) {
|
||||||
case Type::Contacts:
|
case Type::Contacts:
|
||||||
return participant.dialog_id.get_type() == DialogType::User &&
|
return participant.dialog_id_.get_type() == DialogType::User &&
|
||||||
td->contacts_manager_->is_user_contact(participant.dialog_id.get_user_id());
|
td->contacts_manager_->is_user_contact(participant.dialog_id_.get_user_id());
|
||||||
case Type::Administrators:
|
case Type::Administrators:
|
||||||
return participant.status.is_administrator();
|
return participant.status_.is_administrator();
|
||||||
case Type::Members:
|
case Type::Members:
|
||||||
return participant.status.is_member();
|
return participant.status_.is_member();
|
||||||
case Type::Restricted:
|
case Type::Restricted:
|
||||||
return participant.status.is_restricted();
|
return participant.status_.is_restricted();
|
||||||
case Type::Banned:
|
case Type::Banned:
|
||||||
return participant.status.is_banned();
|
return participant.status_.is_banned();
|
||||||
case Type::Mention:
|
case Type::Mention:
|
||||||
return true;
|
return true;
|
||||||
case Type::Bots:
|
case Type::Bots:
|
||||||
return participant.dialog_id.get_type() == DialogType::User &&
|
return participant.dialog_id_.get_type() == DialogType::User &&
|
||||||
td->contacts_manager_->is_user_bot(participant.dialog_id.get_user_id());
|
td->contacts_manager_->is_user_bot(participant.dialog_id_.get_user_id());
|
||||||
default:
|
default:
|
||||||
UNREACHABLE();
|
UNREACHABLE();
|
||||||
return false;
|
return false;
|
||||||
|
@ -390,10 +390,10 @@ bool operator!=(const DialogParticipantStatus &lhs, const DialogParticipantStatu
|
|||||||
StringBuilder &operator<<(StringBuilder &string_builder, const DialogParticipantStatus &status);
|
StringBuilder &operator<<(StringBuilder &string_builder, const DialogParticipantStatus &status);
|
||||||
|
|
||||||
struct DialogParticipant {
|
struct DialogParticipant {
|
||||||
DialogId dialog_id;
|
DialogId dialog_id_;
|
||||||
UserId inviter_user_id;
|
UserId inviter_user_id_;
|
||||||
int32 joined_date = 0;
|
int32 joined_date_ = 0;
|
||||||
DialogParticipantStatus status = DialogParticipantStatus::Left();
|
DialogParticipantStatus status_ = DialogParticipantStatus::Left();
|
||||||
|
|
||||||
DialogParticipant() = default;
|
DialogParticipant() = default;
|
||||||
|
|
||||||
@ -417,24 +417,24 @@ struct DialogParticipant {
|
|||||||
|
|
||||||
template <class StorerT>
|
template <class StorerT>
|
||||||
void store(StorerT &storer) const {
|
void store(StorerT &storer) const {
|
||||||
td::store(dialog_id, storer);
|
td::store(dialog_id_, storer);
|
||||||
td::store(inviter_user_id, storer);
|
td::store(inviter_user_id_, storer);
|
||||||
td::store(joined_date, storer);
|
td::store(joined_date_, storer);
|
||||||
td::store(status, storer);
|
td::store(status_, storer);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class ParserT>
|
template <class ParserT>
|
||||||
void parse(ParserT &parser) {
|
void parse(ParserT &parser) {
|
||||||
if (parser.version() >= static_cast<int32>(Version::SupportBannedChannels)) {
|
if (parser.version() >= static_cast<int32>(Version::SupportBannedChannels)) {
|
||||||
td::parse(dialog_id, parser);
|
td::parse(dialog_id_, parser);
|
||||||
} else {
|
} else {
|
||||||
UserId user_id;
|
UserId user_id;
|
||||||
td::parse(user_id, parser);
|
td::parse(user_id, parser);
|
||||||
dialog_id = DialogId(user_id);
|
dialog_id_ = DialogId(user_id);
|
||||||
}
|
}
|
||||||
td::parse(inviter_user_id, parser);
|
td::parse(inviter_user_id_, parser);
|
||||||
td::parse(joined_date, parser);
|
td::parse(joined_date_, parser);
|
||||||
td::parse(status, parser);
|
td::parse(status_, parser);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -2702,9 +2702,9 @@ void GroupCallManager::finish_load_group_call_administrators(InputGroupCallId in
|
|||||||
vector<DialogId> administrator_dialog_ids;
|
vector<DialogId> administrator_dialog_ids;
|
||||||
auto participants = result.move_as_ok();
|
auto participants = result.move_as_ok();
|
||||||
for (auto &administrator : participants.participants_) {
|
for (auto &administrator : participants.participants_) {
|
||||||
if (administrator.status.can_manage_calls() &&
|
if (administrator.status_.can_manage_calls() &&
|
||||||
administrator.dialog_id != DialogId(td_->contacts_manager_->get_my_id())) {
|
administrator.dialog_id_ != DialogId(td_->contacts_manager_->get_my_id())) {
|
||||||
administrator_dialog_ids.push_back(administrator.dialog_id);
|
administrator_dialog_ids.push_back(administrator.dialog_id_);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -31796,21 +31796,21 @@ tl_object_ptr<td_api::ChatEventAction> MessagesManager::get_chat_event_action_ob
|
|||||||
case telegram_api::channelAdminLogEventActionParticipantInvite::ID: {
|
case telegram_api::channelAdminLogEventActionParticipantInvite::ID: {
|
||||||
auto action = move_tl_object_as<telegram_api::channelAdminLogEventActionParticipantInvite>(action_ptr);
|
auto action = move_tl_object_as<telegram_api::channelAdminLogEventActionParticipantInvite>(action_ptr);
|
||||||
DialogParticipant dialog_participant(std::move(action->participant_));
|
DialogParticipant dialog_participant(std::move(action->participant_));
|
||||||
if (!dialog_participant.is_valid() || dialog_participant.dialog_id.get_type() != DialogType::User) {
|
if (!dialog_participant.is_valid() || dialog_participant.dialog_id_.get_type() != DialogType::User) {
|
||||||
LOG(ERROR) << "Wrong invite: " << dialog_participant;
|
LOG(ERROR) << "Wrong invite: " << dialog_participant;
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return make_tl_object<td_api::chatEventMemberInvited>(
|
return make_tl_object<td_api::chatEventMemberInvited>(
|
||||||
td_->contacts_manager_->get_user_id_object(dialog_participant.dialog_id.get_user_id(),
|
td_->contacts_manager_->get_user_id_object(dialog_participant.dialog_id_.get_user_id(),
|
||||||
"chatEventMemberInvited"),
|
"chatEventMemberInvited"),
|
||||||
dialog_participant.status.get_chat_member_status_object());
|
dialog_participant.status_.get_chat_member_status_object());
|
||||||
}
|
}
|
||||||
case telegram_api::channelAdminLogEventActionParticipantToggleBan::ID: {
|
case telegram_api::channelAdminLogEventActionParticipantToggleBan::ID: {
|
||||||
auto action = move_tl_object_as<telegram_api::channelAdminLogEventActionParticipantToggleBan>(action_ptr);
|
auto action = move_tl_object_as<telegram_api::channelAdminLogEventActionParticipantToggleBan>(action_ptr);
|
||||||
DialogParticipant old_dialog_participant(std::move(action->prev_participant_));
|
DialogParticipant old_dialog_participant(std::move(action->prev_participant_));
|
||||||
DialogParticipant new_dialog_participant(std::move(action->new_participant_));
|
DialogParticipant new_dialog_participant(std::move(action->new_participant_));
|
||||||
if (old_dialog_participant.dialog_id != new_dialog_participant.dialog_id) {
|
if (old_dialog_participant.dialog_id_ != new_dialog_participant.dialog_id_) {
|
||||||
LOG(ERROR) << old_dialog_participant.dialog_id << " VS " << new_dialog_participant.dialog_id;
|
LOG(ERROR) << old_dialog_participant.dialog_id_ << " VS " << new_dialog_participant.dialog_id_;
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
if (!old_dialog_participant.is_valid() || !new_dialog_participant.is_valid()) {
|
if (!old_dialog_participant.is_valid() || !new_dialog_participant.is_valid()) {
|
||||||
@ -31818,28 +31818,28 @@ tl_object_ptr<td_api::ChatEventAction> MessagesManager::get_chat_event_action_ob
|
|||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return make_tl_object<td_api::chatEventMemberRestricted>(
|
return make_tl_object<td_api::chatEventMemberRestricted>(
|
||||||
get_message_sender_object(old_dialog_participant.dialog_id, "chatEventMemberRestricted"),
|
get_message_sender_object(old_dialog_participant.dialog_id_, "chatEventMemberRestricted"),
|
||||||
old_dialog_participant.status.get_chat_member_status_object(),
|
old_dialog_participant.status_.get_chat_member_status_object(),
|
||||||
new_dialog_participant.status.get_chat_member_status_object());
|
new_dialog_participant.status_.get_chat_member_status_object());
|
||||||
}
|
}
|
||||||
case telegram_api::channelAdminLogEventActionParticipantToggleAdmin::ID: {
|
case telegram_api::channelAdminLogEventActionParticipantToggleAdmin::ID: {
|
||||||
auto action = move_tl_object_as<telegram_api::channelAdminLogEventActionParticipantToggleAdmin>(action_ptr);
|
auto action = move_tl_object_as<telegram_api::channelAdminLogEventActionParticipantToggleAdmin>(action_ptr);
|
||||||
DialogParticipant old_dialog_participant(std::move(action->prev_participant_));
|
DialogParticipant old_dialog_participant(std::move(action->prev_participant_));
|
||||||
DialogParticipant new_dialog_participant(std::move(action->new_participant_));
|
DialogParticipant new_dialog_participant(std::move(action->new_participant_));
|
||||||
if (old_dialog_participant.dialog_id != new_dialog_participant.dialog_id) {
|
if (old_dialog_participant.dialog_id_ != new_dialog_participant.dialog_id_) {
|
||||||
LOG(ERROR) << old_dialog_participant.dialog_id << " VS " << new_dialog_participant.dialog_id;
|
LOG(ERROR) << old_dialog_participant.dialog_id_ << " VS " << new_dialog_participant.dialog_id_;
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
if (!old_dialog_participant.is_valid() || !new_dialog_participant.is_valid() ||
|
if (!old_dialog_participant.is_valid() || !new_dialog_participant.is_valid() ||
|
||||||
old_dialog_participant.dialog_id.get_type() != DialogType::User) {
|
old_dialog_participant.dialog_id_.get_type() != DialogType::User) {
|
||||||
LOG(ERROR) << "Wrong edit administrator: " << old_dialog_participant << " -> " << new_dialog_participant;
|
LOG(ERROR) << "Wrong edit administrator: " << old_dialog_participant << " -> " << new_dialog_participant;
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return make_tl_object<td_api::chatEventMemberPromoted>(
|
return make_tl_object<td_api::chatEventMemberPromoted>(
|
||||||
td_->contacts_manager_->get_user_id_object(old_dialog_participant.dialog_id.get_user_id(),
|
td_->contacts_manager_->get_user_id_object(old_dialog_participant.dialog_id_.get_user_id(),
|
||||||
"chatEventMemberPromoted"),
|
"chatEventMemberPromoted"),
|
||||||
old_dialog_participant.status.get_chat_member_status_object(),
|
old_dialog_participant.status_.get_chat_member_status_object(),
|
||||||
new_dialog_participant.status.get_chat_member_status_object());
|
new_dialog_participant.status_.get_chat_member_status_object());
|
||||||
}
|
}
|
||||||
case telegram_api::channelAdminLogEventActionChangeTitle::ID: {
|
case telegram_api::channelAdminLogEventActionChangeTitle::ID: {
|
||||||
auto action = move_tl_object_as<telegram_api::channelAdminLogEventActionChangeTitle>(action_ptr);
|
auto action = move_tl_object_as<telegram_api::channelAdminLogEventActionChangeTitle>(action_ptr);
|
||||||
|
@ -96,8 +96,8 @@ void PhoneNumberManager::resend_authentication_code(uint64 query_id) {
|
|||||||
start_net_query(NetQueryType::SendCode, G()->net_query_creator().create_unauth(r_resend_code.move_as_ok()));
|
start_net_query(NetQueryType::SendCode, G()->net_query_creator().create_unauth(r_resend_code.move_as_ok()));
|
||||||
}
|
}
|
||||||
|
|
||||||
void PhoneNumberManager::send_new_check_code_query(const telegram_api::Function &query) {
|
void PhoneNumberManager::send_new_check_code_query(const telegram_api::Function &check_code) {
|
||||||
start_net_query(NetQueryType::CheckCode, G()->net_query_creator().create(query));
|
start_net_query(NetQueryType::CheckCode, G()->net_query_creator().create(check_code));
|
||||||
}
|
}
|
||||||
|
|
||||||
void PhoneNumberManager::check_code(uint64 query_id, string code) {
|
void PhoneNumberManager::check_code(uint64 query_id, string code) {
|
||||||
|
@ -56,9 +56,9 @@ class PhoneNumberManager final : public NetActor {
|
|||||||
|
|
||||||
void start_net_query(NetQueryType net_query_type, NetQueryPtr net_query);
|
void start_net_query(NetQueryType net_query_type, NetQueryPtr net_query);
|
||||||
|
|
||||||
void send_new_send_code_query(uint64 query_id, const telegram_api::Function &query);
|
void send_new_send_code_query(uint64 query_id, const telegram_api::Function &send_code);
|
||||||
|
|
||||||
void send_new_check_code_query(const telegram_api::Function &query);
|
void send_new_check_code_query(const telegram_api::Function &check_code);
|
||||||
|
|
||||||
void process_check_code_result(Result<tl_object_ptr<telegram_api::User>> &&result);
|
void process_check_code_result(Result<tl_object_ptr<telegram_api::User>> &&result);
|
||||||
|
|
||||||
|
@ -135,7 +135,7 @@ class LambdaPromise : public PromiseInterface<ValueT> {
|
|||||||
, on_fail_(use_ok_as_fail ? OnFail::Ok : OnFail::Fail)
|
, on_fail_(use_ok_as_fail ? OnFail::Ok : OnFail::Fail)
|
||||||
, has_lambda_(true) {
|
, has_lambda_(true) {
|
||||||
}
|
}
|
||||||
template <class FromOkT>
|
template <class FromOkT, std::enable_if_t<!std::is_same<std::decay_t<FromOkT>, LambdaPromise>::value, int> = 0>
|
||||||
LambdaPromise(FromOkT &&ok) : LambdaPromise(std::forward<FromOkT>(ok), Ignore(), true) {
|
LambdaPromise(FromOkT &&ok) : LambdaPromise(std::forward<FromOkT>(ok), Ignore(), true) {
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -307,7 +307,7 @@ class Promise {
|
|||||||
}
|
}
|
||||||
Promise(SafePromise<T> &&other);
|
Promise(SafePromise<T> &&other);
|
||||||
Promise &operator=(SafePromise<T> &&other);
|
Promise &operator=(SafePromise<T> &&other);
|
||||||
template <class F>
|
template <class F, std::enable_if_t<!std::is_same<std::decay_t<F>, Promise>::value, int> = 0>
|
||||||
Promise(F &&f) : promise_(promise_interface_ptr<T>(std::forward<F>(f))) {
|
Promise(F &&f) : promise_(promise_interface_ptr<T>(std::forward<F>(f))) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -97,7 +97,7 @@ class LambdaEvent final : public CustomEvent {
|
|||||||
LOG(FATAL) << "Not supported";
|
LOG(FATAL) << "Not supported";
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
template <class FromLambdaT>
|
template <class FromLambdaT, std::enable_if_t<!std::is_same<std::decay_t<FromLambdaT>, LambdaEvent>::value, int> = 0>
|
||||||
explicit LambdaEvent(FromLambdaT &&lambda) : f_(std::forward<FromLambdaT>(lambda)) {
|
explicit LambdaEvent(FromLambdaT &&lambda) : f_(std::forward<FromLambdaT>(lambda)) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -31,6 +31,9 @@ class optional {
|
|||||||
}
|
}
|
||||||
|
|
||||||
optional &operator=(const optional &other) {
|
optional &operator=(const optional &other) {
|
||||||
|
if (this == &other) {
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
if (other) {
|
if (other) {
|
||||||
impl_ = Result<T>(other.value());
|
impl_ = Result<T>(other.value());
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user