(1.3.4) Fix voice chat issue in EaglerXBungee
This commit is contained in:
parent
1e235f93bf
commit
28b7627a0f
Binary file not shown.
|
@ -64,8 +64,8 @@ import net.md_5.bungee.BungeeCord;
|
||||||
*/
|
*/
|
||||||
public class EaglerXBungee extends Plugin {
|
public class EaglerXBungee extends Plugin {
|
||||||
|
|
||||||
public static final String NATIVE_BUNGEECORD_BUILD = "1.21-R0.1-SNAPSHOT:4886c4b:1881";
|
public static final String NATIVE_BUNGEECORD_BUILD = "1.21-R0.1-SNAPSHOT:20a71b0:1887";
|
||||||
public static final String NATIVE_WATERFALL_BUILD = "1.21-R0.1-SNAPSHOT:de8345a:579";
|
public static final String NATIVE_WATERFALL_BUILD = "1.21-R0.1-SNAPSHOT:bf1be7e:581";
|
||||||
|
|
||||||
static {
|
static {
|
||||||
CompatWarning.displayCompatWarning();
|
CompatWarning.displayCompatWarning();
|
||||||
|
|
|
@ -5,6 +5,7 @@ import java.util.Collection;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
@ -98,8 +99,11 @@ public class VoiceServerImpl {
|
||||||
}
|
}
|
||||||
|
|
||||||
void handleVoiceSignalPacketTypeRequest(UUID player, UserConnection sender) {
|
void handleVoiceSignalPacketTypeRequest(UUID player, UserConnection sender) {
|
||||||
|
UUID senderUUID;
|
||||||
|
EaglerInitialHandler targetInitialHandler;
|
||||||
|
EaglerInitialHandler senderInitialHandler;
|
||||||
synchronized (voicePlayers) {
|
synchronized (voicePlayers) {
|
||||||
UUID senderUUID = sender.getUniqueId();
|
senderUUID = sender.getUniqueId();
|
||||||
if (senderUUID.equals(player))
|
if (senderUUID.equals(player))
|
||||||
return; // prevent duplicates
|
return; // prevent duplicates
|
||||||
if (!voicePlayers.containsKey(senderUUID))
|
if (!voicePlayers.containsKey(senderUUID))
|
||||||
|
@ -129,8 +133,12 @@ public class VoiceServerImpl {
|
||||||
voiceRequests.remove(senderUUID);
|
voiceRequests.remove(senderUUID);
|
||||||
// send each other add data
|
// send each other add data
|
||||||
voicePairs.add(newPair);
|
voicePairs.add(newPair);
|
||||||
EaglerInitialHandler targetInitialHandler = (EaglerInitialHandler) targetPlayerCon
|
targetInitialHandler = (EaglerInitialHandler) targetPlayerCon.getPendingConnection();
|
||||||
.getPendingConnection();
|
senderInitialHandler = (EaglerInitialHandler) sender.getPendingConnection();
|
||||||
|
}else {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
if (targetInitialHandler.getEaglerProtocol().ver <= 3) {
|
if (targetInitialHandler.getEaglerProtocol().ver <= 3) {
|
||||||
targetInitialHandler.sendEaglerMessage(new SPacketVoiceSignalConnectV3EAG(
|
targetInitialHandler.sendEaglerMessage(new SPacketVoiceSignalConnectV3EAG(
|
||||||
senderUUID.getMostSignificantBits(), senderUUID.getLeastSignificantBits(), false, false));
|
senderUUID.getMostSignificantBits(), senderUUID.getLeastSignificantBits(), false, false));
|
||||||
|
@ -138,7 +146,6 @@ public class VoiceServerImpl {
|
||||||
targetInitialHandler.sendEaglerMessage(new SPacketVoiceSignalConnectV4EAG(
|
targetInitialHandler.sendEaglerMessage(new SPacketVoiceSignalConnectV4EAG(
|
||||||
senderUUID.getMostSignificantBits(), senderUUID.getLeastSignificantBits(), false));
|
senderUUID.getMostSignificantBits(), senderUUID.getLeastSignificantBits(), false));
|
||||||
}
|
}
|
||||||
EaglerInitialHandler senderInitialHandler = (EaglerInitialHandler) sender.getPendingConnection();
|
|
||||||
if (senderInitialHandler.getEaglerProtocol().ver <= 3) {
|
if (senderInitialHandler.getEaglerProtocol().ver <= 3) {
|
||||||
senderInitialHandler.sendEaglerMessage(new SPacketVoiceSignalConnectV3EAG(
|
senderInitialHandler.sendEaglerMessage(new SPacketVoiceSignalConnectV3EAG(
|
||||||
player.getMostSignificantBits(), player.getLeastSignificantBits(), false, true));
|
player.getMostSignificantBits(), player.getLeastSignificantBits(), false, true));
|
||||||
|
@ -147,8 +154,6 @@ public class VoiceServerImpl {
|
||||||
player.getMostSignificantBits(), player.getLeastSignificantBits(), true));
|
player.getMostSignificantBits(), player.getLeastSignificantBits(), true));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void handleVoiceSignalPacketTypeConnect(UserConnection sender) {
|
void handleVoiceSignalPacketTypeConnect(UserConnection sender) {
|
||||||
EaglerInitialHandler eaglerHandler = (EaglerInitialHandler)sender.getPendingConnection();
|
EaglerInitialHandler eaglerHandler = (EaglerInitialHandler)sender.getPendingConnection();
|
||||||
|
@ -159,27 +164,48 @@ public class VoiceServerImpl {
|
||||||
if(eaglerHandler.getRPCEventSubscribed(EnumSubscribedEvent.TOGGLE_VOICE)) {
|
if(eaglerHandler.getRPCEventSubscribed(EnumSubscribedEvent.TOGGLE_VOICE)) {
|
||||||
eaglerHandler.getRPCSessionHandler().handleVoiceStateTransition(SPacketRPCEventToggledVoice.VOICE_STATE_ENABLED);
|
eaglerHandler.getRPCSessionHandler().handleVoiceStateTransition(SPacketRPCEventToggledVoice.VOICE_STATE_ENABLED);
|
||||||
}
|
}
|
||||||
|
UUID senderUuid = eaglerHandler.getUniqueId();
|
||||||
|
List<UserConnection> lst;
|
||||||
synchronized (voicePlayers) {
|
synchronized (voicePlayers) {
|
||||||
if (voicePlayers.containsKey(eaglerHandler.getUniqueId())) {
|
if (voicePlayers.containsKey(senderUuid)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
boolean hasNoOtherPlayers = voicePlayers.isEmpty();
|
boolean hasNoOtherPlayers = voicePlayers.isEmpty();
|
||||||
voicePlayers.put(eaglerHandler.getUniqueId(), sender);
|
voicePlayers.put(senderUuid, sender);
|
||||||
if (hasNoOtherPlayers) {
|
if (hasNoOtherPlayers) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Collection<SPacketVoiceSignalGlobalEAG.UserData> userDatas = new ArrayList<>(voicePlayers.size());
|
lst = new ArrayList<>(voicePlayers.values());
|
||||||
for(UserConnection userCon : voicePlayers.values()) {
|
}
|
||||||
|
GameMessagePacket v3p = null;
|
||||||
|
GameMessagePacket v4p = null;
|
||||||
|
for (UserConnection conn : lst) {
|
||||||
|
EaglerInitialHandler handler = (EaglerInitialHandler) conn.getPendingConnection();
|
||||||
|
if (handler.getEaglerProtocol().ver <= 3) {
|
||||||
|
handler.sendEaglerMessage(
|
||||||
|
v3p == null
|
||||||
|
? (v3p = new SPacketVoiceSignalConnectV3EAG(senderUuid.getMostSignificantBits(),
|
||||||
|
senderUuid.getLeastSignificantBits(), true, false))
|
||||||
|
: v3p);
|
||||||
|
} else {
|
||||||
|
handler.sendEaglerMessage(
|
||||||
|
v4p == null
|
||||||
|
? (v4p = new SPacketVoiceSignalConnectAnnounceV4EAG(senderUuid.getMostSignificantBits(),
|
||||||
|
senderUuid.getLeastSignificantBits()))
|
||||||
|
: v4p);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Collection<SPacketVoiceSignalGlobalEAG.UserData> userDatas = new ArrayList<>(lst.size());
|
||||||
|
for(UserConnection userCon : lst) {
|
||||||
UUID uuid = userCon.getUniqueId();
|
UUID uuid = userCon.getUniqueId();
|
||||||
userDatas.add(new SPacketVoiceSignalGlobalEAG.UserData(uuid.getMostSignificantBits(),
|
userDatas.add(new SPacketVoiceSignalGlobalEAG.UserData(uuid.getMostSignificantBits(),
|
||||||
uuid.getLeastSignificantBits(), userCon.getDisplayName()));
|
uuid.getLeastSignificantBits(), userCon.getDisplayName()));
|
||||||
}
|
}
|
||||||
GameMessagePacket packetToBroadcast = new SPacketVoiceSignalGlobalEAG(userDatas);
|
GameMessagePacket packetToBroadcast = new SPacketVoiceSignalGlobalEAG(userDatas);
|
||||||
for (UserConnection userCon : voicePlayers.values()) {
|
for (UserConnection userCon : lst) {
|
||||||
((EaglerInitialHandler)userCon.getPendingConnection()).sendEaglerMessage(packetToBroadcast);
|
((EaglerInitialHandler)userCon.getPendingConnection()).sendEaglerMessage(packetToBroadcast);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void handleVoiceSignalPacketTypeICE(UUID player, byte[] str, UserConnection sender) {
|
void handleVoiceSignalPacketTypeICE(UUID player, byte[] str, UserConnection sender) {
|
||||||
UserConnection pass;
|
UserConnection pass;
|
||||||
|
@ -212,6 +238,7 @@ public class VoiceServerImpl {
|
||||||
}
|
}
|
||||||
|
|
||||||
void handleVoiceSignalPacketTypeDisconnectPeer(UUID player, UserConnection sender) {
|
void handleVoiceSignalPacketTypeDisconnectPeer(UUID player, UserConnection sender) {
|
||||||
|
List<Runnable> peersToDisconnect = new ArrayList<>();
|
||||||
synchronized (voicePlayers) {
|
synchronized (voicePlayers) {
|
||||||
if (!voicePlayers.containsKey(player)) {
|
if (!voicePlayers.containsKey(player)) {
|
||||||
return;
|
return;
|
||||||
|
@ -227,31 +254,42 @@ public class VoiceServerImpl {
|
||||||
}
|
}
|
||||||
if (target != null) {
|
if (target != null) {
|
||||||
pairsItr.remove();
|
pairsItr.remove();
|
||||||
UserConnection conn = voicePlayers.get(target);
|
final UserConnection conn = voicePlayers.get(target);
|
||||||
|
final UUID target2 = target;
|
||||||
|
peersToDisconnect.add(() -> {
|
||||||
if (conn != null) {
|
if (conn != null) {
|
||||||
((EaglerInitialHandler) conn.getPendingConnection()).sendEaglerMessage(
|
((EaglerInitialHandler) conn.getPendingConnection()).sendEaglerMessage(
|
||||||
new SPacketVoiceSignalDisconnectPeerEAG(player.getMostSignificantBits(),
|
new SPacketVoiceSignalDisconnectPeerEAG(player.getMostSignificantBits(),
|
||||||
player.getLeastSignificantBits()));
|
player.getLeastSignificantBits()));
|
||||||
}
|
}
|
||||||
((EaglerInitialHandler) sender.getPendingConnection())
|
((EaglerInitialHandler) sender.getPendingConnection())
|
||||||
.sendEaglerMessage(new SPacketVoiceSignalDisconnectPeerEAG(target.getMostSignificantBits(),
|
.sendEaglerMessage(new SPacketVoiceSignalDisconnectPeerEAG(target2.getMostSignificantBits(),
|
||||||
target.getLeastSignificantBits()));
|
target2.getLeastSignificantBits()));
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
for(Runnable r : peersToDisconnect) {
|
||||||
|
r.run();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void removeUser(UUID user) {
|
void removeUser(final UUID user) {
|
||||||
|
List<Runnable> peersToDisconnect;
|
||||||
synchronized (voicePlayers) {
|
synchronized (voicePlayers) {
|
||||||
UserConnection connRemove;
|
final UserConnection connRemove;
|
||||||
if ((connRemove = voicePlayers.remove(user)) == null) {
|
if ((connRemove = voicePlayers.remove(user)) == null) {
|
||||||
return;
|
return;
|
||||||
}else {
|
}
|
||||||
|
peersToDisconnect = new ArrayList<>();
|
||||||
|
if(connRemove != null) {
|
||||||
|
peersToDisconnect.add(() -> {
|
||||||
EaglerInitialHandler eaglerHandler = (EaglerInitialHandler)connRemove.getPendingConnection();
|
EaglerInitialHandler eaglerHandler = (EaglerInitialHandler)connRemove.getPendingConnection();
|
||||||
eaglerHandler.fireVoiceStateChange(EaglercraftVoiceStatusChangeEvent.EnumVoiceState.DISABLED);
|
eaglerHandler.fireVoiceStateChange(EaglercraftVoiceStatusChangeEvent.EnumVoiceState.DISABLED);
|
||||||
if(eaglerHandler.getRPCEventSubscribed(EnumSubscribedEvent.TOGGLE_VOICE)) {
|
if(eaglerHandler.getRPCEventSubscribed(EnumSubscribedEvent.TOGGLE_VOICE)) {
|
||||||
eaglerHandler.getRPCSessionHandler().handleVoiceStateTransition(SPacketRPCEventToggledVoice.VOICE_STATE_DISABLED);
|
eaglerHandler.getRPCSessionHandler().handleVoiceStateTransition(SPacketRPCEventToggledVoice.VOICE_STATE_DISABLED);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
voiceRequests.remove(user);
|
voiceRequests.remove(user);
|
||||||
if (voicePlayers.size() > 0) {
|
if (voicePlayers.size() > 0) {
|
||||||
|
@ -261,10 +299,12 @@ public class VoiceServerImpl {
|
||||||
userDatas.add(new SPacketVoiceSignalGlobalEAG.UserData(uuid.getMostSignificantBits(),
|
userDatas.add(new SPacketVoiceSignalGlobalEAG.UserData(uuid.getMostSignificantBits(),
|
||||||
uuid.getLeastSignificantBits(), userCon.getDisplayName()));
|
uuid.getLeastSignificantBits(), userCon.getDisplayName()));
|
||||||
}
|
}
|
||||||
GameMessagePacket voicePlayersPkt = new SPacketVoiceSignalGlobalEAG(userDatas);
|
final GameMessagePacket voicePlayersPkt = new SPacketVoiceSignalGlobalEAG(userDatas);
|
||||||
for (UserConnection userCon : voicePlayers.values()) {
|
for (final UserConnection userCon : voicePlayers.values()) {
|
||||||
if (!user.equals(userCon.getUniqueId())) {
|
if (!user.equals(userCon.getUniqueId())) {
|
||||||
|
peersToDisconnect.add(() -> {
|
||||||
((EaglerInitialHandler)userCon.getPendingConnection()).sendEaglerMessage(voicePlayersPkt);
|
((EaglerInitialHandler)userCon.getPendingConnection()).sendEaglerMessage(voicePlayersPkt);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -280,16 +320,21 @@ public class VoiceServerImpl {
|
||||||
if (target != null) {
|
if (target != null) {
|
||||||
pairsItr.remove();
|
pairsItr.remove();
|
||||||
if (voicePlayers.size() > 0) {
|
if (voicePlayers.size() > 0) {
|
||||||
UserConnection conn = voicePlayers.get(target);
|
final UserConnection conn = voicePlayers.get(target);
|
||||||
if (conn != null) {
|
if (conn != null) {
|
||||||
|
peersToDisconnect.add(() -> {
|
||||||
((EaglerInitialHandler) conn.getPendingConnection()).sendEaglerMessage(
|
((EaglerInitialHandler) conn.getPendingConnection()).sendEaglerMessage(
|
||||||
new SPacketVoiceSignalDisconnectPeerEAG(user.getMostSignificantBits(),
|
new SPacketVoiceSignalDisconnectPeerEAG(user.getMostSignificantBits(),
|
||||||
user.getLeastSignificantBits()));
|
user.getLeastSignificantBits()));
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
for(Runnable r : peersToDisconnect) {
|
||||||
|
r.run();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
EnumVoiceState getPlayerVoiceState(UUID uniqueId) {
|
EnumVoiceState getPlayerVoiceState(UUID uniqueId) {
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
name: EaglercraftXBungee
|
name: EaglercraftXBungee
|
||||||
main: net.lax1dude.eaglercraft.v1_8.plugin.gateway_bungeecord.EaglerXBungee
|
main: net.lax1dude.eaglercraft.v1_8.plugin.gateway_bungeecord.EaglerXBungee
|
||||||
version: 1.3.3
|
version: 1.3.4
|
||||||
description: Plugin to allow EaglercraftX 1.8 players to join your network, or allow EaglercraftX 1.8 players to use your network as a proxy to join other networks
|
description: Plugin to allow EaglercraftX 1.8 players to join your network, or allow EaglercraftX 1.8 players to use your network as a proxy to join other networks
|
||||||
author: lax1dude
|
author: lax1dude
|
|
@ -1 +1 @@
|
||||||
1.3.3
|
1.3.4
|
Loading…
Reference in New Issue
Block a user