tdesktop/Telegram/SourceFiles/data/data_group_call.h

156 lines
4.2 KiB
C
Raw Normal View History

2020-11-20 19:25:35 +00:00
/*
This file is part of Telegram Desktop,
the official desktop application for the Telegram messaging service.
For license and copyright information please follow this link:
https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
*/
#pragma once
#include "base/timer.h"
class PeerData;
2020-11-20 19:25:35 +00:00
2020-11-29 15:18:51 +00:00
class ApiWrap;
2020-11-20 19:25:35 +00:00
namespace Data {
struct LastSpokeTimes {
crl::time anything = 0;
crl::time voice = 0;
};
2021-03-08 07:57:00 +00:00
struct GroupCallParticipant {
not_null<PeerData*> peer;
TimeId date = 0;
TimeId lastActive = 0;
uint64 raisedHandRating = 0;
2021-03-08 07:57:00 +00:00
uint32 ssrc = 0;
int volume = 0;
bool applyVolumeFromMin = true;
bool sounding = false;
bool speaking = false;
bool muted = false;
bool mutedByMe = false;
bool canSelfUnmute = false;
bool onlyMinLoaded = false;
};
2020-11-20 19:25:35 +00:00
class GroupCall final {
public:
GroupCall(not_null<PeerData*> peer, uint64 id, uint64 accessHash);
2020-11-24 11:56:46 +00:00
~GroupCall();
2020-11-20 19:25:35 +00:00
[[nodiscard]] uint64 id() const;
[[nodiscard]] not_null<PeerData*> peer() const;
2020-11-20 19:25:35 +00:00
[[nodiscard]] MTPInputGroupCall input() const;
2021-03-05 16:59:35 +00:00
[[nodiscard]] QString title() const {
return _title.current();
}
[[nodiscard]] rpl::producer<QString> titleValue() const {
return _title.value();
}
void setTitle(const QString &title) {
_title = title;
}
2021-03-09 09:27:17 +00:00
[[nodiscard]] TimeId recordStartDate() const {
2021-03-09 13:24:32 +00:00
return _recordStartDate.current();
}
[[nodiscard]] rpl::producer<TimeId> recordStartDateValue() const {
return _recordStartDate.value();
}
[[nodiscard]] rpl::producer<TimeId> recordStartDateChanges() const {
return _recordStartDate.changes();
2021-03-09 09:27:17 +00:00
}
2020-11-20 19:25:35 +00:00
void setPeer(not_null<PeerData*> peer);
2021-03-08 07:57:00 +00:00
using Participant = GroupCallParticipant;
struct ParticipantUpdate {
std::optional<Participant> was;
std::optional<Participant> now;
};
2020-11-20 19:25:35 +00:00
static constexpr auto kSoundStatusKeptFor = crl::time(350);
2020-11-20 19:25:35 +00:00
[[nodiscard]] auto participants() const
-> const std::vector<Participant> &;
void requestParticipants();
[[nodiscard]] bool participantsLoaded() const;
2021-03-08 07:57:00 +00:00
[[nodiscard]] PeerData *participantPeerBySsrc(uint32 ssrc) const;
2020-11-20 19:25:35 +00:00
[[nodiscard]] rpl::producer<> participantsSliceAdded();
[[nodiscard]] rpl::producer<ParticipantUpdate> participantUpdated() const;
2020-11-24 11:56:46 +00:00
void applyUpdate(const MTPGroupCall &update);
void applyUpdate(const MTPDupdateGroupCallParticipants &update);
void applyUpdateChecked(
const MTPDupdateGroupCallParticipants &update);
void applyLastSpoke(uint32 ssrc, LastSpokeTimes when, crl::time now);
void applyActiveUpdate(
2021-03-03 15:29:33 +00:00
PeerId participantPeerId,
LastSpokeTimes when,
2021-03-03 15:29:33 +00:00
PeerData *participantPeerLoaded);
2020-11-24 11:56:46 +00:00
2021-03-08 07:57:00 +00:00
void resolveParticipants(const base::flat_set<uint32> &ssrcs);
2020-11-20 19:25:35 +00:00
[[nodiscard]] int fullCount() const;
[[nodiscard]] rpl::producer<int> fullCountValue() const;
2020-11-20 19:25:35 +00:00
void setInCall();
2020-11-24 11:56:46 +00:00
void reload();
void processFullCall(const MTPphone_GroupCall &call);
2020-11-24 11:56:46 +00:00
2020-11-28 16:18:51 +00:00
void setJoinMutedLocally(bool muted);
[[nodiscard]] bool joinMuted() const;
[[nodiscard]] bool canChangeJoinMuted() const;
2020-11-20 19:25:35 +00:00
private:
2020-11-29 15:18:51 +00:00
enum class ApplySliceSource {
SliceLoaded,
UnknownLoaded,
UpdateReceived,
};
[[nodiscard]] ApiWrap &api() const;
[[nodiscard]] bool inCall() const;
2020-11-24 11:56:46 +00:00
void applyCall(const MTPGroupCall &call, bool force);
void applyParticipantsSlice(
const QVector<MTPGroupCallParticipant> &list,
2020-11-29 15:18:51 +00:00
ApplySliceSource sliceSource);
void requestUnknownParticipants();
void changePeerEmptyCallFlag();
void checkFinishSpeakingByActive();
2020-11-24 11:56:46 +00:00
2020-11-20 19:25:35 +00:00
const uint64 _id = 0;
const uint64 _accessHash = 0;
not_null<PeerData*> _peer;
2020-11-20 19:25:35 +00:00
int _version = 0;
mtpRequestId _participantsRequestId = 0;
2020-11-24 11:56:46 +00:00
mtpRequestId _reloadRequestId = 0;
2021-03-05 16:59:35 +00:00
rpl::variable<QString> _title;
2020-11-20 19:25:35 +00:00
std::vector<Participant> _participants;
2021-03-03 15:29:33 +00:00
base::flat_map<uint32, not_null<PeerData*>> _participantPeerBySsrc;
base::flat_map<not_null<PeerData*>, crl::time> _speakingByActiveFinishes;
base::Timer _speakingByActiveFinishTimer;
2020-11-26 11:04:00 +00:00
QString _nextOffset;
rpl::variable<int> _fullCount = 0;
2021-03-09 13:24:32 +00:00
rpl::variable<TimeId> _recordStartDate = 0;
base::flat_map<uint32, LastSpokeTimes> _unknownSpokenSsrcs;
2021-03-03 15:29:33 +00:00
base::flat_map<PeerId, LastSpokeTimes> _unknownSpokenPeerIds;
mtpRequestId _unknownParticipantPeersRequestId = 0;
2020-11-29 15:18:51 +00:00
rpl::event_stream<ParticipantUpdate> _participantUpdates;
rpl::event_stream<> _participantsSliceAdded;
2020-11-28 16:18:51 +00:00
bool _joinMuted = false;
bool _canChangeJoinMuted = true;
2020-11-20 19:25:35 +00:00
bool _allReceived = false;
};
} // namespace Data