Send updates when groupCall.can_enable_video changes.

This commit is contained in:
levlam 2021-07-12 20:21:34 +03:00
parent 401e5ee3fa
commit b83b3a45cb
4 changed files with 84 additions and 23 deletions

View File

@ -1667,6 +1667,7 @@ void GroupCallManager::on_update_group_call_participants(
if (!need_group_call_participants(input_group_call_id)) { if (!need_group_call_participants(input_group_call_id)) {
int32 diff = 0; int32 diff = 0;
int32 video_diff = 0;
bool need_update = false; bool need_update = false;
auto group_call = get_group_call(input_group_call_id); auto group_call = get_group_call(input_group_call_id);
for (auto &group_call_participant : participants) { for (auto &group_call_participant : participants) {
@ -1678,12 +1679,16 @@ void GroupCallManager::on_update_group_call_participants(
if (participant.joined_date == 0) { if (participant.joined_date == 0) {
if (group_call == nullptr || version > group_call->leave_version) { if (group_call == nullptr || version > group_call->leave_version) {
diff--; diff--;
video_diff += participant.video_diff;
} }
remove_recent_group_call_speaker(input_group_call_id, participant.dialog_id); remove_recent_group_call_speaker(input_group_call_id, participant.dialog_id);
} else { } else {
if (participant.is_just_joined && (group_call == nullptr || version >= group_call->leave_version)) { if (group_call == nullptr || version >= group_call->leave_version) {
if (participant.is_just_joined) {
diff++; diff++;
} }
video_diff += participant.video_diff;
}
on_participant_speaking_in_group_call(input_group_call_id, participant); on_participant_speaking_in_group_call(input_group_call_id, participant);
} }
} }
@ -1691,6 +1696,8 @@ void GroupCallManager::on_update_group_call_participants(
if (group_call != nullptr && group_call->is_inited && group_call->is_active && group_call->version == -1) { if (group_call != nullptr && group_call->is_inited && group_call->is_active && group_call->version == -1) {
need_update |= set_group_call_participant_count(group_call, group_call->participant_count + diff, need_update |= set_group_call_participant_count(group_call, group_call->participant_count + diff,
"on_update_group_call_participants"); "on_update_group_call_participants");
need_update |= set_group_call_unmuted_video_count(group_call, group_call->unmuted_video_count + video_diff,
"on_update_group_call_participants");
} }
if (need_update) { if (need_update) {
send_update_group_call(group_call, "on_update_group_call_participants"); send_update_group_call(group_call, "on_update_group_call_participants");
@ -1782,7 +1789,7 @@ bool GroupCallManager::process_pending_group_call_participant_updates(InputGroup
return false; return false;
} }
int32 diff = 0; std::pair<int32, int32> diff{0, 0};
bool is_left = false; bool is_left = false;
bool need_rejoin = true; bool need_rejoin = true;
auto &pending_version_updates = participants_it->second->pending_version_updates_; auto &pending_version_updates = participants_it->second->pending_version_updates_;
@ -1799,8 +1806,9 @@ bool GroupCallManager::process_pending_group_call_participant_updates(InputGroup
for (auto &participant_it : participants) { for (auto &participant_it : participants) {
auto &participant = participant_it.second; auto &participant = participant_it.second;
on_participant_speaking_in_group_call(input_group_call_id, participant); on_participant_speaking_in_group_call(input_group_call_id, participant);
int mute_diff = process_group_call_participant(input_group_call_id, std::move(participant)); auto mute_diff = process_group_call_participant(input_group_call_id, std::move(participant));
CHECK(mute_diff == 0); CHECK(mute_diff.first == 0);
diff.second += mute_diff.second;
} }
pending_mute_updates.erase(it); pending_mute_updates.erase(it);
} }
@ -1818,7 +1826,9 @@ bool GroupCallManager::process_pending_group_call_participant_updates(InputGroup
auto &participant = participant_it.second; auto &participant = participant_it.second;
on_participant_speaking_in_group_call(input_group_call_id, participant); on_participant_speaking_in_group_call(input_group_call_id, participant);
if (participant.is_self || participant.joined_date != 0) { if (participant.is_self || participant.joined_date != 0) {
diff += process_group_call_participant(input_group_call_id, std::move(participant)); auto new_diff = process_group_call_participant(input_group_call_id, std::move(participant));
diff.first += new_diff.first;
diff.second += new_diff.second;
} }
} }
LOG(INFO) << "Ignore already applied updateGroupCallParticipants with version " << version << " in " LOG(INFO) << "Ignore already applied updateGroupCallParticipants with version " << version << " in "
@ -1840,7 +1850,9 @@ bool GroupCallManager::process_pending_group_call_participant_updates(InputGroup
continue; continue;
} }
} }
diff += process_group_call_participant(input_group_call_id, std::move(participant)); auto new_diff = process_group_call_participant(input_group_call_id, std::move(participant));
diff.first += new_diff.first;
diff.second += new_diff.second;
} }
pending_version_updates.erase(it); pending_version_updates.erase(it);
} else { } else {
@ -1864,7 +1876,9 @@ bool GroupCallManager::process_pending_group_call_participant_updates(InputGroup
sync_participants_timeout_.cancel_timeout(group_call->group_call_id.get()); sync_participants_timeout_.cancel_timeout(group_call->group_call_id.get());
} }
need_update |= set_group_call_participant_count(group_call, group_call->participant_count + diff, need_update |= set_group_call_participant_count(group_call, group_call->participant_count + diff.first,
"process_pending_group_call_participant_updates");
need_update |= set_group_call_unmuted_video_count(group_call, group_call->unmuted_video_count + diff.second,
"process_pending_group_call_participant_updates"); "process_pending_group_call_participant_updates");
if (is_left && group_call->is_joined) { if (is_left && group_call->is_joined) {
on_group_call_left_impl(group_call, need_rejoin, "process_pending_group_call_participant_updates"); on_group_call_left_impl(group_call, need_rejoin, "process_pending_group_call_participant_updates");
@ -2140,14 +2154,14 @@ void GroupCallManager::process_my_group_call_participant(InputGroupCallId input_
} }
} }
int GroupCallManager::process_group_call_participant(InputGroupCallId input_group_call_id, std::pair<int32, int32> GroupCallManager::process_group_call_participant(InputGroupCallId input_group_call_id,
GroupCallParticipant &&participant) { GroupCallParticipant &&participant) {
if (!participant.is_valid()) { if (!participant.is_valid()) {
LOG(ERROR) << "Receive invalid " << participant; LOG(ERROR) << "Receive invalid " << participant;
return 0; return {0, 0};
} }
if (!need_group_call_participants(input_group_call_id)) { if (!need_group_call_participants(input_group_call_id)) {
return 0; return {0, 0};
} }
LOG(INFO) << "Process " << participant << " in " << input_group_call_id; LOG(INFO) << "Process " << participant << " in " << input_group_call_id;
@ -2176,13 +2190,14 @@ int GroupCallManager::process_group_call_participant(InputGroupCallId input_grou
} }
on_remove_group_call_participant(input_group_call_id, old_participant.dialog_id); on_remove_group_call_participant(input_group_call_id, old_participant.dialog_id);
remove_recent_group_call_speaker(input_group_call_id, old_participant.dialog_id); remove_recent_group_call_speaker(input_group_call_id, old_participant.dialog_id);
int32 unmuted_video_diff = old_participant.video_payload.is_empty() ? 0 : -1;
participants->participants.erase(participants->participants.begin() + i); participants->participants.erase(participants->participants.begin() + i);
return -1; return {-1, unmuted_video_diff};
} }
if (old_participant.version > participant.version) { if (old_participant.version > participant.version) {
LOG(INFO) << "Ignore outdated update of " << old_participant.dialog_id; LOG(INFO) << "Ignore outdated update of " << old_participant.dialog_id;
return 0; return {0, 0};
} }
if (old_participant.dialog_id != participant.dialog_id) { if (old_participant.dialog_id != participant.dialog_id) {
@ -2201,15 +2216,17 @@ int GroupCallManager::process_group_call_participant(InputGroupCallId input_grou
send_update_group_call_participant(input_group_call_id, participant, "process_group_call_participant edit"); send_update_group_call_participant(input_group_call_id, participant, "process_group_call_participant edit");
} }
on_participant_speaking_in_group_call(input_group_call_id, participant); on_participant_speaking_in_group_call(input_group_call_id, participant);
int32 unmuted_video_diff = static_cast<int32>(participant.video_payload.is_empty()) -
static_cast<int32>(old_participant.video_payload.is_empty());
old_participant = std::move(participant); old_participant = std::move(participant);
return 0; return {0, unmuted_video_diff};
} }
} }
if (participant.joined_date == 0) { if (participant.joined_date == 0) {
LOG(INFO) << "Remove unknown " << participant; LOG(INFO) << "Remove unknown " << participant;
remove_recent_group_call_speaker(input_group_call_id, participant.dialog_id); remove_recent_group_call_speaker(input_group_call_id, participant.dialog_id);
return -1; return {-1, participant.video_diff};
} }
CHECK(!participant.is_min); CHECK(!participant.is_min);
@ -2236,7 +2253,7 @@ int GroupCallManager::process_group_call_participant(InputGroupCallId input_grou
} }
on_add_group_call_participant(input_group_call_id, participants->participants.back().dialog_id); on_add_group_call_participant(input_group_call_id, participants->participants.back().dialog_id);
on_participant_speaking_in_group_call(input_group_call_id, participants->participants.back()); on_participant_speaking_in_group_call(input_group_call_id, participants->participants.back());
return diff; return {diff, participant.video_diff};
} }
void GroupCallManager::on_add_group_call_participant(InputGroupCallId input_group_call_id, void GroupCallManager::on_add_group_call_participant(InputGroupCallId input_group_call_id,
@ -2505,12 +2522,18 @@ void GroupCallManager::join_group_call(GroupCallId group_call_id, DialogId as_di
participant.server_is_muted_by_admin = !group_call->can_self_unmute && !can_manage_group_call(input_group_call_id); participant.server_is_muted_by_admin = !group_call->can_self_unmute && !can_manage_group_call(input_group_call_id);
participant.server_is_muted_by_themselves = is_muted && !participant.server_is_muted_by_admin; participant.server_is_muted_by_themselves = is_muted && !participant.server_is_muted_by_admin;
participant.is_just_joined = !is_rejoin; participant.is_just_joined = !is_rejoin;
participant.video_diff = get_group_call_can_enable_video(group_call) && is_my_video_enabled;
participant.is_fake = true; participant.is_fake = true;
int diff = process_group_call_participant(input_group_call_id, std::move(participant)); auto diff = process_group_call_participant(input_group_call_id, std::move(participant));
if (diff != 0) { if (diff.first != 0) {
CHECK(diff == 1); CHECK(diff.first == 1);
need_update |= need_update |= set_group_call_participant_count(group_call, group_call->participant_count + diff.first,
set_group_call_participant_count(group_call, group_call->participant_count + diff, "join_group_call", true); "join_group_call", true);
}
if (diff.second != 0) {
CHECK(diff.second == 1);
need_update |= set_group_call_unmuted_video_count(group_call, group_call->unmuted_video_count + diff.second,
"join_group_call");
} }
} }
if (group_call->is_my_video_enabled != is_my_video_enabled) { if (group_call->is_my_video_enabled != is_my_video_enabled) {
@ -4043,6 +4066,10 @@ bool GroupCallManager::try_clear_group_call_participants(InputGroupCallId input_
if (participant.is_self) { if (participant.is_self) {
need_update |= set_group_call_participant_count(group_call, group_call->participant_count - 1, need_update |= set_group_call_participant_count(group_call, group_call->participant_count - 1,
"try_clear_group_call_participants"); "try_clear_group_call_participants");
if (!participant.video_payload.is_empty()) {
need_update |= set_group_call_unmuted_video_count(group_call, group_call->unmuted_video_count - 1,
"try_clear_group_call_participants");
}
} }
} }
on_remove_group_call_participant(input_group_call_id, participant.dialog_id); on_remove_group_call_participant(input_group_call_id, participant.dialog_id);
@ -4528,6 +4555,27 @@ bool GroupCallManager::set_group_call_participant_count(GroupCall *group_call, i
return true; return true;
} }
bool GroupCallManager::set_group_call_unmuted_video_count(GroupCall *group_call, int32 count, const char *source) {
CHECK(group_call != nullptr);
CHECK(group_call->is_inited);
if (count < 0) {
LOG(ERROR) << "Video participant count became negative in " << group_call->group_call_id << " in "
<< group_call->dialog_id << " from " << source;
count = 0;
}
if (group_call->unmuted_video_count == count) {
return false;
}
LOG(DEBUG) << "Set " << group_call->group_call_id << " video participant count to " << count << " from " << source;
auto old_can_enable_video = get_group_call_can_enable_video(group_call);
group_call->unmuted_video_count = count;
return old_can_enable_video != get_group_call_can_enable_video(group_call);
}
void GroupCallManager::update_group_call_dialog(const GroupCall *group_call, const char *source, bool force) { void GroupCallManager::update_group_call_dialog(const GroupCall *group_call, const char *source, bool force) {
CHECK(group_call != nullptr); CHECK(group_call != nullptr);
if (!group_call->dialog_id.is_valid()) { if (!group_call->dialog_id.is_valid()) {

View File

@ -24,6 +24,7 @@
#include "td/utils/Status.h" #include "td/utils/Status.h"
#include <unordered_map> #include <unordered_map>
#include <utility>
namespace td { namespace td {
@ -246,7 +247,9 @@ class GroupCallManager final : public Actor {
void update_group_call_participants_order(InputGroupCallId input_group_call_id, bool can_self_unmute, void update_group_call_participants_order(InputGroupCallId input_group_call_id, bool can_self_unmute,
GroupCallParticipants *participants, const char *source); GroupCallParticipants *participants, const char *source);
int process_group_call_participant(InputGroupCallId group_call_id, GroupCallParticipant &&participant); // returns participant_count_diff and video_participant_count_diff
std::pair<int32, int32> process_group_call_participant(InputGroupCallId group_call_id,
GroupCallParticipant &&participant);
void on_add_group_call_participant(InputGroupCallId input_group_call_id, DialogId participant_dialog_id); void on_add_group_call_participant(InputGroupCallId input_group_call_id, DialogId participant_dialog_id);
@ -343,6 +346,8 @@ class GroupCallManager final : public Actor {
bool set_group_call_participant_count(GroupCall *group_call, int32 count, const char *source, bool set_group_call_participant_count(GroupCall *group_call, int32 count, const char *source,
bool force_update = false); bool force_update = false);
bool set_group_call_unmuted_video_count(GroupCall *group_call, int32 count, const char *source);
void update_group_call_dialog(const GroupCall *group_call, const char *source, bool force); void update_group_call_dialog(const GroupCall *group_call, const char *source, bool force);
vector<td_api::object_ptr<td_api::groupCallRecentSpeaker>> get_recent_speakers(const GroupCall *group_call, vector<td_api::object_ptr<td_api::groupCallRecentSpeaker>> get_recent_speakers(const GroupCall *group_call,

View File

@ -65,6 +65,13 @@ GroupCallParticipant::GroupCallParticipant(const tl_object_ptr<telegram_api::gro
} }
presentation_payload = GroupCallVideoPayload(participant->presentation_.get()); presentation_payload = GroupCallVideoPayload(participant->presentation_.get());
} }
if (is_just_joined && !video_payload.is_empty()) {
video_diff++;
}
if (joined_date == 0) {
video_diff--;
}
} }
bool GroupCallParticipant::is_versioned_update(const tl_object_ptr<telegram_api::groupCallParticipant> &participant) { bool GroupCallParticipant::is_versioned_update(const tl_object_ptr<telegram_api::groupCallParticipant> &participant) {

View File

@ -45,6 +45,7 @@ struct GroupCallParticipant {
bool is_fake = false; bool is_fake = false;
bool is_just_joined = false; bool is_just_joined = false;
bool is_speaking = false; bool is_speaking = false;
int32 video_diff = 0;
int32 local_active_date = 0; int32 local_active_date = 0;
GroupCallParticipantOrder order; GroupCallParticipantOrder order;
int32 version = 0; int32 version = 0;