mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2024-12-31 21:48:32 +01:00
Improved local execution of InfoRequests
This commit is contained in:
parent
0d4c065b52
commit
1f0d74b127
@ -1,7 +1,9 @@
|
|||||||
package com.djrapitops.plan.command.commands.manage;
|
package com.djrapitops.plan.command.commands.manage;
|
||||||
|
|
||||||
import com.djrapitops.plan.Plan;
|
import com.djrapitops.plan.Plan;
|
||||||
|
import com.djrapitops.plan.api.exceptions.connection.BadRequestException;
|
||||||
import com.djrapitops.plan.api.exceptions.connection.ForbiddenException;
|
import com.djrapitops.plan.api.exceptions.connection.ForbiddenException;
|
||||||
|
import com.djrapitops.plan.api.exceptions.connection.UnauthorizedServerException;
|
||||||
import com.djrapitops.plan.api.exceptions.connection.WebException;
|
import com.djrapitops.plan.api.exceptions.connection.WebException;
|
||||||
import com.djrapitops.plan.system.info.InfoSystem;
|
import com.djrapitops.plan.system.info.InfoSystem;
|
||||||
import com.djrapitops.plan.system.settings.Permissions;
|
import com.djrapitops.plan.system.settings.Permissions;
|
||||||
@ -68,9 +70,13 @@ public class ManageSetupCommand extends SubCommand {
|
|||||||
|
|
||||||
InfoSystem.getInstance().requestSetUp(address);
|
InfoSystem.getInstance().requestSetUp(address);
|
||||||
|
|
||||||
sender.sendMessage("§eConnection successful, Plan may restart in a few seconds, if it doesn't something has gone wrong.");
|
sender.sendMessage("§aConnection successful, Plan may restart in a few seconds..");
|
||||||
} catch (ForbiddenException e) {
|
} catch (ForbiddenException e) {
|
||||||
sender.sendMessage("§eConnection succeeded, but Bungee has set-up mode disabled - use '/planbungee setup' to enable it.");
|
sender.sendMessage("§eConnection succeeded, but Bungee has set-up mode disabled - use '/planbungee setup' to enable it.");
|
||||||
|
} catch (BadRequestException e) {
|
||||||
|
sender.sendMessage("§eConnection succeeded, but Receiving server was a Bukkit server. Use Bungee address instead.");
|
||||||
|
} catch (UnauthorizedServerException e) {
|
||||||
|
sender.sendMessage("§eConnection succeeded, but Receiving server didn't authorize this server. Contact Discord for support");
|
||||||
} catch (WebException e) {
|
} catch (WebException 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");
|
||||||
|
@ -8,12 +8,10 @@ import com.djrapitops.plan.api.exceptions.connection.WebException;
|
|||||||
import com.djrapitops.plan.system.info.connection.BukkitConnectionSystem;
|
import com.djrapitops.plan.system.info.connection.BukkitConnectionSystem;
|
||||||
import com.djrapitops.plan.system.info.request.CacheNetworkPageContentRequest;
|
import com.djrapitops.plan.system.info.request.CacheNetworkPageContentRequest;
|
||||||
import com.djrapitops.plan.system.info.request.InfoRequest;
|
import com.djrapitops.plan.system.info.request.InfoRequest;
|
||||||
import com.djrapitops.plan.system.info.request.InfoRequestWithVariables;
|
import com.djrapitops.plan.system.info.request.SetupRequest;
|
||||||
import com.djrapitops.plan.system.info.server.ServerInfo;
|
import com.djrapitops.plan.system.info.server.ServerInfo;
|
||||||
import com.djrapitops.plan.utilities.html.HtmlStructure;
|
import com.djrapitops.plan.utilities.html.HtmlStructure;
|
||||||
|
|
||||||
import java.util.HashMap;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* InfoSystem for Bukkit servers.
|
* InfoSystem for Bukkit servers.
|
||||||
*
|
*
|
||||||
@ -26,16 +24,11 @@ public class BukkitInfoSystem extends InfoSystem {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void runLocally(InfoRequest infoRequest) throws WebException {
|
public void runLocally(InfoRequest infoRequest) throws WebException {
|
||||||
if (infoRequest instanceof CacheNetworkPageContentRequest) {
|
if (infoRequest instanceof SetupRequest) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
infoRequest.placeDataToDatabase();
|
infoRequest.runLocally();
|
||||||
if (infoRequest instanceof InfoRequestWithVariables) {
|
|
||||||
infoRequest.handleRequest(((InfoRequestWithVariables) infoRequest).getVariables());
|
|
||||||
} else {
|
|
||||||
infoRequest.handleRequest(new HashMap<>());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -28,7 +28,7 @@ public class BungeeInfoSystem extends InfoSystem {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void runLocally(InfoRequest infoRequest) throws WebException {
|
public void runLocally(InfoRequest infoRequest) throws WebException {
|
||||||
// runLocally is called when ConnectionSystem has no servers.
|
// runLocally is called when ConnectionSystem has no servers.
|
||||||
throw new NoServersException("No servers were available to process this request.");
|
throw new NoServersException("No servers were available to process this request.");
|
||||||
}
|
}
|
||||||
|
@ -73,7 +73,7 @@ public abstract class InfoSystem implements SubSystem {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected abstract void runLocally(InfoRequest infoRequest) throws WebException;
|
public abstract void runLocally(InfoRequest infoRequest) throws WebException;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void enable() throws EnableException {
|
public void enable() throws EnableException {
|
||||||
|
@ -53,7 +53,7 @@ public class ConnectionOut {
|
|||||||
/**
|
/**
|
||||||
* Constructor.
|
* Constructor.
|
||||||
*
|
*
|
||||||
* @param toServer Full address to another Plan webserver. (http://something:port)
|
* @param toServer Full address to another Plan webserver. (http://something:port)
|
||||||
* @param serverUUID UUID of server this outbound connection.
|
* @param serverUUID UUID of server this outbound connection.
|
||||||
* @param infoRequest Type of the action this connection wants to be performed.
|
* @param infoRequest Type of the action this connection wants to be performed.
|
||||||
*/
|
*/
|
||||||
@ -120,9 +120,9 @@ public class ConnectionOut {
|
|||||||
case 200:
|
case 200:
|
||||||
return;
|
return;
|
||||||
case 400:
|
case 400:
|
||||||
throw new WebFailException("Bad Request: " + url.toString() + " | " + parameters);
|
throw new BadRequestException("Bad Request: " + url.toString() + " | " + parameters);
|
||||||
case 403:
|
case 403:
|
||||||
throw new ForbiddenException(url.toString() + " returned 403.");
|
throw new ForbiddenException(url.toString() + " returned 403 | " + parameters);
|
||||||
case 404:
|
case 404:
|
||||||
throw new NotFoundException(url.toString() + " returned a 404, ensure that your server is connected to an up to date Plan server.");
|
throw new NotFoundException(url.toString() + " returned a 404, ensure that your server is connected to an up to date Plan server.");
|
||||||
case 412:
|
case 412:
|
||||||
|
@ -77,7 +77,11 @@ public abstract class ConnectionSystem implements SubSystem {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void sendInfoRequest(InfoRequest infoRequest, Server toServer) throws WebException {
|
public void sendInfoRequest(InfoRequest infoRequest, Server toServer) throws WebException {
|
||||||
new ConnectionOut(toServer, ServerInfo.getServerUUID(), infoRequest).sendRequest();
|
if (ServerInfo.getServerUUID().equals(toServer.getUuid())) {
|
||||||
|
InfoSystem.getInstance().runLocally(infoRequest);
|
||||||
|
} else {
|
||||||
|
new ConnectionOut(toServer, ServerInfo.getServerUUID(), infoRequest).sendRequest();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public ConnectionLog getConnectionLog() {
|
public ConnectionLog getConnectionLog() {
|
||||||
|
@ -11,6 +11,7 @@ import com.djrapitops.plan.system.webserver.Request;
|
|||||||
import com.djrapitops.plan.system.webserver.pages.PageHandler;
|
import com.djrapitops.plan.system.webserver.pages.PageHandler;
|
||||||
import com.djrapitops.plan.system.webserver.response.DefaultResponses;
|
import com.djrapitops.plan.system.webserver.response.DefaultResponses;
|
||||||
import com.djrapitops.plan.system.webserver.response.Response;
|
import com.djrapitops.plan.system.webserver.response.Response;
|
||||||
|
import com.djrapitops.plan.system.webserver.response.api.BadRequestResponse;
|
||||||
import com.djrapitops.plan.utilities.NullCheck;
|
import com.djrapitops.plan.utilities.NullCheck;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -30,6 +31,10 @@ public class InfoRequestPageHandler extends PageHandler {
|
|||||||
return DefaultResponses.NOT_FOUND.get();
|
return DefaultResponses.NOT_FOUND.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!request.getRequestMethod().equals("POST")) {
|
||||||
|
return new BadRequestResponse("POST should be used for Info calls.");
|
||||||
|
}
|
||||||
|
|
||||||
String requestName = target.get(0);
|
String requestName = target.get(0);
|
||||||
InfoRequest infoRequest = ConnectionSystem.getInstance().getInfoRequest(requestName);
|
InfoRequest infoRequest = ConnectionSystem.getInstance().getInfoRequest(requestName);
|
||||||
|
|
||||||
|
@ -71,14 +71,23 @@ public class CacheAnalysisPageRequest implements CacheRequest {
|
|||||||
UUID serverUUID = entry.getKey();
|
UUID serverUUID = entry.getKey();
|
||||||
String html = Base64Util.decode(entry.getValue());
|
String html = Base64Util.decode(entry.getValue());
|
||||||
|
|
||||||
ResponseCache.cacheResponse(PageId.SERVER.of(serverUUID), () -> new AnalysisPageResponse(html));
|
cache(export, serverUUID, html);
|
||||||
if (export) {
|
|
||||||
Processor.queue(() -> HtmlExport.exportServer(serverUUID));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} catch (DBException e) {
|
} catch (DBException e) {
|
||||||
throw new TransferDatabaseException(e);
|
throw new TransferDatabaseException(e);
|
||||||
}
|
}
|
||||||
return DefaultResponses.SUCCESS.get();
|
return DefaultResponses.SUCCESS.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void cache(boolean export, UUID serverUUID, String html) {
|
||||||
|
ResponseCache.cacheResponse(PageId.SERVER.of(serverUUID), () -> new AnalysisPageResponse(html));
|
||||||
|
if (export) {
|
||||||
|
Processor.queue(() -> HtmlExport.exportServer(serverUUID));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void runLocally() {
|
||||||
|
cache(Settings.ANALYSIS_EXPORT.isTrue(), serverUUID, html);
|
||||||
|
}
|
||||||
}
|
}
|
@ -71,14 +71,23 @@ public class CacheInspectPageRequest implements CacheRequest {
|
|||||||
UUID uuid = entry.getKey();
|
UUID uuid = entry.getKey();
|
||||||
String html = Base64Util.decode(entry.getValue());
|
String html = Base64Util.decode(entry.getValue());
|
||||||
|
|
||||||
ResponseCache.cacheResponse(PageId.PLAYER.of(uuid), () -> new InspectPageResponse(uuid, html));
|
cache(export, uuid, html);
|
||||||
if (export) {
|
|
||||||
Processor.queue(() -> HtmlExport.exportPlayer(uuid));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} catch (DBException e) {
|
} catch (DBException e) {
|
||||||
throw new TransferDatabaseException(e);
|
throw new TransferDatabaseException(e);
|
||||||
}
|
}
|
||||||
return DefaultResponses.SUCCESS.get();
|
return DefaultResponses.SUCCESS.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void cache(boolean export, UUID uuid, String html) {
|
||||||
|
ResponseCache.cacheResponse(PageId.PLAYER.of(uuid), () -> new InspectPageResponse(uuid, html));
|
||||||
|
if (export) {
|
||||||
|
Processor.queue(() -> HtmlExport.exportPlayer(uuid));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void runLocally() {
|
||||||
|
cache(Settings.ANALYSIS_EXPORT.isTrue(), player, html);
|
||||||
|
}
|
||||||
}
|
}
|
@ -9,6 +9,7 @@ import com.djrapitops.plan.api.exceptions.connection.TransferDatabaseException;
|
|||||||
import com.djrapitops.plan.api.exceptions.connection.WebException;
|
import com.djrapitops.plan.api.exceptions.connection.WebException;
|
||||||
import com.djrapitops.plan.api.exceptions.database.DBException;
|
import com.djrapitops.plan.api.exceptions.database.DBException;
|
||||||
import com.djrapitops.plan.system.database.databases.Database;
|
import com.djrapitops.plan.system.database.databases.Database;
|
||||||
|
import com.djrapitops.plan.system.info.server.ServerInfo;
|
||||||
import com.djrapitops.plan.system.webserver.response.DefaultResponses;
|
import com.djrapitops.plan.system.webserver.response.DefaultResponses;
|
||||||
import com.djrapitops.plan.system.webserver.response.Response;
|
import com.djrapitops.plan.system.webserver.response.Response;
|
||||||
import com.djrapitops.plan.system.webserver.response.cache.PageId;
|
import com.djrapitops.plan.system.webserver.response.cache.PageId;
|
||||||
@ -29,19 +30,23 @@ import java.util.UUID;
|
|||||||
public class CacheInspectPluginsTabRequest extends InfoRequestWithVariables implements CacheRequest {
|
public class CacheInspectPluginsTabRequest extends InfoRequestWithVariables implements CacheRequest {
|
||||||
|
|
||||||
private static final String SPLIT = ";;SPLIT;;";
|
private static final String SPLIT = ";;SPLIT;;";
|
||||||
|
|
||||||
private final UUID player;
|
private final UUID player;
|
||||||
private final String navAndHtml;
|
private final String nav;
|
||||||
|
private final String html;
|
||||||
|
|
||||||
private CacheInspectPluginsTabRequest() {
|
private CacheInspectPluginsTabRequest() {
|
||||||
player = null;
|
player = null;
|
||||||
navAndHtml = null;
|
nav = null;
|
||||||
|
html = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public CacheInspectPluginsTabRequest(UUID player, String nav, String html) {
|
public CacheInspectPluginsTabRequest(UUID player, String nav, String html) {
|
||||||
Verify.nullCheck(player, nav);
|
Verify.nullCheck(player, nav);
|
||||||
variables.put("player", player.toString());
|
variables.put("player", player.toString());
|
||||||
this.player = player;
|
this.player = player;
|
||||||
this.navAndHtml = nav + SPLIT + html;
|
this.nav = nav;
|
||||||
|
this.html = html;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static CacheInspectPluginsTabRequest createHandler() {
|
public static CacheInspectPluginsTabRequest createHandler() {
|
||||||
@ -50,9 +55,9 @@ public class CacheInspectPluginsTabRequest extends InfoRequestWithVariables impl
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void placeDataToDatabase() throws WebException {
|
public void placeDataToDatabase() throws WebException {
|
||||||
Verify.nullCheck(player, navAndHtml);
|
Verify.nullCheck(player, nav);
|
||||||
|
|
||||||
String encodedHtml = Base64Util.encode(navAndHtml);
|
String encodedHtml = Base64Util.encode(nav + SPLIT + html);
|
||||||
try {
|
try {
|
||||||
Database.getActive().transfer().storePlayerPluginsTab(player, encodedHtml);
|
Database.getActive().transfer().storePlayerPluginsTab(player, encodedHtml);
|
||||||
} catch (DBException e) {
|
} catch (DBException e) {
|
||||||
@ -70,20 +75,28 @@ public class CacheInspectPluginsTabRequest extends InfoRequestWithVariables impl
|
|||||||
UUID uuid = UUID.fromString(player);
|
UUID uuid = UUID.fromString(player);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
Map<UUID, String> pages = Database.getActive().transfer().getEncodedPlayerPluginsTabs(uuid);
|
InspectPagePluginsContent pluginsTab = getPluginsTab(uuid);
|
||||||
|
|
||||||
InspectPagePluginsContent pluginsTab = (InspectPagePluginsContent)
|
Map<UUID, String> pages = Database.getActive().transfer().getEncodedPlayerPluginsTabs(uuid);
|
||||||
ResponseCache.loadResponse(PageId.PLAYER_PLUGINS_TAB.of(uuid), InspectPagePluginsContent::new);
|
|
||||||
|
|
||||||
for (Map.Entry<UUID, String> entry : pages.entrySet()) {
|
for (Map.Entry<UUID, String> entry : pages.entrySet()) {
|
||||||
UUID serverUUID = entry.getKey();
|
UUID serverUUID = entry.getKey();
|
||||||
String[] html = Base64Util.decode(entry.getValue()).split(SPLIT);
|
String[] navAndHtml = Base64Util.decode(entry.getValue()).split(SPLIT);
|
||||||
|
|
||||||
pluginsTab.addTab(serverUUID, html[0], html[1]);
|
pluginsTab.addTab(serverUUID, navAndHtml[0], navAndHtml[1]);
|
||||||
}
|
}
|
||||||
} catch (DBException e) {
|
} catch (DBException e) {
|
||||||
throw new TransferDatabaseException(e);
|
throw new TransferDatabaseException(e);
|
||||||
}
|
}
|
||||||
return DefaultResponses.SUCCESS.get();
|
return DefaultResponses.SUCCESS.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private InspectPagePluginsContent getPluginsTab(UUID uuid) {
|
||||||
|
return (InspectPagePluginsContent) ResponseCache.loadResponse(PageId.PLAYER_PLUGINS_TAB.of(uuid), InspectPagePluginsContent::new);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void runLocally() {
|
||||||
|
getPluginsTab(player).addTab(ServerInfo.getServerUUID(), nav, html);
|
||||||
|
}
|
||||||
}
|
}
|
@ -9,6 +9,7 @@ import com.djrapitops.plan.api.exceptions.connection.WebException;
|
|||||||
import com.djrapitops.plan.api.exceptions.database.DBException;
|
import com.djrapitops.plan.api.exceptions.database.DBException;
|
||||||
import com.djrapitops.plan.system.database.databases.Database;
|
import com.djrapitops.plan.system.database.databases.Database;
|
||||||
import com.djrapitops.plan.system.info.InfoSystem;
|
import com.djrapitops.plan.system.info.InfoSystem;
|
||||||
|
import com.djrapitops.plan.system.info.server.ServerInfo;
|
||||||
import com.djrapitops.plan.system.webserver.response.DefaultResponses;
|
import com.djrapitops.plan.system.webserver.response.DefaultResponses;
|
||||||
import com.djrapitops.plan.system.webserver.response.Response;
|
import com.djrapitops.plan.system.webserver.response.Response;
|
||||||
import com.djrapitops.plan.system.webserver.response.cache.PageId;
|
import com.djrapitops.plan.system.webserver.response.cache.PageId;
|
||||||
@ -21,7 +22,7 @@ import java.util.UUID;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* InfoRequest for caching Network page parts to ResponseCache of receiving server.
|
* InfoRequest for caching Network page parts to ResponseCache of receiving server.
|
||||||
*
|
* <p>
|
||||||
* SHOULD NOT BE SENT TO BUKKIT
|
* SHOULD NOT BE SENT TO BUKKIT
|
||||||
*
|
*
|
||||||
* @author Rsl1122
|
* @author Rsl1122
|
||||||
@ -70,9 +71,8 @@ public class CacheNetworkPageContentRequest implements CacheRequest {
|
|||||||
String serverName = serverNames.getOrDefault(serverUUID, "Unknown");
|
String serverName = serverNames.getOrDefault(serverUUID, "Unknown");
|
||||||
String html = entry.getValue();
|
String html = entry.getValue();
|
||||||
|
|
||||||
NetworkPageContent response = (NetworkPageContent)
|
NetworkPageContent networkPage = getNetworkPageContent();
|
||||||
ResponseCache.loadResponse(PageId.NETWORK_CONTENT.id(), NetworkPageContent::new);
|
networkPage.addElement(serverName, html);
|
||||||
response.addElement(serverName, html);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
InfoSystem.getInstance().updateNetworkPage();
|
InfoSystem.getInstance().updateNetworkPage();
|
||||||
@ -80,6 +80,15 @@ public class CacheNetworkPageContentRequest implements CacheRequest {
|
|||||||
return DefaultResponses.SUCCESS.get();
|
return DefaultResponses.SUCCESS.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private NetworkPageContent getNetworkPageContent() {
|
||||||
|
return (NetworkPageContent) ResponseCache.loadResponse(PageId.NETWORK_CONTENT.id(), NetworkPageContent::new);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void runLocally() {
|
||||||
|
getNetworkPageContent().addElement(ServerInfo.getServerName(), html);
|
||||||
|
}
|
||||||
|
|
||||||
public static CacheNetworkPageContentRequest createHandler() {
|
public static CacheNetworkPageContentRequest createHandler() {
|
||||||
return new CacheNetworkPageContentRequest();
|
return new CacheNetworkPageContentRequest();
|
||||||
}
|
}
|
||||||
|
@ -12,8 +12,8 @@ import com.djrapitops.plan.system.cache.DataCache;
|
|||||||
import com.djrapitops.plan.system.database.databases.Database;
|
import com.djrapitops.plan.system.database.databases.Database;
|
||||||
import com.djrapitops.plan.system.info.InfoSystem;
|
import com.djrapitops.plan.system.info.InfoSystem;
|
||||||
import com.djrapitops.plan.system.info.server.ServerInfo;
|
import com.djrapitops.plan.system.info.server.ServerInfo;
|
||||||
import com.djrapitops.plan.system.webserver.response.DefaultResponses;
|
|
||||||
import com.djrapitops.plan.system.webserver.pages.parsing.AnalysisPage;
|
import com.djrapitops.plan.system.webserver.pages.parsing.AnalysisPage;
|
||||||
|
import com.djrapitops.plan.system.webserver.response.DefaultResponses;
|
||||||
import com.djrapitops.plan.system.webserver.response.Response;
|
import com.djrapitops.plan.system.webserver.response.Response;
|
||||||
import com.djrapitops.plan.system.webserver.response.pages.AnalysisPageResponse;
|
import com.djrapitops.plan.system.webserver.response.pages.AnalysisPageResponse;
|
||||||
import com.djrapitops.plan.utilities.NullCheck;
|
import com.djrapitops.plan.utilities.NullCheck;
|
||||||
@ -60,14 +60,23 @@ public class GenerateAnalysisPageRequest extends InfoRequestWithVariables implem
|
|||||||
throw new BadRequestException("Requested Analysis page from wrong server.");
|
throw new BadRequestException("Requested Analysis page from wrong server.");
|
||||||
}
|
}
|
||||||
|
|
||||||
InfoSystem infoSystem = InfoSystem.getInstance();
|
generateAndCache(serverUUID);
|
||||||
infoSystem.sendRequest(new CacheAnalysisPageRequest(serverUUID, AnalysisPageResponse.getRefreshingHtml()));
|
|
||||||
infoSystem.sendRequest(new CacheAnalysisPageRequest(serverUUID, analyseAndGetHtml()));
|
|
||||||
|
|
||||||
return DefaultResponses.SUCCESS.get();
|
return DefaultResponses.SUCCESS.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
public String analyseAndGetHtml() throws InternalErrorException {
|
private void generateAndCache(UUID serverUUID) throws WebException {
|
||||||
|
InfoSystem infoSystem = InfoSystem.getInstance();
|
||||||
|
infoSystem.sendRequest(new CacheAnalysisPageRequest(serverUUID, AnalysisPageResponse.getRefreshingHtml()));
|
||||||
|
infoSystem.sendRequest(new CacheAnalysisPageRequest(serverUUID, analyseAndGetHtml()));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void runLocally() throws WebException {
|
||||||
|
generateAndCache(serverUUID);
|
||||||
|
}
|
||||||
|
|
||||||
|
private String analyseAndGetHtml() throws InternalErrorException {
|
||||||
try {
|
try {
|
||||||
UUID serverUUID = ServerInfo.getServerUUID();
|
UUID serverUUID = ServerInfo.getServerUUID();
|
||||||
Database db = Database.getActive();
|
Database db = Database.getActive();
|
||||||
|
@ -11,8 +11,8 @@ import com.djrapitops.plan.api.exceptions.connection.WebException;
|
|||||||
import com.djrapitops.plan.api.exceptions.connection.WebFailException;
|
import com.djrapitops.plan.api.exceptions.connection.WebFailException;
|
||||||
import com.djrapitops.plan.api.exceptions.database.DBException;
|
import com.djrapitops.plan.api.exceptions.database.DBException;
|
||||||
import com.djrapitops.plan.system.info.InfoSystem;
|
import com.djrapitops.plan.system.info.InfoSystem;
|
||||||
import com.djrapitops.plan.system.webserver.response.DefaultResponses;
|
|
||||||
import com.djrapitops.plan.system.webserver.pages.parsing.InspectPage;
|
import com.djrapitops.plan.system.webserver.pages.parsing.InspectPage;
|
||||||
|
import com.djrapitops.plan.system.webserver.response.DefaultResponses;
|
||||||
import com.djrapitops.plan.system.webserver.response.Response;
|
import com.djrapitops.plan.system.webserver.response.Response;
|
||||||
import com.djrapitops.plan.utilities.NullCheck;
|
import com.djrapitops.plan.utilities.NullCheck;
|
||||||
import com.djrapitops.plugin.utilities.Verify;
|
import com.djrapitops.plugin.utilities.Verify;
|
||||||
@ -56,13 +56,23 @@ public class GenerateInspectPageRequest extends InfoRequestWithVariables impleme
|
|||||||
NullCheck.check(player, new BadRequestException("Player UUID 'player' variable not supplied in the request."));
|
NullCheck.check(player, new BadRequestException("Player UUID 'player' variable not supplied in the request."));
|
||||||
|
|
||||||
UUID uuid = UUID.fromString(player);
|
UUID uuid = UUID.fromString(player);
|
||||||
String html = getHtml(uuid);
|
|
||||||
|
|
||||||
InfoSystem.getInstance().sendRequest(new CacheInspectPageRequest(uuid, html));
|
generateAndCache(uuid);
|
||||||
|
|
||||||
return DefaultResponses.SUCCESS.get();
|
return DefaultResponses.SUCCESS.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void generateAndCache(UUID uuid) throws WebException {
|
||||||
|
String html = getHtml(uuid);
|
||||||
|
InfoSystem.getInstance().getConnectionSystem().sendWideInfoRequest(new GenerateInspectPluginsTabRequest(uuid));
|
||||||
|
InfoSystem.getInstance().sendRequest(new CacheInspectPageRequest(uuid, html));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void runLocally() throws WebException {
|
||||||
|
generateAndCache(playerUUID);
|
||||||
|
}
|
||||||
|
|
||||||
private String getHtml(UUID uuid) throws WebException {
|
private String getHtml(UUID uuid) throws WebException {
|
||||||
try {
|
try {
|
||||||
|
|
||||||
|
@ -9,8 +9,6 @@ import com.djrapitops.plan.api.exceptions.connection.WebException;
|
|||||||
import com.djrapitops.plan.system.info.InfoSystem;
|
import com.djrapitops.plan.system.info.InfoSystem;
|
||||||
import com.djrapitops.plan.system.webserver.response.DefaultResponses;
|
import com.djrapitops.plan.system.webserver.response.DefaultResponses;
|
||||||
import com.djrapitops.plan.system.webserver.response.Response;
|
import com.djrapitops.plan.system.webserver.response.Response;
|
||||||
import com.djrapitops.plan.system.webserver.response.cache.PageId;
|
|
||||||
import com.djrapitops.plan.system.webserver.response.cache.ResponseCache;
|
|
||||||
import com.djrapitops.plan.system.webserver.response.pages.parts.InspectPagePluginsContent;
|
import com.djrapitops.plan.system.webserver.response.pages.parts.InspectPagePluginsContent;
|
||||||
import com.djrapitops.plan.utilities.NullCheck;
|
import com.djrapitops.plan.utilities.NullCheck;
|
||||||
import com.djrapitops.plugin.utilities.Verify;
|
import com.djrapitops.plugin.utilities.Verify;
|
||||||
@ -54,16 +52,20 @@ public class GenerateInspectPluginsTabRequest extends InfoRequestWithVariables i
|
|||||||
NullCheck.check(player, new BadRequestException("Player UUID 'player' variable not supplied in the request."));
|
NullCheck.check(player, new BadRequestException("Player UUID 'player' variable not supplied in the request."));
|
||||||
|
|
||||||
UUID uuid = UUID.fromString(player);
|
UUID uuid = UUID.fromString(player);
|
||||||
String[] navAndhtml = getNavAndHtml(uuid);
|
|
||||||
|
|
||||||
InfoSystem.getInstance().sendRequest(new CacheInspectPluginsTabRequest(uuid, navAndhtml[0], navAndhtml[1]));
|
generateAndCache(uuid);
|
||||||
|
|
||||||
return DefaultResponses.SUCCESS.get();
|
return DefaultResponses.SUCCESS.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
private String[] getNavAndHtml(UUID uuid) {
|
private void generateAndCache(UUID uuid) throws WebException {
|
||||||
return ((InspectPagePluginsContent) ResponseCache.loadResponse(PageId.PLAYER_PLUGINS_TAB.of(uuid),
|
String[] navAndHtml = InspectPagePluginsContent.generateForThisServer(uuid).getContents();
|
||||||
InspectPagePluginsContent::new)).getContents();
|
InfoSystem.getInstance().sendRequest(new CacheInspectPluginsTabRequest(uuid, navAndHtml[0], navAndHtml[1]));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void runLocally() throws WebException {
|
||||||
|
generateAndCache(playerUUID);
|
||||||
}
|
}
|
||||||
|
|
||||||
public UUID getPlayerUUID() {
|
public UUID getPlayerUUID() {
|
||||||
|
@ -20,4 +20,6 @@ public interface InfoRequest {
|
|||||||
|
|
||||||
Response handleRequest(Map<String, String> variables) throws WebException;
|
Response handleRequest(Map<String, String> variables) throws WebException;
|
||||||
|
|
||||||
|
void runLocally() throws WebException;
|
||||||
|
|
||||||
}
|
}
|
@ -48,6 +48,11 @@ public class SaveDBSettingsRequest extends InfoRequestWithVariables implements S
|
|||||||
/* Not necessary */
|
/* Not necessary */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void runLocally() {
|
||||||
|
/* Won't be run */
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Response handleRequest(Map<String, String> variables) throws WebException {
|
public Response handleRequest(Map<String, String> variables) throws WebException {
|
||||||
if (Check.isBungeeAvailable()) {
|
if (Check.isBungeeAvailable()) {
|
||||||
|
@ -47,6 +47,11 @@ public class SendDBSettingsRequest extends InfoRequestWithVariables implements S
|
|||||||
/* Not necessary */
|
/* Not necessary */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void runLocally() {
|
||||||
|
/* Won't be run */
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Response handleRequest(Map<String, String> variables) throws WebException {
|
public Response handleRequest(Map<String, String> variables) throws WebException {
|
||||||
// Available variables: sender, address
|
// Available variables: sender, address
|
||||||
|
@ -12,7 +12,7 @@ import com.djrapitops.plan.system.webserver.response.Response;
|
|||||||
public class BadRequestResponse extends Response {
|
public class BadRequestResponse extends Response {
|
||||||
|
|
||||||
public BadRequestResponse(String error) {
|
public BadRequestResponse(String error) {
|
||||||
super.setHeader("HTTP/1.1 400 Bad Request");
|
super.setHeader("HTTP/1.1 400 Bad Request " + error);
|
||||||
super.setContent(error);
|
super.setContent("400 Bad Request: " + error);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5,7 +5,6 @@ import com.djrapitops.plan.system.webserver.response.pages.InspectPageResponse;
|
|||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.function.Predicate;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class contains the page cache.
|
* This class contains the page cache.
|
||||||
@ -103,19 +102,6 @@ public class ResponseCache {
|
|||||||
return cache.containsKey(identifier);
|
return cache.containsKey(identifier);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Removes all of the elements of this cache that satisfy the given predicate.
|
|
||||||
*
|
|
||||||
* @param filter a predicate which returns true for entries to be removed
|
|
||||||
*/
|
|
||||||
public static void removeIf(Predicate<String> filter) {
|
|
||||||
for (String identifier : cache.keySet()) {
|
|
||||||
if (filter.test(identifier)) {
|
|
||||||
cache.remove(identifier);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Clears the cache from all its contents.
|
* Clears the cache from all its contents.
|
||||||
*/
|
*/
|
||||||
|
@ -36,13 +36,13 @@ public class InspectPagePluginsContent extends Response {
|
|||||||
addTab(serverUUID, nav, html);
|
addTab(serverUUID, nav, html);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static InspectPagePluginsContent generateForThisServer(UUID uuid) {
|
public static InspectPagePluginsContent generateForThisServer(UUID playerUUID) {
|
||||||
HookHandler hookHandler = HookHandler.getInstance();
|
HookHandler hookHandler = HookHandler.getInstance();
|
||||||
Map<PluginData, InspectContainer> containers = hookHandler.getInspectContainersFor(uuid);
|
Map<PluginData, InspectContainer> containers = hookHandler.getInspectContainersFor(playerUUID);
|
||||||
String serverName = ServerInfo.getServerName();
|
String serverName = ServerInfo.getServerName();
|
||||||
String actualServerName = serverName.equals("Plan") ? "Server " + ServerInfo.getServerID() : serverName;
|
String actualServerName = serverName.equals("Plan") ? "Server " + ServerInfo.getServerID() : serverName;
|
||||||
if (containers.isEmpty()) {
|
if (containers.isEmpty()) {
|
||||||
new InspectPagePluginsContent(uuid, "<li><a>" + actualServerName + "(No Data)</a></li>", "");
|
new InspectPagePluginsContent(playerUUID, "<li><a>" + actualServerName + "(No Data)</a></li>", "");
|
||||||
}
|
}
|
||||||
|
|
||||||
String nav = "<li><a class=\"nav-button\" href=\"javascript:void(0)\">" + actualServerName + "</a></li>";
|
String nav = "<li><a class=\"nav-button\" href=\"javascript:void(0)\">" + actualServerName + "</a></li>";
|
||||||
|
@ -38,13 +38,4 @@ public class ResponseCacheTest {
|
|||||||
ResponseCache.clearCache();
|
ResponseCache.clearCache();
|
||||||
assertFalse(ResponseCache.isCached(IDENTIFIER));
|
assertFalse(ResponseCache.isCached(IDENTIFIER));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testRemoveIf() {
|
|
||||||
ResponseCache.cacheResponse(IDENTIFIER, () -> RESPONSE);
|
|
||||||
assertTrue(ResponseCache.isCached(IDENTIFIER));
|
|
||||||
|
|
||||||
ResponseCache.removeIf(identifier -> identifier.equals(IDENTIFIER));
|
|
||||||
assertFalse(ResponseCache.isCached(IDENTIFIER));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* 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 com.djrapitops.plan.system.database;
|
package com.djrapitops.plan.system.database.databases;
|
||||||
|
|
||||||
import com.djrapitops.plan.system.database.databases.sql.MySQLDB;
|
import com.djrapitops.plan.system.database.databases.sql.MySQLDB;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
@ -3,7 +3,7 @@
|
|||||||
* To change this template file, choose Tools | Templates
|
* To change this template file, choose Tools | Templates
|
||||||
* and open the template in the editor.
|
* and open the template in the editor.
|
||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.system.database;
|
package com.djrapitops.plan.system.database.databases;
|
||||||
|
|
||||||
import com.djrapitops.plan.Plan;
|
import com.djrapitops.plan.Plan;
|
||||||
import com.djrapitops.plan.api.exceptions.database.DBException;
|
import com.djrapitops.plan.api.exceptions.database.DBException;
|
||||||
@ -844,6 +844,7 @@ public class SQLiteTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@Ignore
|
||||||
public void testRegisterProcessorRegisterException() throws SQLException {
|
public void testRegisterProcessorRegisterException() throws SQLException {
|
||||||
assertFalse(db.getUsersTable().isRegistered(playerUUID));
|
assertFalse(db.getUsersTable().isRegistered(playerUUID));
|
||||||
assertFalse(db.getUserInfoTable().isRegistered(playerUUID));
|
assertFalse(db.getUserInfoTable().isRegistered(playerUUID));
|
Loading…
Reference in New Issue
Block a user