mirror of
https://github.com/nextcloud/talk-android
synced 2025-01-18 21:18:15 +00:00
Set "hasMCU" once its value is known
"hasMCU" (which has always been the wrong name, because it is an SFU rather than an MCU, but it is wrong even in the signaling server so for now the legacy name is kept) was set again and again whenever the call participant list changed. Now it is set instead once its value is known, that is, when it is known that the internal signaling server is used (as no "MCU" is used in that case), or when the connection with the external signaling server is established, as its supported features are not known until then. This change should have no effect in the usages of "hasMCU", as it is used when the call participant list change, which will happen only after joining the call in the signaling server, or when sending "isSpeaking" and toggling media, in both cases guarded by "isConnectionEstablished", which will be true only once "performCall" was called or if the call is active with other participants. Signed-off-by: Daniel Calviño Sánchez <danxuliu@gmail.com>
This commit is contained in:
parent
d0d1597577
commit
8fa3224879
@ -1618,6 +1618,9 @@ class CallActivity : CallBaseActivity() {
|
|||||||
signalingMessageReceiver!!.addListener(localParticipantMessageListener)
|
signalingMessageReceiver!!.addListener(localParticipantMessageListener)
|
||||||
signalingMessageReceiver!!.addListener(offerMessageListener)
|
signalingMessageReceiver!!.addListener(offerMessageListener)
|
||||||
signalingMessageSender = internalSignalingMessageSender
|
signalingMessageSender = internalSignalingMessageSender
|
||||||
|
|
||||||
|
hasMCU = false
|
||||||
|
|
||||||
joinRoomAndCall()
|
joinRoomAndCall()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1903,6 +1906,11 @@ class CallActivity : CallBaseActivity() {
|
|||||||
signalingMessageReceiver!!.addListener(localParticipantMessageListener)
|
signalingMessageReceiver!!.addListener(localParticipantMessageListener)
|
||||||
signalingMessageReceiver!!.addListener(offerMessageListener)
|
signalingMessageReceiver!!.addListener(offerMessageListener)
|
||||||
signalingMessageSender = webSocketClient!!.signalingMessageSender
|
signalingMessageSender = webSocketClient!!.signalingMessageSender
|
||||||
|
|
||||||
|
// If the connection with the signaling server was not established yet the value will be false, but it will
|
||||||
|
// be overwritten with the right value once the response to the "hello" message is received.
|
||||||
|
hasMCU = webSocketClient!!.hasMCU()
|
||||||
|
Log.d(TAG, "hasMCU is $hasMCU")
|
||||||
} else {
|
} else {
|
||||||
if (webSocketClient!!.isConnected && currentCallStatus === CallStatus.PUBLISHER_FAILED) {
|
if (webSocketClient!!.isConnected && currentCallStatus === CallStatus.PUBLISHER_FAILED) {
|
||||||
webSocketClient!!.restartWebSocket()
|
webSocketClient!!.restartWebSocket()
|
||||||
@ -1928,6 +1936,10 @@ class CallActivity : CallBaseActivity() {
|
|||||||
when (webSocketCommunicationEvent.getType()) {
|
when (webSocketCommunicationEvent.getType()) {
|
||||||
"hello" -> {
|
"hello" -> {
|
||||||
Log.d(TAG, "onMessageEvent 'hello'")
|
Log.d(TAG, "onMessageEvent 'hello'")
|
||||||
|
|
||||||
|
hasMCU = webSocketClient!!.hasMCU()
|
||||||
|
Log.d(TAG, "hasMCU is $hasMCU")
|
||||||
|
|
||||||
if (!webSocketCommunicationEvent.getHashMap()!!.containsKey("oldResumeId")) {
|
if (!webSocketCommunicationEvent.getHashMap()!!.containsKey("oldResumeId")) {
|
||||||
if (currentCallStatus === CallStatus.RECONNECTING) {
|
if (currentCallStatus === CallStatus.RECONNECTING) {
|
||||||
hangup(false, false)
|
hangup(false, false)
|
||||||
@ -2136,8 +2148,6 @@ class CallActivity : CallBaseActivity() {
|
|||||||
unchanged: Collection<Participant>
|
unchanged: Collection<Participant>
|
||||||
) {
|
) {
|
||||||
Log.d(TAG, "handleCallParticipantsChanged")
|
Log.d(TAG, "handleCallParticipantsChanged")
|
||||||
hasMCU = hasExternalSignalingServer && webSocketClient != null && webSocketClient!!.hasMCU()
|
|
||||||
Log.d(TAG, " hasMCU is $hasMCU")
|
|
||||||
|
|
||||||
// The signaling session is the same as the Nextcloud session only when the MCU is not used.
|
// The signaling session is the same as the Nextcloud session only when the MCU is not used.
|
||||||
var currentSessionId = callSession
|
var currentSessionId = callSession
|
||||||
|
Loading…
Reference in New Issue
Block a user