mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2025-01-08 17:37:34 +01:00
Use of JSONCache & permission levels for JSON endpoints
This commit is contained in:
parent
20ef9df63d
commit
58bff282eb
@ -106,7 +106,7 @@ public class JSONFactory {
|
|||||||
).toJSONString();
|
).toJSONString();
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<Map<String, Object>> networkSessionsAsJSONMap(UUID serverUUID) {
|
public List<Map<String, Object>> serverSessionsAsJSONMap(UUID serverUUID) {
|
||||||
Database db = dbSystem.getDatabase();
|
Database db = dbSystem.getDatabase();
|
||||||
|
|
||||||
Integer perPageLimit = config.get(DisplaySettings.SESSIONS_PER_PAGE);
|
Integer perPageLimit = config.get(DisplaySettings.SESSIONS_PER_PAGE);
|
||||||
|
@ -37,6 +37,7 @@ public enum DataID {
|
|||||||
GRAPH_WORLD_MAP,
|
GRAPH_WORLD_MAP,
|
||||||
GRAPH_ACTIVITY,
|
GRAPH_ACTIVITY,
|
||||||
GRAPH_PING,
|
GRAPH_PING,
|
||||||
|
GRAPH_SERVER_PIE,
|
||||||
GRAPH_PUNCHCARD,
|
GRAPH_PUNCHCARD,
|
||||||
SERVER_OVERVIEW,
|
SERVER_OVERVIEW,
|
||||||
ONLINE_OVERVIEW,
|
ONLINE_OVERVIEW,
|
||||||
|
@ -39,6 +39,9 @@ public class JSONCache {
|
|||||||
return new JSONResponse(found);
|
return new JSONResponse(found);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Response getOrCache(DataID dataID, Supplier<JSONResponse> jsonResponseSupplier) {
|
||||||
|
return getOrCache(dataID.name(), jsonResponseSupplier);
|
||||||
|
}
|
||||||
public Response getOrCache(DataID dataID, UUID serverUUID, Supplier<JSONResponse> jsonResponseSupplier) {
|
public Response getOrCache(DataID dataID, UUID serverUUID, Supplier<JSONResponse> jsonResponseSupplier) {
|
||||||
return getOrCache(dataID.of(serverUUID), jsonResponseSupplier);
|
return getOrCache(dataID.of(serverUUID), jsonResponseSupplier);
|
||||||
}
|
}
|
||||||
|
@ -47,6 +47,19 @@ public abstract class TreePageHandler implements PageHandler {
|
|||||||
pages.put(targetPage, handler);
|
pages.put(targetPage, handler);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void registerPage(String targetPage, PageHandler handler, int requiredPerm) {
|
||||||
|
pages.put(targetPage, new PageHandler() {
|
||||||
|
@Override
|
||||||
|
public Response getResponse(Request request, RequestTarget target) throws WebException {
|
||||||
|
return handler.getResponse(request, target);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isAuthorized(Authentication auth, RequestTarget target) throws WebUserAuthException {
|
||||||
|
return auth.getWebUser().getPermLevel() <= requiredPerm;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
public void registerPage(String targetPage, Response response, int requiredPerm) {
|
public void registerPage(String targetPage, Response response, int requiredPerm) {
|
||||||
pages.put(targetPage, new PageHandler() {
|
pages.put(targetPage, new PageHandler() {
|
||||||
@Override
|
@Override
|
||||||
|
@ -20,6 +20,8 @@ import com.djrapitops.plan.delivery.rendering.json.graphs.GraphJSONParser;
|
|||||||
import com.djrapitops.plan.delivery.webserver.Request;
|
import com.djrapitops.plan.delivery.webserver.Request;
|
||||||
import com.djrapitops.plan.delivery.webserver.RequestTarget;
|
import com.djrapitops.plan.delivery.webserver.RequestTarget;
|
||||||
import com.djrapitops.plan.delivery.webserver.auth.Authentication;
|
import com.djrapitops.plan.delivery.webserver.auth.Authentication;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.cache.DataID;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.cache.JSONCache;
|
||||||
import com.djrapitops.plan.delivery.webserver.pages.PageHandler;
|
import com.djrapitops.plan.delivery.webserver.pages.PageHandler;
|
||||||
import com.djrapitops.plan.delivery.webserver.response.Response;
|
import com.djrapitops.plan.delivery.webserver.response.Response;
|
||||||
import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse;
|
import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse;
|
||||||
@ -30,6 +32,7 @@ import com.djrapitops.plan.identification.Identifiers;
|
|||||||
|
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
import javax.inject.Singleton;
|
import javax.inject.Singleton;
|
||||||
|
import java.util.Collections;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -42,14 +45,17 @@ public class GraphsJSONHandler implements PageHandler {
|
|||||||
|
|
||||||
private final Identifiers identifiers;
|
private final Identifiers identifiers;
|
||||||
private final GraphJSONParser graphJSON;
|
private final GraphJSONParser graphJSON;
|
||||||
|
private final JSONCache cache;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public GraphsJSONHandler(
|
public GraphsJSONHandler(
|
||||||
Identifiers identifiers,
|
Identifiers identifiers,
|
||||||
GraphJSONParser graphJSON
|
GraphJSONParser graphJSON,
|
||||||
|
JSONCache cache
|
||||||
) {
|
) {
|
||||||
this.identifiers = identifiers;
|
this.identifiers = identifiers;
|
||||||
this.graphJSON = graphJSON;
|
this.graphJSON = graphJSON;
|
||||||
|
this.cache = cache;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -57,51 +63,68 @@ public class GraphsJSONHandler implements PageHandler {
|
|||||||
String type = target.getParameter("type")
|
String type = target.getParameter("type")
|
||||||
.orElseThrow(() -> new BadRequestException("'type' parameter was not defined."));
|
.orElseThrow(() -> new BadRequestException("'type' parameter was not defined."));
|
||||||
|
|
||||||
|
DataID dataID = getDataID(type);
|
||||||
|
|
||||||
if (target.getParameter("server").isPresent()) {
|
if (target.getParameter("server").isPresent()) {
|
||||||
UUID serverUUID = identifiers.getServerUUID(target); // Can throw BadRequestException
|
UUID serverUUID = identifiers.getServerUUID(target); // Can throw BadRequestException
|
||||||
return generateGraphDataJSONOfType(type, serverUUID);
|
return cache.getOrCache(dataID, serverUUID, () -> generateGraphDataJSONOfType(dataID, serverUUID));
|
||||||
}
|
}
|
||||||
// Assume network
|
// Assume network
|
||||||
return generateGraphDataJSONOfType(type);
|
return cache.getOrCache(dataID, () -> generateGraphDataJSONOfType(dataID));
|
||||||
}
|
}
|
||||||
|
|
||||||
private JSONResponse generateGraphDataJSONOfType(String type, UUID serverUUID) throws BadRequestException {
|
private DataID getDataID(String type) throws BadRequestException {
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case "performance":
|
case "performance": return DataID.GRAPH_PERFORMANCE;
|
||||||
|
case "playersOnline": return DataID.GRAPH_ONLINE;
|
||||||
|
case "uniqueAndNew": return DataID.GRAPH_UNIQUE_NEW;
|
||||||
|
case "serverCalendar": return DataID.GRAPH_CALENDAR;
|
||||||
|
case "worldPie": return DataID.GRAPH_WORLD_PIE;
|
||||||
|
case "activity": return DataID.GRAPH_ACTIVITY;
|
||||||
|
case "geolocation": return DataID.GRAPH_WORLD_MAP;
|
||||||
|
case "aggregatedPing": return DataID.GRAPH_PING;
|
||||||
|
case "punchCard": return DataID.GRAPH_PUNCHCARD;
|
||||||
|
default: throw new BadRequestException("unknown 'type' parameter: " + type);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private JSONResponse generateGraphDataJSONOfType(DataID id, UUID serverUUID) {
|
||||||
|
switch (id) {
|
||||||
|
case GRAPH_PERFORMANCE:
|
||||||
return new JSONResponse(graphJSON.performanceGraphJSON(serverUUID));
|
return new JSONResponse(graphJSON.performanceGraphJSON(serverUUID));
|
||||||
case "playersOnline":
|
case GRAPH_ONLINE:
|
||||||
return new JSONResponse(graphJSON.playersOnlineGraph(serverUUID));
|
return new JSONResponse(graphJSON.playersOnlineGraph(serverUUID));
|
||||||
case "uniqueAndNew":
|
case GRAPH_UNIQUE_NEW:
|
||||||
return new JSONResponse(graphJSON.uniqueAndNewGraphJSON(serverUUID));
|
return new JSONResponse(graphJSON.uniqueAndNewGraphJSON(serverUUID));
|
||||||
case "serverCalendar":
|
case GRAPH_CALENDAR:
|
||||||
return new JSONResponse(graphJSON.serverCalendarJSON(serverUUID));
|
return new JSONResponse(graphJSON.serverCalendarJSON(serverUUID));
|
||||||
case "worldPie":
|
case GRAPH_WORLD_PIE:
|
||||||
return new JSONResponse(graphJSON.serverWorldPieJSONAsMap(serverUUID));
|
return new JSONResponse(graphJSON.serverWorldPieJSONAsMap(serverUUID));
|
||||||
case "activity":
|
case GRAPH_ACTIVITY:
|
||||||
return new JSONResponse(graphJSON.activityGraphsJSONAsMap(serverUUID));
|
return new JSONResponse(graphJSON.activityGraphsJSONAsMap(serverUUID));
|
||||||
case "geolocation":
|
case GRAPH_WORLD_MAP:
|
||||||
return new JSONResponse(graphJSON.geolocationGraphsJSONAsMap(serverUUID));
|
return new JSONResponse(graphJSON.geolocationGraphsJSONAsMap(serverUUID));
|
||||||
case "aggregatedPing":
|
case GRAPH_PING:
|
||||||
return new JSONResponse(graphJSON.pingGraphsJSON(serverUUID));
|
return new JSONResponse(graphJSON.pingGraphsJSON(serverUUID));
|
||||||
case "punchCard":
|
case GRAPH_PUNCHCARD:
|
||||||
return new JSONResponse(graphJSON.punchCardJSONAsMap(serverUUID));
|
return new JSONResponse(graphJSON.punchCardJSONAsMap(serverUUID));
|
||||||
default:
|
default:
|
||||||
throw new BadRequestException("unknown 'type' parameter: " + type);
|
return new JSONResponse(Collections.singletonMap("error", "Undefined ID: " + id.name()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private JSONResponse generateGraphDataJSONOfType(String type) throws BadRequestException {
|
private JSONResponse generateGraphDataJSONOfType(DataID id) {
|
||||||
switch (type) {
|
switch (id) {
|
||||||
case "activity":
|
case GRAPH_ACTIVITY:
|
||||||
return new JSONResponse(graphJSON.activityGraphsJSONAsMap());
|
return new JSONResponse(graphJSON.activityGraphsJSONAsMap());
|
||||||
case "uniqueAndNew":
|
case GRAPH_UNIQUE_NEW:
|
||||||
return new JSONResponse(graphJSON.uniqueAndNewGraphJSON());
|
return new JSONResponse(graphJSON.uniqueAndNewGraphJSON());
|
||||||
case "serverPie":
|
case GRAPH_SERVER_PIE:
|
||||||
return new JSONResponse(graphJSON.serverPreferencePieJSONAsMap());
|
return new JSONResponse(graphJSON.serverPreferencePieJSONAsMap());
|
||||||
case "geolocation":
|
case GRAPH_WORLD_MAP:
|
||||||
return new JSONResponse(graphJSON.geolocationGraphsJSONAsMap());
|
return new JSONResponse(graphJSON.geolocationGraphsJSONAsMap());
|
||||||
default:
|
default:
|
||||||
throw new BadRequestException("unknown 'type' parameter: " + type);
|
return new JSONResponse(Collections.singletonMap("error", "Undefined ID: " + id.name()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -23,6 +23,8 @@ import com.djrapitops.plan.delivery.rendering.json.network.NetworkSessionsOvervi
|
|||||||
import com.djrapitops.plan.delivery.rendering.json.network.NetworkTabJSONParser;
|
import com.djrapitops.plan.delivery.rendering.json.network.NetworkTabJSONParser;
|
||||||
import com.djrapitops.plan.delivery.webserver.RequestTarget;
|
import com.djrapitops.plan.delivery.webserver.RequestTarget;
|
||||||
import com.djrapitops.plan.delivery.webserver.auth.Authentication;
|
import com.djrapitops.plan.delivery.webserver.auth.Authentication;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.cache.DataID;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.cache.JSONCache;
|
||||||
import com.djrapitops.plan.delivery.webserver.pages.TreePageHandler;
|
import com.djrapitops.plan.delivery.webserver.pages.TreePageHandler;
|
||||||
import com.djrapitops.plan.delivery.webserver.response.ResponseFactory;
|
import com.djrapitops.plan.delivery.webserver.response.ResponseFactory;
|
||||||
import com.djrapitops.plan.exceptions.WebUserAuthException;
|
import com.djrapitops.plan.exceptions.WebUserAuthException;
|
||||||
@ -38,25 +40,29 @@ import javax.inject.Singleton;
|
|||||||
@Singleton
|
@Singleton
|
||||||
public class NetworkJSONHandler extends TreePageHandler {
|
public class NetworkJSONHandler extends TreePageHandler {
|
||||||
|
|
||||||
|
private final JSONCache cache;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public NetworkJSONHandler(
|
public NetworkJSONHandler(
|
||||||
ResponseFactory responseFactory,
|
ResponseFactory responseFactory,
|
||||||
JSONFactory jsonFactory,
|
JSONFactory jsonFactory,
|
||||||
|
JSONCache cache,
|
||||||
NetworkOverviewJSONParser networkOverviewJSONParser,
|
NetworkOverviewJSONParser networkOverviewJSONParser,
|
||||||
NetworkPlayerBaseOverviewJSONParser playerBaseOverviewJSONParser,
|
NetworkPlayerBaseOverviewJSONParser playerBaseOverviewJSONParser,
|
||||||
NetworkSessionsOverviewJSONParser sessionsOverviewJSONParser
|
NetworkSessionsOverviewJSONParser sessionsOverviewJSONParser
|
||||||
) {
|
) {
|
||||||
super(responseFactory);
|
super(responseFactory);
|
||||||
|
this.cache = cache;
|
||||||
|
|
||||||
registerPage("overview", networkOverviewJSONParser);
|
registerPage("overview", DataID.SERVER_OVERVIEW, networkOverviewJSONParser);
|
||||||
registerPage("playerbaseOverview", playerBaseOverviewJSONParser);
|
registerPage("playerbaseOverview", DataID.PLAYERBASE_OVERVIEW, playerBaseOverviewJSONParser);
|
||||||
registerPage("sessionsOverview", sessionsOverviewJSONParser);
|
registerPage("sessionsOverview", DataID.SESSIONS_OVERVIEW, sessionsOverviewJSONParser);
|
||||||
registerPage("servers", jsonFactory::serversAsJSONMaps);
|
registerPage("servers", DataID.SERVER_OVERVIEW, jsonFactory::serversAsJSONMaps);
|
||||||
registerPage("pingTable", jsonFactory::pingPerGeolocation);
|
registerPage("pingTable", DataID.PING_TABLE, jsonFactory::pingPerGeolocation);
|
||||||
}
|
}
|
||||||
|
|
||||||
private <T> void registerPage(String identifier, NetworkTabJSONParser<T> tabJSONParser) {
|
private <T> void registerPage(String identifier, DataID dataID, NetworkTabJSONParser<T> tabJSONParser) {
|
||||||
registerPage(identifier, new NetworkTabJSONHandler<>(tabJSONParser));
|
registerPage(identifier, new NetworkTabJSONHandler<>(dataID, cache, tabJSONParser));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -20,11 +20,12 @@ import com.djrapitops.plan.delivery.rendering.json.network.NetworkTabJSONParser;
|
|||||||
import com.djrapitops.plan.delivery.webserver.Request;
|
import com.djrapitops.plan.delivery.webserver.Request;
|
||||||
import com.djrapitops.plan.delivery.webserver.RequestTarget;
|
import com.djrapitops.plan.delivery.webserver.RequestTarget;
|
||||||
import com.djrapitops.plan.delivery.webserver.auth.Authentication;
|
import com.djrapitops.plan.delivery.webserver.auth.Authentication;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.cache.DataID;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.cache.JSONCache;
|
||||||
import com.djrapitops.plan.delivery.webserver.pages.PageHandler;
|
import com.djrapitops.plan.delivery.webserver.pages.PageHandler;
|
||||||
import com.djrapitops.plan.delivery.webserver.response.Response;
|
import com.djrapitops.plan.delivery.webserver.response.Response;
|
||||||
import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse;
|
import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse;
|
||||||
import com.djrapitops.plan.exceptions.WebUserAuthException;
|
import com.djrapitops.plan.exceptions.WebUserAuthException;
|
||||||
import com.djrapitops.plan.exceptions.connection.WebException;
|
|
||||||
|
|
||||||
import java.util.function.Supplier;
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
@ -35,15 +36,19 @@ import java.util.function.Supplier;
|
|||||||
*/
|
*/
|
||||||
public class NetworkTabJSONHandler<T> implements PageHandler {
|
public class NetworkTabJSONHandler<T> implements PageHandler {
|
||||||
|
|
||||||
|
private final DataID dataID;
|
||||||
|
private final JSONCache cache;
|
||||||
private final Supplier<T> jsonParser;
|
private final Supplier<T> jsonParser;
|
||||||
|
|
||||||
public NetworkTabJSONHandler(NetworkTabJSONParser<T> jsonParser) {
|
public NetworkTabJSONHandler(DataID dataID, JSONCache cache, NetworkTabJSONParser<T> jsonParser) {
|
||||||
|
this.dataID = dataID;
|
||||||
|
this.cache = cache;
|
||||||
this.jsonParser = jsonParser;
|
this.jsonParser = jsonParser;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Response getResponse(Request request, RequestTarget target) throws WebException {
|
public Response getResponse(Request request, RequestTarget target) {
|
||||||
return new JSONResponse(jsonParser.get());
|
return cache.getOrCache(dataID, () -> new JSONResponse(jsonParser.get()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -20,6 +20,8 @@ import com.djrapitops.plan.delivery.rendering.json.JSONFactory;
|
|||||||
import com.djrapitops.plan.delivery.webserver.Request;
|
import com.djrapitops.plan.delivery.webserver.Request;
|
||||||
import com.djrapitops.plan.delivery.webserver.RequestTarget;
|
import com.djrapitops.plan.delivery.webserver.RequestTarget;
|
||||||
import com.djrapitops.plan.delivery.webserver.auth.Authentication;
|
import com.djrapitops.plan.delivery.webserver.auth.Authentication;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.cache.DataID;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.cache.JSONCache;
|
||||||
import com.djrapitops.plan.delivery.webserver.pages.PageHandler;
|
import com.djrapitops.plan.delivery.webserver.pages.PageHandler;
|
||||||
import com.djrapitops.plan.delivery.webserver.response.Response;
|
import com.djrapitops.plan.delivery.webserver.response.Response;
|
||||||
import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse;
|
import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse;
|
||||||
@ -42,20 +44,25 @@ public class PlayerKillsJSONHandler implements PageHandler {
|
|||||||
|
|
||||||
private final Identifiers identifiers;
|
private final Identifiers identifiers;
|
||||||
private final JSONFactory jsonFactory;
|
private final JSONFactory jsonFactory;
|
||||||
|
private final JSONCache cache;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public PlayerKillsJSONHandler(
|
public PlayerKillsJSONHandler(
|
||||||
Identifiers identifiers,
|
Identifiers identifiers,
|
||||||
JSONFactory jsonFactory
|
JSONFactory jsonFactory,
|
||||||
|
JSONCache cache
|
||||||
) {
|
) {
|
||||||
this.identifiers = identifiers;
|
this.identifiers = identifiers;
|
||||||
this.jsonFactory = jsonFactory;
|
this.jsonFactory = jsonFactory;
|
||||||
|
this.cache = cache;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Response getResponse(Request request, RequestTarget target) throws WebException {
|
public Response getResponse(Request request, RequestTarget target) throws WebException {
|
||||||
UUID serverUUID = identifiers.getServerUUID(target);
|
UUID serverUUID = identifiers.getServerUUID(target);
|
||||||
return new JSONResponse(Collections.singletonMap("player_kills", jsonFactory.serverPlayerKillsAsJSONMap(serverUUID)));
|
return cache.getOrCache(DataID.KILLS, serverUUID, () ->
|
||||||
|
new JSONResponse(Collections.singletonMap("player_kills", jsonFactory.serverPlayerKillsAsJSONMap(serverUUID)))
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -21,6 +21,8 @@ import com.djrapitops.plan.delivery.rendering.json.PlayersTableJSONParser;
|
|||||||
import com.djrapitops.plan.delivery.webserver.Request;
|
import com.djrapitops.plan.delivery.webserver.Request;
|
||||||
import com.djrapitops.plan.delivery.webserver.RequestTarget;
|
import com.djrapitops.plan.delivery.webserver.RequestTarget;
|
||||||
import com.djrapitops.plan.delivery.webserver.auth.Authentication;
|
import com.djrapitops.plan.delivery.webserver.auth.Authentication;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.cache.DataID;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.cache.JSONCache;
|
||||||
import com.djrapitops.plan.delivery.webserver.pages.PageHandler;
|
import com.djrapitops.plan.delivery.webserver.pages.PageHandler;
|
||||||
import com.djrapitops.plan.delivery.webserver.response.Response;
|
import com.djrapitops.plan.delivery.webserver.response.Response;
|
||||||
import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse;
|
import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse;
|
||||||
@ -43,24 +45,27 @@ public class PlayersTableJSONHandler implements PageHandler {
|
|||||||
|
|
||||||
private final Identifiers identifiers;
|
private final Identifiers identifiers;
|
||||||
private final JSONFactory jsonFactory;
|
private final JSONFactory jsonFactory;
|
||||||
|
private final JSONCache cache;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public PlayersTableJSONHandler(
|
public PlayersTableJSONHandler(
|
||||||
Identifiers identifiers,
|
Identifiers identifiers,
|
||||||
JSONFactory jsonFactory
|
JSONFactory jsonFactory,
|
||||||
|
JSONCache cache
|
||||||
) {
|
) {
|
||||||
this.identifiers = identifiers;
|
this.identifiers = identifiers;
|
||||||
this.jsonFactory = jsonFactory;
|
this.jsonFactory = jsonFactory;
|
||||||
|
this.cache = cache;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Response getResponse(Request request, RequestTarget target) throws WebException {
|
public Response getResponse(Request request, RequestTarget target) throws WebException {
|
||||||
if (target.getParameter("server").isPresent()) {
|
if (target.getParameter("server").isPresent()) {
|
||||||
UUID serverUUID = identifiers.getServerUUID(target); // Can throw BadRequestException
|
UUID serverUUID = identifiers.getServerUUID(target); // Can throw BadRequestException
|
||||||
return new JSONResponse(jsonFactory.serverPlayersTableJSON(serverUUID));
|
return cache.getOrCache(DataID.PLAYERS, serverUUID, () -> new JSONResponse(jsonFactory.serverPlayersTableJSON(serverUUID)));
|
||||||
}
|
}
|
||||||
// Assume network
|
// Assume network
|
||||||
return new JSONResponse(jsonFactory.networkPlayersTableJSON());
|
return cache.getOrCache(DataID.PLAYERS, () -> new JSONResponse(jsonFactory.networkPlayersTableJSON()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -19,6 +19,8 @@ package com.djrapitops.plan.delivery.webserver.pages.json;
|
|||||||
import com.djrapitops.plan.delivery.rendering.json.*;
|
import com.djrapitops.plan.delivery.rendering.json.*;
|
||||||
import com.djrapitops.plan.delivery.webserver.RequestTarget;
|
import com.djrapitops.plan.delivery.webserver.RequestTarget;
|
||||||
import com.djrapitops.plan.delivery.webserver.auth.Authentication;
|
import com.djrapitops.plan.delivery.webserver.auth.Authentication;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.cache.DataID;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.cache.JSONCache;
|
||||||
import com.djrapitops.plan.delivery.webserver.pages.TreePageHandler;
|
import com.djrapitops.plan.delivery.webserver.pages.TreePageHandler;
|
||||||
import com.djrapitops.plan.delivery.webserver.response.ResponseFactory;
|
import com.djrapitops.plan.delivery.webserver.response.ResponseFactory;
|
||||||
import com.djrapitops.plan.exceptions.WebUserAuthException;
|
import com.djrapitops.plan.exceptions.WebUserAuthException;
|
||||||
@ -35,11 +37,13 @@ import javax.inject.Singleton;
|
|||||||
@Singleton
|
@Singleton
|
||||||
public class RootJSONHandler extends TreePageHandler {
|
public class RootJSONHandler extends TreePageHandler {
|
||||||
|
|
||||||
|
private final JSONCache cache;
|
||||||
private Identifiers identifiers;
|
private Identifiers identifiers;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public RootJSONHandler(
|
public RootJSONHandler(
|
||||||
ResponseFactory responseFactory,
|
ResponseFactory responseFactory,
|
||||||
|
JSONCache cache,
|
||||||
Identifiers identifiers,
|
Identifiers identifiers,
|
||||||
JSONFactory jsonFactory,
|
JSONFactory jsonFactory,
|
||||||
GraphsJSONHandler graphsJSONHandler,
|
GraphsJSONHandler graphsJSONHandler,
|
||||||
@ -56,29 +60,28 @@ public class RootJSONHandler extends TreePageHandler {
|
|||||||
NetworkJSONHandler networkJSONHandler
|
NetworkJSONHandler networkJSONHandler
|
||||||
) {
|
) {
|
||||||
super(responseFactory);
|
super(responseFactory);
|
||||||
|
this.cache = cache;
|
||||||
this.identifiers = identifiers;
|
this.identifiers = identifiers;
|
||||||
|
|
||||||
registerPage("players", playersTableJSONHandler);
|
registerPage("players", playersTableJSONHandler, 1);
|
||||||
registerPage("sessions", sessionsJSONHandler);
|
registerPage("sessions", sessionsJSONHandler, 0);
|
||||||
registerPage("kills", playerKillsJSONHandler);
|
registerPage("kills", playerKillsJSONHandler, 0);
|
||||||
registerPage("pingTable", jsonFactory::pingPerGeolocation);
|
registerPage("pingTable", DataID.PING_TABLE, jsonFactory::pingPerGeolocation);
|
||||||
registerPage("graph", graphsJSONHandler);
|
registerPage("graph", graphsJSONHandler, 0);
|
||||||
|
|
||||||
registerPage("serverOverview", serverOverviewJSONParser);
|
registerPage("serverOverview", DataID.SERVER_OVERVIEW, serverOverviewJSONParser);
|
||||||
registerPage("onlineOverview", onlineActivityOverviewJSONParser);
|
registerPage("onlineOverview", DataID.ONLINE_OVERVIEW, onlineActivityOverviewJSONParser);
|
||||||
registerPage("sessionsOverview", sessionsOverviewJSONParser);
|
registerPage("sessionsOverview", DataID.SESSIONS_OVERVIEW, sessionsOverviewJSONParser);
|
||||||
registerPage("playerVersus", pvPPvEJSONParser);
|
registerPage("playerVersus", DataID.PVP_PVE, pvPPvEJSONParser);
|
||||||
registerPage("playerbaseOverview", playerBaseOverviewJSONParser);
|
registerPage("playerbaseOverview", DataID.PLAYERBASE_OVERVIEW, playerBaseOverviewJSONParser);
|
||||||
registerPage("performanceOverview", performanceJSONParser);
|
registerPage("performanceOverview", DataID.PERFORMANCE_OVERVIEW, performanceJSONParser);
|
||||||
|
|
||||||
registerPage("player", playerJSONHandler);
|
registerPage("player", playerJSONHandler, 2);
|
||||||
registerPage("network", networkJSONHandler);
|
registerPage("network", networkJSONHandler, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
private <T> void registerPage(String identifier, ServerTabJSONParser<T> tabJSONParser) {
|
private <T> void registerPage(String identifier, DataID dataID, ServerTabJSONParser<T> tabJSONParser) {
|
||||||
registerPage(identifier, new ServerTabJSONHandler<>(identifiers, tabJSONParser));
|
registerPage(identifier, new ServerTabJSONHandler<>(dataID, cache, identifiers, tabJSONParser), 0);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -20,6 +20,8 @@ import com.djrapitops.plan.delivery.rendering.json.ServerTabJSONParser;
|
|||||||
import com.djrapitops.plan.delivery.webserver.Request;
|
import com.djrapitops.plan.delivery.webserver.Request;
|
||||||
import com.djrapitops.plan.delivery.webserver.RequestTarget;
|
import com.djrapitops.plan.delivery.webserver.RequestTarget;
|
||||||
import com.djrapitops.plan.delivery.webserver.auth.Authentication;
|
import com.djrapitops.plan.delivery.webserver.auth.Authentication;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.cache.DataID;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.cache.JSONCache;
|
||||||
import com.djrapitops.plan.delivery.webserver.pages.PageHandler;
|
import com.djrapitops.plan.delivery.webserver.pages.PageHandler;
|
||||||
import com.djrapitops.plan.delivery.webserver.response.Response;
|
import com.djrapitops.plan.delivery.webserver.response.Response;
|
||||||
import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse;
|
import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse;
|
||||||
@ -37,10 +39,19 @@ import java.util.function.Function;
|
|||||||
*/
|
*/
|
||||||
public class ServerTabJSONHandler<T> implements PageHandler {
|
public class ServerTabJSONHandler<T> implements PageHandler {
|
||||||
|
|
||||||
|
private final DataID dataID;
|
||||||
|
private final JSONCache cache;
|
||||||
private final Identifiers identifiers;
|
private final Identifiers identifiers;
|
||||||
private final Function<UUID, T> jsonParser;
|
private final Function<UUID, T> jsonParser;
|
||||||
|
|
||||||
public ServerTabJSONHandler(Identifiers identifiers, ServerTabJSONParser<T> jsonParser) {
|
public ServerTabJSONHandler(
|
||||||
|
DataID dataID,
|
||||||
|
JSONCache cache,
|
||||||
|
Identifiers identifiers,
|
||||||
|
ServerTabJSONParser<T> jsonParser
|
||||||
|
) {
|
||||||
|
this.dataID = dataID;
|
||||||
|
this.cache = cache;
|
||||||
this.identifiers = identifiers;
|
this.identifiers = identifiers;
|
||||||
this.jsonParser = jsonParser;
|
this.jsonParser = jsonParser;
|
||||||
}
|
}
|
||||||
@ -48,7 +59,7 @@ public class ServerTabJSONHandler<T> implements PageHandler {
|
|||||||
@Override
|
@Override
|
||||||
public Response getResponse(Request request, RequestTarget target) throws WebException {
|
public Response getResponse(Request request, RequestTarget target) throws WebException {
|
||||||
UUID serverUUID = identifiers.getServerUUID(target); // Can throw BadRequestException
|
UUID serverUUID = identifiers.getServerUUID(target); // Can throw BadRequestException
|
||||||
return new JSONResponse(jsonParser.apply(serverUUID));
|
return cache.getOrCache(dataID, serverUUID, () -> new JSONResponse(jsonParser.apply(serverUUID)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -20,6 +20,8 @@ import com.djrapitops.plan.delivery.rendering.json.JSONFactory;
|
|||||||
import com.djrapitops.plan.delivery.webserver.Request;
|
import com.djrapitops.plan.delivery.webserver.Request;
|
||||||
import com.djrapitops.plan.delivery.webserver.RequestTarget;
|
import com.djrapitops.plan.delivery.webserver.RequestTarget;
|
||||||
import com.djrapitops.plan.delivery.webserver.auth.Authentication;
|
import com.djrapitops.plan.delivery.webserver.auth.Authentication;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.cache.DataID;
|
||||||
|
import com.djrapitops.plan.delivery.webserver.cache.JSONCache;
|
||||||
import com.djrapitops.plan.delivery.webserver.pages.PageHandler;
|
import com.djrapitops.plan.delivery.webserver.pages.PageHandler;
|
||||||
import com.djrapitops.plan.delivery.webserver.response.Response;
|
import com.djrapitops.plan.delivery.webserver.response.Response;
|
||||||
import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse;
|
import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse;
|
||||||
@ -42,24 +44,31 @@ public class SessionsJSONHandler implements PageHandler {
|
|||||||
|
|
||||||
private final Identifiers identifiers;
|
private final Identifiers identifiers;
|
||||||
private final JSONFactory jsonFactory;
|
private final JSONFactory jsonFactory;
|
||||||
|
private final JSONCache cache;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public SessionsJSONHandler(
|
public SessionsJSONHandler(
|
||||||
Identifiers identifiers,
|
Identifiers identifiers,
|
||||||
JSONFactory jsonFactory
|
JSONFactory jsonFactory,
|
||||||
|
JSONCache cache
|
||||||
) {
|
) {
|
||||||
this.identifiers = identifiers;
|
this.identifiers = identifiers;
|
||||||
this.jsonFactory = jsonFactory;
|
this.jsonFactory = jsonFactory;
|
||||||
|
this.cache = cache;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Response getResponse(Request request, RequestTarget target) throws WebException {
|
public Response getResponse(Request request, RequestTarget target) throws WebException {
|
||||||
if (target.getParameter("server").isPresent()) {
|
if (target.getParameter("server").isPresent()) {
|
||||||
UUID serverUUID = identifiers.getServerUUID(target);
|
UUID serverUUID = identifiers.getServerUUID(target);
|
||||||
return new JSONResponse(Collections.singletonMap("sessions", jsonFactory.networkSessionsAsJSONMap(serverUUID)));
|
return cache.getOrCache(DataID.SESSIONS, serverUUID, () ->
|
||||||
|
new JSONResponse(Collections.singletonMap("sessions", jsonFactory.serverSessionsAsJSONMap(serverUUID)))
|
||||||
|
);
|
||||||
}
|
}
|
||||||
// Assume network
|
// Assume network
|
||||||
return new JSONResponse(Collections.singletonMap("sessions", jsonFactory.networkSessionsAsJSONMap()));
|
return cache.getOrCache(DataID.SESSIONS, () ->
|
||||||
|
new JSONResponse(Collections.singletonMap("sessions", jsonFactory.networkSessionsAsJSONMap()))
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
Loading…
Reference in New Issue
Block a user