Don't rejoin voice chats in left basic groups.
This commit is contained in:
parent
aa2f645d74
commit
f9ef4c0c36
@ -2140,9 +2140,13 @@ void GroupCallManager::on_group_call_left_impl(GroupCall *group_call, bool need_
|
|||||||
CHECK(group_call != nullptr && group_call->is_inited && group_call->is_joined);
|
CHECK(group_call != nullptr && group_call->is_inited && group_call->is_joined);
|
||||||
group_call->is_joined = false;
|
group_call->is_joined = false;
|
||||||
group_call->need_rejoin = need_rejoin && !group_call->is_being_left;
|
group_call->need_rejoin = need_rejoin && !group_call->is_being_left;
|
||||||
if (group_call->need_rejoin && group_call->dialog_id.is_valid() &&
|
if (group_call->need_rejoin && group_call->dialog_id.is_valid()) {
|
||||||
!td_->messages_manager_->have_input_peer(group_call->dialog_id, AccessRights::Read)) {
|
auto dialog_id = group_call->dialog_id;
|
||||||
group_call->need_rejoin = false;
|
if (!td_->messages_manager_->have_input_peer(dialog_id, AccessRights::Read) ||
|
||||||
|
(dialog_id.get_type() == DialogType::Chat &&
|
||||||
|
!td_->contacts_manager_->get_chat_status(dialog_id.get_chat_id()).is_member())) {
|
||||||
|
group_call->need_rejoin = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
group_call->is_being_left = false;
|
group_call->is_being_left = false;
|
||||||
group_call->is_speaking = false;
|
group_call->is_speaking = false;
|
||||||
|
Loading…
Reference in New Issue
Block a user