mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2024-12-31 21:48:32 +01:00
Merge pull request #478 from Rsl1122/RefactoringBranch
Pull request for 4.1.4
This commit is contained in:
commit
1d5c162251
@ -4,7 +4,7 @@
|
|||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>com.djrapitops</groupId>
|
<groupId>com.djrapitops</groupId>
|
||||||
<artifactId>Plan</artifactId>
|
<artifactId>Plan</artifactId>
|
||||||
<version>4.1.3</version>
|
<version>4.1.3.2</version>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
<repositories>
|
<repositories>
|
||||||
<repository>
|
<repository>
|
||||||
@ -32,7 +32,7 @@
|
|||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.djrapitops</groupId>
|
<groupId>com.djrapitops</groupId>
|
||||||
<artifactId>PlanPluginBridge</artifactId>
|
<artifactId>PlanPluginBridge</artifactId>
|
||||||
<version>4.1.3</version>
|
<version>4.1.3.2</version>
|
||||||
<scope>compile</scope>
|
<scope>compile</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
<!-- Full PaperSpigot JAR -->
|
<!-- Full PaperSpigot JAR -->
|
||||||
|
@ -22,17 +22,13 @@ package main.java.com.djrapitops.plan;
|
|||||||
import com.djrapitops.plugin.BukkitPlugin;
|
import com.djrapitops.plugin.BukkitPlugin;
|
||||||
import com.djrapitops.plugin.StaticHolder;
|
import com.djrapitops.plugin.StaticHolder;
|
||||||
import com.djrapitops.plugin.api.Benchmark;
|
import com.djrapitops.plugin.api.Benchmark;
|
||||||
import com.djrapitops.plugin.api.Priority;
|
|
||||||
import com.djrapitops.plugin.api.TimeAmount;
|
import com.djrapitops.plugin.api.TimeAmount;
|
||||||
import com.djrapitops.plugin.api.config.Config;
|
import com.djrapitops.plugin.api.config.Config;
|
||||||
import com.djrapitops.plugin.api.systems.NotificationCenter;
|
|
||||||
import com.djrapitops.plugin.api.systems.TaskCenter;
|
import com.djrapitops.plugin.api.systems.TaskCenter;
|
||||||
import com.djrapitops.plugin.api.utility.Version;
|
|
||||||
import com.djrapitops.plugin.api.utility.log.DebugLog;
|
import com.djrapitops.plugin.api.utility.log.DebugLog;
|
||||||
import com.djrapitops.plugin.api.utility.log.Log;
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
import com.djrapitops.plugin.settings.ColorScheme;
|
import com.djrapitops.plugin.settings.ColorScheme;
|
||||||
import com.djrapitops.plugin.task.AbsRunnable;
|
import com.djrapitops.plugin.task.AbsRunnable;
|
||||||
import com.djrapitops.plugin.task.ITask;
|
|
||||||
import com.djrapitops.plugin.task.RunnableFactory;
|
import com.djrapitops.plugin.task.RunnableFactory;
|
||||||
import main.java.com.djrapitops.plan.api.API;
|
import main.java.com.djrapitops.plan.api.API;
|
||||||
import main.java.com.djrapitops.plan.api.IPlan;
|
import main.java.com.djrapitops.plan.api.IPlan;
|
||||||
@ -43,12 +39,14 @@ import main.java.com.djrapitops.plan.database.Database;
|
|||||||
import main.java.com.djrapitops.plan.settings.Settings;
|
import main.java.com.djrapitops.plan.settings.Settings;
|
||||||
import main.java.com.djrapitops.plan.settings.locale.Locale;
|
import main.java.com.djrapitops.plan.settings.locale.Locale;
|
||||||
import main.java.com.djrapitops.plan.settings.locale.Msg;
|
import main.java.com.djrapitops.plan.settings.locale.Msg;
|
||||||
|
import main.java.com.djrapitops.plan.settings.theme.PlanColorScheme;
|
||||||
import main.java.com.djrapitops.plan.settings.theme.Theme;
|
import main.java.com.djrapitops.plan.settings.theme.Theme;
|
||||||
import main.java.com.djrapitops.plan.systems.DatabaseSystem;
|
|
||||||
import main.java.com.djrapitops.plan.systems.FileSystem;
|
|
||||||
import main.java.com.djrapitops.plan.systems.Systems;
|
import main.java.com.djrapitops.plan.systems.Systems;
|
||||||
import main.java.com.djrapitops.plan.systems.cache.DataCache;
|
import main.java.com.djrapitops.plan.systems.cache.DataCache;
|
||||||
import main.java.com.djrapitops.plan.systems.cache.GeolocationCache;
|
import main.java.com.djrapitops.plan.systems.cache.GeolocationCache;
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.FileSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.config.ConfigSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.database.DBSystem;
|
||||||
import main.java.com.djrapitops.plan.systems.info.BukkitInformationManager;
|
import main.java.com.djrapitops.plan.systems.info.BukkitInformationManager;
|
||||||
import main.java.com.djrapitops.plan.systems.info.ImporterManager;
|
import main.java.com.djrapitops.plan.systems.info.ImporterManager;
|
||||||
import main.java.com.djrapitops.plan.systems.info.InformationManager;
|
import main.java.com.djrapitops.plan.systems.info.InformationManager;
|
||||||
@ -57,13 +55,13 @@ import main.java.com.djrapitops.plan.systems.listeners.*;
|
|||||||
import main.java.com.djrapitops.plan.systems.processing.Processor;
|
import main.java.com.djrapitops.plan.systems.processing.Processor;
|
||||||
import main.java.com.djrapitops.plan.systems.processing.importing.importers.OfflinePlayerImporter;
|
import main.java.com.djrapitops.plan.systems.processing.importing.importers.OfflinePlayerImporter;
|
||||||
import main.java.com.djrapitops.plan.systems.queue.ProcessingQueue;
|
import main.java.com.djrapitops.plan.systems.queue.ProcessingQueue;
|
||||||
import main.java.com.djrapitops.plan.systems.tasks.TPSCountTimer;
|
import main.java.com.djrapitops.plan.systems.tasks.TaskSystem;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.PageCache;
|
import main.java.com.djrapitops.plan.systems.update.VersionCheckSystem;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.WebServer;
|
import main.java.com.djrapitops.plan.systems.webserver.WebServer;
|
||||||
import main.java.com.djrapitops.plan.utilities.file.FileUtil;
|
import main.java.com.djrapitops.plan.systems.webserver.WebServerSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageCache;
|
||||||
import main.java.com.djrapitops.plan.utilities.file.export.HtmlExport;
|
import main.java.com.djrapitops.plan.utilities.file.export.HtmlExport;
|
||||||
import main.java.com.djrapitops.plan.utilities.metrics.BStats;
|
import main.java.com.djrapitops.plan.utilities.metrics.BStats;
|
||||||
import org.bukkit.ChatColor;
|
|
||||||
import org.bukkit.configuration.file.FileConfiguration;
|
import org.bukkit.configuration.file.FileConfiguration;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
@ -84,22 +82,15 @@ public class Plan extends BukkitPlugin implements IPlan {
|
|||||||
|
|
||||||
private API api;
|
private API api;
|
||||||
|
|
||||||
private Config config;
|
|
||||||
private Theme theme;
|
|
||||||
|
|
||||||
private Systems systems;
|
private Systems systems;
|
||||||
|
|
||||||
private ProcessingQueue processingQueue;
|
private ProcessingQueue processingQueue;
|
||||||
private HookHandler hookHandler; // Manages 3rd party data sources
|
private HookHandler hookHandler; // Manages 3rd party data sources
|
||||||
|
|
||||||
private WebServer webServer;
|
|
||||||
|
|
||||||
private BukkitInformationManager infoManager;
|
private BukkitInformationManager infoManager;
|
||||||
private BukkitServerInfoManager serverInfoManager;
|
private BukkitServerInfoManager serverInfoManager;
|
||||||
|
|
||||||
private ServerVariableHolder serverVariableHolder;
|
private ServerVariableHolder serverVariableHolder;
|
||||||
private TPSCountTimer tpsCountTimer;
|
|
||||||
private int bootAnalysisTaskID = -1;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Used to get the PlanAPI. @see API
|
* Used to get the PlanAPI. @see API
|
||||||
@ -145,28 +136,11 @@ public class Plan extends BukkitPlugin implements IPlan {
|
|||||||
try {
|
try {
|
||||||
systems = new Systems(this);
|
systems = new Systems(this);
|
||||||
FileSystem.getInstance().init();
|
FileSystem.getInstance().init();
|
||||||
|
ConfigSystem.getInstance().init();
|
||||||
config = new Config(FileSystem.getConfigFile());
|
|
||||||
config.copyDefaults(FileUtil.lines(this, "config.yml"));
|
|
||||||
config.save();
|
|
||||||
|
|
||||||
Log.setDebugMode(Settings.DEBUG.toString());
|
Log.setDebugMode(Settings.DEBUG.toString());
|
||||||
|
|
||||||
String currentVersion = getVersion();
|
VersionCheckSystem.getInstance().init();
|
||||||
String githubVersionUrl = "https://raw.githubusercontent.com/Rsl1122/Plan-PlayerAnalytics/master/Plan/src/main/resources/plugin.yml";
|
|
||||||
String spigotUrl = "https://www.spigotmc.org/resources/plan-player-analytics.32536/";
|
|
||||||
try {
|
|
||||||
if (Version.checkVersion(currentVersion, githubVersionUrl) || Version.checkVersion(currentVersion, spigotUrl)) {
|
|
||||||
Log.infoColor("§a----------------------------------------");
|
|
||||||
Log.infoColor("§aNew version is available at https://www.spigotmc.org/resources/plan-player-analytics.32536/");
|
|
||||||
Log.infoColor("§a----------------------------------------");
|
|
||||||
NotificationCenter.addNotification(Priority.HIGH, "New Version is available at https://www.spigotmc.org/resources/plan-player-analytics.32536/");
|
|
||||||
} else {
|
|
||||||
Log.info("You're using the latest version.");
|
|
||||||
}
|
|
||||||
} catch (IOException e) {
|
|
||||||
Log.error("Failed to check newest version number");
|
|
||||||
}
|
|
||||||
|
|
||||||
Benchmark.start("Enable");
|
Benchmark.start("Enable");
|
||||||
|
|
||||||
@ -178,26 +152,23 @@ public class Plan extends BukkitPlugin implements IPlan {
|
|||||||
throw new PlanEnableException("Something went wrong saving the downloaded GeoLite2 Geolocation database", e);
|
throw new PlanEnableException("Something went wrong saving the downloaded GeoLite2 Geolocation database", e);
|
||||||
}
|
}
|
||||||
|
|
||||||
new Locale(this).loadLocale();
|
new Locale().loadLocale();
|
||||||
|
|
||||||
theme = new Theme();
|
Theme.getInstance().init();
|
||||||
|
|
||||||
Benchmark.start("Reading server variables");
|
Benchmark.start("Reading server variables");
|
||||||
serverVariableHolder = new ServerVariableHolder(getServer());
|
serverVariableHolder = new ServerVariableHolder(getServer());
|
||||||
Benchmark.stop("Enable", "Reading server variables");
|
Benchmark.stop("Enable", "Reading server variables");
|
||||||
|
|
||||||
DatabaseSystem.getInstance().init();
|
DBSystem.getInstance().init();
|
||||||
|
|
||||||
Benchmark.start("WebServer Initialization");
|
Benchmark.start("WebServer Initialization");
|
||||||
webServer = new WebServer(this);
|
|
||||||
|
|
||||||
processingQueue = new ProcessingQueue();
|
processingQueue = new ProcessingQueue();
|
||||||
|
|
||||||
serverInfoManager = new BukkitServerInfoManager(this);
|
serverInfoManager = new BukkitServerInfoManager(this);
|
||||||
infoManager = new BukkitInformationManager(this);
|
infoManager = new BukkitInformationManager(this);
|
||||||
|
WebServerSystem.getInstance().init();
|
||||||
webServer.initServer();
|
if (!WebServerSystem.isWebServerEnabled()) {
|
||||||
if (!webServer.isEnabled()) {
|
|
||||||
if (Settings.WEBSERVER_DISABLED.isTrue()) {
|
if (Settings.WEBSERVER_DISABLED.isTrue()) {
|
||||||
Log.warn("WebServer was not initialized. (WebServer.DisableWebServer: true)");
|
Log.warn("WebServer was not initialized. (WebServer.DisableWebServer: true)");
|
||||||
} else {
|
} else {
|
||||||
@ -206,6 +177,7 @@ public class Plan extends BukkitPlugin implements IPlan {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
serverInfoManager.updateServerInfo();
|
serverInfoManager.updateServerInfo();
|
||||||
|
infoManager.updateConnection();
|
||||||
|
|
||||||
Benchmark.stop("Enable", "WebServer Initialization");
|
Benchmark.stop("Enable", "WebServer Initialization");
|
||||||
|
|
||||||
@ -213,7 +185,8 @@ public class Plan extends BukkitPlugin implements IPlan {
|
|||||||
registerListeners();
|
registerListeners();
|
||||||
}
|
}
|
||||||
PlanPlayerListener.setCountKicks(true);
|
PlanPlayerListener.setCountKicks(true);
|
||||||
registerTasks();
|
|
||||||
|
TaskSystem.getInstance().init();
|
||||||
|
|
||||||
this.api = new API(this);
|
this.api = new API(this);
|
||||||
|
|
||||||
@ -254,62 +227,9 @@ public class Plan extends BukkitPlugin implements IPlan {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void registerTasks() {
|
|
||||||
String bootAnalysisMsg = Locale.get(Msg.ENABLE_BOOT_ANALYSIS_INFO).toString();
|
|
||||||
String bootAnalysisRunMsg = Locale.get(Msg.ENABLE_BOOT_ANALYSIS_RUN_INFO).toString();
|
|
||||||
|
|
||||||
Benchmark.start("Task Registration");
|
|
||||||
tpsCountTimer = new TPSCountTimer(this);
|
|
||||||
RunnableFactory.createNew(tpsCountTimer).runTaskTimer(1000, TimeAmount.SECOND.ticks());
|
|
||||||
|
|
||||||
// Analysis refresh settings
|
|
||||||
int analysisRefreshMinutes = Settings.ANALYSIS_AUTO_REFRESH.getNumber();
|
|
||||||
boolean analysisRefreshTaskIsEnabled = analysisRefreshMinutes > 0;
|
|
||||||
long analysisPeriod = analysisRefreshMinutes * TimeAmount.MINUTE.ticks();
|
|
||||||
|
|
||||||
Log.info(bootAnalysisMsg);
|
|
||||||
|
|
||||||
ITask bootAnalysisTask = RunnableFactory.createNew("BootAnalysisTask", new AbsRunnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
Log.info(bootAnalysisRunMsg);
|
|
||||||
infoManager.refreshAnalysis(getServerUUID());
|
|
||||||
this.cancel();
|
|
||||||
}
|
|
||||||
}).runTaskLaterAsynchronously(30 * TimeAmount.SECOND.ticks());
|
|
||||||
|
|
||||||
bootAnalysisTaskID = bootAnalysisTask.getTaskId();
|
|
||||||
|
|
||||||
if (analysisRefreshTaskIsEnabled) {
|
|
||||||
RunnableFactory.createNew("PeriodicalAnalysisTask", new AbsRunnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
infoManager.refreshAnalysis(getServerUUID());
|
|
||||||
}
|
|
||||||
}).runTaskTimerAsynchronously(analysisPeriod, analysisPeriod);
|
|
||||||
}
|
|
||||||
|
|
||||||
RunnableFactory.createNew("PeriodicNetworkBoxRefreshTask", new AbsRunnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
infoManager.updateNetworkPageContent();
|
|
||||||
}
|
|
||||||
}).runTaskTimerAsynchronously(TimeAmount.SECOND.ticks(), TimeAmount.MINUTE.ticks() * 5L);
|
|
||||||
|
|
||||||
Benchmark.stop("Enable", "Task Registration");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ColorScheme getColorScheme() {
|
public ColorScheme getColorScheme() {
|
||||||
try {
|
return PlanColorScheme.create();
|
||||||
ChatColor mainColor = ChatColor.getByChar(Settings.COLOR_MAIN.toString().charAt(1));
|
|
||||||
ChatColor secColor = ChatColor.getByChar(Settings.COLOR_SEC.toString().charAt(1));
|
|
||||||
ChatColor terColor = ChatColor.getByChar(Settings.COLOR_TER.toString().charAt(1));
|
|
||||||
return new ColorScheme(mainColor, secColor, terColor);
|
|
||||||
} catch (Exception e) {
|
|
||||||
Log.infoColor(ChatColor.RED + "Customization, Chat colors set-up wrong, using defaults.");
|
|
||||||
return new ColorScheme(ChatColor.DARK_GREEN, ChatColor.GRAY, ChatColor.WHITE);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -320,11 +240,6 @@ public class Plan extends BukkitPlugin implements IPlan {
|
|||||||
//Clears the page cache
|
//Clears the page cache
|
||||||
PageCache.clearCache();
|
PageCache.clearCache();
|
||||||
|
|
||||||
// Stop the UI Server
|
|
||||||
if (webServer != null) {
|
|
||||||
webServer.stop();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Processes unprocessed processors
|
// Processes unprocessed processors
|
||||||
if (processingQueue != null) {
|
if (processingQueue != null) {
|
||||||
List<Processor> processors = processingQueue.stopAndReturnLeftovers();
|
List<Processor> processors = processingQueue.stopAndReturnLeftovers();
|
||||||
@ -359,11 +274,7 @@ public class Plan extends BukkitPlugin implements IPlan {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onReload() {
|
public void onReload() {
|
||||||
try {
|
ConfigSystem.reload();
|
||||||
config.read();
|
|
||||||
} catch (IOException e) {
|
|
||||||
Log.toLog(this.getClass().getName(), e);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void registerListeners() {
|
private void registerListeners() {
|
||||||
@ -393,7 +304,7 @@ public class Plan extends BukkitPlugin implements IPlan {
|
|||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public Database getDB() {
|
public Database getDB() {
|
||||||
return DatabaseSystem.getInstance().getActiveDatabase();
|
return DBSystem.getInstance().getActiveDatabase();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -402,7 +313,7 @@ public class Plan extends BukkitPlugin implements IPlan {
|
|||||||
* @return the WebServer
|
* @return the WebServer
|
||||||
*/
|
*/
|
||||||
public WebServer getWebServer() {
|
public WebServer getWebServer() {
|
||||||
return webServer;
|
return WebServerSystem.getInstance().getWebServer();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -414,15 +325,6 @@ public class Plan extends BukkitPlugin implements IPlan {
|
|||||||
return hookHandler;
|
return hookHandler;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Used to get the ID of the BootAnalysisTask, so that it can be disabled.
|
|
||||||
*
|
|
||||||
* @return ID of the bootAnalysisTask
|
|
||||||
*/
|
|
||||||
public int getBootAnalysisTaskID() {
|
|
||||||
return bootAnalysisTaskID;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Used to get the object storing server variables that are constant after
|
* Used to get the object storing server variables that are constant after
|
||||||
* boot.
|
* boot.
|
||||||
@ -448,10 +350,6 @@ public class Plan extends BukkitPlugin implements IPlan {
|
|||||||
return processingQueue;
|
return processingQueue;
|
||||||
}
|
}
|
||||||
|
|
||||||
public TPSCountTimer getTpsCountTimer() {
|
|
||||||
return tpsCountTimer;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void addToProcessQueue(Processor... processors) {
|
public void addToProcessQueue(Processor... processors) {
|
||||||
if (!reloading) {
|
if (!reloading) {
|
||||||
for (Processor processor : processors) {
|
for (Processor processor : processors) {
|
||||||
@ -473,7 +371,7 @@ public class Plan extends BukkitPlugin implements IPlan {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Config getMainConfig() {
|
public Config getMainConfig() {
|
||||||
return config;
|
return ConfigSystem.getInstance().getConfig();
|
||||||
}
|
}
|
||||||
|
|
||||||
public InformationManager getInfoManager() {
|
public InformationManager getInfoManager() {
|
||||||
@ -534,11 +432,6 @@ public class Plan extends BukkitPlugin implements IPlan {
|
|||||||
return api;
|
return api;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public Theme getTheme() {
|
|
||||||
return theme;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Systems getSystems() {
|
public Systems getSystems() {
|
||||||
return systems;
|
return systems;
|
||||||
}
|
}
|
||||||
|
@ -7,14 +7,11 @@ package main.java.com.djrapitops.plan;
|
|||||||
import com.djrapitops.plugin.BungeePlugin;
|
import com.djrapitops.plugin.BungeePlugin;
|
||||||
import com.djrapitops.plugin.StaticHolder;
|
import com.djrapitops.plugin.StaticHolder;
|
||||||
import com.djrapitops.plugin.api.Benchmark;
|
import com.djrapitops.plugin.api.Benchmark;
|
||||||
import com.djrapitops.plugin.api.Priority;
|
|
||||||
import com.djrapitops.plugin.api.TimeAmount;
|
|
||||||
import com.djrapitops.plugin.api.config.Config;
|
import com.djrapitops.plugin.api.config.Config;
|
||||||
import com.djrapitops.plugin.api.systems.NotificationCenter;
|
import com.djrapitops.plugin.api.systems.TaskCenter;
|
||||||
import com.djrapitops.plugin.api.utility.Version;
|
import com.djrapitops.plugin.api.utility.log.DebugLog;
|
||||||
import com.djrapitops.plugin.api.utility.log.Log;
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
import com.djrapitops.plugin.settings.ColorScheme;
|
import com.djrapitops.plugin.settings.ColorScheme;
|
||||||
import com.djrapitops.plugin.task.AbsRunnable;
|
|
||||||
import com.djrapitops.plugin.task.RunnableFactory;
|
import com.djrapitops.plugin.task.RunnableFactory;
|
||||||
import main.java.com.djrapitops.plan.api.IPlan;
|
import main.java.com.djrapitops.plan.api.IPlan;
|
||||||
import main.java.com.djrapitops.plan.command.PlanBungeeCommand;
|
import main.java.com.djrapitops.plan.command.PlanBungeeCommand;
|
||||||
@ -22,23 +19,24 @@ import main.java.com.djrapitops.plan.database.Database;
|
|||||||
import main.java.com.djrapitops.plan.settings.Settings;
|
import main.java.com.djrapitops.plan.settings.Settings;
|
||||||
import main.java.com.djrapitops.plan.settings.locale.Locale;
|
import main.java.com.djrapitops.plan.settings.locale.Locale;
|
||||||
import main.java.com.djrapitops.plan.settings.locale.Msg;
|
import main.java.com.djrapitops.plan.settings.locale.Msg;
|
||||||
|
import main.java.com.djrapitops.plan.settings.theme.PlanColorScheme;
|
||||||
import main.java.com.djrapitops.plan.settings.theme.Theme;
|
import main.java.com.djrapitops.plan.settings.theme.Theme;
|
||||||
import main.java.com.djrapitops.plan.systems.DatabaseSystem;
|
|
||||||
import main.java.com.djrapitops.plan.systems.FileSystem;
|
|
||||||
import main.java.com.djrapitops.plan.systems.Systems;
|
import main.java.com.djrapitops.plan.systems.Systems;
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.FileSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.config.ConfigSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.database.DBSystem;
|
||||||
import main.java.com.djrapitops.plan.systems.info.BungeeInformationManager;
|
import main.java.com.djrapitops.plan.systems.info.BungeeInformationManager;
|
||||||
import main.java.com.djrapitops.plan.systems.info.InformationManager;
|
import main.java.com.djrapitops.plan.systems.info.InformationManager;
|
||||||
import main.java.com.djrapitops.plan.systems.info.server.BungeeServerInfoManager;
|
import main.java.com.djrapitops.plan.systems.info.server.BungeeServerInfoManager;
|
||||||
import main.java.com.djrapitops.plan.systems.listeners.BungeePlayerListener;
|
import main.java.com.djrapitops.plan.systems.listeners.BungeePlayerListener;
|
||||||
import main.java.com.djrapitops.plan.systems.processing.Processor;
|
import main.java.com.djrapitops.plan.systems.processing.Processor;
|
||||||
import main.java.com.djrapitops.plan.systems.queue.ProcessingQueue;
|
import main.java.com.djrapitops.plan.systems.queue.ProcessingQueue;
|
||||||
import main.java.com.djrapitops.plan.systems.tasks.TPSCountTimer;
|
import main.java.com.djrapitops.plan.systems.tasks.TaskSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.update.VersionCheckSystem;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.WebServer;
|
import main.java.com.djrapitops.plan.systems.webserver.WebServer;
|
||||||
import main.java.com.djrapitops.plan.utilities.file.FileUtil;
|
import main.java.com.djrapitops.plan.systems.webserver.WebServerSystem;
|
||||||
import main.java.com.djrapitops.plan.utilities.file.export.HtmlExport;
|
import main.java.com.djrapitops.plan.utilities.file.export.HtmlExport;
|
||||||
import net.md_5.bungee.api.ChatColor;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
@ -49,55 +47,34 @@ import java.util.UUID;
|
|||||||
*/
|
*/
|
||||||
public class PlanBungee extends BungeePlugin implements IPlan {
|
public class PlanBungee extends BungeePlugin implements IPlan {
|
||||||
|
|
||||||
private Config config;
|
|
||||||
private Theme theme;
|
|
||||||
|
|
||||||
private Systems systems;
|
private Systems systems;
|
||||||
|
|
||||||
private WebServer webServer;
|
|
||||||
private BungeeServerInfoManager serverInfoManager;
|
private BungeeServerInfoManager serverInfoManager;
|
||||||
private BungeeInformationManager infoManager;
|
private BungeeInformationManager infoManager;
|
||||||
private ServerVariableHolder variableHolder;
|
private ServerVariableHolder variableHolder;
|
||||||
|
|
||||||
private ProcessingQueue processingQueue;
|
private ProcessingQueue processingQueue;
|
||||||
|
|
||||||
|
private boolean setupAllowed = false;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onEnable() {
|
public void onEnable() {
|
||||||
super.onEnable();
|
super.onEnable();
|
||||||
try {
|
try {
|
||||||
systems = new Systems(this);
|
systems = new Systems(this);
|
||||||
FileSystem.getInstance().init();
|
FileSystem.getInstance().init();
|
||||||
|
ConfigSystem.getInstance().init();
|
||||||
config = new Config(FileSystem.getConfigFile());
|
|
||||||
config.copyDefaults(FileUtil.lines(this, "bungeeconfig.yml"));
|
|
||||||
config.save();
|
|
||||||
|
|
||||||
Log.setDebugMode(Settings.DEBUG.toString());
|
Log.setDebugMode(Settings.DEBUG.toString());
|
||||||
|
|
||||||
String currentVersion = getVersion();
|
VersionCheckSystem.getInstance().init();
|
||||||
String githubVersionUrl = "https://raw.githubusercontent.com/Rsl1122/Plan-PlayerAnalytics/master/Plan/src/main/resources/plugin.yml";
|
|
||||||
String spigotUrl = "https://www.spigotmc.org/resources/plan-player-analytics.32536/";
|
|
||||||
try {
|
|
||||||
if (Version.checkVersion(currentVersion, githubVersionUrl) || Version.checkVersion(currentVersion, spigotUrl)) {
|
|
||||||
Log.infoColor("§a----------------------------------------");
|
|
||||||
Log.infoColor("§aNew version is available at https://www.spigotmc.org/resources/plan-player-analytics.32536/");
|
|
||||||
Log.infoColor("§a----------------------------------------");
|
|
||||||
NotificationCenter.addNotification(Priority.HIGH, "New Version is available at https://www.spigotmc.org/resources/plan-player-analytics.32536/");
|
|
||||||
} else {
|
|
||||||
Log.info("You're using the latest version.");
|
|
||||||
}
|
|
||||||
} catch (IOException e) {
|
|
||||||
Log.error("Failed to check newest version number");
|
|
||||||
}
|
|
||||||
variableHolder = new ServerVariableHolder(getProxy());
|
variableHolder = new ServerVariableHolder(getProxy());
|
||||||
|
|
||||||
new Locale(this).loadLocale();
|
new Locale().loadLocale();
|
||||||
|
|
||||||
theme = new Theme();
|
Theme.getInstance().init();
|
||||||
|
DBSystem.getInstance().init();
|
||||||
DatabaseSystem.getInstance().init();
|
|
||||||
|
|
||||||
registerCommand("planbungee", new PlanBungeeCommand(this));
|
|
||||||
|
|
||||||
String ip = variableHolder.getIp();
|
String ip = variableHolder.getIp();
|
||||||
if ("0.0.0.0".equals(ip)) {
|
if ("0.0.0.0".equals(ip)) {
|
||||||
@ -107,35 +84,14 @@ public class PlanBungee extends BungeePlugin implements IPlan {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Benchmark.start("WebServer Initialization");
|
Benchmark.start("WebServer Initialization");
|
||||||
webServer = new WebServer(this);
|
|
||||||
|
|
||||||
serverInfoManager = new BungeeServerInfoManager(this);
|
serverInfoManager = new BungeeServerInfoManager(this);
|
||||||
infoManager = new BungeeInformationManager(this);
|
infoManager = new BungeeInformationManager(this);
|
||||||
webServer.initServer();
|
|
||||||
|
WebServerSystem.getInstance().init();
|
||||||
serverInfoManager.loadServerInfo();
|
serverInfoManager.loadServerInfo();
|
||||||
|
|
||||||
|
TaskSystem.getInstance().init();
|
||||||
if (!webServer.isEnabled()) {
|
|
||||||
Log.error("WebServer was not successfully initialized.");
|
|
||||||
onDisable();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
RunnableFactory.createNew("Enable Bukkit Connection Task", new AbsRunnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
infoManager.attemptConnection();
|
|
||||||
infoManager.sendConfigSettings();
|
|
||||||
}
|
|
||||||
}).runTaskAsynchronously();
|
|
||||||
RunnableFactory.createNew("Player Count task", new TPSCountTimer(this))
|
|
||||||
.runTaskTimerAsynchronously(1000, TimeAmount.SECOND.ticks());
|
|
||||||
RunnableFactory.createNew("NetworkPageContentUpdateTask", new AbsRunnable("NetworkPageContentUpdateTask") {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
infoManager.updateNetworkPageContent();
|
|
||||||
}
|
|
||||||
}).runTaskTimerAsynchronously(1500, TimeAmount.MINUTE.ticks());
|
|
||||||
|
|
||||||
processingQueue = new ProcessingQueue();
|
processingQueue = new ProcessingQueue();
|
||||||
|
|
||||||
@ -149,8 +105,8 @@ public class PlanBungee extends BungeePlugin implements IPlan {
|
|||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
Log.error("Plugin Failed to Initialize Correctly.");
|
Log.error("Plugin Failed to Initialize Correctly.");
|
||||||
Log.toLog(this.getClass().getName(), e);
|
Log.toLog(this.getClass().getName(), e);
|
||||||
onDisable();
|
|
||||||
}
|
}
|
||||||
|
registerCommand("planbungee", new PlanBungeeCommand(this));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static PlanBungee getInstance() {
|
public static PlanBungee getInstance() {
|
||||||
@ -166,12 +122,11 @@ public class PlanBungee extends BungeePlugin implements IPlan {
|
|||||||
/*ignored*/
|
/*ignored*/
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (webServer != null) {
|
|
||||||
webServer.stop();
|
|
||||||
}
|
|
||||||
systems.close();
|
systems.close();
|
||||||
Log.info(Locale.get(Msg.DISABLED).toString());
|
Log.info(Locale.get(Msg.DISABLED).toString());
|
||||||
super.onDisable();
|
Benchmark.pluginDisabled(PlanBungee.class);
|
||||||
|
DebugLog.pluginDisabled(PlanBungee.class);
|
||||||
|
TaskCenter.cancelAllKnownTasks(PlanBungee.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -181,17 +136,13 @@ public class PlanBungee extends BungeePlugin implements IPlan {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onReload() {
|
public void onReload() {
|
||||||
try {
|
ConfigSystem.reload();
|
||||||
config.read();
|
|
||||||
} catch (IOException e) {
|
|
||||||
Log.toLog(this.getClass().getName(), e);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public Database getDB() {
|
public Database getDB() {
|
||||||
return DatabaseSystem.getInstance().getActiveDatabase();
|
return DBSystem.getInstance().getActiveDatabase();
|
||||||
}
|
}
|
||||||
|
|
||||||
public BungeeServerInfoManager getServerInfoManager() {
|
public BungeeServerInfoManager getServerInfoManager() {
|
||||||
@ -205,7 +156,7 @@ public class PlanBungee extends BungeePlugin implements IPlan {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public WebServer getWebServer() {
|
public WebServer getWebServer() {
|
||||||
return webServer;
|
return WebServerSystem.getInstance().getWebServer();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -228,20 +179,12 @@ public class PlanBungee extends BungeePlugin implements IPlan {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Config getMainConfig() {
|
public Config getMainConfig() {
|
||||||
return config;
|
return ConfigSystem.getInstance().getConfig();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ColorScheme getColorScheme() {
|
public ColorScheme getColorScheme() {
|
||||||
try {
|
return PlanColorScheme.create();
|
||||||
ChatColor mainColor = ChatColor.getByChar(Settings.COLOR_MAIN.toString().charAt(1));
|
|
||||||
ChatColor secColor = ChatColor.getByChar(Settings.COLOR_SEC.toString().charAt(1));
|
|
||||||
ChatColor terColor = ChatColor.getByChar(Settings.COLOR_TER.toString().charAt(1));
|
|
||||||
return new ColorScheme(mainColor, secColor, terColor);
|
|
||||||
} catch (Exception e) {
|
|
||||||
Log.infoColor(ChatColor.RED + "Customization, Chat colors set-up wrong, using defaults.");
|
|
||||||
return new ColorScheme(ChatColor.DARK_GREEN, ChatColor.GRAY, ChatColor.WHITE);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -257,13 +200,16 @@ public class PlanBungee extends BungeePlugin implements IPlan {
|
|||||||
return serverInfoManager.getServerUUID();
|
return serverInfoManager.getServerUUID();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public Theme getTheme() {
|
|
||||||
return theme;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Systems getSystems() {
|
public Systems getSystems() {
|
||||||
return systems;
|
return systems;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isSetupAllowed() {
|
||||||
|
return setupAllowed;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setSetupAllowed(boolean setupAllowed) {
|
||||||
|
this.setupAllowed = setupAllowed;
|
||||||
|
}
|
||||||
}
|
}
|
@ -9,7 +9,6 @@ import com.djrapitops.plugin.api.config.Config;
|
|||||||
import com.djrapitops.plugin.settings.ColorScheme;
|
import com.djrapitops.plugin.settings.ColorScheme;
|
||||||
import main.java.com.djrapitops.plan.ServerVariableHolder;
|
import main.java.com.djrapitops.plan.ServerVariableHolder;
|
||||||
import main.java.com.djrapitops.plan.database.Database;
|
import main.java.com.djrapitops.plan.database.Database;
|
||||||
import main.java.com.djrapitops.plan.settings.theme.Theme;
|
|
||||||
import main.java.com.djrapitops.plan.systems.Systems;
|
import main.java.com.djrapitops.plan.systems.Systems;
|
||||||
import main.java.com.djrapitops.plan.systems.info.InformationManager;
|
import main.java.com.djrapitops.plan.systems.info.InformationManager;
|
||||||
import main.java.com.djrapitops.plan.systems.processing.Processor;
|
import main.java.com.djrapitops.plan.systems.processing.Processor;
|
||||||
@ -48,7 +47,5 @@ public interface IPlan extends IPlugin {
|
|||||||
|
|
||||||
ColorScheme getColorScheme();
|
ColorScheme getColorScheme();
|
||||||
|
|
||||||
Theme getTheme();
|
|
||||||
|
|
||||||
Systems getSystems();
|
Systems getSystems();
|
||||||
}
|
}
|
@ -27,7 +27,7 @@ public class PlanBungeeCommand extends TreeCommand<PlanBungee> {
|
|||||||
* @param plugin Current instance of Plan
|
* @param plugin Current instance of Plan
|
||||||
*/
|
*/
|
||||||
public PlanBungeeCommand(PlanBungee plugin) {
|
public PlanBungeeCommand(PlanBungee plugin) {
|
||||||
super(plugin, "planbungee", CommandType.CONSOLE, "", "", "planbungee");
|
super(plugin, "planbungee", CommandType.CONSOLE, Permissions.MANAGE.getPermission(), "", "planbungee");
|
||||||
super.setDefaultCommand("help");
|
super.setDefaultCommand("help");
|
||||||
super.setColorScheme(plugin.getColorScheme());
|
super.setColorScheme(plugin.getColorScheme());
|
||||||
}
|
}
|
||||||
@ -42,7 +42,8 @@ public class PlanBungeeCommand extends TreeCommand<PlanBungee> {
|
|||||||
add(
|
add(
|
||||||
new ReloadCommand(plugin),
|
new ReloadCommand(plugin),
|
||||||
new StatusCommand<>(plugin, Permissions.MANAGE.getPermission(), plugin.getColorScheme()),
|
new StatusCommand<>(plugin, Permissions.MANAGE.getPermission(), plugin.getColorScheme()),
|
||||||
new ListCommand()
|
new ListCommand(),
|
||||||
|
new BungeeSetupToggleCommand(plugin)
|
||||||
);
|
);
|
||||||
RegisterCommand registerCommand = new RegisterCommand(plugin);
|
RegisterCommand registerCommand = new RegisterCommand(plugin);
|
||||||
add(
|
add(
|
||||||
|
@ -131,10 +131,6 @@ public class AnalyzeCommand extends SubCommand {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void updateCache(ISender sender, UUID serverUUID) {
|
private void updateCache(ISender sender, UUID serverUUID) {
|
||||||
int bootAnID = plugin.getBootAnalysisTaskID();
|
|
||||||
if (bootAnID != -1) {
|
|
||||||
plugin.getServer().getScheduler().cancelTask(bootAnID);
|
|
||||||
}
|
|
||||||
infoManager.addAnalysisNotification(sender, serverUUID);
|
infoManager.addAnalysisNotification(sender, serverUUID);
|
||||||
infoManager.refreshAnalysis(serverUUID);
|
infoManager.refreshAnalysis(serverUUID);
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,39 @@
|
|||||||
|
/*
|
||||||
|
* Licence is provided in the jar as license.yml also here:
|
||||||
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
|
*/
|
||||||
|
package main.java.com.djrapitops.plan.command.commands;
|
||||||
|
|
||||||
|
import com.djrapitops.plugin.command.CommandType;
|
||||||
|
import com.djrapitops.plugin.command.ISender;
|
||||||
|
import com.djrapitops.plugin.command.SubCommand;
|
||||||
|
import main.java.com.djrapitops.plan.PlanBungee;
|
||||||
|
import main.java.com.djrapitops.plan.settings.Permissions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* //TODO Class Javadoc Comment
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public class BungeeSetupToggleCommand extends SubCommand {
|
||||||
|
|
||||||
|
private final PlanBungee plugin;
|
||||||
|
|
||||||
|
public BungeeSetupToggleCommand(PlanBungee plugin) {
|
||||||
|
super("setup", CommandType.ALL, Permissions.MANAGE.getPermission(), "Toggle Setup mode for Bungee");
|
||||||
|
this.plugin = plugin;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(ISender sender, String s, String[] strings) {
|
||||||
|
boolean setupAllowed = plugin.isSetupAllowed();
|
||||||
|
if (setupAllowed) {
|
||||||
|
plugin.setSetupAllowed(false);
|
||||||
|
} else {
|
||||||
|
plugin.setSetupAllowed(true);
|
||||||
|
}
|
||||||
|
String msg = !setupAllowed ? "§aSet-up is now Allowed" : "§cSet-up is now Forbidden";
|
||||||
|
sender.sendMessage(msg);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
@ -63,16 +63,22 @@ public class RegisterCommandFilter extends AbstractFilter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private Result validateMessage(String message) {
|
private Result validateMessage(String message) {
|
||||||
return isSensibleCommand(message)
|
if (message == null) {
|
||||||
|
return Result.NEUTRAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return commandShouldBeCensored(message)
|
||||||
? Result.DENY
|
? Result.DENY
|
||||||
: Result.NEUTRAL;
|
: Result.NEUTRAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isSensibleCommand(String message) {
|
private boolean commandShouldBeCensored(String message) {
|
||||||
return message.toLowerCase().contains("issued server command:") && isSensible(message);
|
return message != null
|
||||||
|
&& (message.toLowerCase().contains("issued server command:")
|
||||||
|
&& shouldBeCensored(message));
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isSensible(String message) {
|
private boolean shouldBeCensored(String message) {
|
||||||
return censoredCommands.stream().anyMatch(message::contains);
|
return message != null && censoredCommands.stream().anyMatch(message::contains);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -38,10 +38,8 @@ public class ReloadCommand extends SubCommand {
|
|||||||
try {
|
try {
|
||||||
plugin.reloadPlugin(true);
|
plugin.reloadPlugin(true);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
sender.sendMessage("§cSomething went wrong during reload of the plugin, a restart is recommended.");
|
|
||||||
String address = plugin.getWebServer().getAccessAddress() + "/debug";
|
|
||||||
sender.sendLink("More info can be found at ", address, address);
|
|
||||||
Log.toLog(this.getClass().getName(), e);
|
Log.toLog(this.getClass().getName(), e);
|
||||||
|
sender.sendMessage("§cSomething went wrong during reload of the plugin, a restart is recommended.");
|
||||||
}
|
}
|
||||||
sender.sendMessage(Locale.get(Msg.CMD_INFO_RELOAD_COMPLETE).toString());
|
sender.sendMessage(Locale.get(Msg.CMD_INFO_RELOAD_COMPLETE).toString());
|
||||||
return true;
|
return true;
|
||||||
|
@ -7,6 +7,7 @@ import com.djrapitops.plugin.command.ISender;
|
|||||||
import com.djrapitops.plugin.command.SubCommand;
|
import com.djrapitops.plugin.command.SubCommand;
|
||||||
import main.java.com.djrapitops.plan.Plan;
|
import main.java.com.djrapitops.plan.Plan;
|
||||||
import main.java.com.djrapitops.plan.api.exceptions.WebAPIException;
|
import main.java.com.djrapitops.plan.api.exceptions.WebAPIException;
|
||||||
|
import main.java.com.djrapitops.plan.api.exceptions.WebAPIForbiddenException;
|
||||||
import main.java.com.djrapitops.plan.settings.Permissions;
|
import main.java.com.djrapitops.plan.settings.Permissions;
|
||||||
import main.java.com.djrapitops.plan.settings.Settings;
|
import main.java.com.djrapitops.plan.settings.Settings;
|
||||||
import main.java.com.djrapitops.plan.settings.locale.Locale;
|
import main.java.com.djrapitops.plan.settings.locale.Locale;
|
||||||
@ -70,6 +71,8 @@ public class ManageSetupCommand extends SubCommand {
|
|||||||
// plugin.getWebServer().getWebAPI().getAPI(PingWebAPI.class).sendRequest(address);
|
// plugin.getWebServer().getWebAPI().getAPI(PingWebAPI.class).sendRequest(address);
|
||||||
plugin.getWebServer().getWebAPI().getAPI(RequestSetupWebAPI.class).sendRequest(address);
|
plugin.getWebServer().getWebAPI().getAPI(RequestSetupWebAPI.class).sendRequest(address);
|
||||||
sender.sendMessage("§eConnection successful, Plan may restart in a few seconds, if it doesn't something has gone wrong.");
|
sender.sendMessage("§eConnection successful, Plan may restart in a few seconds, if it doesn't something has gone wrong.");
|
||||||
|
} catch (WebAPIForbiddenException e) {
|
||||||
|
sender.sendMessage("§eConnection succeeded, but Bungee has set-up mode disabled - use '/planbungee setup' to enable it.");
|
||||||
} catch (WebAPIException e) {
|
} catch (WebAPIException e) {
|
||||||
Log.toLog(this.getClass().getName(), e);
|
Log.toLog(this.getClass().getName(), e);
|
||||||
sender.sendMessage("§cConnection to Bungee WebServer failed: More info on console");
|
sender.sendMessage("§cConnection to Bungee WebServer failed: More info on console");
|
||||||
|
@ -69,7 +69,7 @@ public class AnalysisData extends RawData {
|
|||||||
addValue("version", MiscUtils.getIPlan().getVersion());
|
addValue("version", MiscUtils.getIPlan().getVersion());
|
||||||
addValue("worldPieColors", Theme.getValue(ThemeVal.GRAPH_WORLD_PIE));
|
addValue("worldPieColors", Theme.getValue(ThemeVal.GRAPH_WORLD_PIE));
|
||||||
addValue("gmPieColors", Theme.getValue(ThemeVal.GRAPH_GM_PIE));
|
addValue("gmPieColors", Theme.getValue(ThemeVal.GRAPH_GM_PIE));
|
||||||
addValue("serverName", Settings.SERVER_NAME.toString());
|
addValue("serverName", Settings.SERVER_NAME.toString().replaceAll("[^a-zA-Z0-9_\\s]", "_"));
|
||||||
addValue("timeZone", MiscUtils.getTimeZoneOffsetHours());
|
addValue("timeZone", MiscUtils.getTimeZoneOffsetHours());
|
||||||
addValue("refresh", FormatUtils.formatTimeStamp(refreshDate));
|
addValue("refresh", FormatUtils.formatTimeStamp(refreshDate));
|
||||||
|
|
||||||
|
@ -18,7 +18,7 @@ import java.util.List;
|
|||||||
public class HookHandler {
|
public class HookHandler {
|
||||||
|
|
||||||
private final List<PluginData> additionalDataSources;
|
private final List<PluginData> additionalDataSources;
|
||||||
private final PluginConfigSectionHandler configHandler;
|
private final PluginsConfigSection configHandler;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class constructor, hooks to plugins.
|
* Class constructor, hooks to plugins.
|
||||||
@ -27,7 +27,7 @@ public class HookHandler {
|
|||||||
*/
|
*/
|
||||||
public HookHandler(Plan plugin) {
|
public HookHandler(Plan plugin) {
|
||||||
additionalDataSources = new ArrayList<>();
|
additionalDataSources = new ArrayList<>();
|
||||||
configHandler = new PluginConfigSectionHandler(plugin);
|
configHandler = new PluginsConfigSection();
|
||||||
try {
|
try {
|
||||||
Bridge.hook(this);
|
Bridge.hook(this);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
@ -2,7 +2,7 @@ package main.java.com.djrapitops.plan.data.plugin;
|
|||||||
|
|
||||||
import com.djrapitops.plugin.api.config.ConfigNode;
|
import com.djrapitops.plugin.api.config.ConfigNode;
|
||||||
import com.djrapitops.plugin.api.utility.log.Log;
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
import main.java.com.djrapitops.plan.Plan;
|
import main.java.com.djrapitops.plan.systems.file.config.ConfigSystem;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
@ -13,25 +13,17 @@ import java.io.IOException;
|
|||||||
* @author Rsl1122
|
* @author Rsl1122
|
||||||
* @since 3.5.0
|
* @since 3.5.0
|
||||||
*/
|
*/
|
||||||
public class PluginConfigSectionHandler {
|
public class PluginsConfigSection {
|
||||||
|
|
||||||
private final Plan plan;
|
|
||||||
|
|
||||||
public PluginConfigSectionHandler(Plan plan) {
|
|
||||||
this.plan = plan;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean hasSection(PluginData dataSource) {
|
public boolean hasSection(PluginData dataSource) {
|
||||||
ConfigNode section = getPluginsSection();
|
ConfigNode section = getPluginsSection();
|
||||||
String pluginName = dataSource.getSourcePlugin();
|
String pluginName = dataSource.getSourcePlugin();
|
||||||
if (!section.getChildren().containsKey(pluginName)) {
|
return section.getChildren().containsKey(pluginName)
|
||||||
return false;
|
&& section.getConfigNode(pluginName).getChildren().containsKey("Enabled");
|
||||||
}
|
|
||||||
return section.getConfigNode(pluginName).getChildren().containsKey("Enabled");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private ConfigNode getPluginsSection() {
|
private ConfigNode getPluginsSection() {
|
||||||
return plan.getMainConfig().getConfigNode("Plugins");
|
return ConfigSystem.getInstance().getConfig().getConfigNode("Plugins");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void createSection(PluginData dataSource) {
|
public void createSection(PluginData dataSource) {
|
@ -71,7 +71,6 @@ public abstract class SQLDB extends Database {
|
|||||||
try {
|
try {
|
||||||
setupDataSource();
|
setupDataSource();
|
||||||
setupDatabase();
|
setupDatabase();
|
||||||
scheduleClean(10L);
|
|
||||||
open = true;
|
open = true;
|
||||||
} finally {
|
} finally {
|
||||||
Benchmark.stop("Database", benchName);
|
Benchmark.stop("Database", benchName);
|
||||||
|
@ -2,7 +2,7 @@ package main.java.com.djrapitops.plan.settings;
|
|||||||
|
|
||||||
import com.djrapitops.plugin.api.Check;
|
import com.djrapitops.plugin.api.Check;
|
||||||
import com.djrapitops.plugin.api.config.Config;
|
import com.djrapitops.plugin.api.config.Config;
|
||||||
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
import main.java.com.djrapitops.plan.systems.file.config.ConfigSystem;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@ -154,7 +154,7 @@ public enum Settings {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private Config getConfig() {
|
private Config getConfig() {
|
||||||
return MiscUtils.getIPlan().getMainConfig();
|
return ConfigSystem.getInstance().getConfig();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ServerSpecificSettings serverSpecific() {
|
public static ServerSpecificSettings serverSpecific() {
|
||||||
|
@ -8,7 +8,7 @@ import com.djrapitops.plugin.api.config.Config;
|
|||||||
import com.djrapitops.plugin.api.config.ConfigNode;
|
import com.djrapitops.plugin.api.config.ConfigNode;
|
||||||
import com.djrapitops.plugin.api.utility.log.Log;
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
import com.djrapitops.plugin.utilities.Verify;
|
import com.djrapitops.plugin.utilities.Verify;
|
||||||
import main.java.com.djrapitops.plan.Plan;
|
import main.java.com.djrapitops.plan.systems.file.config.ConfigSystem;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
@ -21,17 +21,6 @@ import java.util.Map;
|
|||||||
*/
|
*/
|
||||||
public class WorldAliasSettings {
|
public class WorldAliasSettings {
|
||||||
|
|
||||||
private final Plan plugin;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param plugin Current instance of Plan.
|
|
||||||
*/
|
|
||||||
public WorldAliasSettings(Plan plugin) {
|
|
||||||
this.plugin = plugin;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Used to get all World aliases in the config
|
* Used to get all World aliases in the config
|
||||||
*
|
*
|
||||||
@ -48,7 +37,7 @@ public class WorldAliasSettings {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private ConfigNode getAliasSection() {
|
private ConfigNode getAliasSection() {
|
||||||
Config config = plugin.getMainConfig();
|
Config config = ConfigSystem.getInstance().getConfig();
|
||||||
return config.getConfigNode(Settings.WORLD_ALIASES.getPath());
|
return config.getConfigNode(Settings.WORLD_ALIASES.getPath());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,13 +1,16 @@
|
|||||||
package main.java.com.djrapitops.plan.settings.locale;
|
package main.java.com.djrapitops.plan.settings.locale;
|
||||||
|
|
||||||
import com.djrapitops.plugin.api.Benchmark;
|
import com.djrapitops.plugin.api.Benchmark;
|
||||||
|
import com.djrapitops.plugin.api.config.Config;
|
||||||
import com.djrapitops.plugin.api.utility.log.Log;
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
import com.djrapitops.plugin.settings.ColorScheme;
|
import com.djrapitops.plugin.settings.ColorScheme;
|
||||||
import com.djrapitops.plugin.settings.DefaultMessages;
|
import com.djrapitops.plugin.settings.DefaultMessages;
|
||||||
import com.djrapitops.plugin.utilities.Verify;
|
import com.djrapitops.plugin.utilities.Verify;
|
||||||
import main.java.com.djrapitops.plan.api.IPlan;
|
|
||||||
import main.java.com.djrapitops.plan.settings.Permissions;
|
import main.java.com.djrapitops.plan.settings.Permissions;
|
||||||
import main.java.com.djrapitops.plan.settings.Settings;
|
import main.java.com.djrapitops.plan.settings.Settings;
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.FileSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.config.ConfigSystem;
|
||||||
|
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
||||||
import main.java.com.djrapitops.plan.utilities.comparators.LocaleEntryComparator;
|
import main.java.com.djrapitops.plan.utilities.comparators.LocaleEntryComparator;
|
||||||
import main.java.com.djrapitops.plan.utilities.comparators.StringLengthComparator;
|
import main.java.com.djrapitops.plan.utilities.comparators.StringLengthComparator;
|
||||||
import main.java.com.djrapitops.plan.utilities.file.FileUtil;
|
import main.java.com.djrapitops.plan.utilities.file.FileUtil;
|
||||||
@ -34,12 +37,10 @@ import java.util.stream.Collectors;
|
|||||||
*/
|
*/
|
||||||
public class Locale {
|
public class Locale {
|
||||||
|
|
||||||
private final IPlan plugin;
|
|
||||||
private final Map<Msg, Message> messages;
|
private final Map<Msg, Message> messages;
|
||||||
|
|
||||||
public Locale(IPlan plugin) {
|
public Locale() {
|
||||||
LocaleHolder.setLocale(this);
|
LocaleHolder.setLocale(this);
|
||||||
this.plugin = plugin;
|
|
||||||
messages = new EnumMap<>(Msg.class);
|
messages = new EnumMap<>(Msg.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -67,7 +68,7 @@ public class Locale {
|
|||||||
if (Settings.WRITE_NEW_LOCALE.isTrue()) {
|
if (Settings.WRITE_NEW_LOCALE.isTrue()) {
|
||||||
writeNewDefaultLocale();
|
writeNewDefaultLocale();
|
||||||
}
|
}
|
||||||
File localeFile = new File(plugin.getDataFolder(), "locale.txt");
|
File localeFile = FileSystem.getLocaleFile();
|
||||||
if (localeFile.exists()) {
|
if (localeFile.exists()) {
|
||||||
loadFromFile(localeFile);
|
loadFromFile(localeFile);
|
||||||
} else if (locale.equals("DEFAULT")) {
|
} else if (locale.equals("DEFAULT")) {
|
||||||
@ -83,7 +84,6 @@ public class Locale {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void writeNewDefaultLocale() throws IOException {
|
private void writeNewDefaultLocale() throws IOException {
|
||||||
|
|
||||||
Optional<String> key = messages.keySet().stream()
|
Optional<String> key = messages.keySet().stream()
|
||||||
.map(Msg::getIdentifier)
|
.map(Msg::getIdentifier)
|
||||||
.sorted(new StringLengthComparator())
|
.sorted(new StringLengthComparator())
|
||||||
@ -96,9 +96,11 @@ public class Locale {
|
|||||||
.sorted(new LocaleEntryComparator())
|
.sorted(new LocaleEntryComparator())
|
||||||
.map(entry -> getSpacedIdentifier(entry.getKey().getIdentifier(), length) + "|| " + entry.getValue().toString())
|
.map(entry -> getSpacedIdentifier(entry.getKey().getIdentifier(), length) + "|| " + entry.getValue().toString())
|
||||||
.collect(Collectors.toList());
|
.collect(Collectors.toList());
|
||||||
Files.write(new File(plugin.getDataFolder(), "locale.txt").toPath(), lines, StandardCharsets.UTF_8);
|
Files.write(FileSystem.getLocaleFile().toPath(), lines, StandardCharsets.UTF_8);
|
||||||
plugin.getMainConfig().set(Settings.WRITE_NEW_LOCALE.getPath(), false);
|
|
||||||
plugin.getMainConfig().save();
|
Config config = ConfigSystem.getInstance().getConfig();
|
||||||
|
config.set(Settings.WRITE_NEW_LOCALE.getPath(), false);
|
||||||
|
config.save();
|
||||||
}
|
}
|
||||||
|
|
||||||
private String getSpacedIdentifier(String identifier, int length) {
|
private String getSpacedIdentifier(String identifier, int length) {
|
||||||
@ -110,13 +112,15 @@ public class Locale {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void loadDefault() {
|
private void loadDefault() {
|
||||||
|
// TODO Move to Msg as DefaultMessages
|
||||||
|
|
||||||
String analysis = "Analysis | ";
|
String analysis = "Analysis | ";
|
||||||
String prefix = "[Plan] ";
|
String prefix = "[Plan] ";
|
||||||
String green = "§a";
|
String green = "§a";
|
||||||
String yellow = "§e";
|
String yellow = "§e";
|
||||||
String red = "§c";
|
String red = "§c";
|
||||||
String arrowsRight = DefaultMessages.ARROWS_RIGHT.parse();
|
String arrowsRight = DefaultMessages.ARROWS_RIGHT.parse();
|
||||||
ColorScheme cs = plugin.getColorScheme();
|
ColorScheme cs = MiscUtils.getIPlan().getColorScheme();
|
||||||
String mCol = cs.getMainColor();
|
String mCol = cs.getMainColor();
|
||||||
String sCol = cs.getSecondaryColor();
|
String sCol = cs.getSecondaryColor();
|
||||||
String tCol = cs.getTertiaryColor();
|
String tCol = cs.getTertiaryColor();
|
||||||
@ -310,7 +314,7 @@ public class Locale {
|
|||||||
|
|
||||||
private void loadFromResource(String fileName) {
|
private void loadFromResource(String fileName) {
|
||||||
try {
|
try {
|
||||||
loadFromContents(FileUtil.lines(plugin, fileName), fileName);
|
loadFromContents(FileSystem.readFromResource(fileName), fileName);
|
||||||
} catch (FileNotFoundException e) {
|
} catch (FileNotFoundException e) {
|
||||||
Log.error("Could not find file inside the jar: " + fileName);
|
Log.error("Could not find file inside the jar: " + fileName);
|
||||||
Log.info("Using Locale: Default (EN)");
|
Log.info("Using Locale: Default (EN)");
|
||||||
|
@ -0,0 +1,35 @@
|
|||||||
|
/*
|
||||||
|
* Licence is provided in the jar as license.yml also here:
|
||||||
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
|
*/
|
||||||
|
package main.java.com.djrapitops.plan.settings.theme;
|
||||||
|
|
||||||
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
|
import com.djrapitops.plugin.settings.ColorScheme;
|
||||||
|
import main.java.com.djrapitops.plan.settings.Settings;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ColorScheme that uses values in config settings specific to Plan or PlanBungee.
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public class PlanColorScheme extends ColorScheme {
|
||||||
|
|
||||||
|
private PlanColorScheme(String... colors) {
|
||||||
|
super(colors);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static PlanColorScheme create() {
|
||||||
|
try {
|
||||||
|
String main = "§" + Settings.COLOR_MAIN.toString().charAt(1);
|
||||||
|
String secondary = "§" + Settings.COLOR_SEC.toString().charAt(1);
|
||||||
|
String tertiary = "§" + Settings.COLOR_TER.toString().charAt(1);
|
||||||
|
|
||||||
|
return new PlanColorScheme(main, secondary, tertiary);
|
||||||
|
} catch (Exception e) {
|
||||||
|
Log.infoColor("§cCustomization, Chat colors set-up wrong, using defaults.");
|
||||||
|
return new PlanColorScheme("§2", "§7", "§f");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -9,7 +9,8 @@ import com.djrapitops.plugin.api.utility.log.Log;
|
|||||||
import com.djrapitops.plugin.utilities.Verify;
|
import com.djrapitops.plugin.utilities.Verify;
|
||||||
import main.java.com.djrapitops.plan.api.exceptions.PlanEnableException;
|
import main.java.com.djrapitops.plan.api.exceptions.PlanEnableException;
|
||||||
import main.java.com.djrapitops.plan.settings.Settings;
|
import main.java.com.djrapitops.plan.settings.Settings;
|
||||||
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
import main.java.com.djrapitops.plan.systems.SubSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.Systems;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -21,11 +22,16 @@ import java.util.List;
|
|||||||
*
|
*
|
||||||
* @author Rsl1122
|
* @author Rsl1122
|
||||||
*/
|
*/
|
||||||
public class Theme {
|
public class Theme implements SubSystem {
|
||||||
|
|
||||||
private final ThemeConfig config;
|
private ThemeConfig config;
|
||||||
|
|
||||||
public Theme() throws PlanEnableException {
|
public static Theme getInstance() {
|
||||||
|
return Systems.getInstance().getThemeSystem();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void init() throws PlanEnableException {
|
||||||
String themeName = Settings.THEME_BASE.toString();
|
String themeName = Settings.THEME_BASE.toString();
|
||||||
try {
|
try {
|
||||||
config = new ThemeConfig(themeName);
|
config = new ThemeConfig(themeName);
|
||||||
@ -34,6 +40,11 @@ public class Theme {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void close() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
public String getColor(ThemeVal variable) {
|
public String getColor(ThemeVal variable) {
|
||||||
String path = variable.getThemePath();
|
String path = variable.getThemePath();
|
||||||
try {
|
try {
|
||||||
@ -83,10 +94,10 @@ public class Theme {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static String getValue(ThemeVal variable) {
|
public static String getValue(ThemeVal variable) {
|
||||||
return MiscUtils.getIPlan().getTheme().getThemeValue(variable);
|
return getInstance().getThemeValue(variable);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String replaceColors(String resourceString) {
|
public static String replaceColors(String resourceString) {
|
||||||
return MiscUtils.getIPlan().getTheme().replaceThemeColors(resourceString);
|
return getInstance().replaceThemeColors(resourceString);
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -4,7 +4,22 @@
|
|||||||
*/
|
*/
|
||||||
package main.java.com.djrapitops.plan.systems;
|
package main.java.com.djrapitops.plan.systems;
|
||||||
|
|
||||||
import main.java.com.djrapitops.plan.api.IPlan;
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
|
import main.java.com.djrapitops.plan.Plan;
|
||||||
|
import main.java.com.djrapitops.plan.PlanBungee;
|
||||||
|
import main.java.com.djrapitops.plan.settings.theme.Theme;
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.FileSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.config.ConfigSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.config.PlanBungeeConfigSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.config.PlanConfigSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.database.DBSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.database.PlanBungeeDBSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.database.PlanDBSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.tasks.PlanBungeeTaskSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.tasks.PlanTaskSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.tasks.TaskSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.update.VersionCheckSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.WebServerSystem;
|
||||||
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
||||||
import org.apache.commons.lang3.ArrayUtils;
|
import org.apache.commons.lang3.ArrayUtils;
|
||||||
|
|
||||||
@ -15,18 +30,60 @@ import org.apache.commons.lang3.ArrayUtils;
|
|||||||
*/
|
*/
|
||||||
public class Systems {
|
public class Systems {
|
||||||
|
|
||||||
FileSystem fileSystem;
|
private FileSystem fileSystem;
|
||||||
DatabaseSystem databaseSystem;
|
private ConfigSystem configSystem;
|
||||||
|
private DBSystem databaseSystem;
|
||||||
|
private Theme themeSystem;
|
||||||
|
|
||||||
public Systems(IPlan plugin) {
|
private WebServerSystem webServerSystem;
|
||||||
databaseSystem = new DatabaseSystem();
|
|
||||||
|
private TaskSystem taskSystem;
|
||||||
|
|
||||||
|
private VersionCheckSystem versionCheckSystem;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor for Bukkit version.
|
||||||
|
*
|
||||||
|
* @param plugin Plan instance
|
||||||
|
*/
|
||||||
|
public Systems(Plan plugin) {
|
||||||
fileSystem = new FileSystem(plugin);
|
fileSystem = new FileSystem(plugin);
|
||||||
|
configSystem = new PlanConfigSystem();
|
||||||
|
databaseSystem = new PlanDBSystem();
|
||||||
|
versionCheckSystem = new VersionCheckSystem(plugin.getVersion());
|
||||||
|
|
||||||
|
taskSystem = new PlanTaskSystem();
|
||||||
|
|
||||||
|
webServerSystem = new WebServerSystem();
|
||||||
|
themeSystem = new Theme();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor for Bungee version.
|
||||||
|
*
|
||||||
|
* @param plugin PlanBungee instance
|
||||||
|
*/
|
||||||
|
public Systems(PlanBungee plugin) {
|
||||||
|
fileSystem = new FileSystem(plugin);
|
||||||
|
configSystem = new PlanBungeeConfigSystem();
|
||||||
|
databaseSystem = new PlanBungeeDBSystem();
|
||||||
|
versionCheckSystem = new VersionCheckSystem(plugin.getVersion());
|
||||||
|
|
||||||
|
taskSystem = new PlanBungeeTaskSystem();
|
||||||
|
|
||||||
|
webServerSystem = new WebServerSystem();
|
||||||
|
themeSystem = new Theme();
|
||||||
}
|
}
|
||||||
|
|
||||||
private SubSystem[] getSubSystems() {
|
private SubSystem[] getSubSystems() {
|
||||||
return new SubSystem[]{
|
return new SubSystem[]{
|
||||||
|
fileSystem,
|
||||||
|
configSystem,
|
||||||
|
versionCheckSystem,
|
||||||
databaseSystem,
|
databaseSystem,
|
||||||
fileSystem
|
taskSystem,
|
||||||
|
webServerSystem,
|
||||||
|
themeSystem
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -34,11 +91,43 @@ public class Systems {
|
|||||||
SubSystem[] subSystems = getSubSystems();
|
SubSystem[] subSystems = getSubSystems();
|
||||||
ArrayUtils.reverse(subSystems);
|
ArrayUtils.reverse(subSystems);
|
||||||
for (SubSystem subSystem : subSystems) {
|
for (SubSystem subSystem : subSystems) {
|
||||||
|
try {
|
||||||
subSystem.close();
|
subSystem.close();
|
||||||
|
} catch (Exception e) {
|
||||||
|
Log.toLog(Systems.class, e);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Systems getInstance() {
|
public static Systems getInstance() {
|
||||||
return MiscUtils.getIPlan().getSystems();
|
return MiscUtils.getIPlan().getSystems();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public FileSystem getFileSystem() {
|
||||||
|
return fileSystem;
|
||||||
|
}
|
||||||
|
|
||||||
|
public DBSystem getDatabaseSystem() {
|
||||||
|
return databaseSystem;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ConfigSystem getConfigSystem() {
|
||||||
|
return configSystem;
|
||||||
|
}
|
||||||
|
|
||||||
|
public WebServerSystem getWebServerSystem() {
|
||||||
|
return webServerSystem;
|
||||||
|
}
|
||||||
|
|
||||||
|
public VersionCheckSystem getVersionCheckSystem() {
|
||||||
|
return versionCheckSystem;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Theme getThemeSystem() {
|
||||||
|
return themeSystem;
|
||||||
|
}
|
||||||
|
|
||||||
|
public TaskSystem getTaskSystem() {
|
||||||
|
return taskSystem;
|
||||||
|
}
|
||||||
}
|
}
|
@ -2,12 +2,18 @@
|
|||||||
* Licence is provided in the jar as license.yml also here:
|
* Licence is provided in the jar as license.yml also here:
|
||||||
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
*/
|
*/
|
||||||
package main.java.com.djrapitops.plan.systems;
|
package main.java.com.djrapitops.plan.systems.file;
|
||||||
|
|
||||||
import main.java.com.djrapitops.plan.api.IPlan;
|
import main.java.com.djrapitops.plan.api.IPlan;
|
||||||
import main.java.com.djrapitops.plan.api.exceptions.PlanEnableException;
|
import main.java.com.djrapitops.plan.api.exceptions.PlanEnableException;
|
||||||
|
import main.java.com.djrapitops.plan.systems.SubSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.Systems;
|
||||||
|
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
||||||
|
import main.java.com.djrapitops.plan.utilities.file.FileUtil;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* //TODO Class Javadoc Comment
|
* //TODO Class Javadoc Comment
|
||||||
@ -20,11 +26,15 @@ public class FileSystem implements SubSystem {
|
|||||||
private File configFile;
|
private File configFile;
|
||||||
|
|
||||||
public FileSystem(IPlan plugin) {
|
public FileSystem(IPlan plugin) {
|
||||||
dataFolder = plugin.getDataFolder();
|
this(plugin.getDataFolder());
|
||||||
|
}
|
||||||
|
|
||||||
|
public FileSystem(File dataFolder) {
|
||||||
|
this.dataFolder = dataFolder;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static FileSystem getInstance() {
|
public static FileSystem getInstance() {
|
||||||
return Systems.getInstance().fileSystem;
|
return Systems.getInstance().getFileSystem();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static File getDataFolder() {
|
public static File getDataFolder() {
|
||||||
@ -35,6 +45,14 @@ public class FileSystem implements SubSystem {
|
|||||||
return getInstance().configFile;
|
return getInstance().configFile;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static File getLocaleFile() {
|
||||||
|
return new File(getInstance().dataFolder, "locale.txt");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static List<String> readFromResource(String fileName) throws IOException {
|
||||||
|
return FileUtil.lines(MiscUtils.getIPlan(), fileName);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void init() throws PlanEnableException {
|
public void init() throws PlanEnableException {
|
||||||
dataFolder.mkdirs();
|
dataFolder.mkdirs();
|
@ -0,0 +1,58 @@
|
|||||||
|
/*
|
||||||
|
* Licence is provided in the jar as license.yml also here:
|
||||||
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
|
*/
|
||||||
|
package main.java.com.djrapitops.plan.systems.file.config;
|
||||||
|
|
||||||
|
import com.djrapitops.plugin.api.config.Config;
|
||||||
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
|
import main.java.com.djrapitops.plan.api.exceptions.PlanEnableException;
|
||||||
|
import main.java.com.djrapitops.plan.systems.SubSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.Systems;
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.FileSystem;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* //TODO Class Javadoc Comment
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public abstract class ConfigSystem implements SubSystem {
|
||||||
|
|
||||||
|
protected Config config;
|
||||||
|
|
||||||
|
public static ConfigSystem getInstance() {
|
||||||
|
return Systems.getInstance().getConfigSystem();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Config getConfig() {
|
||||||
|
return config;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void init() throws PlanEnableException {
|
||||||
|
try {
|
||||||
|
config = new Config(FileSystem.getConfigFile());
|
||||||
|
copyDefaults();
|
||||||
|
config.save();
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new PlanEnableException("Config Subsystem failed to initialize", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected abstract void copyDefaults() throws IOException;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void close() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void reload() {
|
||||||
|
try {
|
||||||
|
getInstance().config.read();
|
||||||
|
} catch (IOException e) {
|
||||||
|
Log.toLog(ConfigSystem.class, e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,22 @@
|
|||||||
|
/*
|
||||||
|
* Licence is provided in the jar as license.yml also here:
|
||||||
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
|
*/
|
||||||
|
package main.java.com.djrapitops.plan.systems.file.config;
|
||||||
|
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.FileSystem;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* //TODO Class Javadoc Comment
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public class PlanBungeeConfigSystem extends ConfigSystem {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void copyDefaults() throws IOException {
|
||||||
|
config.copyDefaults(FileSystem.readFromResource("bungeeconfig.yml"));
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,22 @@
|
|||||||
|
/*
|
||||||
|
* Licence is provided in the jar as license.yml also here:
|
||||||
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
|
*/
|
||||||
|
package main.java.com.djrapitops.plan.systems.file.config;
|
||||||
|
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.FileSystem;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* //TODO Class Javadoc Comment
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public class PlanConfigSystem extends ConfigSystem {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void copyDefaults() throws IOException {
|
||||||
|
config.copyDefaults(FileSystem.readFromResource("config.yml"));
|
||||||
|
}
|
||||||
|
}
|
@ -2,20 +2,19 @@
|
|||||||
* Licence is provided in the jar as license.yml also here:
|
* Licence is provided in the jar as license.yml also here:
|
||||||
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
*/
|
*/
|
||||||
package main.java.com.djrapitops.plan.systems;
|
package main.java.com.djrapitops.plan.systems.file.database;
|
||||||
|
|
||||||
import com.djrapitops.plugin.api.Benchmark;
|
import com.djrapitops.plugin.api.Benchmark;
|
||||||
import com.djrapitops.plugin.api.Check;
|
|
||||||
import com.djrapitops.plugin.api.utility.log.Log;
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
import com.djrapitops.plugin.utilities.Verify;
|
import com.djrapitops.plugin.utilities.Verify;
|
||||||
import main.java.com.djrapitops.plan.api.exceptions.DatabaseInitException;
|
import main.java.com.djrapitops.plan.api.exceptions.DatabaseInitException;
|
||||||
import main.java.com.djrapitops.plan.api.exceptions.PlanEnableException;
|
import main.java.com.djrapitops.plan.api.exceptions.PlanEnableException;
|
||||||
import main.java.com.djrapitops.plan.database.Database;
|
import main.java.com.djrapitops.plan.database.Database;
|
||||||
import main.java.com.djrapitops.plan.database.databases.MySQLDB;
|
import main.java.com.djrapitops.plan.database.databases.SQLDB;
|
||||||
import main.java.com.djrapitops.plan.database.databases.SQLiteDB;
|
|
||||||
import main.java.com.djrapitops.plan.settings.Settings;
|
|
||||||
import main.java.com.djrapitops.plan.settings.locale.Locale;
|
import main.java.com.djrapitops.plan.settings.locale.Locale;
|
||||||
import main.java.com.djrapitops.plan.settings.locale.Msg;
|
import main.java.com.djrapitops.plan.settings.locale.Msg;
|
||||||
|
import main.java.com.djrapitops.plan.systems.SubSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.Systems;
|
||||||
|
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
@ -26,10 +25,18 @@ import java.util.Set;
|
|||||||
*
|
*
|
||||||
* @author Rsl1122
|
* @author Rsl1122
|
||||||
*/
|
*/
|
||||||
public class DatabaseSystem implements SubSystem {
|
public abstract class DBSystem implements SubSystem {
|
||||||
|
|
||||||
private Database db;
|
protected SQLDB db;
|
||||||
private Set<Database> databases;
|
protected Set<SQLDB> databases;
|
||||||
|
|
||||||
|
public DBSystem() {
|
||||||
|
databases = new HashSet<>();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static DBSystem getInstance() {
|
||||||
|
return Systems.getInstance().getDatabaseSystem();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void init() throws PlanEnableException {
|
public void init() throws PlanEnableException {
|
||||||
@ -37,38 +44,21 @@ public class DatabaseSystem implements SubSystem {
|
|||||||
Benchmark.start("Init Database");
|
Benchmark.start("Init Database");
|
||||||
Log.info(Locale.get(Msg.ENABLE_DB_INIT).toString());
|
Log.info(Locale.get(Msg.ENABLE_DB_INIT).toString());
|
||||||
initDatabase();
|
initDatabase();
|
||||||
|
db.scheduleClean(10L);
|
||||||
Log.info(Locale.get(Msg.ENABLE_DB_INFO).parse(db.getConfigName()));
|
Log.info(Locale.get(Msg.ENABLE_DB_INFO).parse(db.getConfigName()));
|
||||||
Benchmark.stop("Systems", "Init Database");
|
Benchmark.stop("Systems", "Init Database");
|
||||||
} catch (DatabaseInitException e) {
|
} catch (DatabaseInitException e) {
|
||||||
throw new PlanEnableException(db.getConfigName() + "-Database failed to initialize", e);
|
throw new PlanEnableException(db.getName() + "-Database failed to initialize", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void initDatabase() throws DatabaseInitException {
|
protected abstract void initDatabase() throws DatabaseInitException;
|
||||||
if (Check.isBungeeAvailable()) {
|
|
||||||
db = new MySQLDB();
|
|
||||||
} else {
|
|
||||||
// Enables database on Bukkit
|
|
||||||
// Bukkit supports SQLite.
|
|
||||||
initPlanDatabase();
|
|
||||||
}
|
|
||||||
db.init();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void initPlanDatabase() throws DatabaseInitException {
|
public Set<SQLDB> getDatabases() {
|
||||||
databases = new HashSet<>();
|
|
||||||
databases.add(new MySQLDB());
|
|
||||||
databases.add(new SQLiteDB());
|
|
||||||
|
|
||||||
String dbType = Settings.DB_TYPE.toString().toLowerCase().trim();
|
|
||||||
db = getActiveDatabase(dbType);
|
|
||||||
}
|
|
||||||
|
|
||||||
public Set<Database> getDatabases() {
|
|
||||||
return databases;
|
return databases;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setDatabases(Set<Database> databases) {
|
public void setDatabases(Set<SQLDB> databases) {
|
||||||
this.databases = databases;
|
this.databases = databases;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -83,16 +73,12 @@ public class DatabaseSystem implements SubSystem {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static DatabaseSystem getInstance() {
|
|
||||||
return Systems.getInstance().databaseSystem;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Database getActiveDatabase() {
|
public Database getActiveDatabase() {
|
||||||
return db;
|
return db;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Database getActiveDatabase(String dbName) throws DatabaseInitException {
|
public static SQLDB getActiveDatabase(String dbName) throws DatabaseInitException {
|
||||||
for (Database database : DatabaseSystem.getInstance().getDatabases()) {
|
for (SQLDB database : DBSystem.getInstance().getDatabases()) {
|
||||||
String dbConfigName = database.getConfigName();
|
String dbConfigName = database.getConfigName();
|
||||||
if (Verify.equalsIgnoreCase(dbName, dbConfigName)) {
|
if (Verify.equalsIgnoreCase(dbName, dbConfigName)) {
|
||||||
database.init();
|
database.init();
|
@ -0,0 +1,24 @@
|
|||||||
|
/*
|
||||||
|
* Licence is provided in the jar as license.yml also here:
|
||||||
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
|
*/
|
||||||
|
package main.java.com.djrapitops.plan.systems.file.database;
|
||||||
|
|
||||||
|
import main.java.com.djrapitops.plan.api.exceptions.DatabaseInitException;
|
||||||
|
import main.java.com.djrapitops.plan.database.databases.MySQLDB;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* //TODO Class Javadoc Comment
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public class PlanBungeeDBSystem extends DBSystem {
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void initDatabase() throws DatabaseInitException {
|
||||||
|
db = new MySQLDB();
|
||||||
|
databases.add(db);
|
||||||
|
db.init();
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,28 @@
|
|||||||
|
/*
|
||||||
|
* Licence is provided in the jar as license.yml also here:
|
||||||
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
|
*/
|
||||||
|
package main.java.com.djrapitops.plan.systems.file.database;
|
||||||
|
|
||||||
|
import main.java.com.djrapitops.plan.api.exceptions.DatabaseInitException;
|
||||||
|
import main.java.com.djrapitops.plan.database.databases.MySQLDB;
|
||||||
|
import main.java.com.djrapitops.plan.database.databases.SQLiteDB;
|
||||||
|
import main.java.com.djrapitops.plan.settings.Settings;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* //TODO Class Javadoc Comment
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public class PlanDBSystem extends DBSystem {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void initDatabase() throws DatabaseInitException {
|
||||||
|
databases.add(new MySQLDB());
|
||||||
|
databases.add(new SQLiteDB());
|
||||||
|
|
||||||
|
String dbType = Settings.DB_TYPE.toString().toLowerCase().trim();
|
||||||
|
db = getActiveDatabase(dbType);
|
||||||
|
db.init();
|
||||||
|
}
|
||||||
|
}
|
@ -19,8 +19,10 @@ import main.java.com.djrapitops.plan.systems.cache.DataCache;
|
|||||||
import main.java.com.djrapitops.plan.systems.info.parsing.AnalysisPageParser;
|
import main.java.com.djrapitops.plan.systems.info.parsing.AnalysisPageParser;
|
||||||
import main.java.com.djrapitops.plan.systems.info.parsing.InspectPageParser;
|
import main.java.com.djrapitops.plan.systems.info.parsing.InspectPageParser;
|
||||||
import main.java.com.djrapitops.plan.systems.processing.Processor;
|
import main.java.com.djrapitops.plan.systems.processing.Processor;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.PageCache;
|
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.WebServer;
|
import main.java.com.djrapitops.plan.systems.webserver.WebServer;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.WebServerSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageCache;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageId;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.*;
|
import main.java.com.djrapitops.plan.systems.webserver.response.*;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.webapi.WebAPIManager;
|
import main.java.com.djrapitops.plan.systems.webserver.webapi.WebAPIManager;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.webapi.bukkit.AnalysisReadyWebAPI;
|
import main.java.com.djrapitops.plan.systems.webserver.webapi.bukkit.AnalysisReadyWebAPI;
|
||||||
@ -62,8 +64,7 @@ public class BukkitInformationManager extends InformationManager {
|
|||||||
dataCache = new DataCache(plugin);
|
dataCache = new DataCache(plugin);
|
||||||
analysis = new Analysis(plugin);
|
analysis = new Analysis(plugin);
|
||||||
pluginsTabContents = new HashMap<>();
|
pluginsTabContents = new HashMap<>();
|
||||||
|
usingAnotherWebServer = false;
|
||||||
updateConnection();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void updateConnection() {
|
public void updateConnection() {
|
||||||
@ -114,7 +115,7 @@ public class BukkitInformationManager extends InformationManager {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
PageCache.cachePage("inspectPage: " + uuid, () -> {
|
PageCache.cachePage(PageId.PLAYER.of(uuid), () -> {
|
||||||
try {
|
try {
|
||||||
return new InspectPageResponse(this, uuid);
|
return new InspectPageResponse(this, uuid);
|
||||||
} catch (ParseException e) {
|
} catch (ParseException e) {
|
||||||
@ -154,7 +155,6 @@ public class BukkitInformationManager extends InformationManager {
|
|||||||
cacheInspectPluginsTab(uuid, origin);
|
cacheInspectPluginsTab(uuid, origin);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
String serverName = plugin.getServerInfoManager().getServerName();
|
|
||||||
HookHandler hookHandler = plugin.getHookHandler();
|
HookHandler hookHandler = plugin.getHookHandler();
|
||||||
List<PluginData> plugins = hookHandler.getAdditionalDataSources();
|
List<PluginData> plugins = hookHandler.getAdditionalDataSources();
|
||||||
Map<PluginData, InspectContainer> containers = new HashMap<>();
|
Map<PluginData, InspectContainer> containers = new HashMap<>();
|
||||||
@ -188,7 +188,7 @@ public class BukkitInformationManager extends InformationManager {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
pluginsTabContents.put(uuid, contents);
|
pluginsTabContents.put(uuid, contents);
|
||||||
Response inspectResponse = PageCache.loadPage("inspectPage: " + uuid);
|
Response inspectResponse = PageCache.loadPage(PageId.PLAYER.of(uuid));
|
||||||
if (inspectResponse != null && inspectResponse instanceof InspectPageResponse) {
|
if (inspectResponse != null && inspectResponse instanceof InspectPageResponse) {
|
||||||
((InspectPageResponse) inspectResponse).setInspectPagePluginsTab(contents);
|
((InspectPageResponse) inspectResponse).setInspectPagePluginsTab(contents);
|
||||||
}
|
}
|
||||||
@ -231,7 +231,7 @@ public class BukkitInformationManager extends InformationManager {
|
|||||||
return isAnalysisCached(serverUUID);
|
return isAnalysisCached(serverUUID);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return PageCache.isCached("analysisPage:" + serverUUID);
|
return PageCache.isCached(PageId.SERVER.of(serverUUID));
|
||||||
}
|
}
|
||||||
|
|
||||||
private WebAPIManager getWebAPI() {
|
private WebAPIManager getWebAPI() {
|
||||||
@ -306,7 +306,7 @@ public class BukkitInformationManager extends InformationManager {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
UUID serverUUID = Plan.getServerUUID();
|
UUID serverUUID = Plan.getServerUUID();
|
||||||
PageCache.cachePage("analysisPage:" + serverUUID, () -> new AnalysisPageResponse(html));
|
PageCache.cachePage(PageId.SERVER.of(serverUUID), () -> new AnalysisPageResponse(html));
|
||||||
if (Settings.ANALYSIS_EXPORT.isTrue()) {
|
if (Settings.ANALYSIS_EXPORT.isTrue()) {
|
||||||
HtmlExport.exportServer(plugin, serverUUID);
|
HtmlExport.exportServer(plugin, serverUUID);
|
||||||
}
|
}
|
||||||
@ -323,8 +323,7 @@ public class BukkitInformationManager extends InformationManager {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean attemptConnection() {
|
public boolean attemptConnection() {
|
||||||
WebServer webServer = plugin.getWebServer();
|
boolean webServerIsEnabled = WebServerSystem.isWebServerEnabled();
|
||||||
boolean webServerIsEnabled = webServer.isEnabled();
|
|
||||||
boolean previousState = usingAnotherWebServer;
|
boolean previousState = usingAnotherWebServer;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
@ -350,6 +349,7 @@ public class BukkitInformationManager extends InformationManager {
|
|||||||
} finally {
|
} finally {
|
||||||
boolean changedState = previousState != usingAnotherWebServer;
|
boolean changedState = previousState != usingAnotherWebServer;
|
||||||
if (webServerIsEnabled && changedState) {
|
if (webServerIsEnabled && changedState) {
|
||||||
|
WebServer webServer = WebServerSystem.getInstance().getWebServer();
|
||||||
webServer.stop();
|
webServer.stop();
|
||||||
webServer.initServer();
|
webServer.initServer();
|
||||||
}
|
}
|
||||||
|
@ -16,7 +16,8 @@ import main.java.com.djrapitops.plan.systems.cache.DataCache;
|
|||||||
import main.java.com.djrapitops.plan.systems.info.parsing.NetworkPageParser;
|
import main.java.com.djrapitops.plan.systems.info.parsing.NetworkPageParser;
|
||||||
import main.java.com.djrapitops.plan.systems.info.server.BungeeServerInfoManager;
|
import main.java.com.djrapitops.plan.systems.info.server.BungeeServerInfoManager;
|
||||||
import main.java.com.djrapitops.plan.systems.info.server.ServerInfo;
|
import main.java.com.djrapitops.plan.systems.info.server.ServerInfo;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.PageCache;
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageCache;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageId;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.*;
|
import main.java.com.djrapitops.plan.systems.webserver.response.*;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.webapi.WebAPIManager;
|
import main.java.com.djrapitops.plan.systems.webserver.webapi.WebAPIManager;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.webapi.bukkit.AnalysisReadyWebAPI;
|
import main.java.com.djrapitops.plan.systems.webserver.webapi.bukkit.AnalysisReadyWebAPI;
|
||||||
@ -233,11 +234,7 @@ public class BungeeInformationManager extends InformationManager {
|
|||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean isAnalysisCached(UUID serverUUID) {
|
public boolean isAnalysisCached(UUID serverUUID) {
|
||||||
if (PlanBungee.getServerUUID().equals(serverUUID)) {
|
return PageCache.isCached(PageId.SERVER.of(serverUUID));
|
||||||
return PageCache.isCached("networkPage");
|
|
||||||
} else {
|
|
||||||
return PageCache.isCached("analysisPage:" + serverUUID);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -250,7 +247,7 @@ public class BungeeInformationManager extends InformationManager {
|
|||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public String getPlayerHtml(UUID uuid) {
|
public String getPlayerHtml(UUID uuid) {
|
||||||
Response response = PageCache.copyPage("inspectPage:" + uuid,
|
Response response = PageCache.copyPage(PageId.PLAYER.of(uuid),
|
||||||
() -> new NotFoundResponse("No Bukkit Servers were online to process this request"));
|
() -> new NotFoundResponse("No Bukkit Servers were online to process this request"));
|
||||||
if (response instanceof InspectPageResponse) {
|
if (response instanceof InspectPageResponse) {
|
||||||
((InspectPageResponse) response).setInspectPagePluginsTab(getPluginsTabContent(uuid));
|
((InspectPageResponse) response).setInspectPagePluginsTab(getPluginsTabContent(uuid));
|
||||||
@ -314,7 +311,7 @@ public class BungeeInformationManager extends InformationManager {
|
|||||||
Map<UUID, String[]> perServerPluginsTab = pluginsTabContent.getOrDefault(uuid, new HashMap<>());
|
Map<UUID, String[]> perServerPluginsTab = pluginsTabContent.getOrDefault(uuid, new HashMap<>());
|
||||||
perServerPluginsTab.put(serverUUID, html);
|
perServerPluginsTab.put(serverUUID, html);
|
||||||
pluginsTabContent.put(uuid, perServerPluginsTab);
|
pluginsTabContent.put(uuid, perServerPluginsTab);
|
||||||
Response inspectResponse = PageCache.loadPage("inspectPage: " + uuid);
|
Response inspectResponse = PageCache.loadPage(PageId.PLAYER.of(uuid));
|
||||||
if (inspectResponse != null && inspectResponse instanceof InspectPageResponse) {
|
if (inspectResponse != null && inspectResponse instanceof InspectPageResponse) {
|
||||||
((InspectPageResponse) inspectResponse).setInspectPagePluginsTab(getPluginsTabContent(uuid));
|
((InspectPageResponse) inspectResponse).setInspectPagePluginsTab(getPluginsTabContent(uuid));
|
||||||
}
|
}
|
||||||
@ -372,7 +369,7 @@ public class BungeeInformationManager extends InformationManager {
|
|||||||
@Override
|
@Override
|
||||||
public void updateNetworkPageContent() {
|
public void updateNetworkPageContent() {
|
||||||
UUID serverUUID = MiscUtils.getIPlan().getServerUuid();
|
UUID serverUUID = MiscUtils.getIPlan().getServerUuid();
|
||||||
PageCache.cachePage("analysisPage:" + serverUUID, () -> new AnalysisPageResponse(this));
|
PageCache.cachePage(PageId.SERVER.of(serverUUID), () -> new AnalysisPageResponse(this));
|
||||||
if (Settings.ANALYSIS_EXPORT.isTrue()) {
|
if (Settings.ANALYSIS_EXPORT.isTrue()) {
|
||||||
HtmlExport.exportServer(plugin, serverUUID);
|
HtmlExport.exportServer(plugin, serverUUID);
|
||||||
}
|
}
|
||||||
|
@ -8,7 +8,8 @@ import com.djrapitops.plugin.command.ISender;
|
|||||||
import main.java.com.djrapitops.plan.api.exceptions.ParseException;
|
import main.java.com.djrapitops.plan.api.exceptions.ParseException;
|
||||||
import main.java.com.djrapitops.plan.systems.cache.DataCache;
|
import main.java.com.djrapitops.plan.systems.cache.DataCache;
|
||||||
import main.java.com.djrapitops.plan.systems.cache.SessionCache;
|
import main.java.com.djrapitops.plan.systems.cache.SessionCache;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.PageCache;
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageCache;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageId;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
@ -46,7 +47,7 @@ public abstract class InformationManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public boolean isCached(UUID uuid) {
|
public boolean isCached(UUID uuid) {
|
||||||
return PageCache.isCached("inspectPage: " + uuid);
|
return PageCache.isCached(PageId.PLAYER.of(uuid));
|
||||||
}
|
}
|
||||||
|
|
||||||
public abstract String getPlayerHtml(UUID uuid) throws ParseException;
|
public abstract String getPlayerHtml(UUID uuid) throws ParseException;
|
||||||
|
@ -235,7 +235,7 @@ public class InspectPageParser extends PageParser {
|
|||||||
addValue("playerStatus", HtmlStructure.playerStatus(online, profile.getBannedOnServers(), profile.isOp()));
|
addValue("playerStatus", HtmlStructure.playerStatus(online, profile.getBannedOnServers(), profile.isOp()));
|
||||||
|
|
||||||
if (!plugin.getInfoManager().isUsingAnotherWebServer()) {
|
if (!plugin.getInfoManager().isUsingAnotherWebServer()) {
|
||||||
addValue("networkName", Settings.SERVER_NAME.toString());
|
addValue("networkName", Settings.SERVER_NAME.toString().replaceAll("[^a-zA-Z0-9_\\s]", "_"));
|
||||||
}
|
}
|
||||||
|
|
||||||
return HtmlUtils.replacePlaceholders(FileUtil.getStringFromResource("web/player.html"), placeHolders);
|
return HtmlUtils.replacePlaceholders(FileUtil.getStringFromResource("web/player.html"), placeHolders);
|
||||||
|
@ -42,13 +42,6 @@ public class BukkitServerInfoManager {
|
|||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
throw new PlanEnableException("Failed to read ServerInfoFile.yml", e);
|
throw new PlanEnableException("Failed to read ServerInfoFile.yml", e);
|
||||||
}
|
}
|
||||||
try {
|
|
||||||
updateServerInfo();
|
|
||||||
} catch (SQLException e) {
|
|
||||||
throw new PlanEnableException("Failed to update Database server info", e);
|
|
||||||
} catch (IOException e) {
|
|
||||||
throw new PlanEnableException("Failed to write to ServerInfoFile.yml", e);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void updateServerInfo() throws SQLException, IOException {
|
public void updateServerInfo() throws SQLException, IOException {
|
||||||
@ -66,7 +59,7 @@ public class BukkitServerInfoManager {
|
|||||||
registerServer(serverUUID);
|
registerServer(serverUUID);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
String name = Settings.SERVER_NAME.toString();
|
String name = Settings.SERVER_NAME.toString().replaceAll("[^a-zA-Z0-9_\\s]", "_");
|
||||||
String webAddress = plugin.getWebServer().getAccessAddress();
|
String webAddress = plugin.getWebServer().getAccessAddress();
|
||||||
if ("plan".equalsIgnoreCase(name)) {
|
if ("plan".equalsIgnoreCase(name)) {
|
||||||
name = "Server " + serverID.get();
|
name = "Server " + serverID.get();
|
||||||
@ -83,7 +76,7 @@ public class BukkitServerInfoManager {
|
|||||||
|
|
||||||
private void registerServer(UUID serverUUID) throws SQLException, IOException {
|
private void registerServer(UUID serverUUID) throws SQLException, IOException {
|
||||||
String webAddress = plugin.getWebServer().getAccessAddress();
|
String webAddress = plugin.getWebServer().getAccessAddress();
|
||||||
String name = Settings.SERVER_NAME.toString();
|
String name = Settings.SERVER_NAME.toString().replaceAll("[^a-zA-Z0-9_\\s]", "_");
|
||||||
int maxPlayers = plugin.getVariable().getMaxPlayers();
|
int maxPlayers = plugin.getVariable().getMaxPlayers();
|
||||||
serverInfo = new ServerInfo(-1, serverUUID, name, webAddress, maxPlayers);
|
serverInfo = new ServerInfo(-1, serverUUID, name, webAddress, maxPlayers);
|
||||||
serverTable.saveCurrentServerInfo(serverInfo);
|
serverTable.saveCurrentServerInfo(serverInfo);
|
||||||
|
@ -49,7 +49,7 @@ public class PlanGamemodeChangeListener implements Listener {
|
|||||||
String gameMode = event.getNewGameMode().name();
|
String gameMode = event.getNewGameMode().name();
|
||||||
String worldName = p.getWorld().getName();
|
String worldName = p.getWorld().getName();
|
||||||
|
|
||||||
new WorldAliasSettings(plugin).addWorld(worldName);
|
new WorldAliasSettings().addWorld(worldName);
|
||||||
|
|
||||||
Optional<Session> cachedSession = plugin.getDataCache().getCachedSession(uuid);
|
Optional<Session> cachedSession = plugin.getDataCache().getCachedSession(uuid);
|
||||||
cachedSession.ifPresent(session -> session.changeState(worldName, gameMode, time));
|
cachedSession.ifPresent(session -> session.changeState(worldName, gameMode, time));
|
||||||
|
@ -7,6 +7,7 @@ import main.java.com.djrapitops.plan.data.container.Session;
|
|||||||
import main.java.com.djrapitops.plan.systems.cache.DataCache;
|
import main.java.com.djrapitops.plan.systems.cache.DataCache;
|
||||||
import main.java.com.djrapitops.plan.systems.processing.info.NetworkPageUpdateProcessor;
|
import main.java.com.djrapitops.plan.systems.processing.info.NetworkPageUpdateProcessor;
|
||||||
import main.java.com.djrapitops.plan.systems.processing.player.*;
|
import main.java.com.djrapitops.plan.systems.processing.player.*;
|
||||||
|
import main.java.com.djrapitops.plan.systems.tasks.TaskSystem;
|
||||||
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
@ -103,7 +104,7 @@ public class PlanPlayerListener implements Listener {
|
|||||||
String playerName = player.getName();
|
String playerName = player.getName();
|
||||||
String displayName = player.getDisplayName();
|
String displayName = player.getDisplayName();
|
||||||
|
|
||||||
int playersOnline = plugin.getTpsCountTimer().getLatestPlayersOnline();
|
int playersOnline = TaskSystem.getInstance().getTpsCountTimer().getLatestPlayersOnline();
|
||||||
|
|
||||||
cache.cacheSession(uuid, Session.start(time, world, gm));
|
cache.cacheSession(uuid, Session.start(time, world, gm));
|
||||||
plugin.addToProcessQueue(
|
plugin.addToProcessQueue(
|
||||||
|
@ -31,7 +31,7 @@ public class PlanWorldChangeListener implements Listener {
|
|||||||
String gameMode = p.getGameMode().name();
|
String gameMode = p.getGameMode().name();
|
||||||
long time = MiscUtils.getTime();
|
long time = MiscUtils.getTime();
|
||||||
|
|
||||||
new WorldAliasSettings(plugin).addWorld(worldName);
|
new WorldAliasSettings().addWorld(worldName);
|
||||||
|
|
||||||
Optional<Session> cachedSession = plugin.getDataCache().getCachedSession(uuid);
|
Optional<Session> cachedSession = plugin.getDataCache().getCachedSession(uuid);
|
||||||
cachedSession.ifPresent(session -> session.changeState(worldName, gameMode, time));
|
cachedSession.ifPresent(session -> session.changeState(worldName, gameMode, time));
|
||||||
|
@ -0,0 +1,44 @@
|
|||||||
|
/*
|
||||||
|
* Licence is provided in the jar as license.yml also here:
|
||||||
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
|
*/
|
||||||
|
package main.java.com.djrapitops.plan.systems.tasks;
|
||||||
|
|
||||||
|
import com.djrapitops.plugin.api.TimeAmount;
|
||||||
|
import com.djrapitops.plugin.task.AbsRunnable;
|
||||||
|
import main.java.com.djrapitops.plan.PlanBungee;
|
||||||
|
import main.java.com.djrapitops.plan.api.exceptions.PlanEnableException;
|
||||||
|
import main.java.com.djrapitops.plan.systems.info.BungeeInformationManager;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* //TODO Class Javadoc Comment
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public class PlanBungeeTaskSystem extends TaskSystem {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void init() throws PlanEnableException {
|
||||||
|
registerTasks();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void registerTasks() {
|
||||||
|
BungeeInformationManager infoManager = ((BungeeInformationManager) PlanBungee.getInstance().getInfoManager());
|
||||||
|
|
||||||
|
registerTask("Enable Bukkit Connection Task", new AbsRunnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
infoManager.attemptConnection();
|
||||||
|
infoManager.sendConfigSettings();
|
||||||
|
}
|
||||||
|
}).runTaskAsynchronously();
|
||||||
|
registerTask("Player Count task", new TPSCountTimer(PlanBungee.getInstance()))
|
||||||
|
.runTaskTimerAsynchronously(1000, TimeAmount.SECOND.ticks());
|
||||||
|
registerTask("NetworkPageContentUpdateTask", new AbsRunnable("NetworkPageContentUpdateTask") {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
infoManager.updateNetworkPageContent();
|
||||||
|
}
|
||||||
|
}).runTaskTimerAsynchronously(1500, TimeAmount.MINUTE.ticks());
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,89 @@
|
|||||||
|
/*
|
||||||
|
* Licence is provided in the jar as license.yml also here:
|
||||||
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
|
*/
|
||||||
|
package main.java.com.djrapitops.plan.systems.tasks;
|
||||||
|
|
||||||
|
import com.djrapitops.plugin.api.Benchmark;
|
||||||
|
import com.djrapitops.plugin.api.TimeAmount;
|
||||||
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
|
import com.djrapitops.plugin.task.AbsRunnable;
|
||||||
|
import com.djrapitops.plugin.task.ITask;
|
||||||
|
import com.djrapitops.plugin.task.RunnableFactory;
|
||||||
|
import main.java.com.djrapitops.plan.Plan;
|
||||||
|
import main.java.com.djrapitops.plan.api.exceptions.PlanEnableException;
|
||||||
|
import main.java.com.djrapitops.plan.settings.Settings;
|
||||||
|
import main.java.com.djrapitops.plan.settings.locale.Locale;
|
||||||
|
import main.java.com.djrapitops.plan.settings.locale.Msg;
|
||||||
|
import main.java.com.djrapitops.plan.systems.info.InformationManager;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* //TODO Class Javadoc Comment
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public class PlanTaskSystem extends TaskSystem {
|
||||||
|
|
||||||
|
// TODO Remove Plan.getInstance requirement.
|
||||||
|
|
||||||
|
private ITask bootAnalysisTask;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void init() throws PlanEnableException {
|
||||||
|
registerTasks();
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO Clean Up
|
||||||
|
private void registerTasks() {
|
||||||
|
String bootAnalysisMsg = Locale.get(Msg.ENABLE_BOOT_ANALYSIS_INFO).toString();
|
||||||
|
String bootAnalysisRunMsg = Locale.get(Msg.ENABLE_BOOT_ANALYSIS_RUN_INFO).toString();
|
||||||
|
|
||||||
|
Benchmark.start("Task Registration");
|
||||||
|
tpsCountTimer = new TPSCountTimer(Plan.getInstance());
|
||||||
|
registerTask(tpsCountTimer).runTaskTimer(1000, TimeAmount.SECOND.ticks());
|
||||||
|
|
||||||
|
// Analysis refresh settings
|
||||||
|
int analysisRefreshMinutes = Settings.ANALYSIS_AUTO_REFRESH.getNumber();
|
||||||
|
boolean analysisRefreshTaskIsEnabled = analysisRefreshMinutes > 0;
|
||||||
|
long analysisPeriod = analysisRefreshMinutes * TimeAmount.MINUTE.ticks();
|
||||||
|
|
||||||
|
Log.info(bootAnalysisMsg);
|
||||||
|
|
||||||
|
InformationManager infoManager = Plan.getInstance().getInfoManager();
|
||||||
|
|
||||||
|
bootAnalysisTask = RunnableFactory.createNew("BootAnalysisTask", new AbsRunnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
Log.info(bootAnalysisRunMsg);
|
||||||
|
infoManager.refreshAnalysis(Plan.getServerUUID());
|
||||||
|
this.cancel();
|
||||||
|
}
|
||||||
|
}).runTaskLaterAsynchronously(30 * TimeAmount.SECOND.ticks());
|
||||||
|
|
||||||
|
if (analysisRefreshTaskIsEnabled) {
|
||||||
|
RunnableFactory.createNew("PeriodicalAnalysisTask", new AbsRunnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
infoManager.refreshAnalysis(Plan.getServerUUID());
|
||||||
|
}
|
||||||
|
}).runTaskTimerAsynchronously(analysisPeriod, analysisPeriod);
|
||||||
|
}
|
||||||
|
|
||||||
|
registerTask("PeriodicNetworkBoxRefreshTask", new AbsRunnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
infoManager.updateNetworkPageContent();
|
||||||
|
}
|
||||||
|
}).runTaskTimerAsynchronously(TimeAmount.SECOND.ticks(), TimeAmount.MINUTE.ticks() * 5L);
|
||||||
|
|
||||||
|
Benchmark.stop("Enable", "Task Registration");
|
||||||
|
}
|
||||||
|
|
||||||
|
public void cancelBootAnalysis() {
|
||||||
|
try {
|
||||||
|
bootAnalysisTask.cancel();
|
||||||
|
} catch (Exception ignored) {
|
||||||
|
/* Ignored */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,45 @@
|
|||||||
|
/*
|
||||||
|
* Licence is provided in the jar as license.yml also here:
|
||||||
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
|
*/
|
||||||
|
package main.java.com.djrapitops.plan.systems.tasks;
|
||||||
|
|
||||||
|
import com.djrapitops.plugin.api.systems.TaskCenter;
|
||||||
|
import com.djrapitops.plugin.task.AbsRunnable;
|
||||||
|
import com.djrapitops.plugin.task.IRunnable;
|
||||||
|
import com.djrapitops.plugin.task.RunnableFactory;
|
||||||
|
import main.java.com.djrapitops.plan.systems.SubSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.Systems;
|
||||||
|
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* //TODO Class Javadoc Comment
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public abstract class TaskSystem implements SubSystem {
|
||||||
|
|
||||||
|
protected TPSCountTimer tpsCountTimer;
|
||||||
|
|
||||||
|
public static TaskSystem getInstance() {
|
||||||
|
return Systems.getInstance().getTaskSystem();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected IRunnable registerTask(AbsRunnable runnable) {
|
||||||
|
String taskName = runnable.getName();
|
||||||
|
return registerTask(taskName != null ? taskName : runnable.getClass().getSimpleName(), runnable);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected IRunnable registerTask(String name, AbsRunnable runnable) {
|
||||||
|
return RunnableFactory.createNew(name, runnable);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void close() {
|
||||||
|
TaskCenter.cancelAllKnownTasks(MiscUtils.getIPlan().getClass());
|
||||||
|
}
|
||||||
|
|
||||||
|
public TPSCountTimer getTpsCountTimer() {
|
||||||
|
return tpsCountTimer;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,68 @@
|
|||||||
|
/*
|
||||||
|
* Licence is provided in the jar as license.yml also here:
|
||||||
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
|
*/
|
||||||
|
package main.java.com.djrapitops.plan.systems.update;
|
||||||
|
|
||||||
|
import com.djrapitops.plugin.api.Priority;
|
||||||
|
import com.djrapitops.plugin.api.systems.NotificationCenter;
|
||||||
|
import com.djrapitops.plugin.api.utility.Version;
|
||||||
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
|
import main.java.com.djrapitops.plan.api.exceptions.PlanEnableException;
|
||||||
|
import main.java.com.djrapitops.plan.systems.SubSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.Systems;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* //TODO Class Javadoc Comment
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public class VersionCheckSystem implements SubSystem {
|
||||||
|
|
||||||
|
private final String currentVersion;
|
||||||
|
private boolean newVersionAvailable = false;
|
||||||
|
|
||||||
|
public VersionCheckSystem(String currentVersion) {
|
||||||
|
this.currentVersion = currentVersion;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static VersionCheckSystem getInstance() {
|
||||||
|
return Systems.getInstance().getVersionCheckSystem();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void init() throws PlanEnableException {
|
||||||
|
checkForNewVersion();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkForNewVersion() {
|
||||||
|
String githubVersionUrl = "https://raw.githubusercontent.com/Rsl1122/Plan-PlayerAnalytics/master/Plan/src/main/resources/plugin.yml";
|
||||||
|
String spigotUrl = "https://www.spigotmc.org/resources/plan-player-analytics.32536/";
|
||||||
|
try {
|
||||||
|
newVersionAvailable = Version.checkVersion(currentVersion, githubVersionUrl)
|
||||||
|
|| Version.checkVersion(currentVersion, spigotUrl);
|
||||||
|
if (newVersionAvailable) {
|
||||||
|
String newVersionNotification = "New Version is available at " + spigotUrl;
|
||||||
|
Log.infoColor("§a----------------------------------------");
|
||||||
|
Log.infoColor("§a"+newVersionNotification);
|
||||||
|
Log.infoColor("§a----------------------------------------");
|
||||||
|
NotificationCenter.addNotification(Priority.HIGH, newVersionNotification);
|
||||||
|
} else {
|
||||||
|
Log.info("You're using the latest version.");
|
||||||
|
}
|
||||||
|
} catch (IOException e) {
|
||||||
|
Log.error("Failed to check newest version number");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void close() {
|
||||||
|
/* Does not need to be closed */
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean isNewVersionAvailable() {
|
||||||
|
return getInstance().newVersionAvailable;
|
||||||
|
}
|
||||||
|
}
|
@ -5,6 +5,8 @@
|
|||||||
package main.java.com.djrapitops.plan.systems.webserver;
|
package main.java.com.djrapitops.plan.systems.webserver;
|
||||||
|
|
||||||
import com.djrapitops.plugin.api.utility.log.Log;
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageCache;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageId;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.*;
|
import main.java.com.djrapitops.plan.systems.webserver.response.*;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.api.BadRequestResponse;
|
import main.java.com.djrapitops.plan.systems.webserver.response.api.BadRequestResponse;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.webapi.WebAPI;
|
import main.java.com.djrapitops.plan.systems.webserver.webapi.WebAPI;
|
||||||
@ -39,29 +41,29 @@ public class APIResponseHandler {
|
|||||||
String[] args = target.split("/");
|
String[] args = target.split("/");
|
||||||
|
|
||||||
if ("/favicon.ico".equalsIgnoreCase(target)) {
|
if ("/favicon.ico".equalsIgnoreCase(target)) {
|
||||||
return PageCache.loadPage("Redirect: favicon", () -> new RedirectResponse("https://puu.sh/tK0KL/6aa2ba141b.ico"));
|
return PageCache.loadPage(PageId.FAVICON_REDIRECT.id(), () -> new RedirectResponse("https://puu.sh/tK0KL/6aa2ba141b.ico"));
|
||||||
}
|
}
|
||||||
if ("/debug".equalsIgnoreCase(target)) {
|
if ("/debug".equalsIgnoreCase(target)) {
|
||||||
return new DebugPageResponse();
|
return new DebugPageResponse();
|
||||||
}
|
}
|
||||||
if (target.endsWith(".css")) {
|
if (target.endsWith(".css")) {
|
||||||
return PageCache.loadPage(target + "css", () -> new CSSResponse(target));
|
return PageCache.loadPage(PageId.CSS.of(target), () -> new CSSResponse(target));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (target.endsWith(".js")) {
|
if (target.endsWith(".js")) {
|
||||||
return PageCache.loadPage(target + "js", () -> new JavaScriptResponse(target));
|
return PageCache.loadPage(PageId.JS.of(target), () -> new JavaScriptResponse(target));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (args.length < 2 || !"api".equals(args[1])) {
|
if (args.length < 2 || !"api".equals(args[1])) {
|
||||||
String address = MiscUtils.getIPlan().getInfoManager().getWebServerAddress() + target;
|
String address = MiscUtils.getIPlan().getInfoManager().getWebServerAddress() + target;
|
||||||
String link = Html.LINK.parse(address, address);
|
String link = Html.LINK.parse(address, address);
|
||||||
return PageCache.loadPage("Non-API Request", () -> new NotFoundResponse("WebServer is in WebAPI-only mode, " +
|
return PageCache.loadPage(PageId.ERROR.of("Non-API Request"), () -> new NotFoundResponse("WebServer is in WebAPI-only mode, " +
|
||||||
"connect to the Bungee server instead: " + link));
|
"connect to the Bungee server instead: " + link));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (args.length < 3) {
|
if (args.length < 3) {
|
||||||
String error = "API Method not specified";
|
String error = "API Method not specified";
|
||||||
return PageCache.loadPage(error, () -> new BadRequestResponse(error));
|
return PageCache.loadPage(PageId.ERROR.of(error), () -> new BadRequestResponse(error));
|
||||||
}
|
}
|
||||||
|
|
||||||
String method = args[2];
|
String method = args[2];
|
||||||
@ -73,7 +75,7 @@ public class APIResponseHandler {
|
|||||||
if (requestBody == null) {
|
if (requestBody == null) {
|
||||||
String error = "Error at reading the POST request." +
|
String error = "Error at reading the POST request." +
|
||||||
"Note that the Encoding must be ISO-8859-1.";
|
"Note that the Encoding must be ISO-8859-1.";
|
||||||
return PageCache.loadPage(error, () -> new BadRequestResponse(error));
|
return PageCache.loadPage(PageId.ERROR.of(error), () -> new BadRequestResponse(error));
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String, String> variables = WebAPI.readVariables(requestBody);
|
Map<String, String> variables = WebAPI.readVariables(requestBody);
|
||||||
@ -92,7 +94,7 @@ public class APIResponseHandler {
|
|||||||
if (!checkKey(sender)) {
|
if (!checkKey(sender)) {
|
||||||
String error = "Server Key not given or invalid";
|
String error = "Server Key not given or invalid";
|
||||||
Log.debug("Request had invalid Server key: " + sender);
|
Log.debug("Request had invalid Server key: " + sender);
|
||||||
return PageCache.loadPage(error, () -> {
|
return PageCache.loadPage(PageId.ERROR.of(error), () -> {
|
||||||
ForbiddenResponse forbidden = new ForbiddenResponse();
|
ForbiddenResponse forbidden = new ForbiddenResponse();
|
||||||
forbidden.setContent(error);
|
forbidden.setContent(error);
|
||||||
return forbidden;
|
return forbidden;
|
||||||
@ -102,7 +104,7 @@ public class APIResponseHandler {
|
|||||||
if (!webAPI.isAuthorized(accessKey)) {
|
if (!webAPI.isAuthorized(accessKey)) {
|
||||||
String error = "Access Key invalid";
|
String error = "Access Key invalid";
|
||||||
Log.debug("Request had invalid Access key: " + accessKey);
|
Log.debug("Request had invalid Access key: " + accessKey);
|
||||||
return PageCache.loadPage(error, () -> {
|
return PageCache.loadPage(PageId.ERROR.of(error), () -> {
|
||||||
ForbiddenResponse forbidden = new ForbiddenResponse();
|
ForbiddenResponse forbidden = new ForbiddenResponse();
|
||||||
forbidden.setContent(error);
|
forbidden.setContent(error);
|
||||||
return forbidden;
|
return forbidden;
|
||||||
@ -116,7 +118,7 @@ public class APIResponseHandler {
|
|||||||
if (api == null) {
|
if (api == null) {
|
||||||
String error = "API Method not found";
|
String error = "API Method not found";
|
||||||
Log.debug(error);
|
Log.debug(error);
|
||||||
return PageCache.loadPage(error, () -> new BadRequestResponse(error));
|
return PageCache.loadPage(PageId.ERROR.of(error), () -> new BadRequestResponse(error));
|
||||||
}
|
}
|
||||||
|
|
||||||
Response response = api.processRequest(MiscUtils.getIPlan(), variables);
|
Response response = api.processRequest(MiscUtils.getIPlan(), variables);
|
||||||
|
@ -10,6 +10,8 @@ import main.java.com.djrapitops.plan.api.exceptions.ParseException;
|
|||||||
import main.java.com.djrapitops.plan.api.exceptions.WebUserAuthException;
|
import main.java.com.djrapitops.plan.api.exceptions.WebUserAuthException;
|
||||||
import main.java.com.djrapitops.plan.data.WebUser;
|
import main.java.com.djrapitops.plan.data.WebUser;
|
||||||
import main.java.com.djrapitops.plan.database.tables.SecurityTable;
|
import main.java.com.djrapitops.plan.database.tables.SecurityTable;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageCache;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageId;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.*;
|
import main.java.com.djrapitops.plan.systems.webserver.response.*;
|
||||||
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
||||||
import main.java.com.djrapitops.plan.utilities.PassEncryptUtil;
|
import main.java.com.djrapitops.plan.utilities.PassEncryptUtil;
|
||||||
@ -42,17 +44,17 @@ public class ResponseHandler extends APIResponseHandler {
|
|||||||
String[] args = target.split("/");
|
String[] args = target.split("/");
|
||||||
try {
|
try {
|
||||||
if ("/favicon.ico".equals(target)) {
|
if ("/favicon.ico".equals(target)) {
|
||||||
return PageCache.loadPage("Redirect: favicon", () -> new RedirectResponse("https://puu.sh/tK0KL/6aa2ba141b.ico"));
|
return PageCache.loadPage(PageId.FAVICON_REDIRECT.id(), () -> new RedirectResponse("https://puu.sh/tK0KL/6aa2ba141b.ico"));
|
||||||
}
|
}
|
||||||
if (request.isAPIRequest()) {
|
if (request.isAPIRequest()) {
|
||||||
return getAPIResponse(request);
|
return getAPIResponse(request);
|
||||||
}
|
}
|
||||||
if (target.endsWith(".css")) {
|
if (target.endsWith(".css")) {
|
||||||
return PageCache.loadPage(target + "css", () -> new CSSResponse(target));
|
return PageCache.loadPage(PageId.CSS.of(target), () -> new CSSResponse(target));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (target.endsWith(".js")) {
|
if (target.endsWith(".js")) {
|
||||||
return PageCache.loadPage(target + "js", () -> new JavaScriptResponse(target));
|
return PageCache.loadPage(PageId.JS.of(target), () -> new JavaScriptResponse(target));
|
||||||
}
|
}
|
||||||
|
|
||||||
UUID serverUUID = MiscUtils.getIPlan().getServerUuid();
|
UUID serverUUID = MiscUtils.getIPlan().getServerUuid();
|
||||||
@ -81,7 +83,7 @@ public class ResponseHandler extends APIResponseHandler {
|
|||||||
case "debug":
|
case "debug":
|
||||||
return new DebugPageResponse();
|
return new DebugPageResponse();
|
||||||
case "players":
|
case "players":
|
||||||
return PageCache.loadPage("players", PlayersPageResponse::new);
|
return PageCache.loadPage(PageId.PLAYERS.id(), PlayersPageResponse::new);
|
||||||
case "player":
|
case "player":
|
||||||
return playerResponse(args);
|
return playerResponse(args);
|
||||||
case "network":
|
case "network":
|
||||||
@ -102,7 +104,7 @@ public class ResponseHandler extends APIResponseHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
} catch (WebUserAuthException e) {
|
} catch (WebUserAuthException e) {
|
||||||
return PageCache.loadPage("promptAuthorization", PromptAuthorizationResponse::new);
|
return PageCache.loadPage(PageId.AUTH_PROMPT.id(), PromptAuthorizationResponse::new);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
Log.toLog(this.getClass().getName(), e);
|
Log.toLog(this.getClass().getName(), e);
|
||||||
return new InternalErrorResponse(e, request.getTarget());
|
return new InternalErrorResponse(e, request.getTarget());
|
||||||
@ -110,7 +112,7 @@ public class ResponseHandler extends APIResponseHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private Response forbiddenResponse(int required, int permLevel) {
|
private Response forbiddenResponse(int required, int permLevel) {
|
||||||
return PageCache.loadPage("forbidden", () ->
|
return PageCache.loadPage(PageId.FORBIDDEN.id(), () ->
|
||||||
new ForbiddenResponse("Unauthorized User.<br>"
|
new ForbiddenResponse("Unauthorized User.<br>"
|
||||||
+ "Make sure your user has the correct access level.<br>"
|
+ "Make sure your user has the correct access level.<br>"
|
||||||
+ "This page requires permission level of " + required + ",<br>"
|
+ "This page requires permission level of " + required + ",<br>"
|
||||||
@ -182,7 +184,7 @@ public class ResponseHandler extends APIResponseHandler {
|
|||||||
case 0:
|
case 0:
|
||||||
return serverResponse(serverUUID);
|
return serverResponse(serverUUID);
|
||||||
case 1:
|
case 1:
|
||||||
return PageCache.loadPage("players", PlayersPageResponse::new);
|
return PageCache.loadPage(PageId.PLAYERS.id(), PlayersPageResponse::new);
|
||||||
case 2:
|
case 2:
|
||||||
return playerResponse(new String[]{"", "", user.getName()});
|
return playerResponse(new String[]{"", "", user.getName()});
|
||||||
default:
|
default:
|
||||||
@ -191,12 +193,12 @@ public class ResponseHandler extends APIResponseHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private Response serverResponse(UUID serverUUID) {
|
private Response serverResponse(UUID serverUUID) {
|
||||||
return PageCache.loadPage("analysisPage:" + serverUUID, () -> new AnalysisPageResponse(plugin.getInfoManager()));
|
return PageCache.loadPage(PageId.SERVER.of(serverUUID), () -> new AnalysisPageResponse(plugin.getInfoManager()));
|
||||||
}
|
}
|
||||||
|
|
||||||
private Response playerResponse(String[] args) {
|
private Response playerResponse(String[] args) {
|
||||||
if (args.length < 3) {
|
if (args.length < 3) {
|
||||||
return PageCache.loadPage("notFound", NotFoundResponse::new);
|
return PageCache.loadPage(PageId.NOT_FOUND.id(), NotFoundResponse::new);
|
||||||
}
|
}
|
||||||
|
|
||||||
String playerName = args[2].trim();
|
String playerName = args[2].trim();
|
||||||
@ -204,22 +206,22 @@ public class ResponseHandler extends APIResponseHandler {
|
|||||||
|
|
||||||
if (uuid == null) {
|
if (uuid == null) {
|
||||||
String error = "Player has no UUID";
|
String error = "Player has no UUID";
|
||||||
return PageCache.loadPage("notFound: " + error, () -> new NotFoundResponse(error));
|
return PageCache.loadPage(PageId.NOT_FOUND.of(error), () -> new NotFoundResponse(error));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (plugin.getDB().wasSeenBefore(uuid)) {
|
if (plugin.getDB().wasSeenBefore(uuid)) {
|
||||||
plugin.getInfoManager().cachePlayer(uuid);
|
plugin.getInfoManager().cachePlayer(uuid);
|
||||||
Response response = PageCache.loadPage("inspectPage: " + uuid);
|
Response response = PageCache.loadPage(PageId.PLAYER.of(uuid));
|
||||||
// TODO Create a new method that places NotFoundResponse to PageCache instead.
|
// TODO Create a new method that places NotFoundResponse to PageCache instead.
|
||||||
if (response == null || response.getContent().contains("No Bukkit Servers were online to process this request")) {
|
if (response == null || response.getContent().contains("No Bukkit Servers were online to process this request")) {
|
||||||
PageCache.cachePage("inspectPage: " + uuid, () -> {
|
PageCache.cachePage(PageId.PLAYER.of(uuid), () -> {
|
||||||
try {
|
try {
|
||||||
return new InspectPageResponse(plugin.getInfoManager(), uuid);
|
return new InspectPageResponse(plugin.getInfoManager(), uuid);
|
||||||
} catch (ParseException e) {
|
} catch (ParseException e) {
|
||||||
return new InternalErrorResponse(e, this.getClass().getName());
|
return new InternalErrorResponse(e, this.getClass().getName());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
response = PageCache.loadPage("inspectPage: " + uuid);
|
response = PageCache.loadPage(PageId.PLAYER.of(uuid));
|
||||||
}
|
}
|
||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
@ -228,7 +230,7 @@ public class ResponseHandler extends APIResponseHandler {
|
|||||||
|
|
||||||
private Response notFoundResponse() {
|
private Response notFoundResponse() {
|
||||||
String error = "404 Not Found";
|
String error = "404 Not Found";
|
||||||
return PageCache.loadPage("notFound: " + error, () -> {
|
return PageCache.loadPage(PageId.NOT_FOUND.of("Wrong Page"), () -> {
|
||||||
String url = plugin.getInfoManager().getWebServerAddress();
|
String url = plugin.getInfoManager().getWebServerAddress();
|
||||||
return new NotFoundResponse("Make sure you're accessing a link given by a command, Examples:</p>"
|
return new NotFoundResponse("Make sure you're accessing a link given by a command, Examples:</p>"
|
||||||
+ "<p>" + url + "/player/Playername<br>" +
|
+ "<p>" + url + "/player/Playername<br>" +
|
||||||
|
@ -0,0 +1,55 @@
|
|||||||
|
/*
|
||||||
|
* Licence is provided in the jar as license.yml also here:
|
||||||
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
|
*/
|
||||||
|
package main.java.com.djrapitops.plan.systems.webserver;
|
||||||
|
|
||||||
|
import com.djrapitops.plugin.api.Check;
|
||||||
|
import main.java.com.djrapitops.plan.api.exceptions.PlanEnableException;
|
||||||
|
import main.java.com.djrapitops.plan.systems.SubSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.Systems;
|
||||||
|
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* //TODO Class Javadoc Comment
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public class WebServerSystem implements SubSystem {
|
||||||
|
|
||||||
|
private WebServer webServer;
|
||||||
|
|
||||||
|
public WebServerSystem() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public static WebServerSystem getInstance() {
|
||||||
|
return Systems.getInstance().getWebServerSystem();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void init() throws PlanEnableException {
|
||||||
|
webServer = new WebServer(MiscUtils.getIPlan());
|
||||||
|
webServer.initServer();
|
||||||
|
if (Check.isBungeeAvailable() && !webServer.isEnabled()) {
|
||||||
|
throw new PlanEnableException("WebServer did not initialize!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void close() {
|
||||||
|
// TODO Remove after WebServer setting requirement is gone.
|
||||||
|
if (webServer != null) {
|
||||||
|
webServer.stop();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean isWebServerEnabled() {
|
||||||
|
WebServer webServer = getInstance().webServer;
|
||||||
|
return webServer != null && webServer.isEnabled();
|
||||||
|
}
|
||||||
|
|
||||||
|
public WebServer getWebServer() {
|
||||||
|
return webServer;
|
||||||
|
}
|
||||||
|
}
|
@ -1,4 +1,4 @@
|
|||||||
package main.java.com.djrapitops.plan.systems.webserver;
|
package main.java.com.djrapitops.plan.systems.webserver.pagecache;
|
||||||
|
|
||||||
import com.google.common.cache.Cache;
|
import com.google.common.cache.Cache;
|
||||||
import com.google.common.cache.CacheBuilder;
|
import com.google.common.cache.CacheBuilder;
|
@ -0,0 +1,50 @@
|
|||||||
|
/*
|
||||||
|
* Licence is provided in the jar as license.yml also here:
|
||||||
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
|
*/
|
||||||
|
package main.java.com.djrapitops.plan.systems.webserver.pagecache;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enum class for "magic" PageCache identifier values.
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public enum PageId {
|
||||||
|
|
||||||
|
SERVER("serverPage:"),
|
||||||
|
PLAYER("playerPage:"),
|
||||||
|
PLAYERS("playersPage"),
|
||||||
|
//
|
||||||
|
ERROR("error:"),
|
||||||
|
FORBIDDEN(ERROR.of("Forbidden")),
|
||||||
|
NOT_FOUND(ERROR.of("Not Found")),
|
||||||
|
TRUE("true"),
|
||||||
|
FALSE("false"),
|
||||||
|
//
|
||||||
|
JS("js:"),
|
||||||
|
CSS("css:"),
|
||||||
|
//
|
||||||
|
FAVICON_REDIRECT("Redirect:Favicon"),
|
||||||
|
AUTH_PROMPT("PromptAuth")
|
||||||
|
;
|
||||||
|
|
||||||
|
private final String id;
|
||||||
|
|
||||||
|
PageId(String id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String of(String additionalInfo) {
|
||||||
|
return id + additionalInfo;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String of(UUID uuid) {
|
||||||
|
return of(uuid.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
public String id() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
}
|
@ -1,4 +1,4 @@
|
|||||||
package main.java.com.djrapitops.plan.systems.webserver;
|
package main.java.com.djrapitops.plan.systems.webserver.pagecache;
|
||||||
|
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.Response;
|
import main.java.com.djrapitops.plan.systems.webserver.response.Response;
|
||||||
|
|
@ -13,7 +13,7 @@ public class ForbiddenResponse extends ErrorResponse {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public ForbiddenResponse(String msg) {
|
public ForbiddenResponse(String msg) {
|
||||||
super.setHeader("HTTP/1.1 404 Not Found");
|
super.setHeader("HTTP/1.1 403 Forbidden");
|
||||||
super.setTitle("403 Forbidden - Access Denied");
|
super.setTitle("403 Forbidden - Access Denied");
|
||||||
super.setParagraph(msg);
|
super.setParagraph(msg);
|
||||||
super.replacePlaceholders();
|
super.replacePlaceholders();
|
||||||
|
@ -37,7 +37,7 @@ public class PlayersPageResponse extends Response {
|
|||||||
Collections.sort(names);
|
Collections.sort(names);
|
||||||
Map<String, String> replace = new HashMap<>();
|
Map<String, String> replace = new HashMap<>();
|
||||||
if (Check.isBukkitAvailable()) {
|
if (Check.isBukkitAvailable()) {
|
||||||
replace.put("networkName", Settings.SERVER_NAME.toString());
|
replace.put("networkName", Settings.SERVER_NAME.toString().replaceAll("[^a-zA-Z0-9_\\s]", "_"));
|
||||||
} else {
|
} else {
|
||||||
replace.put("networkName", Settings.BUNGEE_NETWORK_NAME.toString());
|
replace.put("networkName", Settings.BUNGEE_NETWORK_NAME.toString());
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,8 @@ import com.djrapitops.plugin.utilities.Verify;
|
|||||||
import main.java.com.djrapitops.plan.api.IPlan;
|
import main.java.com.djrapitops.plan.api.IPlan;
|
||||||
import main.java.com.djrapitops.plan.api.exceptions.*;
|
import main.java.com.djrapitops.plan.api.exceptions.*;
|
||||||
import main.java.com.djrapitops.plan.settings.Settings;
|
import main.java.com.djrapitops.plan.settings.Settings;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.PageCache;
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageCache;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageId;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.NotFoundResponse;
|
import main.java.com.djrapitops.plan.systems.webserver.response.NotFoundResponse;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.Response;
|
import main.java.com.djrapitops.plan.systems.webserver.response.Response;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.api.BadRequestResponse;
|
import main.java.com.djrapitops.plan.systems.webserver.response.api.BadRequestResponse;
|
||||||
@ -165,11 +166,11 @@ public abstract class WebAPI {
|
|||||||
};
|
};
|
||||||
|
|
||||||
protected Response success() {
|
protected Response success() {
|
||||||
return PageCache.loadPage("success", SuccessResponse::new);
|
return PageCache.loadPage(PageId.TRUE.id(), SuccessResponse::new);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Response fail(String reason) {
|
protected Response fail(String reason) {
|
||||||
return PageCache.loadPage("fail", () -> {
|
return PageCache.loadPage(PageId.FALSE.id(), () -> {
|
||||||
NotFoundResponse notFoundResponse = new NotFoundResponse("");
|
NotFoundResponse notFoundResponse = new NotFoundResponse("");
|
||||||
notFoundResponse.setContent(reason);
|
notFoundResponse.setContent(reason);
|
||||||
return notFoundResponse;
|
return notFoundResponse;
|
||||||
@ -177,7 +178,7 @@ public abstract class WebAPI {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected Response badRequest(String error) {
|
protected Response badRequest(String error) {
|
||||||
return PageCache.loadPage(error, () -> new BadRequestResponse(error));
|
return PageCache.loadPage(PageId.ERROR.of(error), () -> new BadRequestResponse(error));
|
||||||
}
|
}
|
||||||
|
|
||||||
private String parseVariables() {
|
private String parseVariables() {
|
||||||
|
@ -9,7 +9,8 @@ import main.java.com.djrapitops.plan.api.IPlan;
|
|||||||
import main.java.com.djrapitops.plan.api.exceptions.WebAPIException;
|
import main.java.com.djrapitops.plan.api.exceptions.WebAPIException;
|
||||||
import main.java.com.djrapitops.plan.settings.Settings;
|
import main.java.com.djrapitops.plan.settings.Settings;
|
||||||
import main.java.com.djrapitops.plan.systems.info.InformationManager;
|
import main.java.com.djrapitops.plan.systems.info.InformationManager;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.PageCache;
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageCache;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageId;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.AnalysisPageResponse;
|
import main.java.com.djrapitops.plan.systems.webserver.response.AnalysisPageResponse;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.InspectPageResponse;
|
import main.java.com.djrapitops.plan.systems.webserver.response.InspectPageResponse;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.Response;
|
import main.java.com.djrapitops.plan.systems.webserver.response.Response;
|
||||||
@ -54,14 +55,14 @@ public class PostHtmlWebAPI extends WebAPI {
|
|||||||
Map<String, String> map = new HashMap<>();
|
Map<String, String> map = new HashMap<>();
|
||||||
map.put("networkName", Settings.BUNGEE_NETWORK_NAME.toString());
|
map.put("networkName", Settings.BUNGEE_NETWORK_NAME.toString());
|
||||||
|
|
||||||
PageCache.cachePage("inspectPage:" + uuid, () -> new InspectPageResponse(infoManager, UUID.fromString(uuid), StrSubstitutor.replace(html, map)));
|
PageCache.cachePage(PageId.PLAYER.of(uuid), () -> new InspectPageResponse(infoManager, UUID.fromString(uuid), StrSubstitutor.replace(html, map)));
|
||||||
if (Settings.ANALYSIS_EXPORT.isTrue()) {
|
if (Settings.ANALYSIS_EXPORT.isTrue()) {
|
||||||
HtmlExport.exportPlayer(plugin, UUID.fromString(uuid));
|
HtmlExport.exportPlayer(plugin, UUID.fromString(uuid));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case "analysisPage":
|
case "analysisPage":
|
||||||
String sender = variables.get("sender");
|
String sender = variables.get("sender");
|
||||||
PageCache.cachePage("analysisPage:" + sender, () -> new AnalysisPageResponse(html));
|
PageCache.cachePage(PageId.SERVER.of(sender), () -> new AnalysisPageResponse(html));
|
||||||
if (Settings.ANALYSIS_EXPORT.isTrue()) {
|
if (Settings.ANALYSIS_EXPORT.isTrue()) {
|
||||||
HtmlExport.exportServer(plugin, UUID.fromString(sender));
|
HtmlExport.exportServer(plugin, UUID.fromString(sender));
|
||||||
}
|
}
|
||||||
|
@ -50,7 +50,7 @@ public class PostOriginalBukkitSettingsWebAPI extends WebAPI {
|
|||||||
@Override
|
@Override
|
||||||
public void sendRequest(String address) throws WebAPIException {
|
public void sendRequest(String address) throws WebAPIException {
|
||||||
addVariable("WebServerPort", Integer.toString(Settings.WEBSERVER_PORT.getNumber()));
|
addVariable("WebServerPort", Integer.toString(Settings.WEBSERVER_PORT.getNumber()));
|
||||||
addVariable("ServerName", Settings.SERVER_NAME.toString());
|
addVariable("ServerName", Settings.SERVER_NAME.toString().replaceAll("[^a-zA-Z0-9_\\s]", "_"));
|
||||||
addVariable("ThemeBase", Settings.THEME_BASE.toString());
|
addVariable("ThemeBase", Settings.THEME_BASE.toString());
|
||||||
super.sendRequest(address);
|
super.sendRequest(address);
|
||||||
}
|
}
|
||||||
|
@ -13,6 +13,7 @@ import main.java.com.djrapitops.plan.PlanBungee;
|
|||||||
import main.java.com.djrapitops.plan.api.IPlan;
|
import main.java.com.djrapitops.plan.api.IPlan;
|
||||||
import main.java.com.djrapitops.plan.api.exceptions.WebAPIException;
|
import main.java.com.djrapitops.plan.api.exceptions.WebAPIException;
|
||||||
import main.java.com.djrapitops.plan.systems.info.server.ServerInfo;
|
import main.java.com.djrapitops.plan.systems.info.server.ServerInfo;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.response.ForbiddenResponse;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.Response;
|
import main.java.com.djrapitops.plan.systems.webserver.response.Response;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.webapi.WebAPI;
|
import main.java.com.djrapitops.plan.systems.webserver.webapi.WebAPI;
|
||||||
|
|
||||||
@ -31,6 +32,11 @@ public class RequestSetupWebAPI extends WebAPI {
|
|||||||
if (!Check.isBungeeAvailable()) {
|
if (!Check.isBungeeAvailable()) {
|
||||||
return badRequest("Called a Bukkit server.");
|
return badRequest("Called a Bukkit server.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!((PlanBungee) plugin).isSetupAllowed()) {
|
||||||
|
return new ForbiddenResponse("Setup mode disabled, use /planbungee setup to enable");
|
||||||
|
}
|
||||||
|
|
||||||
String serverUUIDS = variables.get("sender");
|
String serverUUIDS = variables.get("sender");
|
||||||
String webAddress = variables.get("webAddress");
|
String webAddress = variables.get("webAddress");
|
||||||
String accessCode = variables.get("accessKey");
|
String accessCode = variables.get("accessKey");
|
||||||
@ -38,7 +44,8 @@ public class RequestSetupWebAPI extends WebAPI {
|
|||||||
return badRequest("Variable was null");
|
return badRequest("Variable was null");
|
||||||
}
|
}
|
||||||
ServerInfo serverInfo = new ServerInfo(-1, UUID.fromString(serverUUIDS), "", webAddress, 0);
|
ServerInfo serverInfo = new ServerInfo(-1, UUID.fromString(serverUUIDS), "", webAddress, 0);
|
||||||
PlanBungee.getInstance().getServerInfoManager().attemptConnection(serverInfo, accessCode);
|
|
||||||
|
((PlanBungee) plugin).getServerInfoManager().attemptConnection(serverInfo, accessCode);
|
||||||
return success();
|
return success();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@ import main.java.com.djrapitops.plan.api.exceptions.DatabaseInitException;
|
|||||||
import main.java.com.djrapitops.plan.database.Database;
|
import main.java.com.djrapitops.plan.database.Database;
|
||||||
import main.java.com.djrapitops.plan.database.databases.SQLiteDB;
|
import main.java.com.djrapitops.plan.database.databases.SQLiteDB;
|
||||||
import main.java.com.djrapitops.plan.database.tables.move.BatchOperationTable;
|
import main.java.com.djrapitops.plan.database.tables.move.BatchOperationTable;
|
||||||
import main.java.com.djrapitops.plan.systems.DatabaseSystem;
|
import main.java.com.djrapitops.plan.systems.file.database.DBSystem;
|
||||||
|
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
@ -76,6 +76,6 @@ public class ManageUtils {
|
|||||||
|
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public static Database getDB(String dbName) throws DatabaseInitException {
|
public static Database getDB(String dbName) throws DatabaseInitException {
|
||||||
return DatabaseSystem.getActiveDatabase(dbName);
|
return DBSystem.getActiveDatabase(dbName);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,8 @@ import main.java.com.djrapitops.plan.systems.cache.DataCache;
|
|||||||
import main.java.com.djrapitops.plan.systems.cache.SessionCache;
|
import main.java.com.djrapitops.plan.systems.cache.SessionCache;
|
||||||
import main.java.com.djrapitops.plan.systems.info.BukkitInformationManager;
|
import main.java.com.djrapitops.plan.systems.info.BukkitInformationManager;
|
||||||
import main.java.com.djrapitops.plan.systems.info.InformationManager;
|
import main.java.com.djrapitops.plan.systems.info.InformationManager;
|
||||||
|
import main.java.com.djrapitops.plan.systems.tasks.PlanTaskSystem;
|
||||||
|
import main.java.com.djrapitops.plan.systems.tasks.TaskSystem;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.ErrorResponse;
|
import main.java.com.djrapitops.plan.systems.webserver.response.ErrorResponse;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.InternalErrorResponse;
|
import main.java.com.djrapitops.plan.systems.webserver.response.InternalErrorResponse;
|
||||||
|
|
||||||
@ -54,6 +56,8 @@ public class Analysis {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
((PlanTaskSystem) TaskSystem.getInstance()).cancelBootAnalysis();
|
||||||
|
|
||||||
Benchmark.start("Analysis");
|
Benchmark.start("Analysis");
|
||||||
log(Locale.get(Msg.ANALYSIS_START).toString());
|
log(Locale.get(Msg.ANALYSIS_START).toString());
|
||||||
// Async task for Analysis
|
// Async task for Analysis
|
||||||
@ -218,10 +222,6 @@ public class Analysis {
|
|||||||
return taskId != -1;
|
return taskId != -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setTaskId(int id) {
|
|
||||||
taskId = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Only available during Analysis.
|
* Only available during Analysis.
|
||||||
*
|
*
|
||||||
|
@ -3,7 +3,7 @@ package main.java.com.djrapitops.plan.utilities.comparators;
|
|||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Compares Strings and sorts them by length
|
* Compares Strings and sorts them by length (Longest fist).
|
||||||
*
|
*
|
||||||
* @author Rsl1122
|
* @author Rsl1122
|
||||||
* @since 3.6.2
|
* @since 3.6.2
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package main.java.com.djrapitops.plan.utilities.file;
|
package main.java.com.djrapitops.plan.utilities.file;
|
||||||
|
|
||||||
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
import com.djrapitops.plugin.utilities.Verify;
|
import com.djrapitops.plugin.utilities.Verify;
|
||||||
import main.java.com.djrapitops.plan.api.IPlan;
|
import main.java.com.djrapitops.plan.api.IPlan;
|
||||||
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
||||||
@ -80,6 +81,8 @@ public class FileUtil {
|
|||||||
lines.add(scanner.nextLine());
|
lines.add(scanner.nextLine());
|
||||||
}
|
}
|
||||||
} catch (NullPointerException e) {
|
} catch (NullPointerException e) {
|
||||||
|
Log.infoColor("§ea Resource was not found inside the jar, Plan does not support /reload or updates using " +
|
||||||
|
"Plugin Managers, restart the server and see if the error persists.");
|
||||||
throw new FileNotFoundException("File not found inside jar: " + resource);
|
throw new FileNotFoundException("File not found inside jar: " + resource);
|
||||||
} finally {
|
} finally {
|
||||||
MiscUtils.close(scanner);
|
MiscUtils.close(scanner);
|
||||||
@ -100,5 +103,4 @@ public class FileUtil {
|
|||||||
}
|
}
|
||||||
return lines;
|
return lines;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -182,7 +182,7 @@ public class HtmlExport extends SpecificExport {
|
|||||||
List<String> lines = FileUtil.lines(plugin, new File(plugin.getDataFolder(), possibleFile), resource);
|
List<String> lines = FileUtil.lines(plugin, new File(plugin.getDataFolder(), possibleFile), resource);
|
||||||
String outputFile = possibleFile.replace("web/", "");
|
String outputFile = possibleFile.replace("web/", "");
|
||||||
File to = new File(outputFolder, outputFile);
|
File to = new File(outputFolder, outputFile);
|
||||||
to.mkdirs();
|
to.getParentFile().mkdirs();
|
||||||
if (to.exists()) {
|
if (to.exists()) {
|
||||||
to.delete();
|
to.delete();
|
||||||
to.createNewFile();
|
to.createNewFile();
|
||||||
|
@ -8,7 +8,8 @@ import com.djrapitops.plugin.api.Check;
|
|||||||
import com.djrapitops.plugin.api.utility.log.Log;
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
import com.djrapitops.plugin.task.AbsRunnable;
|
import com.djrapitops.plugin.task.AbsRunnable;
|
||||||
import main.java.com.djrapitops.plan.settings.Settings;
|
import main.java.com.djrapitops.plan.settings.Settings;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.PageCache;
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageCache;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageId;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.Response;
|
import main.java.com.djrapitops.plan.systems.webserver.response.Response;
|
||||||
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
||||||
|
|
||||||
@ -73,7 +74,7 @@ public abstract class SpecificExport extends AbsRunnable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected void exportAvailablePlayerPage(UUID uuid, String name) throws IOException {
|
protected void exportAvailablePlayerPage(UUID uuid, String name) throws IOException {
|
||||||
Response response = PageCache.loadPage("inspectPage: " + uuid);
|
Response response = PageCache.loadPage(PageId.PLAYER.of(uuid));
|
||||||
if (response == null) {
|
if (response == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -90,7 +91,7 @@ public abstract class SpecificExport extends AbsRunnable {
|
|||||||
|
|
||||||
protected void exportAvailableServerPage(UUID serverUUID, String serverName) throws IOException {
|
protected void exportAvailableServerPage(UUID serverUUID, String serverName) throws IOException {
|
||||||
|
|
||||||
Response response = PageCache.loadPage("analysisPage:" + serverUUID);
|
Response response = PageCache.loadPage(PageId.SERVER.of(serverUUID));
|
||||||
if (response == null) {
|
if (response == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1,12 +1,11 @@
|
|||||||
package main.java.com.djrapitops.plan.utilities.html.graphs.pie;
|
package main.java.com.djrapitops.plan.utilities.html.graphs.pie;
|
||||||
|
|
||||||
import main.java.com.djrapitops.plan.Plan;
|
|
||||||
import main.java.com.djrapitops.plan.data.time.GMTimes;
|
import main.java.com.djrapitops.plan.data.time.GMTimes;
|
||||||
import main.java.com.djrapitops.plan.data.time.WorldTimes;
|
import main.java.com.djrapitops.plan.data.time.WorldTimes;
|
||||||
import main.java.com.djrapitops.plan.settings.Settings;
|
import main.java.com.djrapitops.plan.settings.Settings;
|
||||||
import main.java.com.djrapitops.plan.settings.WorldAliasSettings;
|
import main.java.com.djrapitops.plan.settings.WorldAliasSettings;
|
||||||
import main.java.com.djrapitops.plan.settings.theme.ThemeVal;
|
|
||||||
import main.java.com.djrapitops.plan.settings.theme.Theme;
|
import main.java.com.djrapitops.plan.settings.theme.Theme;
|
||||||
|
import main.java.com.djrapitops.plan.settings.theme.ThemeVal;
|
||||||
import main.java.com.djrapitops.plan.utilities.comparators.PieSliceComparator;
|
import main.java.com.djrapitops.plan.utilities.comparators.PieSliceComparator;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
@ -64,14 +63,14 @@ public class WorldPie {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static Map<String, Long> transformToAliases(Map<String, Long> playtimePerWorld) {
|
private static Map<String, Long> transformToAliases(Map<String, Long> playtimePerWorld) {
|
||||||
WorldAliasSettings aliasSettings = new WorldAliasSettings(Plan.getInstance());
|
WorldAliasSettings aliasSettings = new WorldAliasSettings();
|
||||||
Map<String, String> aliases = aliasSettings.getAliases();
|
Map<String, String> aliases = aliasSettings.getAliases();
|
||||||
return transformToAliases(playtimePerWorld, aliases);
|
return transformToAliases(playtimePerWorld, aliases);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Map<String, Long> transformToAliases(Map<String, Long> playtimePerWorld, Map<String, String> aliases) {
|
public static Map<String, Long> transformToAliases(Map<String, Long> playtimePerWorld, Map<String, String> aliases) {
|
||||||
// TODO Optimization is possible
|
// TODO Optimization is possible
|
||||||
WorldAliasSettings aliasSettings = new WorldAliasSettings(Plan.getInstance());
|
WorldAliasSettings aliasSettings = new WorldAliasSettings();
|
||||||
|
|
||||||
Map<String, Long> playtimePerAlias = new HashMap<>();
|
Map<String, Long> playtimePerAlias = new HashMap<>();
|
||||||
for (Map.Entry<String, Long> entry : playtimePerWorld.entrySet()) {
|
for (Map.Entry<String, Long> entry : playtimePerWorld.entrySet()) {
|
||||||
@ -121,7 +120,7 @@ public class WorldPie {
|
|||||||
|
|
||||||
private static Map<String, GMTimes> transformToGMAliases(Map<String, GMTimes> gmTimesMap) {
|
private static Map<String, GMTimes> transformToGMAliases(Map<String, GMTimes> gmTimesMap) {
|
||||||
// TODO Optimization is possible
|
// TODO Optimization is possible
|
||||||
WorldAliasSettings aliasSettings = new WorldAliasSettings(Plan.getInstance());
|
WorldAliasSettings aliasSettings = new WorldAliasSettings();
|
||||||
Map<String, String> aliases = aliasSettings.getAliases();
|
Map<String, String> aliases = aliasSettings.getAliases();
|
||||||
|
|
||||||
Map<String, GMTimes> gmTimesPerAlias = new HashMap<>();
|
Map<String, GMTimes> gmTimesPerAlias = new HashMap<>();
|
||||||
|
@ -38,6 +38,7 @@ public class ServerAccordionCreator {
|
|||||||
"</div>", ""};
|
"</div>", ""};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int i = 0;
|
||||||
for (Map.Entry<UUID, WorldTimes> entry : worldTimesPerServer.entrySet()) {
|
for (Map.Entry<UUID, WorldTimes> entry : worldTimesPerServer.entrySet()) {
|
||||||
UUID serverUUID = entry.getKey();
|
UUID serverUUID = entry.getKey();
|
||||||
String serverName = serverNames.getOrDefault(serverUUID, "Unknown");
|
String serverName = serverNames.getOrDefault(serverUUID, "Unknown");
|
||||||
@ -60,7 +61,8 @@ public class ServerAccordionCreator {
|
|||||||
String longest = sessionCount != 0 ? FormatUtils.formatTimeAmount(longestSession) : "-";
|
String longest = sessionCount != 0 ? FormatUtils.formatTimeAmount(longestSession) : "-";
|
||||||
|
|
||||||
String sanitizedServerName = new Format(serverName)
|
String sanitizedServerName = new Format(serverName)
|
||||||
.removeSymbols().removeWhitespace().toString();
|
.removeSymbols()
|
||||||
|
.removeWhitespace().toString() + i;
|
||||||
String htmlID = "server_" + sanitizedServerName;
|
String htmlID = "server_" + sanitizedServerName;
|
||||||
|
|
||||||
String worldId = "worldPieServer" + sanitizedServerName;
|
String worldId = "worldPieServer" + sanitizedServerName;
|
||||||
@ -116,6 +118,8 @@ public class ServerAccordionCreator {
|
|||||||
.append(worldId).append("series, ")
|
.append(worldId).append("series, ")
|
||||||
.append(worldId).append("gmseries")
|
.append(worldId).append("gmseries")
|
||||||
.append(");");
|
.append(");");
|
||||||
|
|
||||||
|
i++;
|
||||||
}
|
}
|
||||||
return new String[]{html.append("</div>").toString(), viewScript.toString()};
|
return new String[]{html.append("</div>").toString(), viewScript.toString()};
|
||||||
}
|
}
|
||||||
|
@ -105,7 +105,7 @@ public class SessionsTableCreator {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static String getLongestWorldPlayed(Session session) {
|
public static String getLongestWorldPlayed(Session session) {
|
||||||
WorldAliasSettings aliasSettings = new WorldAliasSettings(Plan.getInstance());
|
WorldAliasSettings aliasSettings = new WorldAliasSettings();
|
||||||
Map<String, String> aliases = aliasSettings.getAliases();
|
Map<String, String> aliases = aliasSettings.getAliases();
|
||||||
if (session.getSessionEnd() == -1) {
|
if (session.getSessionEnd() == -1) {
|
||||||
return "Current: " + aliases.get(session.getWorldTimes().getCurrentWorld());
|
return "Current: " + aliases.get(session.getWorldTimes().getCurrentWorld());
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
name: Plan
|
name: Plan
|
||||||
author: Rsl1122
|
author: Rsl1122
|
||||||
main: main.java.com.djrapitops.plan.PlanBungee
|
main: main.java.com.djrapitops.plan.PlanBungee
|
||||||
version: 4.1.3.1
|
version: 4.1.4
|
@ -1,7 +1,7 @@
|
|||||||
name: Plan
|
name: Plan
|
||||||
author: Rsl1122
|
author: Rsl1122
|
||||||
main: main.java.com.djrapitops.plan.Plan
|
main: main.java.com.djrapitops.plan.Plan
|
||||||
version: 4.1.3.1
|
version: 4.1.4
|
||||||
softdepend:
|
softdepend:
|
||||||
- EssentialsX
|
- EssentialsX
|
||||||
- Towny
|
- Towny
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
package main.java.com.djrapitops.plan.data.cache;
|
package main.java.com.djrapitops.plan.data.cache;
|
||||||
|
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.PageCache;
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageCache;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.PageLoader;
|
import main.java.com.djrapitops.plan.systems.webserver.pagecache.PageLoader;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.response.Response;
|
import main.java.com.djrapitops.plan.systems.webserver.response.Response;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import test.java.utils.RandomData;
|
import test.java.utils.RandomData;
|
||||||
|
@ -51,7 +51,7 @@ public class TestInit {
|
|||||||
* Does not load any messages from anywhere because that would cause exceptions.
|
* Does not load any messages from anywhere because that would cause exceptions.
|
||||||
*/
|
*/
|
||||||
public static void initEmptyLocale() {
|
public static void initEmptyLocale() {
|
||||||
new Locale(null);
|
new Locale();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -62,7 +62,7 @@ public class TestInit {
|
|||||||
* @param plan Mocked Plan
|
* @param plan Mocked Plan
|
||||||
*/
|
*/
|
||||||
public static void initLocale(Plan plan) {
|
public static void initLocale(Plan plan) {
|
||||||
new Locale(plan).loadLocale();
|
new Locale().loadLocale();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static TestInit init() throws Exception {
|
public static TestInit init() throws Exception {
|
||||||
@ -139,7 +139,7 @@ public class TestInit {
|
|||||||
when(planMock.getServerInfoManager()).thenReturn(bukkitServerInfoManager);
|
when(planMock.getServerInfoManager()).thenReturn(bukkitServerInfoManager);
|
||||||
ColorScheme cs = new ColorScheme(ChatColor.BLACK, ChatColor.BLACK, ChatColor.BLACK, ChatColor.BLACK);
|
ColorScheme cs = new ColorScheme(ChatColor.BLACK, ChatColor.BLACK, ChatColor.BLACK, ChatColor.BLACK);
|
||||||
when(planMock.getColorScheme()).thenReturn(cs);
|
when(planMock.getColorScheme()).thenReturn(cs);
|
||||||
initLocale(planMock);
|
initLocale(null);
|
||||||
|
|
||||||
RunnableFactory.activateTestMode();
|
RunnableFactory.activateTestMode();
|
||||||
}
|
}
|
||||||
|
34
Plan/test/test/java/utils/testsystem/TestConfigSystem.java
Normal file
34
Plan/test/test/java/utils/testsystem/TestConfigSystem.java
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
/*
|
||||||
|
* Licence is provided in the jar as license.yml also here:
|
||||||
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
|
*/
|
||||||
|
package test.java.utils.testsystem;
|
||||||
|
|
||||||
|
import main.java.com.djrapitops.plan.systems.file.config.ConfigSystem;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Scanner;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* //TODO Class Javadoc Comment
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public class TestConfigSystem extends ConfigSystem {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void copyDefaults() throws IOException {
|
||||||
|
File file = new File(getClass().getResource("/config.yml").getPath());
|
||||||
|
Scanner scanner = new Scanner(new FileInputStream(file));
|
||||||
|
|
||||||
|
List<String> lines = new ArrayList<>();
|
||||||
|
while (scanner.hasNextLine()) {
|
||||||
|
lines.add(scanner.nextLine());
|
||||||
|
}
|
||||||
|
config.copyDefaults(lines);
|
||||||
|
}
|
||||||
|
}
|
BIN
PlanPluginBridge/PlanPluginBridge-4.1.3.2.jar
Normal file
BIN
PlanPluginBridge/PlanPluginBridge-4.1.3.2.jar
Normal file
Binary file not shown.
@ -33,7 +33,7 @@ public class HackerTable extends Table {
|
|||||||
private final String columnViolations;
|
private final String columnViolations;
|
||||||
|
|
||||||
public HackerTable(SQLDB db) {
|
public HackerTable(SQLDB db) {
|
||||||
super("plan_viaversion_protocol", db, db.isUsingMySQL());
|
super("plan_aac_hack_table", db, db.isUsingMySQL());
|
||||||
columnUUID = "uuid";
|
columnUUID = "uuid";
|
||||||
columnDate = "date";
|
columnDate = "date";
|
||||||
columnHackType = "hack_type";
|
columnHackType = "hack_type";
|
||||||
@ -43,7 +43,7 @@ public class HackerTable extends Table {
|
|||||||
@Override
|
@Override
|
||||||
public void createTable() throws DBCreateTableException {
|
public void createTable() throws DBCreateTableException {
|
||||||
createTable("CREATE TABLE IF NOT EXISTS " + tableName + " ("
|
createTable("CREATE TABLE IF NOT EXISTS " + tableName + " ("
|
||||||
+ columnUUID + " varchar(36) NOT NULL UNIQUE, "
|
+ columnUUID + " varchar(36) NOT NULL, "
|
||||||
+ columnDate + " bigint NOT NULL, "
|
+ columnDate + " bigint NOT NULL, "
|
||||||
+ columnHackType + " varchar(100) NOT NULL, "
|
+ columnHackType + " varchar(100) NOT NULL, "
|
||||||
+ columnViolations + " integer NOT NULL"
|
+ columnViolations + " integer NOT NULL"
|
||||||
@ -107,7 +107,7 @@ public class HackerTable extends Table {
|
|||||||
public void prepare(PreparedStatement statement) throws SQLException {
|
public void prepare(PreparedStatement statement) throws SQLException {
|
||||||
statement.setString(1, hackObject.getUuid().toString());
|
statement.setString(1, hackObject.getUuid().toString());
|
||||||
statement.setLong(2, hackObject.getDate());
|
statement.setLong(2, hackObject.getDate());
|
||||||
statement.setString(3, hackObject.getHackType().getName());
|
statement.setString(3, hackObject.getHackType().name());
|
||||||
statement.setInt(4, hackObject.getViolationLevel());
|
statement.setInt(4, hackObject.getViolationLevel());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -50,7 +50,7 @@ public class PlayerHackKickListener implements Listener {
|
|||||||
try {
|
try {
|
||||||
new HackerTable((SQLDB) plan.getDB()).insertHackRow(hackObject);
|
new HackerTable((SQLDB) plan.getDB()).insertHackRow(hackObject);
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
Log.toLog(this.getClass().getName() + ":PlanViaVersionJoinListener", e);
|
Log.toLog(this.getClass().getName(), e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -46,7 +46,7 @@ public class PlayerVersionListener implements Listener {
|
|||||||
try {
|
try {
|
||||||
new ProtocolTable((SQLDB) plan.getDB()).saveProtocolVersion(uuid, playerVersion);
|
new ProtocolTable((SQLDB) plan.getDB()).saveProtocolVersion(uuid, playerVersion);
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
Log.toLog(this.getClass().getName() + ":PlanViaVersionJoinListener", e);
|
Log.toLog(this.getClass().getName(), e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -32,7 +32,7 @@ public class ProtocolTable extends Table {
|
|||||||
private final String columnProtocolVersion;
|
private final String columnProtocolVersion;
|
||||||
|
|
||||||
public ProtocolTable(SQLDB db) {
|
public ProtocolTable(SQLDB db) {
|
||||||
super("plan_viaversion_protocol", db, db.isUsingMySQL());
|
super("plan_version_protocol", db, db.isUsingMySQL());
|
||||||
columnUUID = "uuid";
|
columnUUID = "uuid";
|
||||||
columnProtocolVersion = "protocol_version";
|
columnProtocolVersion = "protocol_version";
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user