mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2025-01-04 23:48:42 +01:00
Refactored Address based rules to a class
Affects issues: - Fixed #1380
This commit is contained in:
parent
278602db36
commit
081f378135
@ -17,13 +17,10 @@
|
|||||||
package com.djrapitops.plan;
|
package com.djrapitops.plan;
|
||||||
|
|
||||||
import com.djrapitops.plan.exceptions.EnableException;
|
import com.djrapitops.plan.exceptions.EnableException;
|
||||||
import com.djrapitops.plan.identification.Server;
|
|
||||||
import com.djrapitops.plan.settings.ConfigSettingKeyTest;
|
import com.djrapitops.plan.settings.ConfigSettingKeyTest;
|
||||||
import com.djrapitops.plan.settings.config.PlanConfig;
|
import com.djrapitops.plan.settings.config.PlanConfig;
|
||||||
import com.djrapitops.plan.settings.config.paths.WebserverSettings;
|
import com.djrapitops.plan.settings.config.paths.WebserverSettings;
|
||||||
import com.djrapitops.plan.settings.config.paths.key.Setting;
|
import com.djrapitops.plan.settings.config.paths.key.Setting;
|
||||||
import com.djrapitops.plan.storage.database.Database;
|
|
||||||
import com.djrapitops.plan.storage.database.queries.objects.ServerQueries;
|
|
||||||
import org.junit.jupiter.api.BeforeEach;
|
import org.junit.jupiter.api.BeforeEach;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.io.TempDir;
|
import org.junit.jupiter.api.io.TempDir;
|
||||||
@ -32,9 +29,7 @@ import utilities.mocks.BukkitMockComponent;
|
|||||||
|
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Optional;
|
|
||||||
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertTrue;
|
import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
|
|
||||||
|
|
||||||
@ -65,21 +60,6 @@ public class BukkitSystemTest {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
void correctWebAddressInDatabaseAfterEnable() throws EnableException {
|
|
||||||
try {
|
|
||||||
system.enable();
|
|
||||||
Database database = system.getDatabaseSystem().getDatabase();
|
|
||||||
String expectedAddress = system.getWebServerSystem().getWebServer().getAccessAddress();
|
|
||||||
Optional<String> found = database.query(ServerQueries.fetchServerMatchingIdentifier(system.getServerInfo().getServerUUID()))
|
|
||||||
.map(Server::getWebAddress);
|
|
||||||
|
|
||||||
assertEquals(expectedAddress, found.orElse(null));
|
|
||||||
} finally {
|
|
||||||
system.disable();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void bukkitSystemHasDefaultConfigValuesAfterEnable() throws EnableException, IllegalAccessException {
|
void bukkitSystemHasDefaultConfigValuesAfterEnable() throws EnableException, IllegalAccessException {
|
||||||
try {
|
try {
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.identification;
|
package com.djrapitops.plan.identification;
|
||||||
|
|
||||||
|
import com.djrapitops.plan.delivery.webserver.Addresses;
|
||||||
import com.djrapitops.plan.delivery.webserver.WebServer;
|
import com.djrapitops.plan.delivery.webserver.WebServer;
|
||||||
import com.djrapitops.plan.exceptions.EnableException;
|
import com.djrapitops.plan.exceptions.EnableException;
|
||||||
import com.djrapitops.plan.exceptions.database.DBOpException;
|
import com.djrapitops.plan.exceptions.database.DBOpException;
|
||||||
@ -42,6 +43,7 @@ import java.util.concurrent.ExecutionException;
|
|||||||
public class BungeeServerInfo extends ServerInfo {
|
public class BungeeServerInfo extends ServerInfo {
|
||||||
|
|
||||||
private final DBSystem dbSystem;
|
private final DBSystem dbSystem;
|
||||||
|
private final Addresses addresses;
|
||||||
private final Lazy<WebServer> webServer;
|
private final Lazy<WebServer> webServer;
|
||||||
private final PluginLogger logger;
|
private final PluginLogger logger;
|
||||||
|
|
||||||
@ -49,11 +51,13 @@ public class BungeeServerInfo extends ServerInfo {
|
|||||||
public BungeeServerInfo(
|
public BungeeServerInfo(
|
||||||
ServerProperties serverProperties,
|
ServerProperties serverProperties,
|
||||||
DBSystem dbSystem,
|
DBSystem dbSystem,
|
||||||
|
Addresses addresses,
|
||||||
Lazy<WebServer> webServer,
|
Lazy<WebServer> webServer,
|
||||||
PluginLogger logger
|
PluginLogger logger
|
||||||
) {
|
) {
|
||||||
super(serverProperties);
|
super(serverProperties);
|
||||||
this.dbSystem = dbSystem;
|
this.dbSystem = dbSystem;
|
||||||
|
this.addresses = addresses;
|
||||||
this.webServer = webServer;
|
this.webServer = webServer;
|
||||||
this.logger = logger;
|
this.logger = logger;
|
||||||
}
|
}
|
||||||
@ -67,7 +71,7 @@ public class BungeeServerInfo extends ServerInfo {
|
|||||||
Optional<Server> proxyInfo = database.query(ServerQueries.fetchProxyServerInformation());
|
Optional<Server> proxyInfo = database.query(ServerQueries.fetchProxyServerInformation());
|
||||||
if (proxyInfo.isPresent()) {
|
if (proxyInfo.isPresent()) {
|
||||||
server = proxyInfo.get();
|
server = proxyInfo.get();
|
||||||
updateServerInfo(database);
|
updateServerInfo();
|
||||||
} else {
|
} else {
|
||||||
server = registerBungeeInfo(database);
|
server = registerBungeeInfo(database);
|
||||||
}
|
}
|
||||||
@ -78,26 +82,29 @@ public class BungeeServerInfo extends ServerInfo {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateServerInfo(Database db) {
|
private void updateServerInfo() {
|
||||||
String accessAddress = webServer.get().getAccessAddress();
|
addresses.getAccessAddress().ifPresent(this::saveAddress);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void saveAddress(String accessAddress) {
|
||||||
if (!accessAddress.equals(server.getWebAddress())) {
|
if (!accessAddress.equals(server.getWebAddress())) {
|
||||||
server.setWebAddress(accessAddress);
|
server.setWebAddress(accessAddress);
|
||||||
db.executeTransaction(new StoreServerInformationTransaction(server));
|
dbSystem.getDatabase().executeTransaction(new StoreServerInformationTransaction(server));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void checkIfDefaultIP() throws EnableException {
|
private void checkIfDefaultIP() throws EnableException {
|
||||||
String ip = serverProperties.getIp();
|
String ip = serverProperties.getIp();
|
||||||
if ("0.0.0.0".equals(ip)) {
|
if ("0.0.0.0".equals(ip)) {
|
||||||
logger.error("IP setting still 0.0.0.0 - Configure AlternativeIP/IP that connects to the Proxy server.");
|
logger.error("IP setting still 0.0.0.0 - Configure Alternative_IP/IP that connects to the Proxy server.");
|
||||||
logger.info("Player Analytics partially enabled (Use /planbungee to reload config)");
|
logger.info("Player Analytics partially enabled (Use /planbungee to reload config)");
|
||||||
throw new EnableException("IP setting still 0.0.0.0 - Configure AlternativeIP/IP that connects to the Proxy server.");
|
throw new EnableException("IP setting still 0.0.0.0 - Configure Alternative_IP/IP that connects to the Proxy server.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private Server registerBungeeInfo(Database db) throws EnableException, ExecutionException, InterruptedException {
|
private Server registerBungeeInfo(Database db) throws EnableException, ExecutionException, InterruptedException {
|
||||||
UUID serverUUID = generateNewUUID();
|
UUID serverUUID = generateNewUUID();
|
||||||
String accessAddress = webServer.get().getAccessAddress();
|
String accessAddress = addresses.getAccessAddress().orElseThrow(() -> new EnableException("BungeeCord can not have '0.0.0.0' or '' as an address. Set up 'Server.IP' setting."));
|
||||||
|
|
||||||
Server proxy = new Server(-1, serverUUID, "BungeeCord", accessAddress, serverProperties.getMaxPlayers());
|
Server proxy = new Server(-1, serverUUID, "BungeeCord", accessAddress, serverProperties.getMaxPlayers());
|
||||||
db.executeTransaction(new StoreServerInformationTransaction(proxy))
|
db.executeTransaction(new StoreServerInformationTransaction(proxy))
|
||||||
@ -107,6 +114,6 @@ public class BungeeServerInfo extends ServerInfo {
|
|||||||
if (proxyInfo.isPresent()) {
|
if (proxyInfo.isPresent()) {
|
||||||
return proxyInfo.get();
|
return proxyInfo.get();
|
||||||
}
|
}
|
||||||
throw new EnableException("BungeeCord registration failed (DB)");
|
throw new EnableException("BungeeCord registration failed (Was not found in the database after saving)");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -93,7 +93,7 @@ public class BungeeSystemTest {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
assertEquals("IP setting still 0.0.0.0 - Configure AlternativeIP/IP that connects to the Proxy server.", thrown.getMessage());
|
assertEquals("IP setting still 0.0.0.0 - Configure Alternative_IP/IP that connects to the Proxy server.", thrown.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -22,7 +22,6 @@ import com.djrapitops.plan.delivery.export.ExportSystem;
|
|||||||
import com.djrapitops.plan.delivery.web.ResolverSvc;
|
import com.djrapitops.plan.delivery.web.ResolverSvc;
|
||||||
import com.djrapitops.plan.delivery.web.ResourceSvc;
|
import com.djrapitops.plan.delivery.web.ResourceSvc;
|
||||||
import com.djrapitops.plan.delivery.webserver.NonProxyWebserverDisableChecker;
|
import com.djrapitops.plan.delivery.webserver.NonProxyWebserverDisableChecker;
|
||||||
import com.djrapitops.plan.delivery.webserver.WebServer;
|
|
||||||
import com.djrapitops.plan.delivery.webserver.WebServerSystem;
|
import com.djrapitops.plan.delivery.webserver.WebServerSystem;
|
||||||
import com.djrapitops.plan.exceptions.EnableException;
|
import com.djrapitops.plan.exceptions.EnableException;
|
||||||
import com.djrapitops.plan.extension.ExtensionService;
|
import com.djrapitops.plan.extension.ExtensionService;
|
||||||
@ -30,7 +29,6 @@ import com.djrapitops.plan.extension.ExtensionSvc;
|
|||||||
import com.djrapitops.plan.gathering.cache.CacheSystem;
|
import com.djrapitops.plan.gathering.cache.CacheSystem;
|
||||||
import com.djrapitops.plan.gathering.importing.ImportSystem;
|
import com.djrapitops.plan.gathering.importing.ImportSystem;
|
||||||
import com.djrapitops.plan.gathering.listeners.ListenerSystem;
|
import com.djrapitops.plan.gathering.listeners.ListenerSystem;
|
||||||
import com.djrapitops.plan.identification.Server;
|
|
||||||
import com.djrapitops.plan.identification.ServerInfo;
|
import com.djrapitops.plan.identification.ServerInfo;
|
||||||
import com.djrapitops.plan.processing.Processing;
|
import com.djrapitops.plan.processing.Processing;
|
||||||
import com.djrapitops.plan.query.QuerySvc;
|
import com.djrapitops.plan.query.QuerySvc;
|
||||||
@ -38,7 +36,6 @@ import com.djrapitops.plan.settings.ConfigSystem;
|
|||||||
import com.djrapitops.plan.settings.SettingsSvc;
|
import com.djrapitops.plan.settings.SettingsSvc;
|
||||||
import com.djrapitops.plan.settings.locale.LocaleSystem;
|
import com.djrapitops.plan.settings.locale.LocaleSystem;
|
||||||
import com.djrapitops.plan.storage.database.DBSystem;
|
import com.djrapitops.plan.storage.database.DBSystem;
|
||||||
import com.djrapitops.plan.storage.database.queries.objects.ServerQueries;
|
|
||||||
import com.djrapitops.plan.storage.file.PlanFiles;
|
import com.djrapitops.plan.storage.file.PlanFiles;
|
||||||
import com.djrapitops.plan.version.VersionChecker;
|
import com.djrapitops.plan.version.VersionChecker;
|
||||||
import com.djrapitops.plugin.benchmarking.Benchmark;
|
import com.djrapitops.plugin.benchmarking.Benchmark;
|
||||||
@ -146,14 +143,9 @@ public class PlanSystem implements SubSystem {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String getMainAddress(WebServer webServer, DBSystem dbSystem) {
|
@Deprecated
|
||||||
return dbSystem.getDatabase().query(ServerQueries.fetchProxyServerInformation())
|
|
||||||
.map(Server::getWebAddress)
|
|
||||||
.orElse(webServer.getAccessAddress());
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getMainAddress() {
|
public String getMainAddress() {
|
||||||
return PlanSystem.getMainAddress(webServerSystem.getWebServer(), databaseSystem);
|
return webServerSystem.getAddresses().getMainAddress().orElse(webServerSystem.getAddresses().getFallbackLocalhostAddress());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -183,7 +175,7 @@ public class PlanSystem implements SubSystem {
|
|||||||
// Disables Webserver if Proxy is detected in the database
|
// Disables Webserver if Proxy is detected in the database
|
||||||
if (serverInfo.getServer().isNotProxy()) {
|
if (serverInfo.getServer().isNotProxy()) {
|
||||||
processing.submitNonCritical(new NonProxyWebserverDisableChecker(
|
processing.submitNonCritical(new NonProxyWebserverDisableChecker(
|
||||||
configSystem.getConfig(), databaseSystem, webServerSystem, logger, errorHandler
|
configSystem.getConfig(), webServerSystem.getAddresses(), webServerSystem, logger, errorHandler
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -16,9 +16,9 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.commands.subcommands;
|
package com.djrapitops.plan.commands.subcommands;
|
||||||
|
|
||||||
import com.djrapitops.plan.PlanSystem;
|
|
||||||
import com.djrapitops.plan.delivery.export.Exporter;
|
import com.djrapitops.plan.delivery.export.Exporter;
|
||||||
import com.djrapitops.plan.delivery.rendering.html.Html;
|
import com.djrapitops.plan.delivery.rendering.html.Html;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.Addresses;
|
||||||
import com.djrapitops.plan.delivery.webserver.WebServer;
|
import com.djrapitops.plan.delivery.webserver.WebServer;
|
||||||
import com.djrapitops.plan.exceptions.ExportException;
|
import com.djrapitops.plan.exceptions.ExportException;
|
||||||
import com.djrapitops.plan.exceptions.database.DBOpException;
|
import com.djrapitops.plan.exceptions.database.DBOpException;
|
||||||
@ -56,6 +56,7 @@ public class AnalyzeCommand extends CommandNode {
|
|||||||
private final Locale locale;
|
private final Locale locale;
|
||||||
private final Processing processing;
|
private final Processing processing;
|
||||||
private final Exporter exporter;
|
private final Exporter exporter;
|
||||||
|
private final Addresses addresses;
|
||||||
private final ServerInfo serverInfo;
|
private final ServerInfo serverInfo;
|
||||||
private final WebServer webServer;
|
private final WebServer webServer;
|
||||||
private final DBSystem dbSystem;
|
private final DBSystem dbSystem;
|
||||||
@ -66,6 +67,7 @@ public class AnalyzeCommand extends CommandNode {
|
|||||||
Locale locale,
|
Locale locale,
|
||||||
Processing processing,
|
Processing processing,
|
||||||
Exporter exporter,
|
Exporter exporter,
|
||||||
|
Addresses addresses,
|
||||||
ServerInfo serverInfo,
|
ServerInfo serverInfo,
|
||||||
WebServer webServer,
|
WebServer webServer,
|
||||||
DBSystem dbSystem,
|
DBSystem dbSystem,
|
||||||
@ -76,6 +78,7 @@ public class AnalyzeCommand extends CommandNode {
|
|||||||
this.locale = locale;
|
this.locale = locale;
|
||||||
this.processing = processing;
|
this.processing = processing;
|
||||||
this.exporter = exporter;
|
this.exporter = exporter;
|
||||||
|
this.addresses = addresses;
|
||||||
this.serverInfo = serverInfo;
|
this.serverInfo = serverInfo;
|
||||||
this.webServer = webServer;
|
this.webServer = webServer;
|
||||||
this.dbSystem = dbSystem;
|
this.dbSystem = dbSystem;
|
||||||
@ -110,7 +113,10 @@ public class AnalyzeCommand extends CommandNode {
|
|||||||
|
|
||||||
private void sendLink(Server server, Sender sender) {
|
private void sendLink(Server server, Sender sender) {
|
||||||
String target = "/server/" + Html.encodeToURL(server.getName());
|
String target = "/server/" + Html.encodeToURL(server.getName());
|
||||||
String address = PlanSystem.getMainAddress(webServer, dbSystem);
|
String address = addresses.getMainAddress().orElseGet(() -> {
|
||||||
|
sender.sendMessage(locale.getString(CommandLang.NO_ADDRESS_NOTIFY));
|
||||||
|
return addresses.getFallbackLocalhostAddress();
|
||||||
|
});
|
||||||
String url = address + target;
|
String url = address + target;
|
||||||
String linkPrefix = locale.getString(CommandLang.LINK_PREFIX);
|
String linkPrefix = locale.getString(CommandLang.LINK_PREFIX);
|
||||||
sender.sendMessage(locale.getString(CommandLang.HEADER_ANALYSIS));
|
sender.sendMessage(locale.getString(CommandLang.HEADER_ANALYSIS));
|
||||||
|
@ -16,8 +16,8 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.commands.subcommands;
|
package com.djrapitops.plan.commands.subcommands;
|
||||||
|
|
||||||
import com.djrapitops.plan.PlanSystem;
|
|
||||||
import com.djrapitops.plan.delivery.rendering.html.Html;
|
import com.djrapitops.plan.delivery.rendering.html.Html;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.Addresses;
|
||||||
import com.djrapitops.plan.delivery.webserver.WebServer;
|
import com.djrapitops.plan.delivery.webserver.WebServer;
|
||||||
import com.djrapitops.plan.exceptions.database.DBOpException;
|
import com.djrapitops.plan.exceptions.database.DBOpException;
|
||||||
import com.djrapitops.plan.identification.UUIDUtility;
|
import com.djrapitops.plan.identification.UUIDUtility;
|
||||||
@ -52,6 +52,7 @@ public class InspectCommand extends CommandNode {
|
|||||||
private final Locale locale;
|
private final Locale locale;
|
||||||
private final DBSystem dbSystem;
|
private final DBSystem dbSystem;
|
||||||
private final WebServer webServer;
|
private final WebServer webServer;
|
||||||
|
private final Addresses addresses;
|
||||||
private final Processing processing;
|
private final Processing processing;
|
||||||
private final UUIDUtility uuidUtility;
|
private final UUIDUtility uuidUtility;
|
||||||
private final ErrorHandler errorHandler;
|
private final ErrorHandler errorHandler;
|
||||||
@ -59,6 +60,7 @@ public class InspectCommand extends CommandNode {
|
|||||||
@Inject
|
@Inject
|
||||||
public InspectCommand(
|
public InspectCommand(
|
||||||
Locale locale,
|
Locale locale,
|
||||||
|
Addresses addresses,
|
||||||
Processing processing,
|
Processing processing,
|
||||||
DBSystem dbSystem,
|
DBSystem dbSystem,
|
||||||
WebServer webServer,
|
WebServer webServer,
|
||||||
@ -66,6 +68,7 @@ public class InspectCommand extends CommandNode {
|
|||||||
ErrorHandler errorHandler
|
ErrorHandler errorHandler
|
||||||
) {
|
) {
|
||||||
super("inspect", Permissions.INSPECT.getPermission(), CommandType.PLAYER_OR_ARGS);
|
super("inspect", Permissions.INSPECT.getPermission(), CommandType.PLAYER_OR_ARGS);
|
||||||
|
this.addresses = addresses;
|
||||||
this.processing = processing;
|
this.processing = processing;
|
||||||
setArguments("<player>");
|
setArguments("<player>");
|
||||||
|
|
||||||
@ -132,7 +135,10 @@ public class InspectCommand extends CommandNode {
|
|||||||
private void sendInspectMsg(Sender sender, String playerName) {
|
private void sendInspectMsg(Sender sender, String playerName) {
|
||||||
sender.sendMessage(locale.getString(CommandLang.HEADER_INSPECT, playerName));
|
sender.sendMessage(locale.getString(CommandLang.HEADER_INSPECT, playerName));
|
||||||
|
|
||||||
String address = PlanSystem.getMainAddress(webServer, dbSystem);
|
String address = addresses.getMainAddress().orElseGet(() -> {
|
||||||
|
sender.sendMessage(locale.getString(CommandLang.NO_ADDRESS_NOTIFY));
|
||||||
|
return addresses.getFallbackLocalhostAddress();
|
||||||
|
});
|
||||||
String url = address + "/player/" + Html.encodeToURL(playerName);
|
String url = address + "/player/" + Html.encodeToURL(playerName);
|
||||||
String linkPrefix = locale.getString(CommandLang.LINK_PREFIX);
|
String linkPrefix = locale.getString(CommandLang.LINK_PREFIX);
|
||||||
|
|
||||||
|
@ -16,14 +16,12 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.commands.subcommands;
|
package com.djrapitops.plan.commands.subcommands;
|
||||||
|
|
||||||
import com.djrapitops.plan.PlanSystem;
|
import com.djrapitops.plan.delivery.webserver.Addresses;
|
||||||
import com.djrapitops.plan.delivery.webserver.WebServer;
|
|
||||||
import com.djrapitops.plan.settings.Permissions;
|
import com.djrapitops.plan.settings.Permissions;
|
||||||
import com.djrapitops.plan.settings.locale.Locale;
|
import com.djrapitops.plan.settings.locale.Locale;
|
||||||
import com.djrapitops.plan.settings.locale.lang.CmdHelpLang;
|
import com.djrapitops.plan.settings.locale.lang.CmdHelpLang;
|
||||||
import com.djrapitops.plan.settings.locale.lang.CommandLang;
|
import com.djrapitops.plan.settings.locale.lang.CommandLang;
|
||||||
import com.djrapitops.plan.settings.locale.lang.DeepHelpLang;
|
import com.djrapitops.plan.settings.locale.lang.DeepHelpLang;
|
||||||
import com.djrapitops.plan.storage.database.DBSystem;
|
|
||||||
import com.djrapitops.plugin.command.CommandNode;
|
import com.djrapitops.plugin.command.CommandNode;
|
||||||
import com.djrapitops.plugin.command.CommandType;
|
import com.djrapitops.plugin.command.CommandType;
|
||||||
import com.djrapitops.plugin.command.CommandUtils;
|
import com.djrapitops.plugin.command.CommandUtils;
|
||||||
@ -39,20 +37,17 @@ import javax.inject.Inject;
|
|||||||
public class ListPlayersCommand extends CommandNode {
|
public class ListPlayersCommand extends CommandNode {
|
||||||
|
|
||||||
private final Locale locale;
|
private final Locale locale;
|
||||||
private final DBSystem dbSystem;
|
private final Addresses addresses;
|
||||||
private final WebServer webServer;
|
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public ListPlayersCommand(
|
public ListPlayersCommand(
|
||||||
Locale locale,
|
Locale locale,
|
||||||
DBSystem dbSystem,
|
Addresses addresses
|
||||||
WebServer webServer
|
|
||||||
) {
|
) {
|
||||||
super("players|pl|playerlist|list", Permissions.INSPECT_OTHER.getPermission(), CommandType.CONSOLE);
|
super("players|pl|playerlist|list", Permissions.INSPECT_OTHER.getPermission(), CommandType.CONSOLE);
|
||||||
|
|
||||||
this.locale = locale;
|
this.locale = locale;
|
||||||
this.dbSystem = dbSystem;
|
this.addresses = addresses;
|
||||||
this.webServer = webServer;
|
|
||||||
|
|
||||||
setShortHelp(locale.getString(CmdHelpLang.PLAYERS));
|
setShortHelp(locale.getString(CmdHelpLang.PLAYERS));
|
||||||
setInDepthHelp(locale.getArray(DeepHelpLang.PLAYERS));
|
setInDepthHelp(locale.getArray(DeepHelpLang.PLAYERS));
|
||||||
@ -67,7 +62,10 @@ public class ListPlayersCommand extends CommandNode {
|
|||||||
sender.sendMessage(locale.getString(CommandLang.HEADER_PLAYERS));
|
sender.sendMessage(locale.getString(CommandLang.HEADER_PLAYERS));
|
||||||
|
|
||||||
// Link
|
// Link
|
||||||
String address = PlanSystem.getMainAddress(webServer, dbSystem);
|
String address = addresses.getMainAddress().orElseGet(() -> {
|
||||||
|
sender.sendMessage(locale.getString(CommandLang.NO_ADDRESS_NOTIFY));
|
||||||
|
return addresses.getFallbackLocalhostAddress();
|
||||||
|
});
|
||||||
String url = address + "/players";
|
String url = address + "/players";
|
||||||
String linkPrefix = locale.getString(CommandLang.LINK_PREFIX);
|
String linkPrefix = locale.getString(CommandLang.LINK_PREFIX);
|
||||||
boolean console = !CommandUtils.isPlayer(sender);
|
boolean console = !CommandUtils.isPlayer(sender);
|
||||||
|
@ -16,14 +16,12 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.commands.subcommands;
|
package com.djrapitops.plan.commands.subcommands;
|
||||||
|
|
||||||
import com.djrapitops.plan.PlanSystem;
|
import com.djrapitops.plan.delivery.webserver.Addresses;
|
||||||
import com.djrapitops.plan.delivery.webserver.WebServer;
|
|
||||||
import com.djrapitops.plan.settings.Permissions;
|
import com.djrapitops.plan.settings.Permissions;
|
||||||
import com.djrapitops.plan.settings.locale.Locale;
|
import com.djrapitops.plan.settings.locale.Locale;
|
||||||
import com.djrapitops.plan.settings.locale.lang.CmdHelpLang;
|
import com.djrapitops.plan.settings.locale.lang.CmdHelpLang;
|
||||||
import com.djrapitops.plan.settings.locale.lang.CommandLang;
|
import com.djrapitops.plan.settings.locale.lang.CommandLang;
|
||||||
import com.djrapitops.plan.settings.locale.lang.DeepHelpLang;
|
import com.djrapitops.plan.settings.locale.lang.DeepHelpLang;
|
||||||
import com.djrapitops.plan.storage.database.DBSystem;
|
|
||||||
import com.djrapitops.plugin.command.CommandNode;
|
import com.djrapitops.plugin.command.CommandNode;
|
||||||
import com.djrapitops.plugin.command.CommandType;
|
import com.djrapitops.plugin.command.CommandType;
|
||||||
import com.djrapitops.plugin.command.CommandUtils;
|
import com.djrapitops.plugin.command.CommandUtils;
|
||||||
@ -39,20 +37,17 @@ import javax.inject.Inject;
|
|||||||
public class NetworkCommand extends CommandNode {
|
public class NetworkCommand extends CommandNode {
|
||||||
|
|
||||||
private final Locale locale;
|
private final Locale locale;
|
||||||
private final DBSystem dbSystem;
|
private final Addresses addresses;
|
||||||
private final WebServer webServer;
|
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public NetworkCommand(
|
public NetworkCommand(
|
||||||
Locale locale,
|
Locale locale,
|
||||||
DBSystem dbSystem,
|
Addresses addresses
|
||||||
WebServer webServer
|
|
||||||
) {
|
) {
|
||||||
super("network|n|netw", Permissions.ANALYZE.getPermission(), CommandType.CONSOLE);
|
super("network|n|netw", Permissions.ANALYZE.getPermission(), CommandType.CONSOLE);
|
||||||
|
|
||||||
this.locale = locale;
|
this.locale = locale;
|
||||||
this.dbSystem = dbSystem;
|
this.addresses = addresses;
|
||||||
this.webServer = webServer;
|
|
||||||
|
|
||||||
setShortHelp(locale.getString(CmdHelpLang.NETWORK));
|
setShortHelp(locale.getString(CmdHelpLang.NETWORK));
|
||||||
setInDepthHelp(locale.getArray(DeepHelpLang.NETWORK));
|
setInDepthHelp(locale.getArray(DeepHelpLang.NETWORK));
|
||||||
@ -67,7 +62,10 @@ public class NetworkCommand extends CommandNode {
|
|||||||
sender.sendMessage(locale.getString(CommandLang.HEADER_NETWORK));
|
sender.sendMessage(locale.getString(CommandLang.HEADER_NETWORK));
|
||||||
|
|
||||||
// Link
|
// Link
|
||||||
String address = PlanSystem.getMainAddress(webServer, dbSystem);
|
String address = addresses.getMainAddress().orElseGet(() -> {
|
||||||
|
sender.sendMessage(locale.getString(CommandLang.NO_ADDRESS_NOTIFY));
|
||||||
|
return addresses.getFallbackLocalhostAddress();
|
||||||
|
});
|
||||||
String url = address + "/network";
|
String url = address + "/network";
|
||||||
String linkPrefix = locale.getString(CommandLang.LINK_PREFIX);
|
String linkPrefix = locale.getString(CommandLang.LINK_PREFIX);
|
||||||
boolean console = !CommandUtils.isPlayer(sender);
|
boolean console = !CommandUtils.isPlayer(sender);
|
||||||
|
@ -16,9 +16,8 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.commands.subcommands;
|
package com.djrapitops.plan.commands.subcommands;
|
||||||
|
|
||||||
import com.djrapitops.plan.PlanSystem;
|
|
||||||
import com.djrapitops.plan.delivery.domain.WebUser;
|
import com.djrapitops.plan.delivery.domain.WebUser;
|
||||||
import com.djrapitops.plan.delivery.webserver.WebServer;
|
import com.djrapitops.plan.delivery.webserver.Addresses;
|
||||||
import com.djrapitops.plan.exceptions.database.DBOpException;
|
import com.djrapitops.plan.exceptions.database.DBOpException;
|
||||||
import com.djrapitops.plan.processing.Processing;
|
import com.djrapitops.plan.processing.Processing;
|
||||||
import com.djrapitops.plan.settings.Permissions;
|
import com.djrapitops.plan.settings.Permissions;
|
||||||
@ -62,7 +61,7 @@ public class RegisterCommand extends CommandNode {
|
|||||||
private final Locale locale;
|
private final Locale locale;
|
||||||
private final Processing processing;
|
private final Processing processing;
|
||||||
private final DBSystem dbSystem;
|
private final DBSystem dbSystem;
|
||||||
private final WebServer webServer;
|
private final Addresses addresses;
|
||||||
private final PluginLogger logger;
|
private final PluginLogger logger;
|
||||||
private final ErrorHandler errorHandler;
|
private final ErrorHandler errorHandler;
|
||||||
|
|
||||||
@ -70,8 +69,8 @@ public class RegisterCommand extends CommandNode {
|
|||||||
public RegisterCommand(
|
public RegisterCommand(
|
||||||
Locale locale,
|
Locale locale,
|
||||||
Processing processing,
|
Processing processing,
|
||||||
|
Addresses addresses,
|
||||||
DBSystem dbSystem,
|
DBSystem dbSystem,
|
||||||
WebServer webServer,
|
|
||||||
PluginLogger logger,
|
PluginLogger logger,
|
||||||
ErrorHandler errorHandler
|
ErrorHandler errorHandler
|
||||||
) {
|
) {
|
||||||
@ -80,7 +79,7 @@ public class RegisterCommand extends CommandNode {
|
|||||||
|
|
||||||
this.locale = locale;
|
this.locale = locale;
|
||||||
this.processing = processing;
|
this.processing = processing;
|
||||||
this.webServer = webServer;
|
this.addresses = addresses;
|
||||||
this.logger = logger;
|
this.logger = logger;
|
||||||
this.dbSystem = dbSystem;
|
this.dbSystem = dbSystem;
|
||||||
this.errorHandler = errorHandler;
|
this.errorHandler = errorHandler;
|
||||||
@ -187,7 +186,10 @@ public class RegisterCommand extends CommandNode {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void sendLink(Sender sender) {
|
private void sendLink(Sender sender) {
|
||||||
String url = PlanSystem.getMainAddress(webServer, dbSystem);
|
String url = addresses.getMainAddress().orElseGet(() -> {
|
||||||
|
sender.sendMessage(locale.getString(CommandLang.NO_ADDRESS_NOTIFY));
|
||||||
|
return addresses.getFallbackLocalhostAddress();
|
||||||
|
});
|
||||||
String linkPrefix = locale.getString(CommandLang.LINK_PREFIX);
|
String linkPrefix = locale.getString(CommandLang.LINK_PREFIX);
|
||||||
// Link
|
// Link
|
||||||
boolean console = !CommandUtils.isPlayer(sender);
|
boolean console = !CommandUtils.isPlayer(sender);
|
||||||
|
@ -16,15 +16,13 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.commands.subcommands.manage;
|
package com.djrapitops.plan.commands.subcommands.manage;
|
||||||
|
|
||||||
import com.djrapitops.plan.PlanSystem;
|
|
||||||
import com.djrapitops.plan.delivery.rendering.html.Html;
|
import com.djrapitops.plan.delivery.rendering.html.Html;
|
||||||
import com.djrapitops.plan.delivery.webserver.WebServer;
|
import com.djrapitops.plan.delivery.webserver.Addresses;
|
||||||
import com.djrapitops.plan.settings.Permissions;
|
import com.djrapitops.plan.settings.Permissions;
|
||||||
import com.djrapitops.plan.settings.locale.Locale;
|
import com.djrapitops.plan.settings.locale.Locale;
|
||||||
import com.djrapitops.plan.settings.locale.lang.CmdHelpLang;
|
import com.djrapitops.plan.settings.locale.lang.CmdHelpLang;
|
||||||
import com.djrapitops.plan.settings.locale.lang.CommandLang;
|
import com.djrapitops.plan.settings.locale.lang.CommandLang;
|
||||||
import com.djrapitops.plan.settings.locale.lang.DeepHelpLang;
|
import com.djrapitops.plan.settings.locale.lang.DeepHelpLang;
|
||||||
import com.djrapitops.plan.storage.database.DBSystem;
|
|
||||||
import com.djrapitops.plan.utilities.MiscUtils;
|
import com.djrapitops.plan.utilities.MiscUtils;
|
||||||
import com.djrapitops.plugin.command.CommandNode;
|
import com.djrapitops.plugin.command.CommandNode;
|
||||||
import com.djrapitops.plugin.command.CommandType;
|
import com.djrapitops.plugin.command.CommandType;
|
||||||
@ -44,16 +42,17 @@ import java.util.Arrays;
|
|||||||
public class ManageRawDataCommand extends CommandNode {
|
public class ManageRawDataCommand extends CommandNode {
|
||||||
|
|
||||||
private final Locale locale;
|
private final Locale locale;
|
||||||
private final DBSystem dbSystem;
|
private Addresses addresses;
|
||||||
private final WebServer webServer;
|
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public ManageRawDataCommand(Locale locale, DBSystem dbSystem, WebServer webServer) {
|
public ManageRawDataCommand(
|
||||||
|
Locale locale,
|
||||||
|
Addresses addresses
|
||||||
|
) {
|
||||||
super("raw", Permissions.MANAGE.getPermission(), CommandType.PLAYER_OR_ARGS);
|
super("raw", Permissions.MANAGE.getPermission(), CommandType.PLAYER_OR_ARGS);
|
||||||
|
|
||||||
this.locale = locale;
|
this.locale = locale;
|
||||||
this.dbSystem = dbSystem;
|
this.addresses = addresses;
|
||||||
this.webServer = webServer;
|
|
||||||
|
|
||||||
setArguments("<player>");
|
setArguments("<player>");
|
||||||
setShortHelp(locale.getString(CmdHelpLang.MANAGE_RAW_DATA));
|
setShortHelp(locale.getString(CmdHelpLang.MANAGE_RAW_DATA));
|
||||||
@ -69,7 +68,10 @@ public class ManageRawDataCommand extends CommandNode {
|
|||||||
|
|
||||||
sender.sendMessage(locale.getString(CommandLang.HEADER_INSPECT, playerName));
|
sender.sendMessage(locale.getString(CommandLang.HEADER_INSPECT, playerName));
|
||||||
// Link
|
// Link
|
||||||
String address = PlanSystem.getMainAddress(webServer, dbSystem);
|
String address = addresses.getMainAddress().orElseGet(() -> {
|
||||||
|
sender.sendMessage(locale.getString(CommandLang.NO_ADDRESS_NOTIFY));
|
||||||
|
return addresses.getFallbackLocalhostAddress();
|
||||||
|
});
|
||||||
String url = address + "/player/" + Html.encodeToURL(playerName) + "/raw";
|
String url = address + "/player/" + Html.encodeToURL(playerName) + "/raw";
|
||||||
String linkPrefix = locale.getString(CommandLang.LINK_PREFIX);
|
String linkPrefix = locale.getString(CommandLang.LINK_PREFIX);
|
||||||
boolean console = !CommandUtils.isPlayer(sender);
|
boolean console = !CommandUtils.isPlayer(sender);
|
||||||
|
@ -0,0 +1,113 @@
|
|||||||
|
/*
|
||||||
|
* This file is part of Player Analytics (Plan).
|
||||||
|
*
|
||||||
|
* Plan is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Lesser General Public License v3 as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Plan is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public License
|
||||||
|
* along with Plan. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
package com.djrapitops.plan.delivery.webserver;
|
||||||
|
|
||||||
|
import com.djrapitops.plan.identification.Server;
|
||||||
|
import com.djrapitops.plan.identification.properties.ServerProperties;
|
||||||
|
import com.djrapitops.plan.settings.config.PlanConfig;
|
||||||
|
import com.djrapitops.plan.settings.config.paths.WebserverSettings;
|
||||||
|
import com.djrapitops.plan.storage.database.DBSystem;
|
||||||
|
import com.djrapitops.plan.storage.database.queries.objects.ServerQueries;
|
||||||
|
import dagger.Lazy;
|
||||||
|
|
||||||
|
import javax.inject.Inject;
|
||||||
|
import javax.inject.Singleton;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* In charge of address management.
|
||||||
|
* <p>
|
||||||
|
* Possible scenarios (problem domain):
|
||||||
|
* - IP in server properties is 0.0.0.0 which is invalid
|
||||||
|
* - IP in server properties is empty string, which is invalid
|
||||||
|
* - Alternative IP is set in the Plan config
|
||||||
|
* - Proxy server is used as main webserver, this address has highest priority
|
||||||
|
* - Webserver is disabled, external webserver address in config should be used
|
||||||
|
* - Webserver uses either http or https
|
||||||
|
* - Webserver always has a port, but Alternative IP can be used to remove the port from the address
|
||||||
|
* <p>
|
||||||
|
* What are the addresses used in:
|
||||||
|
* - Given as links to commands
|
||||||
|
* - Redirection
|
||||||
|
* - Storing proxy server address in database
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
@Singleton
|
||||||
|
public class Addresses {
|
||||||
|
|
||||||
|
private final PlanConfig config;
|
||||||
|
private final DBSystem dbSystem;
|
||||||
|
private final Lazy<ServerProperties> serverProperties;
|
||||||
|
private final Lazy<WebServer> webserver;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
public Addresses(
|
||||||
|
PlanConfig config,
|
||||||
|
DBSystem dbSystem,
|
||||||
|
Lazy<ServerProperties> serverProperties,
|
||||||
|
Lazy<WebServer> webserver
|
||||||
|
) {
|
||||||
|
this.config = config;
|
||||||
|
this.dbSystem = dbSystem;
|
||||||
|
this.serverProperties = serverProperties;
|
||||||
|
this.webserver = webserver;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Optional<String> getMainAddress() {
|
||||||
|
Optional<String> proxyServerAddress = getProxyServerAddress();
|
||||||
|
return proxyServerAddress.isPresent() ? proxyServerAddress : getAccessAddress();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Optional<String> getAccessAddress() {
|
||||||
|
WebServer webServer = this.webserver.get();
|
||||||
|
if (!webServer.isEnabled()) {
|
||||||
|
return Optional.of(getFallbackExternalAddress());
|
||||||
|
}
|
||||||
|
return getIP().map(ip -> webServer.getProtocol() + "://" + ip);
|
||||||
|
}
|
||||||
|
|
||||||
|
private Optional<String> getIP() {
|
||||||
|
int port = webserver.get().getPort();
|
||||||
|
return config.isTrue(WebserverSettings.SHOW_ALTERNATIVE_IP)
|
||||||
|
? Optional.of(config.get(WebserverSettings.ALTERNATIVE_IP).replace("%port%", String.valueOf(port)))
|
||||||
|
: getServerPropertyIP().map(ip -> ip + ":" + port);
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getFallbackExternalAddress() {
|
||||||
|
return config.get(WebserverSettings.EXTERNAL_LINK);
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getFallbackLocalhostAddress() {
|
||||||
|
WebServer webServer = this.webserver.get();
|
||||||
|
return webServer.getProtocol() + "://localhost:" + webServer.getPort();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Optional<String> getProxyServerAddress() {
|
||||||
|
return dbSystem.getDatabase().query(ServerQueries.fetchProxyServerInformation()).map(Server::getWebAddress)
|
||||||
|
.filter(this::isValidAddress);
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isValidAddress(String address) {
|
||||||
|
return !address.isEmpty() && !address.equals("0.0.0.0");
|
||||||
|
}
|
||||||
|
|
||||||
|
public Optional<String> getServerPropertyIP() {
|
||||||
|
String ip = serverProperties.get().getIp();
|
||||||
|
return isValidAddress(ip) ? Optional.of(ip) : Optional.empty();
|
||||||
|
}
|
||||||
|
}
|
@ -19,8 +19,6 @@ package com.djrapitops.plan.delivery.webserver;
|
|||||||
import com.djrapitops.plan.settings.config.PlanConfig;
|
import com.djrapitops.plan.settings.config.PlanConfig;
|
||||||
import com.djrapitops.plan.settings.config.paths.PluginSettings;
|
import com.djrapitops.plan.settings.config.paths.PluginSettings;
|
||||||
import com.djrapitops.plan.settings.config.paths.WebserverSettings;
|
import com.djrapitops.plan.settings.config.paths.WebserverSettings;
|
||||||
import com.djrapitops.plan.storage.database.DBSystem;
|
|
||||||
import com.djrapitops.plan.storage.database.queries.objects.ServerQueries;
|
|
||||||
import com.djrapitops.plugin.logging.L;
|
import com.djrapitops.plugin.logging.L;
|
||||||
import com.djrapitops.plugin.logging.console.PluginLogger;
|
import com.djrapitops.plugin.logging.console.PluginLogger;
|
||||||
import com.djrapitops.plugin.logging.error.ErrorHandler;
|
import com.djrapitops.plugin.logging.error.ErrorHandler;
|
||||||
@ -35,20 +33,20 @@ import java.io.IOException;
|
|||||||
public class NonProxyWebserverDisableChecker implements Runnable {
|
public class NonProxyWebserverDisableChecker implements Runnable {
|
||||||
|
|
||||||
private final PlanConfig config;
|
private final PlanConfig config;
|
||||||
private final DBSystem dbSystem;
|
private final Addresses addresses;
|
||||||
private final WebServerSystem webServerSystem;
|
private final WebServerSystem webServerSystem;
|
||||||
private final PluginLogger logger;
|
private final PluginLogger logger;
|
||||||
private final ErrorHandler errorHandler;
|
private final ErrorHandler errorHandler;
|
||||||
|
|
||||||
public NonProxyWebserverDisableChecker(
|
public NonProxyWebserverDisableChecker(
|
||||||
PlanConfig config,
|
PlanConfig config,
|
||||||
DBSystem dbSystem,
|
Addresses addresses,
|
||||||
WebServerSystem webServerSystem,
|
WebServerSystem webServerSystem,
|
||||||
PluginLogger logger,
|
PluginLogger logger,
|
||||||
ErrorHandler errorHandler
|
ErrorHandler errorHandler
|
||||||
) {
|
) {
|
||||||
this.config = config;
|
this.config = config;
|
||||||
this.dbSystem = dbSystem;
|
this.addresses = addresses;
|
||||||
this.webServerSystem = webServerSystem;
|
this.webServerSystem = webServerSystem;
|
||||||
this.logger = logger;
|
this.logger = logger;
|
||||||
this.errorHandler = errorHandler;
|
this.errorHandler = errorHandler;
|
||||||
@ -58,8 +56,8 @@ public class NonProxyWebserverDisableChecker implements Runnable {
|
|||||||
public void run() {
|
public void run() {
|
||||||
if (config.isFalse(PluginSettings.PROXY_COPY_CONFIG)) return;
|
if (config.isFalse(PluginSettings.PROXY_COPY_CONFIG)) return;
|
||||||
|
|
||||||
dbSystem.getDatabase().query(ServerQueries.fetchProxyServerInformation()).ifPresent(proxy -> {
|
addresses.getProxyServerAddress().ifPresent(address -> {
|
||||||
logger.info("Proxy server detected in the database - Proxy Webserver address is '" + proxy.getWebAddress() + "'.");
|
logger.info("Proxy server detected in the database - Proxy Webserver address is '" + address + "'.");
|
||||||
WebServer webServer = webServerSystem.getWebServer();
|
WebServer webServer = webServerSystem.getWebServer();
|
||||||
|
|
||||||
if (webServer.isEnabled()) {
|
if (webServer.isEnabled()) {
|
||||||
|
@ -23,7 +23,6 @@ import com.djrapitops.plan.settings.config.PlanConfig;
|
|||||||
import com.djrapitops.plan.settings.config.paths.PluginSettings;
|
import com.djrapitops.plan.settings.config.paths.PluginSettings;
|
||||||
import com.djrapitops.plan.settings.config.paths.WebserverSettings;
|
import com.djrapitops.plan.settings.config.paths.WebserverSettings;
|
||||||
import com.djrapitops.plan.settings.locale.Locale;
|
import com.djrapitops.plan.settings.locale.Locale;
|
||||||
import com.djrapitops.plan.settings.theme.Theme;
|
|
||||||
import com.djrapitops.plan.storage.database.DBSystem;
|
import com.djrapitops.plan.storage.database.DBSystem;
|
||||||
import com.djrapitops.plugin.logging.L;
|
import com.djrapitops.plugin.logging.L;
|
||||||
import com.djrapitops.plugin.logging.console.PluginLogger;
|
import com.djrapitops.plugin.logging.console.PluginLogger;
|
||||||
@ -52,8 +51,8 @@ public class RequestHandler implements HttpHandler {
|
|||||||
|
|
||||||
private final Locale locale;
|
private final Locale locale;
|
||||||
private final PlanConfig config;
|
private final PlanConfig config;
|
||||||
private final Theme theme;
|
|
||||||
private final DBSystem dbSystem;
|
private final DBSystem dbSystem;
|
||||||
|
private final Addresses addresses;
|
||||||
private final ResponseResolver responseResolver;
|
private final ResponseResolver responseResolver;
|
||||||
private final ResponseFactory responseFactory;
|
private final ResponseFactory responseFactory;
|
||||||
private final PluginLogger logger;
|
private final PluginLogger logger;
|
||||||
@ -67,8 +66,8 @@ public class RequestHandler implements HttpHandler {
|
|||||||
RequestHandler(
|
RequestHandler(
|
||||||
Locale locale,
|
Locale locale,
|
||||||
PlanConfig config,
|
PlanConfig config,
|
||||||
Theme theme,
|
|
||||||
DBSystem dbSystem,
|
DBSystem dbSystem,
|
||||||
|
Addresses addresses,
|
||||||
ResponseResolver responseResolver,
|
ResponseResolver responseResolver,
|
||||||
ResponseFactory responseFactory,
|
ResponseFactory responseFactory,
|
||||||
PluginLogger logger,
|
PluginLogger logger,
|
||||||
@ -76,8 +75,8 @@ public class RequestHandler implements HttpHandler {
|
|||||||
) {
|
) {
|
||||||
this.locale = locale;
|
this.locale = locale;
|
||||||
this.config = config;
|
this.config = config;
|
||||||
this.theme = theme;
|
|
||||||
this.dbSystem = dbSystem;
|
this.dbSystem = dbSystem;
|
||||||
|
this.addresses = addresses;
|
||||||
this.responseResolver = responseResolver;
|
this.responseResolver = responseResolver;
|
||||||
this.responseFactory = responseFactory;
|
this.responseFactory = responseFactory;
|
||||||
this.logger = logger;
|
this.logger = logger;
|
||||||
@ -109,7 +108,7 @@ public class RequestHandler implements HttpHandler {
|
|||||||
response.getHeaders().putIfAbsent("Access-Control-Allow-Origin", config.get(WebserverSettings.CORS_ALLOW_ORIGIN));
|
response.getHeaders().putIfAbsent("Access-Control-Allow-Origin", config.get(WebserverSettings.CORS_ALLOW_ORIGIN));
|
||||||
response.getHeaders().putIfAbsent("Access-Control-Allow-Methods", "GET, OPTIONS");
|
response.getHeaders().putIfAbsent("Access-Control-Allow-Methods", "GET, OPTIONS");
|
||||||
|
|
||||||
ResponseSender sender = new ResponseSender(exchange, response);
|
ResponseSender sender = new ResponseSender(addresses, exchange, response);
|
||||||
sender.send();
|
sender.send();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
if (config.isTrue(PluginSettings.DEV_MODE)) {
|
if (config.isTrue(PluginSettings.DEV_MODE)) {
|
||||||
|
@ -33,10 +33,12 @@ import java.util.zip.GZIPOutputStream;
|
|||||||
*/
|
*/
|
||||||
public class ResponseSender {
|
public class ResponseSender {
|
||||||
|
|
||||||
|
private final Addresses addresses;
|
||||||
private final HttpExchange exchange;
|
private final HttpExchange exchange;
|
||||||
private final Response response;
|
private final Response response;
|
||||||
|
|
||||||
public ResponseSender(HttpExchange exchange, Response response) {
|
public ResponseSender(Addresses addresses, HttpExchange exchange, Response response) {
|
||||||
|
this.addresses = addresses;
|
||||||
this.exchange = exchange;
|
this.exchange = exchange;
|
||||||
this.response = response;
|
this.response = response;
|
||||||
}
|
}
|
||||||
@ -52,11 +54,23 @@ public class ResponseSender {
|
|||||||
|
|
||||||
private void setResponseHeaders() {
|
private void setResponseHeaders() {
|
||||||
Headers headers = exchange.getResponseHeaders();
|
Headers headers = exchange.getResponseHeaders();
|
||||||
for (Map.Entry<String, String> header : response.getHeaders().entrySet()) {
|
|
||||||
|
Map<String, String> responseHeaders = response.getHeaders();
|
||||||
|
correctRedirect(responseHeaders);
|
||||||
|
|
||||||
|
for (Map.Entry<String, String> header : responseHeaders.entrySet()) {
|
||||||
headers.set(header.getKey(), header.getValue());
|
headers.set(header.getKey(), header.getValue());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void correctRedirect(Map<String, String> responseHeaders) {
|
||||||
|
String redirect = responseHeaders.get("Location");
|
||||||
|
if (redirect != null) {
|
||||||
|
if (redirect.startsWith("http") || !redirect.startsWith("/")) return;
|
||||||
|
addresses.getAccessAddress().ifPresent(address -> responseHeaders.put("Location", address + redirect));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void sendCompressed() throws IOException {
|
private void sendCompressed() throws IOException {
|
||||||
exchange.getResponseHeaders().set("Content-Encoding", "gzip");
|
exchange.getResponseHeaders().set("Content-Encoding", "gzip");
|
||||||
beginSend();
|
beginSend();
|
||||||
|
@ -58,6 +58,7 @@ public class WebServer implements SubSystem {
|
|||||||
private final PlanConfig config;
|
private final PlanConfig config;
|
||||||
|
|
||||||
private final ServerProperties serverProperties;
|
private final ServerProperties serverProperties;
|
||||||
|
private Addresses addresses;
|
||||||
private final RequestHandler requestHandler;
|
private final RequestHandler requestHandler;
|
||||||
|
|
||||||
private final PluginLogger logger;
|
private final PluginLogger logger;
|
||||||
@ -75,6 +76,7 @@ public class WebServer implements SubSystem {
|
|||||||
PlanFiles files,
|
PlanFiles files,
|
||||||
PlanConfig config,
|
PlanConfig config,
|
||||||
ServerInfo serverInfo,
|
ServerInfo serverInfo,
|
||||||
|
Addresses addresses,
|
||||||
PluginLogger logger,
|
PluginLogger logger,
|
||||||
ErrorHandler errorHandler,
|
ErrorHandler errorHandler,
|
||||||
RequestHandler requestHandler
|
RequestHandler requestHandler
|
||||||
@ -83,6 +85,7 @@ public class WebServer implements SubSystem {
|
|||||||
this.files = files;
|
this.files = files;
|
||||||
this.config = config;
|
this.config = config;
|
||||||
this.serverProperties = serverInfo.getServerProperties();
|
this.serverProperties = serverInfo.getServerProperties();
|
||||||
|
this.addresses = addresses;
|
||||||
|
|
||||||
this.requestHandler = requestHandler;
|
this.requestHandler = requestHandler;
|
||||||
|
|
||||||
@ -96,7 +99,7 @@ public class WebServer implements SubSystem {
|
|||||||
|
|
||||||
initServer();
|
initServer();
|
||||||
|
|
||||||
if (getAccessAddress().contains("0.0.0.0")) {
|
if (!addresses.getAccessAddress().isPresent()) {
|
||||||
logger.warn(locale.getString(PluginLang.ENABLE_NOTIFY_BAD_IP));
|
logger.warn(locale.getString(PluginLang.ENABLE_NOTIFY_BAD_IP));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -156,9 +159,11 @@ public class WebServer implements SubSystem {
|
|||||||
|
|
||||||
enabled = true;
|
enabled = true;
|
||||||
|
|
||||||
logger.info(locale.getString(PluginLang.ENABLED_WEB_SERVER, server.getAddress().getPort(), getAccessAddress()));
|
String address = addresses.getAccessAddress().orElse(addresses.getFallbackLocalhostAddress());
|
||||||
|
logger.info(locale.getString(PluginLang.ENABLED_WEB_SERVER, server.getAddress().getPort(), address));
|
||||||
|
|
||||||
boolean usingAlternativeIP = config.isTrue(WebserverSettings.SHOW_ALTERNATIVE_IP);
|
boolean usingAlternativeIP = config.isTrue(WebserverSettings.SHOW_ALTERNATIVE_IP);
|
||||||
if (!usingAlternativeIP && serverProperties.getIp().isEmpty()) {
|
if (!usingAlternativeIP && !addresses.getAccessAddress().isPresent()) {
|
||||||
logger.log(L.INFO_COLOR, "§e" + locale.getString(PluginLang.ENABLE_NOTIFY_EMPTY_IP));
|
logger.log(L.INFO_COLOR, "§e" + locale.getString(PluginLang.ENABLE_NOTIFY_EMPTY_IP));
|
||||||
}
|
}
|
||||||
} catch (BindException failedToBind) {
|
} catch (BindException failedToBind) {
|
||||||
@ -298,13 +303,7 @@ public class WebServer implements SubSystem {
|
|||||||
return isUsingHTTPS() && config.isFalse(WebserverSettings.DISABLED_AUTHENTICATION);
|
return isUsingHTTPS() && config.isFalse(WebserverSettings.DISABLED_AUTHENTICATION);
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getAccessAddress() {
|
public int getPort() {
|
||||||
return isEnabled() ? getProtocol() + "://" + getIP() : config.get(WebserverSettings.EXTERNAL_LINK);
|
return port;
|
||||||
}
|
|
||||||
|
|
||||||
private String getIP() {
|
|
||||||
return config.isTrue(WebserverSettings.SHOW_ALTERNATIVE_IP)
|
|
||||||
? config.get(WebserverSettings.ALTERNATIVE_IP).replace("%port%", String.valueOf(port))
|
|
||||||
: serverProperties.getIp() + ":" + port;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,12 +30,15 @@ import javax.inject.Singleton;
|
|||||||
@Singleton
|
@Singleton
|
||||||
public class WebServerSystem implements SubSystem {
|
public class WebServerSystem implements SubSystem {
|
||||||
|
|
||||||
|
private final Addresses addresses;
|
||||||
private final WebServer webServer;
|
private final WebServer webServer;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public WebServerSystem(
|
public WebServerSystem(
|
||||||
|
Addresses addresses,
|
||||||
WebServer webServer
|
WebServer webServer
|
||||||
) {
|
) {
|
||||||
|
this.addresses = addresses;
|
||||||
this.webServer = webServer;
|
this.webServer = webServer;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -55,4 +58,7 @@ public class WebServerSystem implements SubSystem {
|
|||||||
return webServer;
|
return webServer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Addresses getAddresses() {
|
||||||
|
return addresses;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -23,12 +23,10 @@ import com.djrapitops.plan.delivery.web.resolver.request.Request;
|
|||||||
import com.djrapitops.plan.delivery.web.resolver.request.URIPath;
|
import com.djrapitops.plan.delivery.web.resolver.request.URIPath;
|
||||||
import com.djrapitops.plan.delivery.web.resolver.request.WebUser;
|
import com.djrapitops.plan.delivery.web.resolver.request.WebUser;
|
||||||
import com.djrapitops.plan.delivery.webserver.ResponseFactory;
|
import com.djrapitops.plan.delivery.webserver.ResponseFactory;
|
||||||
import com.djrapitops.plan.delivery.webserver.WebServer;
|
|
||||||
import com.djrapitops.plan.identification.Server;
|
import com.djrapitops.plan.identification.Server;
|
||||||
import com.djrapitops.plan.identification.ServerInfo;
|
import com.djrapitops.plan.identification.ServerInfo;
|
||||||
import com.djrapitops.plan.storage.database.DBSystem;
|
import com.djrapitops.plan.storage.database.DBSystem;
|
||||||
import com.djrapitops.plan.storage.database.queries.objects.ServerQueries;
|
import com.djrapitops.plan.storage.database.queries.objects.ServerQueries;
|
||||||
import dagger.Lazy;
|
|
||||||
|
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
import javax.inject.Singleton;
|
import javax.inject.Singleton;
|
||||||
@ -46,19 +44,16 @@ public class ServerPageResolver implements Resolver {
|
|||||||
private final ResponseFactory responseFactory;
|
private final ResponseFactory responseFactory;
|
||||||
private final DBSystem dbSystem;
|
private final DBSystem dbSystem;
|
||||||
private final ServerInfo serverInfo;
|
private final ServerInfo serverInfo;
|
||||||
private final Lazy<WebServer> webServer;
|
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public ServerPageResolver(
|
public ServerPageResolver(
|
||||||
ResponseFactory responseFactory,
|
ResponseFactory responseFactory,
|
||||||
DBSystem dbSystem,
|
DBSystem dbSystem,
|
||||||
ServerInfo serverInfo,
|
ServerInfo serverInfo
|
||||||
Lazy<WebServer> webServer
|
|
||||||
) {
|
) {
|
||||||
this.responseFactory = responseFactory;
|
this.responseFactory = responseFactory;
|
||||||
this.dbSystem = dbSystem;
|
this.dbSystem = dbSystem;
|
||||||
this.serverInfo = serverInfo;
|
this.serverInfo = serverInfo;
|
||||||
this.webServer = webServer;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -81,7 +76,7 @@ public class ServerPageResolver implements Resolver {
|
|||||||
String directTo = serverInfo.getServer().isProxy()
|
String directTo = serverInfo.getServer().isProxy()
|
||||||
? "/network"
|
? "/network"
|
||||||
: "/server/" + Html.encodeToURL(serverInfo.getServer().getIdentifiableName());
|
: "/server/" + Html.encodeToURL(serverInfo.getServer().getIdentifiableName());
|
||||||
return Optional.of(responseFactory.redirectResponse(webServer.get().getAccessAddress() + directTo));
|
return Optional.of(responseFactory.redirectResponse(directTo));
|
||||||
}
|
}
|
||||||
|
|
||||||
private Optional<Response> getServerPage(UUID serverUUID) {
|
private Optional<Response> getServerPage(UUID serverUUID) {
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.identification;
|
package com.djrapitops.plan.identification;
|
||||||
|
|
||||||
import com.djrapitops.plan.delivery.webserver.WebServer;
|
import com.djrapitops.plan.delivery.webserver.Addresses;
|
||||||
import com.djrapitops.plan.exceptions.EnableException;
|
import com.djrapitops.plan.exceptions.EnableException;
|
||||||
import com.djrapitops.plan.exceptions.database.DBOpException;
|
import com.djrapitops.plan.exceptions.database.DBOpException;
|
||||||
import com.djrapitops.plan.identification.properties.ServerProperties;
|
import com.djrapitops.plan.identification.properties.ServerProperties;
|
||||||
@ -29,7 +29,6 @@ import com.djrapitops.plan.storage.database.queries.objects.ServerQueries;
|
|||||||
import com.djrapitops.plan.storage.database.transactions.StoreServerInformationTransaction;
|
import com.djrapitops.plan.storage.database.transactions.StoreServerInformationTransaction;
|
||||||
import com.djrapitops.plugin.logging.L;
|
import com.djrapitops.plugin.logging.L;
|
||||||
import com.djrapitops.plugin.logging.error.ErrorHandler;
|
import com.djrapitops.plugin.logging.error.ErrorHandler;
|
||||||
import dagger.Lazy;
|
|
||||||
|
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
import javax.inject.Singleton;
|
import javax.inject.Singleton;
|
||||||
@ -53,7 +52,7 @@ public class ServerServerInfo extends ServerInfo {
|
|||||||
private final PlanConfig config;
|
private final PlanConfig config;
|
||||||
private final Processing processing;
|
private final Processing processing;
|
||||||
private final DBSystem dbSystem;
|
private final DBSystem dbSystem;
|
||||||
private final Lazy<WebServer> webServer;
|
private final Addresses addresses;
|
||||||
private final ErrorHandler errorHandler;
|
private final ErrorHandler errorHandler;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
@ -63,14 +62,14 @@ public class ServerServerInfo extends ServerInfo {
|
|||||||
Processing processing,
|
Processing processing,
|
||||||
PlanConfig config,
|
PlanConfig config,
|
||||||
DBSystem dbSystem,
|
DBSystem dbSystem,
|
||||||
Lazy<WebServer> webServer,
|
Addresses addresses,
|
||||||
ErrorHandler errorHandler
|
ErrorHandler errorHandler
|
||||||
) {
|
) {
|
||||||
super(serverProperties);
|
super(serverProperties);
|
||||||
this.serverInfoFile = serverInfoFile;
|
this.serverInfoFile = serverInfoFile;
|
||||||
this.processing = processing;
|
this.processing = processing;
|
||||||
this.dbSystem = dbSystem;
|
this.dbSystem = dbSystem;
|
||||||
this.webServer = webServer;
|
this.addresses = addresses;
|
||||||
this.config = config;
|
this.config = config;
|
||||||
this.errorHandler = errorHandler;
|
this.errorHandler = errorHandler;
|
||||||
}
|
}
|
||||||
@ -128,8 +127,7 @@ public class ServerServerInfo extends ServerInfo {
|
|||||||
String name = config.get(PluginSettings.SERVER_NAME);
|
String name = config.get(PluginSettings.SERVER_NAME);
|
||||||
server.setName("plan".equalsIgnoreCase(name) ? "Server " + server.getId() : name);
|
server.setName("plan".equalsIgnoreCase(name) ? "Server " + server.getId() : name);
|
||||||
|
|
||||||
String webAddress = webServer.get().getAccessAddress();
|
addresses.getAccessAddress().ifPresent(server::setWebAddress);
|
||||||
server.setWebAddress(webAddress);
|
|
||||||
|
|
||||||
int maxPlayers = serverProperties.getMaxPlayers();
|
int maxPlayers = serverProperties.getMaxPlayers();
|
||||||
server.setMaxPlayers(maxPlayers);
|
server.setMaxPlayers(maxPlayers);
|
||||||
@ -161,7 +159,7 @@ public class ServerServerInfo extends ServerInfo {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private Server createServerObject(UUID serverUUID) {
|
private Server createServerObject(UUID serverUUID) {
|
||||||
String webAddress = webServer.get().getAccessAddress();
|
String webAddress = addresses.getAccessAddress().orElse(addresses.getFallbackLocalhostAddress());
|
||||||
String name = config.get(PluginSettings.SERVER_NAME);
|
String name = config.get(PluginSettings.SERVER_NAME);
|
||||||
int maxPlayers = serverProperties.getMaxPlayers();
|
int maxPlayers = serverProperties.getMaxPlayers();
|
||||||
return new Server(-1, serverUUID, name, webAddress, maxPlayers);
|
return new Server(-1, serverUUID, name, webAddress, maxPlayers);
|
||||||
|
@ -73,7 +73,8 @@ public enum CommandLang implements Lang {
|
|||||||
DISABLE_DISABLED("Cmd Disable - Disabled", "§aPlan systems are now disabled. You can still use /planbungee reload to restart the plugin."),
|
DISABLE_DISABLED("Cmd Disable - Disabled", "§aPlan systems are now disabled. You can still use /planbungee reload to restart the plugin."),
|
||||||
|
|
||||||
RELOAD_COMPLETE("Cmd Info - Reload Complete", "§aReload Complete"),
|
RELOAD_COMPLETE("Cmd Info - Reload Complete", "§aReload Complete"),
|
||||||
RELOAD_FAILED("Cmd Info - Reload Failed", "§cSomething went wrong during reload of the plugin, a restart is recommended.");
|
RELOAD_FAILED("Cmd Info - Reload Failed", "§cSomething went wrong during reload of the plugin, a restart is recommended."),
|
||||||
|
NO_ADDRESS_NOTIFY("Cmd Notify - No Address", "§eNo address was available - using localhost as fallback. Set up 'Alternative_IP' settings.");
|
||||||
|
|
||||||
private final String identifier;
|
private final String identifier;
|
||||||
private final String defaultValue;
|
private final String defaultValue;
|
||||||
|
@ -28,8 +28,8 @@ public enum PluginLang implements Lang {
|
|||||||
API_ADD_RESOURCE_JS("API - js+", "PageExtension: ${0} added javascript(s) to ${1}, ${2}"),
|
API_ADD_RESOURCE_JS("API - js+", "PageExtension: ${0} added javascript(s) to ${1}, ${2}"),
|
||||||
API_ADD_RESOURCE_CSS("API - css+", "PageExtension: ${0} added stylesheet(s) to ${1}, ${2}"),
|
API_ADD_RESOURCE_CSS("API - css+", "PageExtension: ${0} added stylesheet(s) to ${1}, ${2}"),
|
||||||
|
|
||||||
ENABLE_NOTIFY_EMPTY_IP("Enable - Notify Empty IP", "IP in server.properties is empty & AlternativeIP is not in use. Incorrect links will be given!"),
|
ENABLE_NOTIFY_EMPTY_IP("Enable - Notify Empty IP", "IP in server.properties is empty & Alternative_IP is not in use. Incorrect links might be given!"),
|
||||||
ENABLE_NOTIFY_BAD_IP("Enable - Notify Bad IP", "0.0.0.0 is not a valid address, set up AlternativeIP settings. Incorrect links will be given!"),
|
ENABLE_NOTIFY_BAD_IP("Enable - Notify Bad IP", "0.0.0.0 is not a valid address, set up Alternative_IP settings. Incorrect links might be given!"),
|
||||||
ENABLE_NOTIFY_WEB_SERVER_DISABLED("Enable - Notify Webserver disabled", "WebServer was not initialized. (WebServer.DisableWebServer: true)"),
|
ENABLE_NOTIFY_WEB_SERVER_DISABLED("Enable - Notify Webserver disabled", "WebServer was not initialized. (WebServer.DisableWebServer: true)"),
|
||||||
ENABLE_NOTIFY_GEOLOCATIONS_INTERNET_REQUIRED("Enable - Notify Geolocations Internet Required", "Plan Requires internet access on first run to download GeoLite2 Geolocation database."),
|
ENABLE_NOTIFY_GEOLOCATIONS_INTERNET_REQUIRED("Enable - Notify Geolocations Internet Required", "Plan Requires internet access on first run to download GeoLite2 Geolocation database."),
|
||||||
ENABLE_NOTIFY_GEOLOCATIONS_DISABLED("Enable - Notify Geolocations disabled", "Geolocation gathering is not active. (Data.Geolocations: false)"),
|
ENABLE_NOTIFY_GEOLOCATIONS_DISABLED("Enable - Notify Geolocations disabled", "Geolocation gathering is not active. (Data.Geolocations: false)"),
|
||||||
@ -45,7 +45,7 @@ public enum PluginLang implements Lang {
|
|||||||
WEB_SERVER_FAIL_EMPTY_FILE("WebServer FAIL - EOF", "WebServer: EOF when reading Certificate file. (Check that the file is not empty)"),
|
WEB_SERVER_FAIL_EMPTY_FILE("WebServer FAIL - EOF", "WebServer: EOF when reading Certificate file. (Check that the file is not empty)"),
|
||||||
WEB_SERVER_NOTIFY_NO_CERT_FILE("WebServer - Notify no Cert file", "WebServer: Certificate KeyStore File not Found: ${0}"),
|
WEB_SERVER_NOTIFY_NO_CERT_FILE("WebServer - Notify no Cert file", "WebServer: Certificate KeyStore File not Found: ${0}"),
|
||||||
WEB_SERVER_NOTIFY_HTTP("WebServer - Notify HTTP", "WebServer: No Certificate -> Using HTTP-server for Visualization."),
|
WEB_SERVER_NOTIFY_HTTP("WebServer - Notify HTTP", "WebServer: No Certificate -> Using HTTP-server for Visualization."),
|
||||||
WEB_SERVER_NOTIFY_USING_PROXY_MODE("WebServer - Notify Using Proxy", "WebServer: Proxy-mode HTTPS enabled, make sure that your reverse-proxy is routing using HTTPS and Plan AlternativeIP.Link points to the Proxy"),
|
WEB_SERVER_NOTIFY_USING_PROXY_MODE("WebServer - Notify Using Proxy", "WebServer: Proxy-mode HTTPS enabled, make sure that your reverse-proxy is routing using HTTPS and Plan Alternative_IP.Link points to the Proxy"),
|
||||||
WEB_SERVER_NOTIFY_HTTP_USER_AUTH("WebServer - Notify HTTP User Auth", "WebServer: User Authorization Disabled! (Not secure over HTTP)"),
|
WEB_SERVER_NOTIFY_HTTP_USER_AUTH("WebServer - Notify HTTP User Auth", "WebServer: User Authorization Disabled! (Not secure over HTTP)"),
|
||||||
WEB_SERVER_NOTIFY_HTTPS_USER_AUTH("WebServer - Notify HTTPS User Auth", "WebServer: User Authorization Disabled! (Disabled in config)"),
|
WEB_SERVER_NOTIFY_HTTPS_USER_AUTH("WebServer - Notify HTTPS User Auth", "WebServer: User Authorization Disabled! (Disabled in config)"),
|
||||||
|
|
||||||
|
@ -83,7 +83,7 @@ Disable - Unsaved Session Save || Saving unfinished sessions..
|
|||||||
Disable - WebServer || Webserver deaktiviert.
|
Disable - WebServer || Webserver deaktiviert.
|
||||||
Enable || Player Analytics eingeschaltet.
|
Enable || Player Analytics eingeschaltet.
|
||||||
Enable - Database || ${0}-dDatenbankverbindung hergestellt.
|
Enable - Database || ${0}-dDatenbankverbindung hergestellt.
|
||||||
Enable - Notify Empty IP || IP in der server.properties ist leer & AlternativeIP ist nicht in Verwendung. Es werden falsche Links verwendet!
|
Enable - Notify Empty IP || IP in der server.properties ist leer & Alternative_IP ist nicht in Verwendung. Es werden falsche Links verwendet!
|
||||||
Enable - Notify Geolocations disabled || Geolocation wird nicht aufgezeichnet (Data.Geolocations: false)
|
Enable - Notify Geolocations disabled || Geolocation wird nicht aufgezeichnet (Data.Geolocations: false)
|
||||||
Enable - Notify Geolocations Internet Required || Plan braucht einen Internetzugang um die GeoLite2 Geolocation Datenbank runterzuladen.
|
Enable - Notify Geolocations Internet Required || Plan braucht einen Internetzugang um die GeoLite2 Geolocation Datenbank runterzuladen.
|
||||||
Enable - Notify Webserver disabled || WebServer wurde nicht geladen. (WebServer.DisableWebServer: true)
|
Enable - Notify Webserver disabled || WebServer wurde nicht geladen. (WebServer.DisableWebServer: true)
|
||||||
|
@ -83,7 +83,7 @@ Disable - Unsaved Session Save || Saving unfinished sessions..
|
|||||||
Disable - WebServer || Webserver has been disabled.
|
Disable - WebServer || Webserver has been disabled.
|
||||||
Enable || Player Analytics Enabled.
|
Enable || Player Analytics Enabled.
|
||||||
Enable - Database || ${0}-database connection established.
|
Enable - Database || ${0}-database connection established.
|
||||||
Enable - Notify Empty IP || IP in server.properties is empty & AlternativeIP is not in use. Incorrect links will be given!
|
Enable - Notify Empty IP || IP in server.properties is empty & Alternative_IP is not in use. Incorrect links might be given!
|
||||||
Enable - Notify Geolocations disabled || Geolocation gathering is not active. (Data.Geolocations: false)
|
Enable - Notify Geolocations disabled || Geolocation gathering is not active. (Data.Geolocations: false)
|
||||||
Enable - Notify Geolocations Internet Required || Plan Requires internet access on first run to download GeoLite2 Geolocation database.
|
Enable - Notify Geolocations Internet Required || Plan Requires internet access on first run to download GeoLite2 Geolocation database.
|
||||||
Enable - Notify Webserver disabled || WebServer was not initialized. (WebServer.DisableWebServer: true)
|
Enable - Notify Webserver disabled || WebServer was not initialized. (WebServer.DisableWebServer: true)
|
||||||
|
@ -83,7 +83,7 @@ Disable - Unsaved Session Save || Tallennetaan päättymättöm
|
|||||||
Disable - WebServer || Web palvelin on sammutettu.
|
Disable - WebServer || Web palvelin on sammutettu.
|
||||||
Enable || Player Analytics Käynnistetty.
|
Enable || Player Analytics Käynnistetty.
|
||||||
Enable - Database || ${0}-tietokanta yhteys luotu.
|
Enable - Database || ${0}-tietokanta yhteys luotu.
|
||||||
Enable - Notify Empty IP || IP server.properties tiedostossa on tyhjä & AlternativeIP ei ole käytössä. Linkit ovat virheellisiä!
|
Enable - Notify Empty IP || IP server.properties tiedostossa on tyhjä & Alternative_IP ei ole käytössä. Linkit ovat virheellisiä!
|
||||||
Enable - Notify Geolocations disabled || Sijaintien keräys ei ole päällä. (Data.Geolocations: false)
|
Enable - Notify Geolocations disabled || Sijaintien keräys ei ole päällä. (Data.Geolocations: false)
|
||||||
Enable - Notify Geolocations Internet Required || Plan Vaatii internetin ensimmäisellä käynnistyskerralla GeoLite2 tietokannan lataamiseen.
|
Enable - Notify Geolocations Internet Required || Plan Vaatii internetin ensimmäisellä käynnistyskerralla GeoLite2 tietokannan lataamiseen.
|
||||||
Enable - Notify Webserver disabled || Web Palvelinta ei käynnistetty. (WebServer.DisableWebServer: true)
|
Enable - Notify Webserver disabled || Web Palvelinta ei käynnistetty. (WebServer.DisableWebServer: true)
|
||||||
|
@ -84,7 +84,7 @@ Disable - WebServer || Le serveur Web a été désac
|
|||||||
Enable || Plan a été activé.
|
Enable || Plan a été activé.
|
||||||
Enable - Database || Connexion à la base de données établie. (${0})
|
Enable - Database || Connexion à la base de données établie. (${0})
|
||||||
Enable - Notify Bad IP || L'adresse IP située dans le fichier 'server.properties' est érronée. Attention, des liens incorrects seront donnés !
|
Enable - Notify Bad IP || L'adresse IP située dans le fichier 'server.properties' est érronée. Attention, des liens incorrects seront donnés !
|
||||||
Enable - Notify Empty IP || L'adresse IP située dans le fichier 'server.properties' est vide et l'option 'AlternativeIP' n'est pas utilisée. Attention, des liens incorrects seront donnés !
|
Enable - Notify Empty IP || L'adresse IP située dans le fichier 'server.properties' est vide et l'option 'Alternative_IP' n'est pas utilisée. Attention, des liens incorrects seront donnés !
|
||||||
Enable - Notify Geolocations disabled || La Géolocalisation n'est pas active. (Data.Geolocations: false)
|
Enable - Notify Geolocations disabled || La Géolocalisation n'est pas active. (Data.Geolocations: false)
|
||||||
Enable - Notify Geolocations Internet Required || Plan nécessite un accès à Internet lors de sa première utilisation pour télécharger la base de données 'GeoLite2 Geolocation'.
|
Enable - Notify Geolocations Internet Required || Plan nécessite un accès à Internet lors de sa première utilisation pour télécharger la base de données 'GeoLite2 Geolocation'.
|
||||||
Enable - Notify Webserver disabled || Le serveur Web n'a pas été initialisé. (WebServer.DisableWebServer: true)
|
Enable - Notify Webserver disabled || Le serveur Web n'a pas été initialisé. (WebServer.DisableWebServer: true)
|
||||||
@ -355,7 +355,7 @@ WebServer - Notify HTTP || Serveur Web : Aucun certifica
|
|||||||
WebServer - Notify HTTP User Auth || Serveur Web : Authentification utilisateur désactivée ! (Non sécurisée avec HTTP)
|
WebServer - Notify HTTP User Auth || Serveur Web : Authentification utilisateur désactivée ! (Non sécurisée avec HTTP)
|
||||||
WebServer - Notify HTTPS User Auth || Serveur Web : Authentification d'utilisateur désactivée ! (dans la configuration)
|
WebServer - Notify HTTPS User Auth || Serveur Web : Authentification d'utilisateur désactivée ! (dans la configuration)
|
||||||
WebServer - Notify no Cert file || Serveur Web : Fichier KeyStore du certificat introuvable : ${0}
|
WebServer - Notify no Cert file || Serveur Web : Fichier KeyStore du certificat introuvable : ${0}
|
||||||
WebServer - Notify Using Proxy || Serveur Web : le Proxy-mode HTTPS est activé, assurez-vous que votre proxy inversé est routé en utilisant HTTPS et Plan AlternativeIP.Link.
|
WebServer - Notify Using Proxy || Serveur Web : le Proxy-mode HTTPS est activé, assurez-vous que votre proxy inversé est routé en utilisant HTTPS et Plan Alternative_IP.Link.
|
||||||
WebServer FAIL - Port Bind || Le Serveur Web n'a pas été initialisé avec succès. Le port (${0}) est-il actuellement utilisé ?
|
WebServer FAIL - Port Bind || Le Serveur Web n'a pas été initialisé avec succès. Le port (${0}) est-il actuellement utilisé ?
|
||||||
WebServer FAIL - SSL Context || Serveur Web : Échec d'initialisation du contexte SSL.
|
WebServer FAIL - SSL Context || Serveur Web : Échec d'initialisation du contexte SSL.
|
||||||
WebServer FAIL - Store Load || Serveur Web : Échec du chargement du certificat SSL.
|
WebServer FAIL - Store Load || Serveur Web : Échec du chargement du certificat SSL.
|
||||||
|
@ -83,7 +83,7 @@ Disable - Unsaved Session Save || Salvano le sessioni..
|
|||||||
Disable - WebServer || Webserver è stato disabilitato.
|
Disable - WebServer || Webserver è stato disabilitato.
|
||||||
Enable || Analisi Giocatori Abilitata.
|
Enable || Analisi Giocatori Abilitata.
|
||||||
Enable - Database || ${0}-connession al database stabilita.
|
Enable - Database || ${0}-connession al database stabilita.
|
||||||
Enable - Notify Empty IP || IP in server.properties è vuoto e AlternativeIP non è in uso. Correggi queste informazioni!
|
Enable - Notify Empty IP || IP in server.properties è vuoto e Alternative_IP non è in uso. Correggi queste informazioni!
|
||||||
Enable - Notify Geolocations disabled || Geolocalizazione non attiva. (Data.Geolocations: false)
|
Enable - Notify Geolocations disabled || Geolocalizazione non attiva. (Data.Geolocations: false)
|
||||||
Enable - Notify Geolocations Internet Required || Plan richiesta una connessione internet la prima volta per scaricare il database Geolite.
|
Enable - Notify Geolocations Internet Required || Plan richiesta una connessione internet la prima volta per scaricare il database Geolite.
|
||||||
Enable - Notify Webserver disabled || WebServer non avviato. (WebServer.DisableWebServer: true)
|
Enable - Notify Webserver disabled || WebServer non avviato. (WebServer.DisableWebServer: true)
|
||||||
|
@ -17,13 +17,10 @@
|
|||||||
package com.djrapitops.plan;
|
package com.djrapitops.plan;
|
||||||
|
|
||||||
import com.djrapitops.plan.exceptions.EnableException;
|
import com.djrapitops.plan.exceptions.EnableException;
|
||||||
import com.djrapitops.plan.identification.Server;
|
|
||||||
import com.djrapitops.plan.settings.ConfigSettingKeyTest;
|
import com.djrapitops.plan.settings.ConfigSettingKeyTest;
|
||||||
import com.djrapitops.plan.settings.config.PlanConfig;
|
import com.djrapitops.plan.settings.config.PlanConfig;
|
||||||
import com.djrapitops.plan.settings.config.paths.WebserverSettings;
|
import com.djrapitops.plan.settings.config.paths.WebserverSettings;
|
||||||
import com.djrapitops.plan.settings.config.paths.key.Setting;
|
import com.djrapitops.plan.settings.config.paths.key.Setting;
|
||||||
import com.djrapitops.plan.storage.database.Database;
|
|
||||||
import com.djrapitops.plan.storage.database.queries.objects.ServerQueries;
|
|
||||||
import org.junit.jupiter.api.BeforeEach;
|
import org.junit.jupiter.api.BeforeEach;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.io.TempDir;
|
import org.junit.jupiter.api.io.TempDir;
|
||||||
@ -32,9 +29,7 @@ import utilities.mocks.NukkitMockComponent;
|
|||||||
|
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Optional;
|
|
||||||
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertTrue;
|
import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -64,21 +59,6 @@ public class NukkitSystemTest {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
void correctWebAddressInDatabaseAfterEnable() throws EnableException {
|
|
||||||
try {
|
|
||||||
system.enable();
|
|
||||||
Database database = system.getDatabaseSystem().getDatabase();
|
|
||||||
String expectedAddress = system.getWebServerSystem().getWebServer().getAccessAddress();
|
|
||||||
Optional<String> found = database.query(ServerQueries.fetchServerMatchingIdentifier(system.getServerInfo().getServerUUID()))
|
|
||||||
.map(Server::getWebAddress);
|
|
||||||
|
|
||||||
assertEquals(expectedAddress, found.orElse(null));
|
|
||||||
} finally {
|
|
||||||
system.disable();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void nukkitSystemHasDefaultConfigValuesAfterEnable() throws EnableException, IllegalAccessException {
|
void nukkitSystemHasDefaultConfigValuesAfterEnable() throws EnableException, IllegalAccessException {
|
||||||
try {
|
try {
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.identification;
|
package com.djrapitops.plan.identification;
|
||||||
|
|
||||||
import com.djrapitops.plan.delivery.webserver.WebServer;
|
import com.djrapitops.plan.delivery.webserver.Addresses;
|
||||||
import com.djrapitops.plan.exceptions.EnableException;
|
import com.djrapitops.plan.exceptions.EnableException;
|
||||||
import com.djrapitops.plan.exceptions.database.DBOpException;
|
import com.djrapitops.plan.exceptions.database.DBOpException;
|
||||||
import com.djrapitops.plan.identification.properties.ServerProperties;
|
import com.djrapitops.plan.identification.properties.ServerProperties;
|
||||||
@ -25,7 +25,6 @@ import com.djrapitops.plan.storage.database.Database;
|
|||||||
import com.djrapitops.plan.storage.database.queries.objects.ServerQueries;
|
import com.djrapitops.plan.storage.database.queries.objects.ServerQueries;
|
||||||
import com.djrapitops.plan.storage.database.transactions.StoreServerInformationTransaction;
|
import com.djrapitops.plan.storage.database.transactions.StoreServerInformationTransaction;
|
||||||
import com.djrapitops.plugin.logging.console.PluginLogger;
|
import com.djrapitops.plugin.logging.console.PluginLogger;
|
||||||
import dagger.Lazy;
|
|
||||||
|
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
import javax.inject.Singleton;
|
import javax.inject.Singleton;
|
||||||
@ -42,19 +41,19 @@ import java.util.concurrent.ExecutionException;
|
|||||||
public class VelocityServerInfo extends ServerInfo {
|
public class VelocityServerInfo extends ServerInfo {
|
||||||
|
|
||||||
private final DBSystem dbSystem;
|
private final DBSystem dbSystem;
|
||||||
private final Lazy<WebServer> webServer;
|
private final Addresses addresses;
|
||||||
private final PluginLogger logger;
|
private final PluginLogger logger;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public VelocityServerInfo(
|
public VelocityServerInfo(
|
||||||
ServerProperties serverProperties,
|
ServerProperties serverProperties,
|
||||||
DBSystem dbSystem,
|
DBSystem dbSystem,
|
||||||
Lazy<WebServer> webServer,
|
Addresses addresses,
|
||||||
PluginLogger logger
|
PluginLogger logger
|
||||||
) {
|
) {
|
||||||
super(serverProperties);
|
super(serverProperties);
|
||||||
this.dbSystem = dbSystem;
|
this.dbSystem = dbSystem;
|
||||||
this.webServer = webServer;
|
this.addresses = addresses;
|
||||||
this.logger = logger;
|
this.logger = logger;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -67,7 +66,7 @@ public class VelocityServerInfo extends ServerInfo {
|
|||||||
Optional<Server> proxyInfo = database.query(ServerQueries.fetchProxyServerInformation());
|
Optional<Server> proxyInfo = database.query(ServerQueries.fetchProxyServerInformation());
|
||||||
if (proxyInfo.isPresent()) {
|
if (proxyInfo.isPresent()) {
|
||||||
server = proxyInfo.get();
|
server = proxyInfo.get();
|
||||||
updateServerInfo(database);
|
updateServerInfo();
|
||||||
} else {
|
} else {
|
||||||
server = registerVelocityInfo(database);
|
server = registerVelocityInfo(database);
|
||||||
}
|
}
|
||||||
@ -78,26 +77,29 @@ public class VelocityServerInfo extends ServerInfo {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateServerInfo(Database db) {
|
private void updateServerInfo() {
|
||||||
String accessAddress = webServer.get().getAccessAddress();
|
addresses.getAccessAddress().ifPresent(this::saveAddress);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void saveAddress(String accessAddress) {
|
||||||
if (!accessAddress.equals(server.getWebAddress())) {
|
if (!accessAddress.equals(server.getWebAddress())) {
|
||||||
server.setWebAddress(accessAddress);
|
server.setWebAddress(accessAddress);
|
||||||
db.executeTransaction(new StoreServerInformationTransaction(server));
|
dbSystem.getDatabase().executeTransaction(new StoreServerInformationTransaction(server));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void checkIfDefaultIP() throws EnableException {
|
private void checkIfDefaultIP() throws EnableException {
|
||||||
String ip = serverProperties.getIp();
|
String ip = serverProperties.getIp();
|
||||||
if ("0.0.0.0".equals(ip)) {
|
if ("0.0.0.0".equals(ip)) {
|
||||||
logger.error("IP setting still 0.0.0.0 - Configure AlternativeIP/IP that connects to the Proxy server.");
|
logger.error("IP setting still 0.0.0.0 - Configure Alternative_IP/IP that connects to the Proxy server.");
|
||||||
logger.info("Player Analytics partially enabled (Use /planbungee to reload config)");
|
logger.info("Player Analytics partially enabled (Use /planbungee to reload config)");
|
||||||
throw new EnableException("IP setting still 0.0.0.0 - Configure AlternativeIP/IP that connects to the Proxy server.");
|
throw new EnableException("IP setting still 0.0.0.0 - Configure Alternative_IP/IP that connects to the Proxy server.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private Server registerVelocityInfo(Database db) throws EnableException, ExecutionException, InterruptedException {
|
private Server registerVelocityInfo(Database db) throws EnableException, ExecutionException, InterruptedException {
|
||||||
UUID serverUUID = generateNewUUID();
|
UUID serverUUID = generateNewUUID();
|
||||||
String accessAddress = webServer.get().getAccessAddress();
|
String accessAddress = addresses.getAccessAddress().orElseThrow(() -> new EnableException("Velocity can not have '0.0.0.0' or '' as an address. Set up 'Server.IP' setting."));
|
||||||
|
|
||||||
// TODO Rework to allow Velocity as name.
|
// TODO Rework to allow Velocity as name.
|
||||||
Server proxy = new Server(-1, serverUUID, "BungeeCord", accessAddress, serverProperties.getMaxPlayers());
|
Server proxy = new Server(-1, serverUUID, "BungeeCord", accessAddress, serverProperties.getMaxPlayers());
|
||||||
|
Loading…
Reference in New Issue
Block a user