Skip to content

Commit

Permalink
Ability to specify servers from the command line (PaperMC#1445)
Browse files Browse the repository at this point in the history
  • Loading branch information
theminecoder authored Oct 21, 2024
1 parent 1e6396d commit d4e89db
Show file tree
Hide file tree
Showing 2 changed files with 62 additions and 2 deletions.
54 changes: 54 additions & 0 deletions proxy/src/main/java/com/velocitypowered/proxy/ProxyOptions.java
Original file line number Diff line number Diff line change
Expand Up @@ -17,11 +17,18 @@

package com.velocitypowered.proxy;

import com.velocitypowered.api.proxy.server.ServerInfo;
import java.io.IOException;
import java.net.InetSocketAddress;
import java.util.Arrays;
import java.util.List;

import com.velocitypowered.proxy.util.AddressUtil;
import joptsimple.OptionParser;
import joptsimple.OptionSet;
import joptsimple.OptionSpec;
import joptsimple.ValueConversionException;
import joptsimple.ValueConverter;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.checkerframework.checker.nullness.qual.Nullable;
Expand All @@ -35,6 +42,8 @@ public final class ProxyOptions {
private final boolean help;
private final @Nullable Integer port;
private final @Nullable Boolean haproxy;
private final boolean ignoreConfigServers;
private final List<ServerInfo> servers;

ProxyOptions(final String[] args) {
final OptionParser parser = new OptionParser();
Expand All @@ -49,11 +58,20 @@ public final class ProxyOptions {
"Choose whether to enable haproxy protocol. "
+ "The configuration haproxy protocol will be ignored.")
.withRequiredArg().ofType(Boolean.class);
final OptionSpec<ServerInfo> servers = parser.accepts("add-server",
"Define a server mapping. "
+ "You must ensure that server name is not also registered in the config or use --ignore-config-servers.")
.withRequiredArg().withValuesConvertedBy(new ServerInfoConverter());
final OptionSpec<Void> ignoreConfigServers = parser.accepts("ignore-config-servers",
"Skip registering servers from the config file. "
+ "Useful in dynamic setups or with the --add-server flag.");
final OptionSet set = parser.parse(args);

this.help = set.has(help);
this.port = port.value(set);
this.haproxy = haproxy.value(set);
this.servers = servers.values(set);
this.ignoreConfigServers = set.has(ignoreConfigServers);

if (this.help) {
try {
Expand All @@ -75,4 +93,40 @@ boolean isHelp() {
public @Nullable Boolean isHaproxy() {
return this.haproxy;
}

public boolean isIgnoreConfigServers() {
return this.ignoreConfigServers;
}

public List<ServerInfo> getServers() {
return this.servers;
}

private static class ServerInfoConverter implements ValueConverter<ServerInfo> {

@Override
public ServerInfo convert(String s) {
String[] split = s.split(":", 2);
if (split.length < 2) {
throw new ValueConversionException("Invalid server format. Use <name>:<address>");
}
InetSocketAddress address;
try {
address = AddressUtil.parseAddress(split[1]);
} catch (IllegalStateException e) {
throw new ValueConversionException("Invalid hostname for server flag with name: " + split[0]);
}
return new ServerInfo(split[0], address);
}

@Override
public Class<? extends ServerInfo> valueType() {
return ServerInfo.class;
}

@Override
public String valuePattern() {
return "name>:<address";
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -275,8 +275,14 @@ void start() {

this.doStartupConfigLoad();

for (Map.Entry<String, String> entry : configuration.getServers().entrySet()) {
servers.register(new ServerInfo(entry.getKey(), AddressUtil.parseAddress(entry.getValue())));
for (ServerInfo cliServer : options.getServers()) {
servers.register(cliServer);
}

if (!options.isIgnoreConfigServers()) {
for (Map.Entry<String, String> entry : configuration.getServers().entrySet()) {
servers.register(new ServerInfo(entry.getKey(), AddressUtil.parseAddress(entry.getValue())));
}
}

ipAttemptLimiter = Ratelimiters.createWithMilliseconds(configuration.getLoginRatelimit());
Expand Down

0 comments on commit d4e89db

Please sign in to comment.