mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2025-01-28 02:54:20 +01:00
Fixed WebAPI, DevCommand, Improved some WebAPI, New WebAPI.
This commit is contained in:
parent
3c2c710115
commit
fb717387d2
@ -24,6 +24,7 @@ public enum Settings {
|
|||||||
LOG_UNKNOWN_COMMANDS("Data.Commands.LogUnknownCommands"),
|
LOG_UNKNOWN_COMMANDS("Data.Commands.LogUnknownCommands"),
|
||||||
COMBINE_COMMAND_ALIASES("Data.Commands.CombineCommandAliases"),
|
COMBINE_COMMAND_ALIASES("Data.Commands.CombineCommandAliases"),
|
||||||
WRITE_NEW_LOCALE("Plugin.WriteNewLocaleFileOnStart"),
|
WRITE_NEW_LOCALE("Plugin.WriteNewLocaleFileOnStart"),
|
||||||
|
DEV_MODE("Plugin.Dev"),
|
||||||
|
|
||||||
// Integer
|
// Integer
|
||||||
WEBSERVER_PORT("WebServer.Port"),
|
WEBSERVER_PORT("WebServer.Port"),
|
||||||
|
@ -5,6 +5,7 @@ import com.djrapitops.plugin.command.TreeCommand;
|
|||||||
import com.djrapitops.plugin.command.defaultcmds.StatusCommand;
|
import com.djrapitops.plugin.command.defaultcmds.StatusCommand;
|
||||||
import main.java.com.djrapitops.plan.Permissions;
|
import main.java.com.djrapitops.plan.Permissions;
|
||||||
import main.java.com.djrapitops.plan.Plan;
|
import main.java.com.djrapitops.plan.Plan;
|
||||||
|
import main.java.com.djrapitops.plan.Settings;
|
||||||
import main.java.com.djrapitops.plan.command.commands.*;
|
import main.java.com.djrapitops.plan.command.commands.*;
|
||||||
import main.java.com.djrapitops.plan.locale.Locale;
|
import main.java.com.djrapitops.plan.locale.Locale;
|
||||||
import main.java.com.djrapitops.plan.locale.Msg;
|
import main.java.com.djrapitops.plan.locale.Msg;
|
||||||
@ -52,5 +53,9 @@ public class PlanCommand extends TreeCommand<Plan> {
|
|||||||
commands.add(registerCommand);
|
commands.add(registerCommand);
|
||||||
commands.add(new WebUserCommand(plugin, registerCommand));
|
commands.add(new WebUserCommand(plugin, registerCommand));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (Settings.DEV_MODE.isTrue()) {
|
||||||
|
commands.add(new DevCommand(plugin));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,71 @@
|
|||||||
|
/*
|
||||||
|
* 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.Plan;
|
||||||
|
import main.java.com.djrapitops.plan.api.exceptions.WebAPIException;
|
||||||
|
import main.java.com.djrapitops.plan.locale.Locale;
|
||||||
|
import main.java.com.djrapitops.plan.locale.Msg;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.webapi.WebAPI;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.webapi.bukkit.InspectWebAPI;
|
||||||
|
import main.java.com.djrapitops.plan.utilities.Check;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* //TODO Class Javadoc Comment
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public class DevCommand extends SubCommand {
|
||||||
|
|
||||||
|
private final Plan plugin;
|
||||||
|
|
||||||
|
public DevCommand(Plan plugin) {
|
||||||
|
super("dev", CommandType.CONSOLE_WITH_ARGUMENTS, "plan.*", "Test Plugin functions not testable with unit tests.", "<feature to test>");
|
||||||
|
this.plugin = plugin;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(ISender sender, String cmd, String[] args) {
|
||||||
|
if (!Check.isTrue(args.length >= 1, Locale.get(Msg.CMD_FAIL_REQ_ONE_ARG).toString(), sender)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
String feature = args[0];
|
||||||
|
switch (feature) {
|
||||||
|
case "webapi":
|
||||||
|
if (!Check.isTrue(args.length >= 2, Locale.get(Msg.CMD_FAIL_REQ_ONE_ARG).toString(), sender)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (!webapi(args[1])) {
|
||||||
|
sender.sendMessage("[Plan] No such API / Exception occurred.");
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean webapi(String method) {
|
||||||
|
WebAPI api = plugin.getWebServer().getWebAPI().getAPI(method);
|
||||||
|
if (api == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
if (api instanceof InspectWebAPI) {
|
||||||
|
((InspectWebAPI) api).sendRequest(plugin.getWebServer().getAccessAddress(), Plan.getServerUUID(), UUID.randomUUID());
|
||||||
|
} else {
|
||||||
|
api.sendRequest(plugin.getWebServer().getAccessAddress(), Plan.getServerUUID());
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
} catch (WebAPIException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
@ -190,7 +190,7 @@ public class WebServer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public String getAccessAddress() {
|
public String getAccessAddress() {
|
||||||
return getProtocol() + ":/" + HtmlUtils.getIP();
|
return getProtocol() + "://" + HtmlUtils.getIP();
|
||||||
}
|
}
|
||||||
|
|
||||||
public WebAPIManager getWebAPI() {
|
public WebAPIManager getWebAPI() {
|
||||||
|
@ -13,4 +13,9 @@ public class AnalysisPageResponse extends Response {
|
|||||||
super.setHeader("HTTP/1.1 200 OK");
|
super.setHeader("HTTP/1.1 200 OK");
|
||||||
super.setContent(Theme.replaceColors(informationManager.getAnalysisHtml()));
|
super.setContent(Theme.replaceColors(informationManager.getAnalysisHtml()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public AnalysisPageResponse(String html) {
|
||||||
|
super.setHeader("HTTP/1.1 200 OK");
|
||||||
|
super.setContent(Theme.replaceColors(html));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,6 +19,12 @@ public class InspectPageResponse extends Response {
|
|||||||
setInspectPagePluginsTab(infoManager.getPluginsTabContent(uuid));
|
setInspectPagePluginsTab(infoManager.getPluginsTabContent(uuid));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public InspectPageResponse(InformationManager infoManager, UUID uuid, String html) {
|
||||||
|
super.setHeader("HTTP/1.1 200 OK");
|
||||||
|
super.setContent(Theme.replaceColors(html));
|
||||||
|
setInspectPagePluginsTab(infoManager.getPluginsTabContent(uuid));
|
||||||
|
}
|
||||||
|
|
||||||
public void setInspectPagePluginsTab(String inspectPagePluginsTab) {
|
public void setInspectPagePluginsTab(String inspectPagePluginsTab) {
|
||||||
if (this.inspectPagePluginsTab != null) {
|
if (this.inspectPagePluginsTab != null) {
|
||||||
setContent(getContent().replace(this.inspectPagePluginsTab, inspectPagePluginsTab));
|
setContent(getContent().replace(this.inspectPagePluginsTab, inspectPagePluginsTab));
|
||||||
|
@ -15,6 +15,7 @@ import java.io.DataOutputStream;
|
|||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.HttpURLConnection;
|
import java.net.HttpURLConnection;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
@ -25,6 +26,10 @@ public abstract class WebAPI {
|
|||||||
|
|
||||||
private Map<String, String> variables;
|
private Map<String, String> variables;
|
||||||
|
|
||||||
|
public WebAPI() {
|
||||||
|
this.variables = new HashMap<>();
|
||||||
|
}
|
||||||
|
|
||||||
public abstract Response onResponse(IPlan plugin, Map<String, String> variables);
|
public abstract Response onResponse(IPlan plugin, Map<String, String> variables);
|
||||||
|
|
||||||
public void sendRequest(String address, UUID receiverUUID) throws WebAPIException {
|
public void sendRequest(String address, UUID receiverUUID) throws WebAPIException {
|
||||||
@ -59,16 +64,15 @@ public abstract class WebAPI {
|
|||||||
int responseCode = connection.getResponseCode();
|
int responseCode = connection.getResponseCode();
|
||||||
switch (responseCode) {
|
switch (responseCode) {
|
||||||
case 200:
|
case 200:
|
||||||
break;
|
return;
|
||||||
case 400:
|
case 400:
|
||||||
throw new WebAPIException("Bad Request: " + url.toString() + "|" + parameters);
|
throw new WebAPIException("Bad Request: " + url.toString() + "|" + parameters);
|
||||||
default:
|
default:
|
||||||
throw new WebAPIException(url.toString() + "| Wrong response code " + responseCode);
|
throw new WebAPIException(url.toString() + "| Wrong response code " + responseCode);
|
||||||
}
|
}
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
throw new WebAPIConnectionFailException("API connection failed.", e);
|
throw new WebAPIConnectionFailException("API connection failed. address: " + address, e);
|
||||||
}
|
}
|
||||||
throw new WebAPIException("Response entity was null");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void addVariable(String key, String value) {
|
protected void addVariable(String key, String value) {
|
||||||
|
@ -16,7 +16,7 @@ import java.util.Map;
|
|||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Fuzzlemann
|
* @author Rsl1122
|
||||||
*/
|
*/
|
||||||
public class InspectWebAPI extends WebAPI {
|
public class InspectWebAPI extends WebAPI {
|
||||||
@Override
|
@Override
|
||||||
@ -33,6 +33,11 @@ public class InspectWebAPI extends WebAPI {
|
|||||||
return PageCache.loadPage("success", SuccessResponse::new);
|
return PageCache.loadPage("success", SuccessResponse::new);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void sendRequest(String address, UUID receiverUUID) throws WebAPIException {
|
||||||
|
throw new IllegalStateException("Wrong method call for this WebAPI, call sendRequest(String, UUID, UUID) instead.");
|
||||||
|
}
|
||||||
|
|
||||||
public void sendRequest(String address, UUID receiverUUID, UUID uuid) throws WebAPIException {
|
public void sendRequest(String address, UUID receiverUUID, UUID uuid) throws WebAPIException {
|
||||||
addVariable("uuid", uuid.toString());
|
addVariable("uuid", uuid.toString());
|
||||||
super.sendRequest(address, receiverUUID);
|
super.sendRequest(address, receiverUUID);
|
||||||
|
@ -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.webserver.webapi.bukkit;
|
||||||
|
|
||||||
|
import main.java.com.djrapitops.plan.api.IPlan;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.response.Response;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.response.api.JsonResponse;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.webapi.WebAPI;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public class MaxPlayersWebAPI extends WebAPI {
|
||||||
|
@Override
|
||||||
|
public Response onResponse(IPlan plugin, Map<String, String> variables) {
|
||||||
|
return new JsonResponse(plugin.getVariable().getMaxPlayers());
|
||||||
|
}
|
||||||
|
}
|
@ -9,7 +9,6 @@ import main.java.com.djrapitops.plan.api.IPlan;
|
|||||||
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.JsonResponse;
|
import main.java.com.djrapitops.plan.systems.webserver.response.api.JsonResponse;
|
||||||
import main.java.com.djrapitops.plan.systems.webserver.webapi.WebAPI;
|
import main.java.com.djrapitops.plan.systems.webserver.webapi.WebAPI;
|
||||||
import org.bukkit.Server;
|
|
||||||
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
@ -19,8 +18,6 @@ import java.util.Map;
|
|||||||
public class OnlinePlayersWebAPI extends WebAPI {
|
public class OnlinePlayersWebAPI extends WebAPI {
|
||||||
@Override
|
@Override
|
||||||
public Response onResponse(IPlan plugin, Map<String, String> variables) {
|
public Response onResponse(IPlan plugin, Map<String, String> variables) {
|
||||||
Server server = ((Plan) plugin).getServer();
|
return new JsonResponse(((Plan) plugin).getServer().getOnlinePlayers());
|
||||||
|
|
||||||
return new JsonResponse(server.getOnlinePlayers() + "/" + server.getMaxPlayers());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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.webapi.bungee;
|
||||||
|
|
||||||
|
import main.java.com.djrapitops.plan.api.IPlan;
|
||||||
|
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.response.AnalysisPageResponse;
|
||||||
|
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.api.BadRequestResponse;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.response.api.SuccessResponse;
|
||||||
|
import main.java.com.djrapitops.plan.systems.webserver.webapi.WebAPI;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* WebAPI for posting Html pages such as Inspect, players or server pages.
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public class PostHtmlWebAPI extends WebAPI {
|
||||||
|
|
||||||
|
private final IPlan plugin;
|
||||||
|
|
||||||
|
public PostHtmlWebAPI(IPlan plugin) {
|
||||||
|
this.plugin = plugin;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response onResponse(IPlan plugin, Map<String, String> variables) {
|
||||||
|
try {
|
||||||
|
String html = variables.get("html");
|
||||||
|
String target = variables.get("target");
|
||||||
|
InformationManager infoManager = plugin.getInfoManager();
|
||||||
|
switch (target) {
|
||||||
|
case "inspectPage":
|
||||||
|
String uuid = variables.get("uuid");
|
||||||
|
PageCache.loadPage("inspectPage:" + uuid, () -> new InspectPageResponse(infoManager, UUID.fromString(uuid), html));
|
||||||
|
break;
|
||||||
|
case "analysisPage":
|
||||||
|
PageCache.loadPage("analysisPage:" + variables.get("sender"), () -> new AnalysisPageResponse(html));
|
||||||
|
default:
|
||||||
|
String error = "Faulty Target";
|
||||||
|
return PageCache.loadPage(error, () -> new BadRequestResponse(error));
|
||||||
|
}
|
||||||
|
return PageCache.loadPage("success", SuccessResponse::new);
|
||||||
|
} catch (NullPointerException e) {
|
||||||
|
return PageCache.loadPage(e.toString(), () -> new BadRequestResponse(e.toString()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user