diff --git a/protocol/src/main/java/net/md_5/bungee/protocol/Protocol.java b/protocol/src/main/java/net/md_5/bungee/protocol/Protocol.java index 4474975a4a..9412a682fe 100644 --- a/protocol/src/main/java/net/md_5/bungee/protocol/Protocol.java +++ b/protocol/src/main/java/net/md_5/bungee/protocol/Protocol.java @@ -390,6 +390,9 @@ public static class DirectionData linkedProtocols.put( ProtocolConstants.MINECRAFT_1_12_1, Arrays.asList( ProtocolConstants.MINECRAFT_1_12_2 ) ); + linkedProtocols.put( ProtocolConstants.MINECRAFT_1_13, Arrays.asList( + ProtocolConstants.MINECRAFT_1_13_1 + ) ); } @Getter diff --git a/protocol/src/main/java/net/md_5/bungee/protocol/ProtocolConstants.java b/protocol/src/main/java/net/md_5/bungee/protocol/ProtocolConstants.java index 14f6c83d7e..e34b83f045 100644 --- a/protocol/src/main/java/net/md_5/bungee/protocol/ProtocolConstants.java +++ b/protocol/src/main/java/net/md_5/bungee/protocol/ProtocolConstants.java @@ -19,6 +19,7 @@ public class ProtocolConstants public static final int MINECRAFT_1_12_1 = 338; public static final int MINECRAFT_1_12_2 = 340; public static final int MINECRAFT_1_13 = 393; + public static final int MINECRAFT_1_13_1 = 401; public static final List SUPPORTED_VERSIONS = Arrays.asList( "1.7.x", "1.8.x", @@ -43,7 +44,8 @@ public class ProtocolConstants ProtocolConstants.MINECRAFT_1_12, ProtocolConstants.MINECRAFT_1_12_1, ProtocolConstants.MINECRAFT_1_12_2, - ProtocolConstants.MINECRAFT_1_13 + ProtocolConstants.MINECRAFT_1_13, + ProtocolConstants.MINECRAFT_1_13_1 ); public enum Direction diff --git a/proxy/src/main/java/net/md_5/bungee/conf/Configuration.java b/proxy/src/main/java/net/md_5/bungee/conf/Configuration.java index 414e2a39db..b5da6f9bcd 100644 --- a/proxy/src/main/java/net/md_5/bungee/conf/Configuration.java +++ b/proxy/src/main/java/net/md_5/bungee/conf/Configuration.java @@ -51,6 +51,7 @@ public class Configuration implements ProxyConfig * Whether we log proxy commands to the proxy log */ private boolean logCommands; + private boolean logPings = true; private int playerLimit = -1; private Collection disabledCommands; private int throttle = 4000; @@ -84,6 +85,7 @@ public void load() uuid = adapter.getString( "stats", uuid ); onlineMode = adapter.getBoolean( "online_mode", onlineMode ); logCommands = adapter.getBoolean( "log_commands", logCommands ); + logPings = adapter.getBoolean( "log_pings", logPings ); playerLimit = adapter.getInt( "player_limit", playerLimit ); throttle = adapter.getInt( "connection_throttle", throttle ); ipForward = adapter.getBoolean( "ip_forward", ipForward ); diff --git a/proxy/src/main/java/net/md_5/bungee/connection/InitialHandler.java b/proxy/src/main/java/net/md_5/bungee/connection/InitialHandler.java index 1c134a07a8..626eb84cc3 100644 --- a/proxy/src/main/java/net/md_5/bungee/connection/InitialHandler.java +++ b/proxy/src/main/java/net/md_5/bungee/connection/InitialHandler.java @@ -293,7 +293,10 @@ public void handle(Handshake handshake) throws Exception } this.virtualHost = InetSocketAddress.createUnresolved( handshake.getHost(), handshake.getPort() ); - bungee.getLogger().log( Level.INFO, "{0} has connected", this ); + if ( bungee.getConfig().isLogPings() ) + { + bungee.getLogger().log( Level.INFO, "{0} has connected", this ); + } bungee.getPluginManager().callEvent( new PlayerHandshakeEvent( InitialHandler.this, handshake ) ); @@ -306,6 +309,10 @@ public void handle(Handshake handshake) throws Exception break; case 2: // Login + if ( !bungee.getConfig().isLogPings() ) + { + bungee.getLogger().log( Level.INFO, "{0} has connected", this ); + } thisState = State.USERNAME; ch.setProtocol( Protocol.LOGIN ); diff --git a/proxy/src/main/java/net/md_5/bungee/entitymap/EntityMap.java b/proxy/src/main/java/net/md_5/bungee/entitymap/EntityMap.java index d3e410600a..069144c8a0 100644 --- a/proxy/src/main/java/net/md_5/bungee/entitymap/EntityMap.java +++ b/proxy/src/main/java/net/md_5/bungee/entitymap/EntityMap.java @@ -52,6 +52,7 @@ public static EntityMap getEntityMap(int version) case ProtocolConstants.MINECRAFT_1_12_2: return EntityMap_1_12_1.INSTANCE; case ProtocolConstants.MINECRAFT_1_13: + case ProtocolConstants.MINECRAFT_1_13_1: return EntityMap_1_13.INSTANCE; } throw new RuntimeException( "Version " + version + " has no entity map" ); diff --git a/proxy/src/main/java/net/md_5/bungee/scheduler/BungeeScheduler.java b/proxy/src/main/java/net/md_5/bungee/scheduler/BungeeScheduler.java index 1dc1cc66e6..fd0dabcf46 100644 --- a/proxy/src/main/java/net/md_5/bungee/scheduler/BungeeScheduler.java +++ b/proxy/src/main/java/net/md_5/bungee/scheduler/BungeeScheduler.java @@ -62,9 +62,12 @@ public void cancel(ScheduledTask task) public int cancel(Plugin plugin) { Set toRemove = new HashSet<>(); - for ( ScheduledTask task : tasksByPlugin.get( plugin ) ) + synchronized ( lock ) { - toRemove.add( task ); + for ( ScheduledTask task : tasksByPlugin.get( plugin ) ) + { + toRemove.add( task ); + } } for ( ScheduledTask task : toRemove ) {