mirror of
https://github.com/PaperMC/Waterfall.git
synced 2024-11-28 13:15:31 +01:00
Add dynamic server addition/removal api patch (#37)
This commit is contained in:
parent
6b65e57f42
commit
34de9687e1
@ -0,0 +1,281 @@
|
|||||||
|
From f003385fe169b5be68b0acdf41a82a55f4140fb8 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Troy Frew <fuzzy_bot@arenaga.me>
|
||||||
|
Date: Tue, 28 Jun 2016 21:29:25 -0500
|
||||||
|
Subject: [PATCH] Add dynamic server addition/removal api.
|
||||||
|
|
||||||
|
The provided methods will not move a player if a server is removed or the server ip/port is changed, however the methods return the old ServerInfo object for you to handle that yourself if needed.
|
||||||
|
|
||||||
|
Thanks to Overcast for the idea
|
||||||
|
|
||||||
|
diff --git a/api/src/main/java/net/md_5/bungee/api/ProxyConfig.java b/api/src/main/java/net/md_5/bungee/api/ProxyConfig.java
|
||||||
|
index 5a49050..f04e2bf 100644
|
||||||
|
--- a/api/src/main/java/net/md_5/bungee/api/ProxyConfig.java
|
||||||
|
+++ b/api/src/main/java/net/md_5/bungee/api/ProxyConfig.java
|
||||||
|
@@ -32,9 +32,83 @@ public interface ProxyConfig
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set of all servers.
|
||||||
|
+ *
|
||||||
|
+ * @deprecated The returned map may be modified concurrently by the proxy.
|
||||||
|
+ * The safe alternative is {@link #getServersCopy()}.
|
||||||
|
*/
|
||||||
|
+ @Deprecated // Waterfall
|
||||||
|
Map<String, ServerInfo> getServers();
|
||||||
|
|
||||||
|
+ // Waterfall start - Dynamic server addition/removal api
|
||||||
|
+ /**
|
||||||
|
+ * Return all servers registered to this proxy, keyed by name. The returned map
|
||||||
|
+ * is an immutable snapshot of the actual server collection. It cannot be modified,
|
||||||
|
+ * and it will not change.
|
||||||
|
+ *
|
||||||
|
+ * @return all registered remote server destinations
|
||||||
|
+ */
|
||||||
|
+ Map<String, ServerInfo> getServersCopy();
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Gets the server info of a server.
|
||||||
|
+ *
|
||||||
|
+ * @param name the name of the configured server
|
||||||
|
+ * @return the server info belonging to the specified server
|
||||||
|
+ */
|
||||||
|
+ ServerInfo getServerInfo(String name);
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Register the given server to the proxy.
|
||||||
|
+ * Any currently registered server with the same name will be replaced.
|
||||||
|
+ * This change is not saved to config.yml
|
||||||
|
+ *
|
||||||
|
+ * @return the previously registered server with the same name, or null if there was no such server.
|
||||||
|
+ */
|
||||||
|
+ ServerInfo addServer(ServerInfo server);
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Register all of the given servers to the proxy.
|
||||||
|
+ * This change is not saved to config.yml
|
||||||
|
+ *
|
||||||
|
+ * @return true if any servers were added or replaced.
|
||||||
|
+ */
|
||||||
|
+ boolean addServers(Collection<ServerInfo> servers);
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Un-register the server with the given name from the proxy.
|
||||||
|
+ * This change is not saved to config.yml
|
||||||
|
+ *
|
||||||
|
+ * @return the server that was removed, or null if there is no server with the given name.
|
||||||
|
+ */
|
||||||
|
+ ServerInfo removeServerNamed(String name);
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Un-register the given server from the proxy.
|
||||||
|
+ * The server is matched by name only, other fields in the given {@link ServerInfo} are ignored.
|
||||||
|
+ * This change is not saved to config.yml
|
||||||
|
+ *
|
||||||
|
+ * @return the server that was removed, or null if there is no server with a matching name.
|
||||||
|
+ */
|
||||||
|
+ ServerInfo removeServer(ServerInfo server);
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Un-register servers with any of the given names from the proxy.
|
||||||
|
+ * This change is not saved to config.yml
|
||||||
|
+ *
|
||||||
|
+ * @return true if any servers were removed.
|
||||||
|
+ */
|
||||||
|
+ boolean removeServersNamed(Collection<String> names);
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Un-register all of the given servers from the proxy.
|
||||||
|
+ * The servers are matched by name only, other fields in the given {@link ServerInfo} are ignored.
|
||||||
|
+ * This change is not saved to config.yml
|
||||||
|
+ *
|
||||||
|
+ * @return true if any servers were removed.
|
||||||
|
+ */
|
||||||
|
+ boolean removeServers(Collection<ServerInfo> servers);
|
||||||
|
+ // Waterfall end
|
||||||
|
+
|
||||||
|
/**
|
||||||
|
* Does the server authenticate with mojang
|
||||||
|
*/
|
||||||
|
diff --git a/api/src/main/java/net/md_5/bungee/api/ProxyServer.java b/api/src/main/java/net/md_5/bungee/api/ProxyServer.java
|
||||||
|
index 11c5b68..1c011d0 100644
|
||||||
|
--- a/api/src/main/java/net/md_5/bungee/api/ProxyServer.java
|
||||||
|
+++ b/api/src/main/java/net/md_5/bungee/api/ProxyServer.java
|
||||||
|
@@ -93,9 +93,25 @@ public abstract class ProxyServer
|
||||||
|
* return a fresh map each time.
|
||||||
|
*
|
||||||
|
* @return all registered remote server destinations
|
||||||
|
+ *
|
||||||
|
+ * @deprecated The returned map is part of the proxy's internal state,
|
||||||
|
+ * and may be modified concurrently by the proxy.
|
||||||
|
+ * The safe alternative is {@link #getServersCopy()}.
|
||||||
|
*/
|
||||||
|
+ @Deprecated // Waterfall
|
||||||
|
public abstract Map<String, ServerInfo> getServers();
|
||||||
|
|
||||||
|
+ // Waterfall begin - Cloned servers map
|
||||||
|
+ /**
|
||||||
|
+ * Return all servers registered to this proxy, keyed by name. The returned map
|
||||||
|
+ * is an immutable snapshot of the actual server collection. It cannot be modified,
|
||||||
|
+ * and it will not change.
|
||||||
|
+ *
|
||||||
|
+ * @return all registered remote server destinations
|
||||||
|
+ */
|
||||||
|
+ public abstract Map<String, ServerInfo> getServersCopy();
|
||||||
|
+ // Waterfall end
|
||||||
|
+
|
||||||
|
/**
|
||||||
|
* Gets the server info of a server.
|
||||||
|
*
|
||||||
|
diff --git a/config/src/main/java/net/md_5/bungee/config/Configuration.java b/config/src/main/java/net/md_5/bungee/config/Configuration.java
|
||||||
|
index 1366f44..05ec159 100644
|
||||||
|
--- a/config/src/main/java/net/md_5/bungee/config/Configuration.java
|
||||||
|
+++ b/config/src/main/java/net/md_5/bungee/config/Configuration.java
|
||||||
|
@@ -28,6 +28,13 @@ public final class Configuration
|
||||||
|
this( new LinkedHashMap<String, Object>(), defaults );
|
||||||
|
}
|
||||||
|
|
||||||
|
+ // Waterfall start - Allow configuration objects to be cloned
|
||||||
|
+ public Configuration(Configuration values, Configuration defaults)
|
||||||
|
+ {
|
||||||
|
+ this( values.self, defaults );
|
||||||
|
+ }
|
||||||
|
+ // Waterfall end
|
||||||
|
+
|
||||||
|
private Configuration getSectionFor(String path)
|
||||||
|
{
|
||||||
|
int index = path.indexOf( SEPARATOR );
|
||||||
|
diff --git a/proxy/src/main/java/net/md_5/bungee/BungeeCord.java b/proxy/src/main/java/net/md_5/bungee/BungeeCord.java
|
||||||
|
index fc5ca3a..92ea9b5 100644
|
||||||
|
--- a/proxy/src/main/java/net/md_5/bungee/BungeeCord.java
|
||||||
|
+++ b/proxy/src/main/java/net/md_5/bungee/BungeeCord.java
|
||||||
|
@@ -559,10 +559,18 @@ public class BungeeCord extends ProxyServer
|
||||||
|
return config.getServers();
|
||||||
|
}
|
||||||
|
|
||||||
|
+ // Waterfall start
|
||||||
|
+ @Override
|
||||||
|
+ public Map<String, ServerInfo> getServersCopy()
|
||||||
|
+ {
|
||||||
|
+ return config.getServersCopy();
|
||||||
|
+ }
|
||||||
|
+ // Waterfall end
|
||||||
|
+
|
||||||
|
@Override
|
||||||
|
public ServerInfo getServerInfo(String name)
|
||||||
|
{
|
||||||
|
- return getServers().get( name );
|
||||||
|
+ return config.getServerInfo( name ); // Waterfall
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
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 db9ebbd..112420a 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
|
||||||
|
@@ -1,6 +1,7 @@
|
||||||
|
package net.md_5.bungee.conf;
|
||||||
|
|
||||||
|
import com.google.common.base.Preconditions;
|
||||||
|
+import com.google.common.collect.ImmutableMap; // Waterfall
|
||||||
|
import gnu.trove.map.TMap;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
@@ -11,6 +12,7 @@ import java.util.UUID;
|
||||||
|
import java.util.logging.Level;
|
||||||
|
import javax.imageio.ImageIO;
|
||||||
|
import lombok.Getter;
|
||||||
|
+import lombok.Synchronized; // Waterfall
|
||||||
|
|
||||||
|
import net.md_5.bungee.BungeeCord;
|
||||||
|
import net.md_5.bungee.api.Favicon;
|
||||||
|
@@ -61,6 +63,7 @@ public abstract class Configuration implements ProxyConfig
|
||||||
|
private Favicon favicon;
|
||||||
|
private int compressionThreshold = 256;
|
||||||
|
|
||||||
|
+ @Synchronized("servers") // Waterfall
|
||||||
|
public void load()
|
||||||
|
{
|
||||||
|
ConfigurationAdapter adapter = ProxyServer.getInstance().getConfigurationAdapter();
|
||||||
|
@@ -100,7 +103,7 @@ public abstract class Configuration implements ProxyConfig
|
||||||
|
servers = new CaseInsensitiveMap<>( newServers );
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
- Map<String, ServerInfo> oldServers = this.servers;
|
||||||
|
+ Map<String, ServerInfo> oldServers = getServersCopy();
|
||||||
|
this.servers = new CaseInsensitiveMap<>(newServers);
|
||||||
|
|
||||||
|
for ( ServerInfo oldServer : oldServers.values() )
|
||||||
|
@@ -158,4 +161,71 @@ public abstract class Configuration implements ProxyConfig
|
||||||
|
{
|
||||||
|
return favicon;
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ // Waterfall start
|
||||||
|
+ @Override
|
||||||
|
+ @Synchronized("servers")
|
||||||
|
+ public Map<String, ServerInfo> getServersCopy() {
|
||||||
|
+ return ImmutableMap.copyOf( servers );
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ @Synchronized("servers")
|
||||||
|
+ public ServerInfo getServerInfo(String name)
|
||||||
|
+ {
|
||||||
|
+ return this.servers.get( name );
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ @Synchronized("servers")
|
||||||
|
+ public ServerInfo addServer(ServerInfo server)
|
||||||
|
+ {
|
||||||
|
+ return this.servers.put( server.getName(), server );
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ @Synchronized("servers")
|
||||||
|
+ public boolean addServers(Collection<ServerInfo> servers)
|
||||||
|
+ {
|
||||||
|
+ boolean changed = false;
|
||||||
|
+ for ( ServerInfo server : servers )
|
||||||
|
+ {
|
||||||
|
+ if ( server != this.servers.put( server.getName(), server ) ) changed = true;
|
||||||
|
+ }
|
||||||
|
+ return changed;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ @Synchronized("servers")
|
||||||
|
+ public ServerInfo removeServerNamed(String name)
|
||||||
|
+ {
|
||||||
|
+ return this.servers.remove( name );
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ @Synchronized("servers")
|
||||||
|
+ public ServerInfo removeServer(ServerInfo server)
|
||||||
|
+ {
|
||||||
|
+ return this.servers.remove( server.getName() );
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ @Synchronized("servers")
|
||||||
|
+ public boolean removeServersNamed(Collection<String> names)
|
||||||
|
+ {
|
||||||
|
+ return this.servers.keySet().removeAll( names );
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ @Synchronized("servers")
|
||||||
|
+ public boolean removeServers(Collection<ServerInfo> servers)
|
||||||
|
+ {
|
||||||
|
+ boolean changed = false;
|
||||||
|
+ for ( ServerInfo server : servers )
|
||||||
|
+ {
|
||||||
|
+ if ( null != this.servers.remove( server.getName() ) ) changed = true;
|
||||||
|
+ }
|
||||||
|
+ return changed;
|
||||||
|
+ }
|
||||||
|
+ // Waterfall end
|
||||||
|
}
|
||||||
|
--
|
||||||
|
2.7.4 (Apple Git-66)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user