From 2736ba042affaa54d99cfe550a2524333e324e47 Mon Sep 17 00:00:00 2001 From: Rsl1122 <24460436+Rsl1122@users.noreply.github.com> Date: Wed, 12 Feb 2020 23:53:02 +0200 Subject: [PATCH] Refactored /debug page to use ResolverService Some issues that were identified: - Going to /debug/ makes the style requests return the debug page content because the /debug resolver is used - In the future when / is to be resolved it might override a bunch of requests. - Use of RequestTarget as incompatible with URIPath for some reason which lead to infinite redirect, so the attempted change was reverted before this commit. - Some Responses are using PlanFiles to obtain a html file (SRP violation) Rest of the pages still use the old resolution that is now deprecated. --- .../web/resolver/CompositeResolver.java | 14 +-- .../plan/delivery/web/resolver/Resolver.java | 24 +++-- .../plan/delivery/web/resolver/Response.java | 8 ++ .../resolver/{URLTarget.java => URIPath.java} | 72 ++++++++------- .../{Parameters.java => URIQuery.java} | 31 ++++++- .../plan/settings/SettingsService.java | 8 +- .../{URLTargetTest.java => URIPathTest.java} | 38 ++++---- .../java/com/djrapitops/plan/PlanSystem.java | 13 ++- .../commands/subcommands/RegisterCommand.java | 8 +- .../subcommands/webuser/WebCheckCommand.java | 6 +- .../subcommands/webuser/WebDeleteCommand.java | 4 +- .../webuser/WebListUsersCommand.java | 6 +- .../domain/{WebUser.java => WebUser_old.java} | 29 +++++- .../plan/delivery/export/Exporter.java | 7 +- .../delivery/export/NetworkPageExporter.java | 11 +-- .../delivery/export/PlayerPageExporter.java | 11 +-- .../delivery/export/PlayersPageExporter.java | 11 +-- .../delivery/export/ServerPageExporter.java | 11 +-- .../delivery/rendering/pages/DebugPage.java | 18 ++++ .../rendering/pages/InternalErrorPage.java | 91 ++++++++++++++++++ .../delivery/rendering/pages/NetworkPage.java | 65 ++++++------- .../plan/delivery/rendering/pages/Page.java | 5 +- .../delivery/rendering/pages/PageFactory.java | 68 +++++++++----- .../delivery/rendering/pages/PlayerPage.java | 21 ++--- .../delivery/rendering/pages/PlayersPage.java | 34 +++---- .../delivery/rendering/pages/ServerPage.java | 18 +--- .../plan/delivery/web/ResolverSvc.java | 92 +++++++++++++++++++ .../plan/delivery/webserver/Request.java | 15 ++- .../delivery/webserver/RequestHandler.java | 12 +-- .../delivery/webserver/RequestTarget.java | 1 + .../delivery/webserver/ResponseResolver.java | 58 ++++++++++-- .../webserver/auth/Authentication.java | 4 +- .../webserver/auth/BasicAuthentication.java | 6 +- .../delivery/webserver/cache/JSONCache.java | 8 +- .../pages/CompositePageResolver.java | 17 +++- .../webserver/pages/DebugPageResolver.java | 24 +++-- .../webserver/pages/PageResolver.java | 5 +- .../webserver/pages/PlayerPageResolver.java | 8 +- .../webserver/pages/PlayersPageResolver.java | 4 +- .../webserver/pages/RootPageResolver.java | 8 +- .../webserver/pages/ServerPageResolver.java | 4 +- .../pages/json/GraphsJSONResolver.java | 4 +- .../pages/json/NetworkTabJSONResolver.java | 4 +- .../pages/json/PlayerJSONResolver.java | 8 +- .../pages/json/PlayerKillsJSONResolver.java | 4 +- .../pages/json/PlayersTableJSONResolver.java | 4 +- .../pages/json/ServerTabJSONResolver.java | 4 +- .../pages/json/SessionsJSONResolver.java | 4 +- .../webserver/response/ByteResponse.java | 4 +- .../webserver/response/FileResponse.java | 2 +- .../webserver/response/OptionsResponse.java | 2 +- .../webserver/response/RedirectResponse.java | 2 +- .../webserver/response/ResponseFactory.java | 56 +++++++---- .../{Response.java => Response_old.java} | 34 +++++-- .../webserver/response/TextResponse.java | 2 +- .../webserver/response/data/JSONResponse.java | 4 +- .../response/errors/BadRequestResponse.java | 4 +- .../response/pages/PageResponse.java | 7 +- .../response/pages/PlayersPageResponse.java | 3 +- .../plan/exceptions/GenerationException.java | 29 ------ .../plan/extension/ExtensionSvc.java | 6 +- .../djrapitops/plan/settings/SettingsSvc.java | 2 +- .../database/queries/LargeStoreQueries.java | 6 +- .../database/queries/objects/PingQueries.java | 4 +- .../queries/objects/WebUserQueries.java | 22 ++--- .../commands/RegisterWebUserTransaction.java | 8 +- .../commands/RemoveWebUserTransaction.java | 4 +- .../comparators/WebUserComparator.java | 6 +- .../webserver/JksHttpsServerTest.java | 4 +- .../webserver/Pkcs12HttpsServerTest.java | 4 +- .../plan/storage/database/DatabaseTest.java | 8 +- .../utilities/comparators/ComparatorTest.java | 8 +- .../src/test/java/utilities/RandomData.java | 8 +- 73 files changed, 761 insertions(+), 408 deletions(-) rename Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/{URLTarget.java => URIPath.java} (63%) rename Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/{Parameters.java => URIQuery.java} (59%) rename Plan/api/src/test/java/com/djrapitops/plan/delivery/web/resolver/{URLTargetTest.java => URIPathTest.java} (78%) rename Plan/common/src/main/java/com/djrapitops/plan/delivery/domain/{WebUser.java => WebUser_old.java} (65%) create mode 100644 Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/InternalErrorPage.java create mode 100644 Plan/common/src/main/java/com/djrapitops/plan/delivery/web/ResolverSvc.java rename Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/{Response.java => Response_old.java} (83%) delete mode 100644 Plan/common/src/main/java/com/djrapitops/plan/exceptions/GenerationException.java diff --git a/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/CompositeResolver.java b/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/CompositeResolver.java index 1c82c69ed..30ab13680 100644 --- a/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/CompositeResolver.java +++ b/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/CompositeResolver.java @@ -23,7 +23,7 @@ import java.util.Optional; /** * Utility Resolver for organizing resolution in a tree-like structure. *

- * CompositeResolver removes first part of the target with {@link URLTarget#omitFirst()} + * CompositeResolver removes first part of the target with {@link URIPath#omitFirst()} * before calling the child Resolvers. * * @author Rsl1122 @@ -42,7 +42,7 @@ public final class CompositeResolver implements Resolver { return new Builder(); } - private Optional getResolver(URLTarget target) { + private Optional getResolver(URIPath target) { return target.getPart(0).flatMap(this::find); } @@ -63,16 +63,16 @@ public final class CompositeResolver implements Resolver { } @Override - public boolean canAccess(WebUser permissions, URLTarget target, Parameters parameters) { + public boolean canAccess(WebUser permissions, URIPath target, URIQuery query) { return getResolver(target) - .map(resolver -> resolver.canAccess(permissions, target.omitFirst(), parameters)) + .map(resolver -> resolver.canAccess(permissions, target.omitFirst(), query)) .orElse(true); } @Override - public Optional resolve(URLTarget target, Parameters parameters) { + public Optional resolve(URIPath target, URIQuery query) { return getResolver(target) - .flatMap(resolver -> resolver.resolve(target.omitFirst(), parameters)); + .flatMap(resolver -> resolver.resolve(target.omitFirst(), query)); } public static class Builder { @@ -86,7 +86,7 @@ public final class CompositeResolver implements Resolver { * Add a new resolver to the CompositeResolver. * * @param prefix Start of the target (first part of the target string, eg "example" in "/example/target/", or "" in "/") - * @param resolver Resolver to call for this target, {@link URLTarget#omitFirst()} will be called for Resolver method calls. + * @param resolver Resolver to call for this target, {@link URIPath#omitFirst()} will be called for Resolver method calls. * @return this builder. */ public Builder add(String prefix, Resolver resolver) { diff --git a/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/Resolver.java b/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/Resolver.java index 5d452979f..3d31763c6 100644 --- a/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/Resolver.java +++ b/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/Resolver.java @@ -27,23 +27,35 @@ public interface Resolver { * * @param permissions WebUser that is accessing this page. * @param target Target that is being accessed, /example/target - * @param parameters Parameters in the URL, ?param=value etc. + * @param query Parameters in the URL, ?param=value etc. * @return true if allowed or invalid target, false if response should be 403 (forbidden) */ - boolean canAccess(WebUser permissions, URLTarget target, Parameters parameters); + boolean canAccess(WebUser permissions, URIPath target, URIQuery query); /** * Implement request resolution. * - * @param target Target that is being accessed, /example/target - * @param parameters Parameters in the URL, ?param=value etc. + * @param target Target that is being accessed, /example/target + * @param query Parameters in the URL, ?param=value etc. * @return Response or empty if the response should be 404 (not found). * @see Response for return value */ - Optional resolve(URLTarget target, Parameters parameters); + Optional resolve(URIPath target, URIQuery query); default ResponseBuilder newResponseBuilder() { - return new ResponseBuilder(); + return Response.builder(); } + /** + * Override this method with false to always allow using this resolver. + *

+ * Use this when content/style is needed for displaying pages where authentication is not available/needed. + * + * @param target Target that is being accessed, /example/target + * @param query Parameters in the URL, ?param=value etc. + * @return true by default. If false is returned {@link #canAccess(WebUser, URIPath, URIQuery)} will not be called. + */ + default boolean requiresAuth(URIPath target, URIQuery query) { + return true; + } } diff --git a/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/Response.java b/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/Response.java index d81e3f9c3..2ea1e169b 100644 --- a/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/Response.java +++ b/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/Response.java @@ -38,6 +38,10 @@ public final class Response { headers = new HashMap<>(); } + public static ResponseBuilder builder() { + return new ResponseBuilder(); + } + public byte[] getBytes() { return bytes; } @@ -54,4 +58,8 @@ public final class Response { return Optional.ofNullable(charset); } + public boolean isErrorResponse() { + return code >= 400; + } + } diff --git a/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/URLTarget.java b/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/URIPath.java similarity index 63% rename from Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/URLTarget.java rename to Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/URIPath.java index 295685ab3..ce15c1e5d 100644 --- a/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/URLTarget.java +++ b/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/URIPath.java @@ -18,29 +18,20 @@ package com.djrapitops.plan.delivery.web.resolver; import java.util.Optional; -public final class URLTarget { +public final class URIPath { - private final String full; + private final String path; - public URLTarget(String target) { - full = target; - } - - /** - * Obtain the full target. - * - * @return Example: "/target/path/in/url" - */ - public String asString() { - return full; + public URIPath(String path) { + this.path = path; } /** * Removes parts of the URL before an index. *

- * Example: /example/target, 0 returns /example/target - * Example: /example/target, 1 returns /target - * Example: /example/target, 2 returns '' + * Example: /example/path, 0 returns /example/path + * Example: /example/path, 1 returns /path + * Example: /example/path, 2 returns '' * Example: /, 0 returns / * Example: /, 1 returns '' * @@ -67,26 +58,35 @@ public final class URLTarget { } /** - * Obtain part of the target by index of slashes in the URL. + * Obtain the full path. + * + * @return Example: "/target/path/in/url" + */ + public String asString() { + return path; + } + + /** + * Obtain part of the path by index of slashes in the URL. *

- * Example: "/example/target", 0 returns "example" - * Example: "/example/target", 1 returns "target" - * Example: "/example/target", 2 returns empty optional - * Example: "/example/target/", 2 returns "" + * Example: "/example/path", 0 returns "example" + * Example: "/example/path", 1 returns "path" + * Example: "/example/path", 2 returns empty optional + * Example: "/example/path/", 2 returns "" * Example: "/", 0 returns "" * Example: "/", 1 returns empty optional * * @param index Index from root, eg. /0/1/2/3 etc - * @return part after a '/' in the target, + * @return part after a '/' in the path, */ public Optional getPart(int index) { - String leftover = removePartsBefore(full, index); + String leftover = removePartsBefore(path, index); if (leftover.isEmpty()) return Optional.empty(); // Remove the leading slash to find ending slash leftover = leftover.substring(1); - // Remove rest of the target (Ends in the next slash) + // Remove rest of the path (Ends in the next slash) int nextSlash = leftover.indexOf('/'); if (nextSlash == -1) { return Optional.of(leftover); @@ -96,19 +96,27 @@ public final class URLTarget { } public boolean endsWith(String suffix) { - return full.endsWith(suffix); + return path.endsWith(suffix); } /** - * Immutable modification, removes first part of the target string. + * Immutable modification, removes first part of the path string. *

- * Example: URLTarget "/example/target" return value of omitFirst URLTarget is "/target" - * Example: URLTarget "/example" return value of omitFirst URLTarget is "/" - * Example: URLTarget "/" return value of omitFirst URLTarget is "" + * Example: URIPath "/example/path" return value of omitFirst URIPath is "/path" + * Example: URIPath "/example" return value of omitFirst URIPath is "/" + * Example: URIPath "/" return value of omitFirst URIPath is "" * - * @return new URLTarget with first part removed. + * @return new URIPath with first part removed. */ - public URLTarget omitFirst() { - return new URLTarget(removePartsBefore(full, 1)); + public URIPath omitFirst() { + return new URIPath(removePartsBefore(path, 1)); + } + + public int length() { + int count = 0; + for (char c : path.toCharArray()) { + if (c == '/') count++; + } + return count; } } diff --git a/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/Parameters.java b/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/URIQuery.java similarity index 59% rename from Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/Parameters.java rename to Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/URIQuery.java index 759ada8ee..0039f2230 100644 --- a/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/Parameters.java +++ b/Plan/api/src/main/java/com/djrapitops/plan/delivery/web/resolver/URIQuery.java @@ -16,6 +16,10 @@ */ package com.djrapitops.plan.delivery.web.resolver; +import org.apache.commons.lang3.StringUtils; + +import java.util.Collections; +import java.util.HashMap; import java.util.Map; import java.util.Optional; @@ -24,14 +28,37 @@ import java.util.Optional; * * @author Rsl1122 */ -public final class Parameters { +public final class URIQuery { private final Map byKey; - public Parameters(Map byKey) { + public URIQuery(Map byKey) { this.byKey = byKey; } + public URIQuery(String fromURI) { + this.byKey = parseParameters(fromURI); + } + + private Map parseParameters(String fromURI) { + if (fromURI == null || fromURI.isEmpty()) { + return Collections.emptyMap(); + } + + Map parameters = new HashMap<>(); + String[] keysAndValues = StringUtils.split(fromURI, '&'); + for (String kv : keysAndValues) { + if (kv.isEmpty()) { + continue; + } + String[] keyAndValue = StringUtils.split(kv, "=", 2); + if (keyAndValue.length >= 2) { + parameters.put(keyAndValue[0], keyAndValue[1]); + } + } + return parameters; + } + /** * Obtain an URI parameter by key. * diff --git a/Plan/api/src/main/java/com/djrapitops/plan/settings/SettingsService.java b/Plan/api/src/main/java/com/djrapitops/plan/settings/SettingsService.java index 136ed9729..911f8453e 100644 --- a/Plan/api/src/main/java/com/djrapitops/plan/settings/SettingsService.java +++ b/Plan/api/src/main/java/com/djrapitops/plan/settings/SettingsService.java @@ -33,7 +33,7 @@ import java.util.function.Supplier; public interface SettingsService { static SettingsService getInstance() { - return Optional.ofNullable(SettingsServiceHolder.service) + return Optional.ofNullable(Holder.service) .orElseThrow(() -> new IllegalStateException("SettingsService has not been initialised yet.")); } @@ -64,15 +64,15 @@ public interface SettingsService { */ List getStringList(String path, Supplier> defaultValue); - class SettingsServiceHolder { + class Holder { static SettingsService service; - private SettingsServiceHolder() { + private Holder() { /* Static variable holder */ } static void set(SettingsService service) { - SettingsServiceHolder.service = service; + Holder.service = service; } } diff --git a/Plan/api/src/test/java/com/djrapitops/plan/delivery/web/resolver/URLTargetTest.java b/Plan/api/src/test/java/com/djrapitops/plan/delivery/web/resolver/URIPathTest.java similarity index 78% rename from Plan/api/src/test/java/com/djrapitops/plan/delivery/web/resolver/URLTargetTest.java rename to Plan/api/src/test/java/com/djrapitops/plan/delivery/web/resolver/URIPathTest.java index 923aea001..9076bb82e 100644 --- a/Plan/api/src/test/java/com/djrapitops/plan/delivery/web/resolver/URLTargetTest.java +++ b/Plan/api/src/test/java/com/djrapitops/plan/delivery/web/resolver/URIPathTest.java @@ -25,16 +25,16 @@ import java.util.Optional; import static org.junit.jupiter.api.Assertions.assertEquals; /** - * Tests for {@link URLTarget} behavior. + * Tests for {@link URIPath} behavior. * * @author Rsl1122 */ @RunWith(JUnitPlatform.class) -class URLTargetTest { +class URIPathTest { @Test void firstPartEmptyForRoot() { - URLTarget target = new URLTarget("/"); + URIPath target = new URIPath("/"); Optional expected = Optional.of(""); Optional result = target.getPart(0); assertEquals(expected, result); @@ -42,7 +42,7 @@ class URLTargetTest { @Test void fullTargetForRoot() { - URLTarget target = new URLTarget("/"); + URIPath target = new URIPath("/"); String expected = "/"; String result = target.asString(); assertEquals(expected, result); @@ -50,7 +50,7 @@ class URLTargetTest { @Test void firstPart() { - URLTarget target = new URLTarget("/example/target"); + URIPath target = new URIPath("/example/target"); Optional expected = Optional.of("example"); Optional result = target.getPart(0); assertEquals(expected, result); @@ -58,7 +58,7 @@ class URLTargetTest { @Test void fullTarget() { - URLTarget target = new URLTarget("/example/target"); + URIPath target = new URIPath("/example/target"); String expected = "/example/target"; String result = target.asString(); assertEquals(expected, result); @@ -66,7 +66,7 @@ class URLTargetTest { @Test void secondPart() { - URLTarget target = new URLTarget("/example/target"); + URIPath target = new URIPath("/example/target"); Optional expected = Optional.of("target"); Optional result = target.getPart(1); assertEquals(expected, result); @@ -74,7 +74,7 @@ class URLTargetTest { @Test void noPart() { - URLTarget target = new URLTarget("/example/target"); + URIPath target = new URIPath("/example/target"); Optional expected = Optional.empty(); Optional result = target.getPart(2); assertEquals(expected, result); @@ -82,7 +82,7 @@ class URLTargetTest { @Test void emptyLastPart() { - URLTarget target = new URLTarget("/example/target/"); + URIPath target = new URIPath("/example/target/"); Optional expected = Optional.of(""); Optional result = target.getPart(2); assertEquals(expected, result); @@ -90,7 +90,7 @@ class URLTargetTest { @Test void omitRoot() { - URLTarget target = new URLTarget("/").omitFirst(); + URIPath target = new URIPath("/").omitFirst(); String expected = ""; String result = target.asString(); assertEquals(expected, result); @@ -98,7 +98,7 @@ class URLTargetTest { @Test void omitRootPart() { - URLTarget target = new URLTarget("/").omitFirst(); + URIPath target = new URIPath("/").omitFirst(); Optional expected = Optional.empty(); Optional result = target.getPart(0); assertEquals(expected, result); @@ -106,7 +106,7 @@ class URLTargetTest { @Test void omitFirstPart() { - URLTarget target = new URLTarget("/example/target").omitFirst(); + URIPath target = new URIPath("/example/target").omitFirst(); Optional expected = Optional.of("target"); Optional result = target.getPart(0); assertEquals(expected, result); @@ -114,7 +114,7 @@ class URLTargetTest { @Test void omitFirstFullTarget() { - URLTarget target = new URLTarget("/example/target").omitFirst(); + URIPath target = new URIPath("/example/target").omitFirst(); String expected = "/target"; String result = target.asString(); assertEquals(expected, result); @@ -124,7 +124,7 @@ class URLTargetTest { void partsAreRemoved() { String test = "/example/target"; String expected = "/target"; - String result = URLTarget.removePartsBefore(test, 1); + String result = URIPath.removePartsBefore(test, 1); assertEquals(expected, result); } @@ -132,7 +132,7 @@ class URLTargetTest { void partsAreRemoved2() { String test = "/example/target/"; String expected = "/"; - String result = URLTarget.removePartsBefore(test, 2); + String result = URIPath.removePartsBefore(test, 2); assertEquals(expected, result); } @@ -140,7 +140,7 @@ class URLTargetTest { void partsAreRemoved3() { String test = "/example/target"; String expected = ""; - String result = URLTarget.removePartsBefore(test, 2); + String result = URIPath.removePartsBefore(test, 2); assertEquals(expected, result); } @@ -148,7 +148,7 @@ class URLTargetTest { void partsAreRemoved4() { String test = "/example/target"; String expected = "/example/target"; - String result = URLTarget.removePartsBefore(test, 0); + String result = URIPath.removePartsBefore(test, 0); assertEquals(expected, result); } @@ -156,7 +156,7 @@ class URLTargetTest { void partsAreRemoved5() { String test = "/example/target/"; String expected = "/"; - String result = URLTarget.removePartsBefore(test, 2); + String result = URIPath.removePartsBefore(test, 2); assertEquals(expected, result); } @@ -164,7 +164,7 @@ class URLTargetTest { void noPartsToRemove() { String test = ""; String expected = ""; - String result = URLTarget.removePartsBefore(test, 1); + String result = URIPath.removePartsBefore(test, 1); assertEquals(expected, result); } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/PlanSystem.java b/Plan/common/src/main/java/com/djrapitops/plan/PlanSystem.java index 074e2ba64..a68990d9b 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/PlanSystem.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/PlanSystem.java @@ -20,6 +20,7 @@ import com.djrapitops.plan.api.PlanAPI; import com.djrapitops.plan.capability.CapabilitySvc; import com.djrapitops.plan.delivery.DeliveryUtilities; import com.djrapitops.plan.delivery.export.ExportSystem; +import com.djrapitops.plan.delivery.web.ResolverSvc; import com.djrapitops.plan.delivery.webserver.NonProxyWebserverDisableChecker; import com.djrapitops.plan.delivery.webserver.WebServer; import com.djrapitops.plan.delivery.webserver.WebServerSystem; @@ -77,6 +78,7 @@ public class PlanSystem implements SubSystem { private final ImportSystem importSystem; private final ExportSystem exportSystem; private final DeliveryUtilities deliveryUtilities; + private final ResolverSvc resolverService; private final ExtensionSvc extensionService; private final QuerySvc queryService; private final SettingsSvc settingsService; @@ -100,6 +102,7 @@ public class PlanSystem implements SubSystem { ImportSystem importSystem, ExportSystem exportSystem, DeliveryUtilities deliveryUtilities, + ResolverSvc resolverService, ExtensionSvc extensionService, QuerySvc queryService, SettingsSvc settingsService, @@ -122,6 +125,7 @@ public class PlanSystem implements SubSystem { this.importSystem = importSystem; this.exportSystem = exportSystem; this.deliveryUtilities = deliveryUtilities; + this.resolverService = resolverService; this.extensionService = extensionService; this.queryService = queryService; this.settingsService = settingsService; @@ -153,6 +157,11 @@ public class PlanSystem implements SubSystem { public void enable() throws EnableException { CapabilitySvc.initialize(); + extensionService.register(); + resolverService.register(); + settingsService.register(); + queryService.register(); + enableSystems( files, configSystem, @@ -176,9 +185,7 @@ public class PlanSystem implements SubSystem { )); } - settingsService.register(); - queryService.register(); - extensionService.register(); + extensionService.registerExtensions(); enabled = true; } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/commands/subcommands/RegisterCommand.java b/Plan/common/src/main/java/com/djrapitops/plan/commands/subcommands/RegisterCommand.java index efdb6c735..0cca45414 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/commands/subcommands/RegisterCommand.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/commands/subcommands/RegisterCommand.java @@ -17,7 +17,7 @@ package com.djrapitops.plan.commands.subcommands; import com.djrapitops.plan.PlanSystem; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.delivery.webserver.WebServer; import com.djrapitops.plan.exceptions.database.DBOpException; import com.djrapitops.plan.processing.Processing; @@ -129,7 +129,7 @@ public class RegisterCommand extends CommandNode { Verify.isTrue(userName.length() <= 100, () -> new IllegalArgumentException("Username can only be 100 characters long.")); int permLevel = Integer.parseInt(args[2]); String passHash = PassEncryptUtil.createHash(args[0]); - registerUser(new WebUser(userName, passHash, permLevel), sender); + registerUser(new WebUser_old(userName, passHash, permLevel), sender); } private void playerRegister(String[] args, Sender sender) throws PassEncryptUtil.CannotPerformOperationException { @@ -138,7 +138,7 @@ public class RegisterCommand extends CommandNode { String user = sender.getName(); String pass = PassEncryptUtil.createHash(args[0]); int permLvl = getPermissionLevel(sender); - registerUser(new WebUser(user, pass, permLvl), sender); + registerUser(new WebUser_old(user, pass, permLvl), sender); } else if (sender.hasPermission(Permissions.MANAGE_WEB.getPermission())) { consoleRegister(args, sender, notEnoughArgsMsg); } else { @@ -162,7 +162,7 @@ public class RegisterCommand extends CommandNode { return 100; } - private void registerUser(WebUser webUser, Sender sender) { + private void registerUser(WebUser_old webUser, Sender sender) { processing.submitCritical(() -> { String userName = webUser.getName(); try { diff --git a/Plan/common/src/main/java/com/djrapitops/plan/commands/subcommands/webuser/WebCheckCommand.java b/Plan/common/src/main/java/com/djrapitops/plan/commands/subcommands/webuser/WebCheckCommand.java index 05144209e..439457589 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/commands/subcommands/webuser/WebCheckCommand.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/commands/subcommands/webuser/WebCheckCommand.java @@ -16,7 +16,7 @@ */ package com.djrapitops.plan.commands.subcommands.webuser; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.processing.Processing; import com.djrapitops.plan.settings.Permissions; import com.djrapitops.plan.settings.locale.Locale; @@ -85,12 +85,12 @@ public class WebCheckCommand extends CommandNode { processing.submitNonCritical(() -> { try { Database db = dbSystem.getDatabase(); - Optional found = db.query(WebUserQueries.fetchWebUser(user)); + Optional found = db.query(WebUserQueries.fetchWebUser(user)); if (!found.isPresent()) { sender.sendMessage(locale.getString(CommandLang.FAIL_WEB_USER_NOT_EXISTS)); return; } - WebUser info = found.get(); + WebUser_old info = found.get(); sender.sendMessage(locale.getString(CommandLang.WEB_USER_LIST, info.getName(), info.getPermLevel())); } catch (Exception e) { errorHandler.log(L.ERROR, this.getClass(), e); diff --git a/Plan/common/src/main/java/com/djrapitops/plan/commands/subcommands/webuser/WebDeleteCommand.java b/Plan/common/src/main/java/com/djrapitops/plan/commands/subcommands/webuser/WebDeleteCommand.java index 4c05fe30b..b611a6c69 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/commands/subcommands/webuser/WebDeleteCommand.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/commands/subcommands/webuser/WebDeleteCommand.java @@ -16,7 +16,7 @@ */ package com.djrapitops.plan.commands.subcommands.webuser; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.processing.Processing; import com.djrapitops.plan.settings.Permissions; import com.djrapitops.plan.settings.locale.Locale; @@ -86,7 +86,7 @@ public class WebDeleteCommand extends CommandNode { processing.submitNonCritical(() -> { try { Database db = dbSystem.getDatabase(); - Optional found = db.query(WebUserQueries.fetchWebUser(user)); + Optional found = db.query(WebUserQueries.fetchWebUser(user)); if (!found.isPresent()) { sender.sendMessage("§c[Plan] User Doesn't exist."); return; diff --git a/Plan/common/src/main/java/com/djrapitops/plan/commands/subcommands/webuser/WebListUsersCommand.java b/Plan/common/src/main/java/com/djrapitops/plan/commands/subcommands/webuser/WebListUsersCommand.java index e4dbc368a..aadb9bf89 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/commands/subcommands/webuser/WebListUsersCommand.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/commands/subcommands/webuser/WebListUsersCommand.java @@ -16,7 +16,7 @@ */ package com.djrapitops.plan.commands.subcommands.webuser; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.processing.Processing; import com.djrapitops.plan.settings.Permissions; import com.djrapitops.plan.settings.locale.Locale; @@ -76,9 +76,9 @@ public class WebListUsersCommand extends CommandNode { processing.submitNonCritical(() -> { try { - List users = dbSystem.getDatabase().query(WebUserQueries.fetchAllPlanWebUsers()); + List users = dbSystem.getDatabase().query(WebUserQueries.fetchAllPlanWebUsers()); sender.sendMessage(locale.getString(CommandLang.HEADER_WEB_USERS, users.size())); - for (WebUser user : users) { + for (WebUser_old user : users) { sender.sendMessage(locale.getString(CommandLang.WEB_USER_LIST, user.getName(), user.getPermLevel())); } sender.sendMessage(">"); diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/domain/WebUser.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/domain/WebUser_old.java similarity index 65% rename from Plan/common/src/main/java/com/djrapitops/plan/delivery/domain/WebUser.java rename to Plan/common/src/main/java/com/djrapitops/plan/delivery/domain/WebUser_old.java index 591e07e6d..6af423cda 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/domain/WebUser.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/domain/WebUser_old.java @@ -16,6 +16,8 @@ */ package com.djrapitops.plan.delivery.domain; +import java.util.ArrayList; +import java.util.List; import java.util.Objects; /** @@ -23,13 +25,14 @@ import java.util.Objects; * * @author Rsl1122 */ -public class WebUser { +@Deprecated +public class WebUser_old { private final String user; private final String saltedPassHash; private final int permLevel; - public WebUser(String user, String saltedPassHash, int permLevel) { + public WebUser_old(String user, String saltedPassHash, int permLevel) { this.user = user; this.saltedPassHash = saltedPassHash; this.permLevel = permLevel; @@ -51,7 +54,7 @@ public class WebUser { public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; - WebUser webUser = (WebUser) o; + WebUser_old webUser = (WebUser_old) o; return permLevel == webUser.permLevel && Objects.equals(user, webUser.user) && Objects.equals(saltedPassHash, webUser.saltedPassHash); @@ -61,4 +64,24 @@ public class WebUser { public int hashCode() { return Objects.hash(user, saltedPassHash, permLevel); } + + public com.djrapitops.plan.delivery.web.resolver.WebUser toNewWebUser() { + List permissions = new ArrayList<>(); + if (permLevel <= 0) { + permissions.add("page.network"); + permissions.add("page.server"); + permissions.add("page.debug"); + // TODO Add JSON Permissions + } + if (permLevel <= 1) { + permissions.add("page.players"); + permissions.add("page.player.other"); + } + if (permLevel <= 2) { + permissions.add("page.player.self"); + } + return new com.djrapitops.plan.delivery.web.resolver.WebUser( + user, permissions.toArray(new String[0]) + ); + } } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/Exporter.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/Exporter.java index 397bc5618..9b0d6af40 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/Exporter.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/Exporter.java @@ -17,7 +17,6 @@ package com.djrapitops.plan.delivery.export; import com.djrapitops.plan.exceptions.ExportException; -import com.djrapitops.plan.exceptions.GenerationException; import com.djrapitops.plan.exceptions.connection.NotFoundException; import com.djrapitops.plan.identification.Server; import com.djrapitops.plan.settings.config.PlanConfig; @@ -86,7 +85,7 @@ public class Exporter extends FileExporter { serverPageExporter.export(toDirectory, server); } return true; - } catch (IOException | NotFoundException | GenerationException e) { + } catch (IOException | NotFoundException e) { failedServers.add(serverUUID); throw new ExportException("Failed to export server: " + server.getIdentifiableName() + " (Attempts disabled until next reload), " + e.toString(), e); } @@ -125,7 +124,7 @@ public class Exporter extends FileExporter { try { playerPageExporter.export(toDirectory, playerUUID, playerName); return true; - } catch (IOException | NotFoundException | GenerationException e) { + } catch (IOException | NotFoundException e) { throw new ExportException("Failed to export player: " + playerName + ", " + e.toString(), e); } } @@ -137,7 +136,7 @@ public class Exporter extends FileExporter { try { playersPageExporter.export(toDirectory); return true; - } catch (IOException | NotFoundException | GenerationException e) { + } catch (IOException | NotFoundException e) { throw new ExportException("Failed to export players page, " + e.toString(), e); } } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/NetworkPageExporter.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/NetworkPageExporter.java index d36b3cceb..330c14991 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/NetworkPageExporter.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/NetworkPageExporter.java @@ -20,9 +20,8 @@ import com.djrapitops.plan.delivery.rendering.pages.Page; import com.djrapitops.plan.delivery.rendering.pages.PageFactory; import com.djrapitops.plan.delivery.webserver.RequestTarget; import com.djrapitops.plan.delivery.webserver.pages.json.RootJSONResolver; -import com.djrapitops.plan.delivery.webserver.response.Response; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.delivery.webserver.response.errors.ErrorResponse; -import com.djrapitops.plan.exceptions.GenerationException; import com.djrapitops.plan.exceptions.connection.NotFoundException; import com.djrapitops.plan.exceptions.connection.WebException; import com.djrapitops.plan.identification.Server; @@ -76,7 +75,7 @@ public class NetworkPageExporter extends FileExporter { exportPaths = new ExportPaths(); } - public void export(Path toDirectory, Server server) throws IOException, NotFoundException, GenerationException { + public void export(Path toDirectory, Server server) throws IOException, NotFoundException { Database.State dbState = dbSystem.getDatabase().getState(); if (dbState == Database.State.CLOSED || dbState == Database.State.CLOSING) return; @@ -87,7 +86,7 @@ public class NetworkPageExporter extends FileExporter { exportPaths.clear(); } - private void exportHtml(Path toDirectory) throws IOException, GenerationException { + private void exportHtml(Path toDirectory) throws IOException { Path to = toDirectory .resolve("network") .resolve("index.html"); @@ -122,7 +121,7 @@ public class NetworkPageExporter extends FileExporter { } private void exportJSON(Path toDirectory, String resource) throws NotFoundException, IOException { - Response found = getJSONResponse(resource); + Response_old found = getJSONResponse(resource); if (found instanceof ErrorResponse) { throw new NotFoundException(resource + " was not properly exported: " + found.getContent()); } @@ -140,7 +139,7 @@ public class NetworkPageExporter extends FileExporter { return StringUtils.replaceEach(resource, new String[]{"?", "&", "type=", "server="}, new String[]{"-", "_", "", ""}); } - private Response getJSONResponse(String resource) { + private Response_old getJSONResponse(String resource) { try { return jsonHandler.resolve(null, new RequestTarget(URI.create(resource))); } catch (WebException e) { diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/PlayerPageExporter.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/PlayerPageExporter.java index 42dfd55fc..26b896f96 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/PlayerPageExporter.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/PlayerPageExporter.java @@ -20,9 +20,8 @@ import com.djrapitops.plan.delivery.rendering.pages.Page; import com.djrapitops.plan.delivery.rendering.pages.PageFactory; import com.djrapitops.plan.delivery.webserver.RequestTarget; import com.djrapitops.plan.delivery.webserver.pages.json.RootJSONResolver; -import com.djrapitops.plan.delivery.webserver.response.Response; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.delivery.webserver.response.errors.ErrorResponse; -import com.djrapitops.plan.exceptions.GenerationException; import com.djrapitops.plan.exceptions.connection.NotFoundException; import com.djrapitops.plan.exceptions.connection.WebException; import com.djrapitops.plan.settings.locale.Locale; @@ -73,7 +72,7 @@ public class PlayerPageExporter extends FileExporter { this.theme = theme; } - public void export(Path toDirectory, UUID playerUUID, String playerName) throws IOException, NotFoundException, GenerationException { + public void export(Path toDirectory, UUID playerUUID, String playerName) throws IOException, NotFoundException { Database.State dbState = dbSystem.getDatabase().getState(); if (dbState == Database.State.CLOSED || dbState == Database.State.CLOSING) return; if (!dbSystem.getDatabase().query(PlayerFetchQueries.isPlayerRegistered(playerUUID))) return; @@ -89,7 +88,7 @@ public class PlayerPageExporter extends FileExporter { exportPaths.clear(); } - private void exportHtml(ExportPaths exportPaths, Path playerDirectory, UUID playerUUID) throws IOException, GenerationException, NotFoundException { + private void exportHtml(ExportPaths exportPaths, Path playerDirectory, UUID playerUUID) throws IOException, NotFoundException { Path to = playerDirectory.resolve("index.html"); try { @@ -105,7 +104,7 @@ public class PlayerPageExporter extends FileExporter { } private void exportJSON(ExportPaths exportPaths, Path toDirectory, String resource, String playerName) throws NotFoundException, IOException { - Response found = getJSONResponse(resource); + Response_old found = getJSONResponse(resource); if (found instanceof ErrorResponse) { throw new NotFoundException(resource + " was not properly exported: " + found.getContent()); } @@ -120,7 +119,7 @@ public class PlayerPageExporter extends FileExporter { return StringUtils.replaceEach(resource, new String[]{"?", "&", "type=", "player="}, new String[]{"-", "_", "", ""}); } - private Response getJSONResponse(String resource) { + private Response_old getJSONResponse(String resource) { try { return jsonHandler.resolve(null, new RequestTarget(URI.create(resource))); } catch (WebException e) { diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/PlayersPageExporter.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/PlayersPageExporter.java index 51f5e870d..74a24f932 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/PlayersPageExporter.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/PlayersPageExporter.java @@ -20,9 +20,8 @@ import com.djrapitops.plan.delivery.rendering.pages.Page; import com.djrapitops.plan.delivery.rendering.pages.PageFactory; import com.djrapitops.plan.delivery.webserver.RequestTarget; import com.djrapitops.plan.delivery.webserver.pages.json.RootJSONResolver; -import com.djrapitops.plan.delivery.webserver.response.Response; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.delivery.webserver.response.errors.ErrorResponse; -import com.djrapitops.plan.exceptions.GenerationException; import com.djrapitops.plan.exceptions.connection.NotFoundException; import com.djrapitops.plan.exceptions.connection.WebException; import com.djrapitops.plan.identification.ServerInfo; @@ -79,7 +78,7 @@ public class PlayersPageExporter extends FileExporter { exportPaths = new ExportPaths(); } - public void export(Path toDirectory) throws IOException, NotFoundException, GenerationException { + public void export(Path toDirectory) throws IOException, NotFoundException { Database.State dbState = dbSystem.getDatabase().getState(); if (dbState == Database.State.CLOSED || dbState == Database.State.CLOSING) return; @@ -90,7 +89,7 @@ public class PlayersPageExporter extends FileExporter { exportPaths.clear(); } - private void exportHtml(Path toDirectory) throws IOException, GenerationException { + private void exportHtml(Path toDirectory) throws IOException { Path to = toDirectory .resolve("players") .resolve("index.html"); @@ -100,7 +99,7 @@ public class PlayersPageExporter extends FileExporter { } private void exportJSON(Path toDirectory) throws NotFoundException, IOException { - Response found = getJSONResponse("players"); + Response_old found = getJSONResponse("players"); if (found instanceof ErrorResponse) { throw new NotFoundException("players page was not properly exported: " + found.getContent()); } @@ -118,7 +117,7 @@ public class PlayersPageExporter extends FileExporter { return StringUtils.replaceEach(resource, new String[]{"?", "&", "type=", "server="}, new String[]{"-", "_", "", ""}); } - private Response getJSONResponse(String resource) { + private Response_old getJSONResponse(String resource) { try { return jsonHandler.resolve(null, new RequestTarget(URI.create(resource))); } catch (WebException e) { diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/ServerPageExporter.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/ServerPageExporter.java index b114aef03..16477b5b9 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/ServerPageExporter.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/export/ServerPageExporter.java @@ -20,9 +20,8 @@ import com.djrapitops.plan.delivery.rendering.pages.Page; import com.djrapitops.plan.delivery.rendering.pages.PageFactory; import com.djrapitops.plan.delivery.webserver.RequestTarget; import com.djrapitops.plan.delivery.webserver.pages.json.RootJSONResolver; -import com.djrapitops.plan.delivery.webserver.response.Response; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.delivery.webserver.response.errors.ErrorResponse; -import com.djrapitops.plan.exceptions.GenerationException; import com.djrapitops.plan.exceptions.connection.NotFoundException; import com.djrapitops.plan.exceptions.connection.WebException; import com.djrapitops.plan.identification.Server; @@ -81,7 +80,7 @@ public class ServerPageExporter extends FileExporter { exportPaths = new ExportPaths(); } - public void export(Path toDirectory, Server server) throws IOException, NotFoundException, GenerationException { + public void export(Path toDirectory, Server server) throws IOException, NotFoundException { Database.State dbState = dbSystem.getDatabase().getState(); if (dbState == Database.State.CLOSED || dbState == Database.State.CLOSING) return; @@ -92,7 +91,7 @@ public class ServerPageExporter extends FileExporter { exportPaths.clear(); } - private void exportHtml(Path toDirectory, Server server) throws IOException, NotFoundException, GenerationException { + private void exportHtml(Path toDirectory, Server server) throws IOException, NotFoundException { UUID serverUUID = server.getUuid(); Path to = toDirectory .resolve(serverInfo.getServer().isProxy() ? "server/" + toFileName(server.getName()) : "server") @@ -134,7 +133,7 @@ public class ServerPageExporter extends FileExporter { } private void exportJSON(Path toDirectory, String resource) throws NotFoundException, IOException { - Response found = getJSONResponse(resource); + Response_old found = getJSONResponse(resource); if (found instanceof ErrorResponse) { throw new NotFoundException(resource + " was not properly exported: " + found.getContent()); } @@ -152,7 +151,7 @@ public class ServerPageExporter extends FileExporter { return StringUtils.replaceEach(resource, new String[]{"?", "&", "type=", "server="}, new String[]{"-", "_", "", ""}); } - private Response getJSONResponse(String resource) { + private Response_old getJSONResponse(String resource) { try { return jsonHandler.resolve(null, new RequestTarget(URI.create(resource))); } catch (WebException e) { diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/DebugPage.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/DebugPage.java index 09c4e5788..6bd04384c 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/DebugPage.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/DebugPage.java @@ -19,6 +19,8 @@ package com.djrapitops.plan.delivery.rendering.pages; import com.djrapitops.plan.delivery.domain.keys.SessionKeys; import com.djrapitops.plan.delivery.formatting.Formatter; import com.djrapitops.plan.delivery.formatting.Formatters; +import com.djrapitops.plan.delivery.formatting.PlaceholderReplacer; +import com.djrapitops.plan.delivery.rendering.html.Contributors; import com.djrapitops.plan.delivery.rendering.html.Html; import com.djrapitops.plan.delivery.rendering.html.icon.Icon; import com.djrapitops.plan.delivery.rendering.html.structure.TabsElement; @@ -52,6 +54,7 @@ import java.util.*; */ public class DebugPage implements Page { + private final String template; private final Database database; private final ServerInfo serverInfo; private final VersionCheckSystem versionCheckSystem; @@ -62,6 +65,8 @@ public class DebugPage implements Page { private final Formatter yearFormatter; DebugPage( + String htmlTemplate, + Database database, ServerInfo serverInfo, Formatters formatters, @@ -70,6 +75,8 @@ public class DebugPage implements Page { Timings timings, ErrorHandler errorHandler ) { + this.template = htmlTemplate; + this.database = database; this.serverInfo = serverInfo; this.versionCheckSystem = versionCheckSystem; @@ -82,6 +89,17 @@ public class DebugPage implements Page { @Override public String toHtml() { + PlaceholderReplacer placeholders = new PlaceholderReplacer(); + placeholders.put("title", Icon.called("bug") + " Debug Information"); + placeholders.put("titleText", "Debug Information"); + placeholders.put("paragraph", createContent()); + placeholders.put("version", versionCheckSystem.getUpdateButton().orElse(versionCheckSystem.getCurrentVersionButton())); + placeholders.put("updateModal", versionCheckSystem.getUpdateModal()); + placeholders.put("contributors", Contributors.generateContributorHtml()); + return placeholders.apply(template); + } + + private String createContent() { StringBuilder preContent = new StringBuilder(); String issueLink = Html.LINK_EXTERNAL.create("https://github.com/Rsl1122/Plan-PlayerAnalytics/issues/new", "Create new issue on Github"); diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/InternalErrorPage.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/InternalErrorPage.java new file mode 100644 index 000000000..1a2914465 --- /dev/null +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/InternalErrorPage.java @@ -0,0 +1,91 @@ +/* + * This file is part of Player Analytics (Plan). + * + * Plan is free software: you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License v3 as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * Plan is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with Plan. If not, see . + */ +package com.djrapitops.plan.delivery.rendering.pages; + +import com.djrapitops.plan.delivery.formatting.PlaceholderReplacer; +import com.djrapitops.plan.delivery.rendering.html.Contributors; +import com.djrapitops.plan.delivery.rendering.html.Html; +import com.djrapitops.plan.delivery.rendering.html.icon.Icon; +import com.djrapitops.plan.version.VersionCheckSystem; + +/** + * Page to display error stacktrace. + * + * @author Rsl1122 + */ +public class InternalErrorPage implements Page { + + private final String template; + private final String errorMsg; + private final Throwable error; + + private final VersionCheckSystem versionCheckSystem; + + public InternalErrorPage( + String template, String errorMsg, Throwable error, + VersionCheckSystem versionCheckSystem + ) { + this.template = template; + this.errorMsg = errorMsg; + this.error = error; + this.versionCheckSystem = versionCheckSystem; + } + + @Override + public String toHtml() { + + PlaceholderReplacer placeholders = new PlaceholderReplacer(); + placeholders.put("title", Icon.called("bug") + " 500 Internal Error occurred"); + placeholders.put("titleText", "500 Internal Error occurred"); + placeholders.put("paragraph", createContent()); + placeholders.put("version", versionCheckSystem.getUpdateButton().orElse(versionCheckSystem.getCurrentVersionButton())); + placeholders.put("updateModal", versionCheckSystem.getUpdateModal()); + placeholders.put("contributors", Contributors.generateContributorHtml()); + return placeholders.apply(template); + } + + private String createContent() { + StringBuilder paragraph = new StringBuilder(); + paragraph.append("Please report this issue here: "); + paragraph.append(Html.LINK.create("https://github.com/Rsl1122/Plan-PlayerAnalytics/issues", "Issues")); + paragraph.append("

");
+        paragraph.append(error).append(" | ").append(errorMsg);
+
+        for (StackTraceElement element : error.getStackTrace()) {
+            paragraph.append("
"); + paragraph.append(" ").append(element); + } + if (error.getCause() != null) { + appendCause(error.getCause(), paragraph); + } + + paragraph.append("
"); + + return paragraph.toString(); + } + + private void appendCause(Throwable cause, StringBuilder paragraph) { + paragraph.append("
Caused by: ").append(cause); + for (StackTraceElement element : cause.getStackTrace()) { + paragraph.append("
"); + paragraph.append(" ").append(element); + } + if (cause.getCause() != null) { + appendCause(cause.getCause(), paragraph); + } + } +} \ No newline at end of file diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/NetworkPage.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/NetworkPage.java index d94bb38be..2c83c5394 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/NetworkPage.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/NetworkPage.java @@ -22,7 +22,6 @@ import com.djrapitops.plan.delivery.formatting.PlaceholderReplacer; import com.djrapitops.plan.delivery.rendering.html.Contributors; import com.djrapitops.plan.delivery.webserver.cache.DataID; import com.djrapitops.plan.delivery.webserver.cache.JSONCache; -import com.djrapitops.plan.exceptions.GenerationException; import com.djrapitops.plan.extension.implementation.results.ExtensionData; import com.djrapitops.plan.extension.implementation.storage.queries.ExtensionServerDataQuery; import com.djrapitops.plan.identification.ServerInfo; @@ -31,7 +30,6 @@ import com.djrapitops.plan.settings.config.paths.ProxySettings; import com.djrapitops.plan.settings.theme.Theme; import com.djrapitops.plan.settings.theme.ThemeVal; import com.djrapitops.plan.storage.database.DBSystem; -import com.djrapitops.plan.storage.file.PlanFiles; import com.djrapitops.plan.version.VersionCheckSystem; import org.apache.commons.lang3.StringUtils; @@ -45,27 +43,28 @@ import java.util.UUID; */ public class NetworkPage implements Page { + private final String templateHtml; private final DBSystem dbSystem; private final VersionCheckSystem versionCheckSystem; - private final PlanFiles files; private final PlanConfig config; private final Theme theme; private final ServerInfo serverInfo; private final Formatters formatters; NetworkPage( + String templateHtml, + DBSystem dbSystem, VersionCheckSystem versionCheckSystem, - PlanFiles files, PlanConfig config, Theme theme, ServerInfo serverInfo, Formatters formatters ) { + this.templateHtml = templateHtml; this.dbSystem = dbSystem; this.versionCheckSystem = versionCheckSystem; - this.files = files; this.config = config; this.theme = theme; this.serverInfo = serverInfo; @@ -73,42 +72,38 @@ public class NetworkPage implements Page { } @Override - public String toHtml() throws GenerationException { - try { - PlaceholderReplacer placeholders = new PlaceholderReplacer(); + public String toHtml() { + PlaceholderReplacer placeholders = new PlaceholderReplacer(); - UUID serverUUID = serverInfo.getServerUUID(); - placeholders.put("networkDisplayName", config.get(ProxySettings.NETWORK_NAME)); - placeholders.put("serverName", config.get(ProxySettings.NETWORK_NAME)); - placeholders.put("serverUUID", serverUUID.toString()); + UUID serverUUID = serverInfo.getServerUUID(); + placeholders.put("networkDisplayName", config.get(ProxySettings.NETWORK_NAME)); + placeholders.put("serverName", config.get(ProxySettings.NETWORK_NAME)); + placeholders.put("serverUUID", serverUUID.toString()); - placeholders.put("gmPieColors", theme.getValue(ThemeVal.GRAPH_GM_PIE)); - placeholders.put("playersGraphColor", theme.getValue(ThemeVal.GRAPH_PLAYERS_ONLINE)); - placeholders.put("worldMapColLow", theme.getValue(ThemeVal.WORLD_MAP_LOW)); - placeholders.put("worldMapColHigh", theme.getValue(ThemeVal.WORLD_MAP_HIGH)); - placeholders.put("maxPingColor", theme.getValue(ThemeVal.GRAPH_MAX_PING)); - placeholders.put("minPingColor", theme.getValue(ThemeVal.GRAPH_MIN_PING)); - placeholders.put("avgPingColor", theme.getValue(ThemeVal.GRAPH_AVG_PING)); - placeholders.put("timeZone", config.getTimeZoneOffsetHours()); + placeholders.put("gmPieColors", theme.getValue(ThemeVal.GRAPH_GM_PIE)); + placeholders.put("playersGraphColor", theme.getValue(ThemeVal.GRAPH_PLAYERS_ONLINE)); + placeholders.put("worldMapColLow", theme.getValue(ThemeVal.WORLD_MAP_LOW)); + placeholders.put("worldMapColHigh", theme.getValue(ThemeVal.WORLD_MAP_HIGH)); + placeholders.put("maxPingColor", theme.getValue(ThemeVal.GRAPH_MAX_PING)); + placeholders.put("minPingColor", theme.getValue(ThemeVal.GRAPH_MIN_PING)); + placeholders.put("avgPingColor", theme.getValue(ThemeVal.GRAPH_AVG_PING)); + placeholders.put("timeZone", config.getTimeZoneOffsetHours()); - placeholders.put("version", versionCheckSystem.getUpdateButton().orElse(versionCheckSystem.getCurrentVersionButton())); - placeholders.put("updateModal", versionCheckSystem.getUpdateModal()); - placeholders.put("contributors", Contributors.generateContributorHtml()); + placeholders.put("version", versionCheckSystem.getUpdateButton().orElse(versionCheckSystem.getCurrentVersionButton())); + placeholders.put("updateModal", versionCheckSystem.getUpdateModal()); + placeholders.put("contributors", Contributors.generateContributorHtml()); - CachingSupplier pluginTabs = new CachingSupplier<>(() -> { - List extensionData = dbSystem.getDatabase().query(new ExtensionServerDataQuery(serverUUID)); - return new ServerPluginTabs(extensionData, formatters); - }); + CachingSupplier pluginTabs = new CachingSupplier<>(() -> { + List extensionData = dbSystem.getDatabase().query(new ExtensionServerDataQuery(serverUUID)); + return new ServerPluginTabs(extensionData, formatters); + }); - String nav = JSONCache.getOrCacheString(DataID.EXTENSION_NAV, serverUUID, () -> pluginTabs.get().getNav()); - String tabs = JSONCache.getOrCacheString(DataID.EXTENSION_TABS, serverUUID, () -> pluginTabs.get().getTabs()); + String nav = JSONCache.getOrCacheString(DataID.EXTENSION_NAV, serverUUID, () -> pluginTabs.get().getNav()); + String tabs = JSONCache.getOrCacheString(DataID.EXTENSION_TABS, serverUUID, () -> pluginTabs.get().getTabs()); - placeholders.put("navPluginsTabs", nav); - placeholders.put("tabsPlugins", StringUtils.remove(tabs, "${backButton}")); + placeholders.put("navPluginsTabs", nav); + placeholders.put("tabsPlugins", StringUtils.remove(tabs, "${backButton}")); - return placeholders.apply(files.getCustomizableResourceOrDefault("web/network.html").asString()); - } catch (Exception e) { - throw new GenerationException(e); - } + return placeholders.apply(templateHtml); } } \ No newline at end of file diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/Page.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/Page.java index 9241a29c5..79b3d9b7b 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/Page.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/Page.java @@ -16,14 +16,11 @@ */ package com.djrapitops.plan.delivery.rendering.pages; -import com.djrapitops.plan.exceptions.GenerationException; - /** * Interface for generating page HTML String. * * @author Rsl1122 */ public interface Page { - - String toHtml() throws GenerationException; + String toHtml(); } \ No newline at end of file diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/PageFactory.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/PageFactory.java index 90b8e12a5..5822271a2 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/PageFactory.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/PageFactory.java @@ -38,6 +38,7 @@ import dagger.Lazy; import javax.inject.Inject; import javax.inject.Singleton; +import java.io.IOException; import java.util.*; /** @@ -49,7 +50,7 @@ import java.util.*; public class PageFactory { private final Lazy versionCheckSystem; - private final Lazy fileSystem; + private final Lazy files; private final Lazy config; private final Lazy theme; private final Lazy dbSystem; @@ -62,7 +63,7 @@ public class PageFactory { @Inject public PageFactory( Lazy versionCheckSystem, - Lazy fileSystem, + Lazy files, Lazy config, Lazy theme, Lazy dbSystem, @@ -73,7 +74,7 @@ public class PageFactory { Lazy errorHandler ) { this.versionCheckSystem = versionCheckSystem; - this.fileSystem = fileSystem; + this.files = files; this.config = config; this.theme = theme; this.dbSystem = dbSystem; @@ -84,38 +85,40 @@ public class PageFactory { this.errorHandler = errorHandler; } - public DebugPage debugPage() { + public DebugPage debugPage() throws IOException { return new DebugPage( + getResource("web/error.html"), dbSystem.get().getDatabase(), serverInfo.get(), formatters.get(), versionCheckSystem.get(), debugLogger.get(), timings.get(), errorHandler.get() ); } - public PlayersPage playersPage() { - return new PlayersPage(versionCheckSystem.get(), fileSystem.get(), config.get(), serverInfo.get()); + public PlayersPage playersPage() throws IOException { + return new PlayersPage(getResource("web/players.html"), versionCheckSystem.get(), config.get(), serverInfo.get()); } - public ServerPage serverPage(UUID serverUUID) throws NotFoundException { - return dbSystem.get().getDatabase().query(ServerQueries.fetchServerMatchingIdentifier(serverUUID)) - .map(server -> new ServerPage( - server, - config.get(), - theme.get(), - versionCheckSystem.get(), - fileSystem.get(), - dbSystem.get(), - serverInfo.get(), - formatters.get() - )).orElseThrow(() -> new NotFoundException("Server not found in the database")); + public ServerPage serverPage(UUID serverUUID) throws NotFoundException, IOException { + Server server = dbSystem.get().getDatabase().query(ServerQueries.fetchServerMatchingIdentifier(serverUUID)) + .orElseThrow(() -> new NotFoundException("Server not found in the database")); + return new ServerPage( + getResource("web/server.html"), + server, + config.get(), + theme.get(), + versionCheckSystem.get(), + dbSystem.get(), + serverInfo.get(), + formatters.get() + ); } - public PlayerPage playerPage(UUID playerUUID) { + public PlayerPage playerPage(UUID playerUUID) throws IOException { Database db = dbSystem.get().getDatabase(); PlayerContainer player = db.query(ContainerFetchQueries.fetchPlayerContainer(playerUUID)); return new PlayerPage( - player, + getResource("web/player.html"), player, versionCheckSystem.get(), - fileSystem.get(), config.get(), this, theme.get(), + config.get(), this, theme.get(), formatters.get(), serverInfo.get() ); } @@ -153,8 +156,25 @@ public class PageFactory { return new PlayerPluginTab(navs.toString(), tabs.toString()); } - public NetworkPage networkPage() { - return new NetworkPage(dbSystem.get(), - versionCheckSystem.get(), fileSystem.get(), config.get(), theme.get(), serverInfo.get(), formatters.get()); + public NetworkPage networkPage() throws IOException { + return new NetworkPage(getResource("web/network.html"), + dbSystem.get(), + versionCheckSystem.get(), config.get(), theme.get(), serverInfo.get(), formatters.get()); + } + + public Page internalErrorPage(String message, Throwable error) { + try { + return new InternalErrorPage( + getResource("web/error.html"), message, error, + versionCheckSystem.get()); + } catch (IOException noParse) { + return () -> "Error occurred: " + error.toString() + + ", additional error occurred when attempting to render error page to user: " + + noParse.toString(); + } + } + + public String getResource(String name) throws IOException { + return files.get().getCustomizableResourceOrDefault(name).asString(); } } \ No newline at end of file diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/PlayerPage.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/PlayerPage.java index ea5930269..ba127bb7e 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/PlayerPage.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/PlayerPage.java @@ -23,15 +23,12 @@ import com.djrapitops.plan.delivery.formatting.Formatters; import com.djrapitops.plan.delivery.formatting.PlaceholderReplacer; import com.djrapitops.plan.delivery.rendering.html.Contributors; import com.djrapitops.plan.delivery.rendering.html.Html; -import com.djrapitops.plan.exceptions.GenerationException; import com.djrapitops.plan.identification.ServerInfo; import com.djrapitops.plan.settings.config.PlanConfig; import com.djrapitops.plan.settings.theme.Theme; import com.djrapitops.plan.settings.theme.ThemeVal; -import com.djrapitops.plan.storage.file.PlanFiles; import com.djrapitops.plan.version.VersionCheckSystem; -import java.io.IOException; import java.util.UUID; /** @@ -41,11 +38,11 @@ import java.util.UUID; */ public class PlayerPage implements Page { + private final String templateHtml; private final PlayerContainer player; private final VersionCheckSystem versionCheckSystem; - private final PlanFiles files; private final PlanConfig config; private final PageFactory pageFactory; private final Theme theme; @@ -55,18 +52,18 @@ public class PlayerPage implements Page { private final Formatter secondLongFormatter; PlayerPage( + String templateHtml, PlayerContainer player, VersionCheckSystem versionCheckSystem, - PlanFiles files, PlanConfig config, PageFactory pageFactory, Theme theme, Formatters formatters, ServerInfo serverInfo ) { + this.templateHtml = templateHtml; this.player = player; this.versionCheckSystem = versionCheckSystem; - this.files = files; this.config = config; this.pageFactory = pageFactory; this.theme = theme; @@ -77,18 +74,14 @@ public class PlayerPage implements Page { } @Override - public String toHtml() throws GenerationException { + public String toHtml() { if (!player.getValue(PlayerKeys.REGISTERED).isPresent()) { throw new IllegalStateException("Player is not registered"); } - try { - return createFor(player); - } catch (Exception e) { - throw new GenerationException(e); - } + return createFor(player); } - public String createFor(PlayerContainer player) throws IOException { + public String createFor(PlayerContainer player) { long now = System.currentTimeMillis(); UUID playerUUID = player.getUnsafe(PlayerKeys.UUID); @@ -116,6 +109,6 @@ public class PlayerPage implements Page { placeholders.put("navPluginsTabs", pluginTabs.getNav()); placeholders.put("pluginsTabs", pluginTabs.getTab()); - return placeholders.apply(files.getCustomizableResourceOrDefault("web/player.html").asString()); + return placeholders.apply(templateHtml); } } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/PlayersPage.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/PlayersPage.java index 13d041a5a..754ca076f 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/PlayersPage.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/PlayersPage.java @@ -18,12 +18,10 @@ package com.djrapitops.plan.delivery.rendering.pages; import com.djrapitops.plan.delivery.formatting.PlaceholderReplacer; import com.djrapitops.plan.delivery.rendering.html.Contributors; -import com.djrapitops.plan.exceptions.GenerationException; import com.djrapitops.plan.identification.ServerInfo; import com.djrapitops.plan.settings.config.PlanConfig; import com.djrapitops.plan.settings.config.paths.PluginSettings; import com.djrapitops.plan.settings.config.paths.ProxySettings; -import com.djrapitops.plan.storage.file.PlanFiles; import com.djrapitops.plan.version.VersionCheckSystem; /** @@ -33,40 +31,36 @@ import com.djrapitops.plan.version.VersionCheckSystem; */ public class PlayersPage implements Page { + private final String templateHtml; private final VersionCheckSystem versionCheckSystem; - private final PlanFiles files; private final PlanConfig config; private final ServerInfo serverInfo; PlayersPage( + String templateHtml, VersionCheckSystem versionCheckSystem, - PlanFiles files, PlanConfig config, ServerInfo serverInfo ) { + this.templateHtml = templateHtml; this.versionCheckSystem = versionCheckSystem; - this.files = files; this.config = config; this.serverInfo = serverInfo; } @Override - public String toHtml() throws GenerationException { - try { - PlaceholderReplacer placeholders = new PlaceholderReplacer(); + public String toHtml() { + PlaceholderReplacer placeholders = new PlaceholderReplacer(); - placeholders.put("version", versionCheckSystem.getUpdateButton().orElse(versionCheckSystem.getCurrentVersionButton())); - placeholders.put("updateModal", versionCheckSystem.getUpdateModal()); - placeholders.put("contributors", Contributors.generateContributorHtml()); - if (serverInfo.getServer().isProxy()) { - placeholders.put("networkName", config.get(ProxySettings.NETWORK_NAME)); - } else { - placeholders.put("networkName", config.get(PluginSettings.SERVER_NAME)); - } - - return placeholders.apply(files.getCustomizableResourceOrDefault("web/players.html").asString()); - } catch (Exception e) { - throw new GenerationException(e); + placeholders.put("version", versionCheckSystem.getUpdateButton().orElse(versionCheckSystem.getCurrentVersionButton())); + placeholders.put("updateModal", versionCheckSystem.getUpdateModal()); + placeholders.put("contributors", Contributors.generateContributorHtml()); + if (serverInfo.getServer().isProxy()) { + placeholders.put("networkName", config.get(ProxySettings.NETWORK_NAME)); + } else { + placeholders.put("networkName", config.get(PluginSettings.SERVER_NAME)); } + + return placeholders.apply(templateHtml); } } \ No newline at end of file diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/ServerPage.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/ServerPage.java index e48cfeaa2..65d4dcebd 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/ServerPage.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/rendering/pages/ServerPage.java @@ -26,7 +26,6 @@ import com.djrapitops.plan.delivery.rendering.html.Contributors; import com.djrapitops.plan.delivery.rendering.html.Html; import com.djrapitops.plan.delivery.webserver.cache.DataID; import com.djrapitops.plan.delivery.webserver.cache.JSONCache; -import com.djrapitops.plan.exceptions.GenerationException; import com.djrapitops.plan.extension.implementation.results.ExtensionData; import com.djrapitops.plan.extension.implementation.storage.queries.ExtensionServerDataQuery; import com.djrapitops.plan.identification.Server; @@ -36,10 +35,8 @@ import com.djrapitops.plan.settings.config.paths.DisplaySettings; import com.djrapitops.plan.settings.theme.Theme; import com.djrapitops.plan.settings.theme.ThemeVal; import com.djrapitops.plan.storage.database.DBSystem; -import com.djrapitops.plan.storage.file.PlanFiles; import com.djrapitops.plan.version.VersionCheckSystem; -import java.io.IOException; import java.util.List; import java.util.UUID; @@ -52,37 +49,36 @@ import static com.djrapitops.plan.delivery.domain.keys.AnalysisKeys.*; */ public class ServerPage implements Page { + private final String templateHtml; private final Server server; private final PlanConfig config; private final Theme theme; private final VersionCheckSystem versionCheckSystem; - private final PlanFiles files; private final DBSystem dbSystem; private final ServerInfo serverInfo; private final Formatters formatters; ServerPage( - Server server, + String templateHtml, Server server, PlanConfig config, Theme theme, VersionCheckSystem versionCheckSystem, - PlanFiles files, DBSystem dbSystem, ServerInfo serverInfo, Formatters formatters ) { + this.templateHtml = templateHtml; this.server = server; this.config = config; this.theme = theme; this.versionCheckSystem = versionCheckSystem; - this.files = files; this.dbSystem = dbSystem; this.serverInfo = serverInfo; this.formatters = formatters; } @Override - public String toHtml() throws GenerationException { + public String toHtml() { PlaceholderReplacer placeholders = new PlaceholderReplacer(); UUID serverUUID = server.getUuid(); @@ -139,10 +135,6 @@ public class ServerPage implements Page { placeholders.put("navPluginsTabs", nav); placeholders.put("tabsPlugins", tabs); - try { - return placeholders.apply(files.getCustomizableResourceOrDefault("web/server.html").asString()); - } catch (IOException e) { - throw new GenerationException(e); - } + return placeholders.apply(templateHtml); } } \ No newline at end of file diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/web/ResolverSvc.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/web/ResolverSvc.java new file mode 100644 index 000000000..476def004 --- /dev/null +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/web/ResolverSvc.java @@ -0,0 +1,92 @@ +/* + * This file is part of Player Analytics (Plan). + * + * Plan is free software: you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License v3 as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * Plan is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with Plan. If not, see . + */ +package com.djrapitops.plan.delivery.web; + +import com.djrapitops.plan.delivery.web.resolver.Resolver; + +import javax.inject.Inject; +import javax.inject.Singleton; +import java.util.ArrayList; +import java.util.Collection; +import java.util.Optional; +import java.util.function.Predicate; +import java.util.regex.Pattern; + +/** + * ResolverService Implementation. + * + * @author Rsl1122 + */ +@Singleton +public class ResolverSvc implements ResolverService { + + private final Collection basicResolvers; + private final Collection regexResolvers; + + @Inject + public ResolverSvc() { + basicResolvers = new ArrayList<>(); + regexResolvers = new ArrayList<>(); + } + + public void register() { + ResolverService.Holder.set(this); + } + + @Override + public void registerResolver(String pluginName, String start, Resolver resolver) { + basicResolvers.add(new Container(pluginName, checking -> checking.startsWith(start), resolver)); + } + + @Override + public void registerResolverForMatches(String pluginName, Pattern pattern, Resolver resolver) { + regexResolvers.add(new Container(pluginName, pattern.asPredicate(), resolver)); + } + + @Override + public Optional getResolver(String target) { + for (Container container : basicResolvers) { + if (container.matcher.test(target)) return Optional.of(container.resolver); + } + for (Container container : regexResolvers) { + if (container.matcher.test(target)) return Optional.of(container.resolver); + } + return Optional.empty(); + } + + public Optional getPluginInChargeOf(String target) { + for (Container container : basicResolvers) { + if (container.matcher.test(target)) return Optional.of(container.plugin); + } + for (Container container : regexResolvers) { + if (container.matcher.test(target)) return Optional.of(container.plugin); + } + return Optional.empty(); + } + + private static class Container { + final String plugin; + final Predicate matcher; + final Resolver resolver; + + public Container(String plugin, Predicate matcher, Resolver resolver) { + this.plugin = plugin; + this.matcher = matcher; + this.resolver = resolver; + } + } +} \ No newline at end of file diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/Request.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/Request.java index 2d8b22eaa..b1011e10c 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/Request.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/Request.java @@ -16,6 +16,8 @@ */ package com.djrapitops.plan.delivery.webserver; +import com.djrapitops.plan.delivery.web.resolver.URIPath; +import com.djrapitops.plan.delivery.web.resolver.URIQuery; import com.djrapitops.plan.delivery.webserver.auth.Authentication; import com.djrapitops.plan.settings.locale.Locale; import com.sun.net.httpserver.HttpExchange; @@ -68,8 +70,12 @@ public class Request { return requestURI.getPath() + '?' + requestURI.getQuery(); } - public RequestTarget getTarget() { - return new RequestTarget(requestURI); + public URIPath getPath() { + return new URIPath(requestURI.getPath()); + } + + public URIQuery getQuery() { + return new URIQuery(requestURI.getQuery()); } public InputStream getRequestBody() { @@ -88,4 +94,9 @@ public class Request { public Locale getLocale() { return locale; } + + @Deprecated + public RequestTarget getRequestTarget() { + return new RequestTarget(requestURI); + } } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/RequestHandler.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/RequestHandler.java index fb453655f..334fd6c81 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/RequestHandler.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/RequestHandler.java @@ -19,8 +19,8 @@ package com.djrapitops.plan.delivery.webserver; import com.djrapitops.plan.delivery.webserver.auth.Authentication; import com.djrapitops.plan.delivery.webserver.auth.BasicAuthentication; import com.djrapitops.plan.delivery.webserver.response.PromptAuthorizationResponse; -import com.djrapitops.plan.delivery.webserver.response.Response; import com.djrapitops.plan.delivery.webserver.response.ResponseFactory; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.delivery.webserver.response.errors.ForbiddenResponse; import com.djrapitops.plan.settings.config.PlanConfig; import com.djrapitops.plan.settings.config.paths.PluginSettings; @@ -96,11 +96,11 @@ public class RequestHandler implements HttpHandler { request.setAuth(getAuthorization(requestHeaders)); try { - Response response = shouldPreventRequest(request.getRemoteAddress()) // Forbidden response (Optional) + Response_old response = shouldPreventRequest(request.getRemoteAddress()) // Forbidden response (Optional) .orElseGet(() -> responseResolver.getResponse(request)); // Or the actual requested response // Increase attempt count and block if too high - Optional forbid = handlePasswordBruteForceAttempts(request, response); + Optional forbid = handlePasswordBruteForceAttempts(request, response); if (forbid.isPresent()) { response = forbid.get(); } @@ -124,7 +124,7 @@ public class RequestHandler implements HttpHandler { } } - private Optional shouldPreventRequest(String accessor) { + private Optional shouldPreventRequest(String accessor) { Integer attempts = failedLoginAttempts.getIfPresent(accessor); if (attempts == null) { attempts = 0; @@ -137,7 +137,7 @@ public class RequestHandler implements HttpHandler { return Optional.empty(); } - private Optional handlePasswordBruteForceAttempts(Request request, Response response) { + private Optional handlePasswordBruteForceAttempts(Request request, Response_old response) { if (request.getAuth().isPresent() && response instanceof PromptAuthorizationResponse) { // Authentication was attempted, but failed so new attempt is going to be given if not forbidden @@ -166,7 +166,7 @@ public class RequestHandler implements HttpHandler { return Optional.empty(); } - private Optional createForbiddenResponse() { + private Optional createForbiddenResponse() { return Optional.of(responseFactory.forbidden403("You have too many failed login attempts. Please wait 2 minutes until attempting again.")); } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/RequestTarget.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/RequestTarget.java index f1c25c7ef..78f5004e1 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/RequestTarget.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/RequestTarget.java @@ -27,6 +27,7 @@ import java.util.stream.Collectors; * * @author Rsl1122 */ +@Deprecated public class RequestTarget { private final String resourceString; diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/ResponseResolver.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/ResponseResolver.java index 494263e6a..32c08cc44 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/ResponseResolver.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/ResponseResolver.java @@ -16,12 +16,17 @@ */ package com.djrapitops.plan.delivery.webserver; +import com.djrapitops.plan.delivery.web.ResolverService; +import com.djrapitops.plan.delivery.web.ResolverSvc; +import com.djrapitops.plan.delivery.web.resolver.Resolver; +import com.djrapitops.plan.delivery.web.resolver.URIPath; +import com.djrapitops.plan.delivery.web.resolver.URIQuery; import com.djrapitops.plan.delivery.webserver.auth.Authentication; import com.djrapitops.plan.delivery.webserver.pages.*; import com.djrapitops.plan.delivery.webserver.pages.json.RootJSONResolver; import com.djrapitops.plan.delivery.webserver.response.OptionsResponse; -import com.djrapitops.plan.delivery.webserver.response.Response; import com.djrapitops.plan.delivery.webserver.response.ResponseFactory; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.exceptions.WebUserAuthException; import com.djrapitops.plan.exceptions.connection.BadRequestException; import com.djrapitops.plan.exceptions.connection.ForbiddenException; @@ -55,10 +60,12 @@ public class ResponseResolver extends CompositePageResolver { private final ErrorHandler errorHandler; private final ServerInfo serverInfo; + private final ResolverService resolverService; private final Lazy webServer; @Inject public ResponseResolver( + ResolverSvc resolverService, ResponseFactory responseFactory, Lazy webServer, ServerInfo serverInfo, @@ -72,6 +79,7 @@ public class ResponseResolver extends CompositePageResolver { ErrorHandler errorHandler ) { super(responseFactory); + this.resolverService = resolverService; this.webServer = webServer; this.serverInfo = serverInfo; this.debugPageResolver = debugPageResolver; @@ -83,19 +91,20 @@ public class ResponseResolver extends CompositePageResolver { } public void registerPages() { - registerPage("debug", debugPageResolver); + resolverService.registerResolver("Plan", "/debug", debugPageResolver); registerPage("players", playersPageResolver); registerPage("player", playerPageResolver); registerPage("network", serverPageResolver); registerPage("server", serverPageResolver); + // TODO Figure out how to deal with stuff like this registerPage("", new RootPageResolver(responseFactory, webServer.get(), serverInfo)); registerPage("v1", rootJSONResolver); } - public Response getResponse(Request request) { + public Response_old getResponse(Request request) { try { return tryToGetResponse(request); } catch (NotFoundException e) { @@ -112,15 +121,47 @@ public class ResponseResolver extends CompositePageResolver { } } - private Response tryToGetResponse(Request request) throws WebException { - Optional authentication = request.getAuth(); - RequestTarget target = request.getTarget(); - String resource = target.getResourceString(); - + private Response_old tryToGetResponse(Request request) throws WebException { if ("OPTIONS".equalsIgnoreCase(request.getRequestMethod())) { return new OptionsResponse(); } + Optional authentication = request.getAuth(); + + URIPath target = request.getPath(); + URIQuery query = request.getQuery(); + + Optional foundResolver = resolverService.getResolver(target.asString()); + if (!foundResolver.isPresent()) return tryToGetResponse_old(request); // TODO Replace with 404 after refactoring + + Resolver resolver = foundResolver.get(); + + if (resolver.requiresAuth(target, query)) { + // Get required auth + boolean isAuthRequired = webServer.get().isAuthRequired(); + if (isAuthRequired && !authentication.isPresent()) { + if (webServer.get().isUsingHTTPS()) { + return responseFactory.basicAuth(); + } else { + return responseFactory.forbidden403(); + } + } + + if (!isAuthRequired || resolver.canAccess(authentication.get().getWebUser().toNewWebUser(), target, query)) { + return resolver.resolve(target, query).map(Response_old::from).orElseGet(responseFactory::pageNotFound404); + } else { + return responseFactory.forbidden403(); + } + } else { + return resolver.resolve(target, query).map(Response_old::from).orElseGet(responseFactory::pageNotFound404); + } + } + + private Response_old tryToGetResponse_old(Request request) throws WebException { + RequestTarget target = request.getRequestTarget(); + Optional authentication = request.getAuth(); + String resource = target.getResourceString(); + // TODO Turn into resolvers if (target.endsWith(".css")) { return responseFactory.cssResponse(resource); } @@ -136,7 +177,6 @@ public class ResponseResolver extends CompositePageResolver { if (target.endsWithAny(".woff", ".woff2", ".eot", ".ttf")) { return responseFactory.fontResponse(resource); } - boolean isAuthRequired = webServer.get().isAuthRequired(); if (isAuthRequired && !authentication.isPresent()) { if (webServer.get().isUsingHTTPS()) { diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/auth/Authentication.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/auth/Authentication.java index 3912fcddf..3914f25ad 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/auth/Authentication.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/auth/Authentication.java @@ -16,7 +16,7 @@ */ package com.djrapitops.plan.delivery.webserver.auth; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.exceptions.WebUserAuthException; /** @@ -26,6 +26,6 @@ import com.djrapitops.plan.exceptions.WebUserAuthException; */ public interface Authentication { - WebUser getWebUser() throws WebUserAuthException; + WebUser_old getWebUser() throws WebUserAuthException; } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/auth/BasicAuthentication.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/auth/BasicAuthentication.java index 0a1797868..f768536b2 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/auth/BasicAuthentication.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/auth/BasicAuthentication.java @@ -16,7 +16,7 @@ */ package com.djrapitops.plan.delivery.webserver.auth; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.exceptions.PassEncryptException; import com.djrapitops.plan.exceptions.WebUserAuthException; import com.djrapitops.plan.exceptions.database.DBOpException; @@ -45,7 +45,7 @@ public class BasicAuthentication implements Authentication { } @Override - public WebUser getWebUser() throws WebUserAuthException { + public WebUser_old getWebUser() throws WebUserAuthException { String decoded = Base64Util.decode(authenticationString); String[] userInfo = StringUtils.split(decoded, ':'); @@ -62,7 +62,7 @@ public class BasicAuthentication implements Authentication { } try { - WebUser webUser = database.query(WebUserQueries.fetchWebUser(user)) + WebUser_old webUser = database.query(WebUserQueries.fetchWebUser(user)) .orElseThrow(() -> new WebUserAuthException(FailReason.USER_DOES_NOT_EXIST, user)); boolean correctPass = PassEncryptUtil.verifyPassword(passwordRaw, webUser.getSaltedPassHash()); diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/cache/JSONCache.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/cache/JSONCache.java index f07cfcd29..75d1834cd 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/cache/JSONCache.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/cache/JSONCache.java @@ -17,7 +17,7 @@ package com.djrapitops.plan.delivery.webserver.cache; import com.djrapitops.plan.delivery.webserver.pages.json.RootJSONResolver; -import com.djrapitops.plan.delivery.webserver.response.Response; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse; import com.djrapitops.plan.storage.file.ResourceCache; import com.djrapitops.plugin.task.AbsRunnable; @@ -47,7 +47,7 @@ public class JSONCache { // Static class } - public static Response getOrCache(String identifier, Supplier jsonResponseSupplier) { + public static Response_old getOrCache(String identifier, Supplier jsonResponseSupplier) { String found = cache.getIfPresent(identifier); if (found == null) { JSONResponse response = jsonResponseSupplier.get(); @@ -68,11 +68,11 @@ public class JSONCache { return found; } - public static Response getOrCache(DataID dataID, Supplier jsonResponseSupplier) { + public static Response_old getOrCache(DataID dataID, Supplier jsonResponseSupplier) { return getOrCache(dataID.name(), jsonResponseSupplier); } - public static Response getOrCache(DataID dataID, UUID serverUUID, Supplier jsonResponseSupplier) { + public static Response_old getOrCache(DataID dataID, UUID serverUUID, Supplier jsonResponseSupplier) { return getOrCache(dataID.of(serverUUID), jsonResponseSupplier); } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/CompositePageResolver.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/CompositePageResolver.java index 13c47cc22..743524f9a 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/CompositePageResolver.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/CompositePageResolver.java @@ -19,8 +19,8 @@ package com.djrapitops.plan.delivery.webserver.pages; import com.djrapitops.plan.delivery.webserver.Request; import com.djrapitops.plan.delivery.webserver.RequestTarget; import com.djrapitops.plan.delivery.webserver.auth.Authentication; -import com.djrapitops.plan.delivery.webserver.response.Response; import com.djrapitops.plan.delivery.webserver.response.ResponseFactory; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.exceptions.WebUserAuthException; import com.djrapitops.plan.exceptions.connection.WebException; @@ -37,6 +37,7 @@ import java.util.Map; * * @author Rsl1122 */ +@Deprecated public abstract class CompositePageResolver implements PageResolver { protected final ResponseFactory responseFactory; @@ -48,14 +49,16 @@ public abstract class CompositePageResolver implements PageResolver { pages = new HashMap<>(); } + @Deprecated public void registerPage(String targetPage, PageResolver resolver) { pages.put(targetPage, resolver); } + @Deprecated public void registerPage(String targetPage, PageResolver resolver, int requiredPerm) { pages.put(targetPage, new PageResolver() { @Override - public Response resolve(Request request, RequestTarget target) throws WebException { + public Response_old resolve(Request request, RequestTarget target) throws WebException { return resolver.resolve(request, target); } @@ -66,10 +69,11 @@ public abstract class CompositePageResolver implements PageResolver { }); } - public void registerPage(String targetPage, Response response, int requiredPerm) { + @Deprecated + public void registerPage(String targetPage, Response_old response, int requiredPerm) { pages.put(targetPage, new PageResolver() { @Override - public Response resolve(Request request, RequestTarget target) { + public Response_old resolve(Request request, RequestTarget target) { return response; } @@ -81,13 +85,15 @@ public abstract class CompositePageResolver implements PageResolver { } @Override - public Response resolve(Request request, RequestTarget target) throws WebException { + @Deprecated + public Response_old resolve(Request request, RequestTarget target) throws WebException { PageResolver pageResolver = getPageResolver(target); return pageResolver != null ? pageResolver.resolve(request, target) : responseFactory.pageNotFound404(); } + @Deprecated public PageResolver getPageResolver(RequestTarget target) { if (target.isEmpty()) { return pages.get(""); @@ -97,6 +103,7 @@ public abstract class CompositePageResolver implements PageResolver { return pages.get(targetPage); } + @Deprecated public PageResolver getPageResolver(String targetPage) { return pages.get(targetPage); } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/DebugPageResolver.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/DebugPageResolver.java index a99ea4ea7..9bf7cdf07 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/DebugPageResolver.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/DebugPageResolver.java @@ -16,16 +16,18 @@ */ package com.djrapitops.plan.delivery.webserver.pages; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; +import com.djrapitops.plan.delivery.web.resolver.*; import com.djrapitops.plan.delivery.webserver.Request; import com.djrapitops.plan.delivery.webserver.RequestTarget; import com.djrapitops.plan.delivery.webserver.auth.Authentication; -import com.djrapitops.plan.delivery.webserver.response.Response; import com.djrapitops.plan.delivery.webserver.response.ResponseFactory; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.exceptions.WebUserAuthException; import javax.inject.Inject; import javax.inject.Singleton; +import java.util.Optional; /** * Resolves /debug URL. @@ -33,7 +35,7 @@ import javax.inject.Singleton; * @author Rsl1122 */ @Singleton -public class DebugPageResolver implements PageResolver { +public class DebugPageResolver implements PageResolver, Resolver { private final ResponseFactory responseFactory; @@ -43,13 +45,23 @@ public class DebugPageResolver implements PageResolver { } @Override - public Response resolve(Request request, RequestTarget target) { - return responseFactory.debugPageResponse(); + public boolean canAccess(WebUser permissions, URIPath target, URIQuery query) { + return permissions.hasPermission("page.debug"); + } + + @Override + public Optional resolve(URIPath target, URIQuery query) { + return Optional.of(responseFactory.debugPageResponse()); + } + + @Override + public Response_old resolve(Request request, RequestTarget target) { + return responseFactory.debugPageResponse_old(); } @Override public boolean isAuthorized(Authentication auth, RequestTarget target) throws WebUserAuthException { - WebUser webUser = auth.getWebUser(); + WebUser_old webUser = auth.getWebUser(); return webUser.getPermLevel() <= 0; } } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/PageResolver.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/PageResolver.java index 9fd06c90e..d5a38d13f 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/PageResolver.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/PageResolver.java @@ -19,7 +19,7 @@ package com.djrapitops.plan.delivery.webserver.pages; import com.djrapitops.plan.delivery.webserver.Request; import com.djrapitops.plan.delivery.webserver.RequestTarget; import com.djrapitops.plan.delivery.webserver.auth.Authentication; -import com.djrapitops.plan.delivery.webserver.response.Response; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.exceptions.WebUserAuthException; import com.djrapitops.plan.exceptions.connection.WebException; @@ -29,6 +29,7 @@ import com.djrapitops.plan.exceptions.connection.WebException; * @author Rsl1122 * @see CompositePageResolver for larger depth resolution than 1. */ +@Deprecated public interface PageResolver { /** @@ -38,7 +39,7 @@ public interface PageResolver { * @param target Rest of the target coordinates after this page has been solved. * @return Appropriate response. */ - Response resolve(Request request, RequestTarget target) throws WebException; + Response_old resolve(Request request, RequestTarget target) throws WebException; default boolean isAuthorized(Authentication auth, RequestTarget target) throws WebUserAuthException { return true; diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/PlayerPageResolver.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/PlayerPageResolver.java index ae033ddba..92e5d4262 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/PlayerPageResolver.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/PlayerPageResolver.java @@ -16,12 +16,12 @@ */ package com.djrapitops.plan.delivery.webserver.pages; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.delivery.webserver.Request; import com.djrapitops.plan.delivery.webserver.RequestTarget; import com.djrapitops.plan.delivery.webserver.auth.Authentication; -import com.djrapitops.plan.delivery.webserver.response.Response; import com.djrapitops.plan.delivery.webserver.response.ResponseFactory; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.exceptions.WebUserAuthException; import com.djrapitops.plan.exceptions.connection.ForbiddenException; import com.djrapitops.plan.exceptions.connection.WebException; @@ -57,7 +57,7 @@ public class PlayerPageResolver implements PageResolver { } @Override - public Response resolve(Request request, RequestTarget target) throws WebException { + public Response_old resolve(Request request, RequestTarget target) throws WebException { if (target.isEmpty()) { return responseFactory.pageNotFound404(); } @@ -82,7 +82,7 @@ public class PlayerPageResolver implements PageResolver { @Override public boolean isAuthorized(Authentication auth, RequestTarget target) throws WebUserAuthException { - WebUser webUser = auth.getWebUser(); + WebUser_old webUser = auth.getWebUser(); return webUser.getPermLevel() <= 1 || webUser.getName().equalsIgnoreCase(target.get(target.size() - 1)); } } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/PlayersPageResolver.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/PlayersPageResolver.java index 27b998c39..991b4e6fe 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/PlayersPageResolver.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/PlayersPageResolver.java @@ -19,8 +19,8 @@ package com.djrapitops.plan.delivery.webserver.pages; import com.djrapitops.plan.delivery.webserver.Request; import com.djrapitops.plan.delivery.webserver.RequestTarget; import com.djrapitops.plan.delivery.webserver.auth.Authentication; -import com.djrapitops.plan.delivery.webserver.response.Response; import com.djrapitops.plan.delivery.webserver.response.ResponseFactory; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.exceptions.WebUserAuthException; import com.djrapitops.plan.exceptions.connection.ForbiddenException; import com.djrapitops.plan.exceptions.connection.WebException; @@ -51,7 +51,7 @@ public class PlayersPageResolver implements PageResolver { } @Override - public Response resolve(Request request, RequestTarget target) throws WebException { + public Response_old resolve(Request request, RequestTarget target) throws WebException { Database.State dbState = dbSystem.getDatabase().getState(); if (dbState != Database.State.OPEN) { throw new ForbiddenException("Database is " + dbState.name() + " - Please try again later. You can check database status with /plan info"); diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/RootPageResolver.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/RootPageResolver.java index 39271213b..5ea3ef4b6 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/RootPageResolver.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/RootPageResolver.java @@ -16,14 +16,14 @@ */ package com.djrapitops.plan.delivery.webserver.pages; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.delivery.rendering.html.Html; import com.djrapitops.plan.delivery.webserver.Request; import com.djrapitops.plan.delivery.webserver.RequestTarget; import com.djrapitops.plan.delivery.webserver.WebServer; import com.djrapitops.plan.delivery.webserver.auth.Authentication; -import com.djrapitops.plan.delivery.webserver.response.Response; import com.djrapitops.plan.delivery.webserver.response.ResponseFactory; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.exceptions.connection.WebException; import com.djrapitops.plan.identification.Server; import com.djrapitops.plan.identification.ServerInfo; @@ -48,7 +48,7 @@ public class RootPageResolver implements PageResolver { } @Override - public Response resolve(Request request, RequestTarget target) throws WebException { + public Response_old resolve(Request request, RequestTarget target) throws WebException { Server server = serverInfo.getServer(); if (!webServer.isAuthRequired()) { return responseFactory.redirectResponse(server.isProxy() ? "network" : "server/" + Html.encodeToURL(server.getIdentifiableName())); @@ -59,7 +59,7 @@ public class RootPageResolver implements PageResolver { return responseFactory.basicAuth(); } - WebUser webUser = auth.get().getWebUser(); + WebUser_old webUser = auth.get().getWebUser(); int permLevel = webUser.getPermLevel(); switch (permLevel) { diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/ServerPageResolver.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/ServerPageResolver.java index acf348664..bfc35f75b 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/ServerPageResolver.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/ServerPageResolver.java @@ -21,8 +21,8 @@ import com.djrapitops.plan.delivery.webserver.Request; import com.djrapitops.plan.delivery.webserver.RequestTarget; import com.djrapitops.plan.delivery.webserver.WebServer; import com.djrapitops.plan.delivery.webserver.auth.Authentication; -import com.djrapitops.plan.delivery.webserver.response.Response; import com.djrapitops.plan.delivery.webserver.response.ResponseFactory; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.exceptions.WebUserAuthException; import com.djrapitops.plan.exceptions.connection.ForbiddenException; import com.djrapitops.plan.exceptions.connection.WebException; @@ -65,7 +65,7 @@ public class ServerPageResolver implements PageResolver { } @Override - public Response resolve(Request request, RequestTarget target) throws WebException { + public Response_old resolve(Request request, RequestTarget target) throws WebException { Optional serverUUID = getServerUUID(target); boolean proxy = serverInfo.getServer().isProxy(); if (serverUUID.isPresent()) { diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/GraphsJSONResolver.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/GraphsJSONResolver.java index be5d7c688..9892ddec3 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/GraphsJSONResolver.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/GraphsJSONResolver.java @@ -23,7 +23,7 @@ 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.PageResolver; -import com.djrapitops.plan.delivery.webserver.response.Response; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse; import com.djrapitops.plan.exceptions.WebUserAuthException; import com.djrapitops.plan.exceptions.connection.BadRequestException; @@ -56,7 +56,7 @@ public class GraphsJSONResolver implements PageResolver { } @Override - public Response resolve(Request request, RequestTarget target) throws WebException { + public Response_old resolve(Request request, RequestTarget target) throws WebException { String type = target.getParameter("type") .orElseThrow(() -> new BadRequestException("'type' parameter was not defined.")); diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/NetworkTabJSONResolver.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/NetworkTabJSONResolver.java index 1956f7f36..34604c801 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/NetworkTabJSONResolver.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/NetworkTabJSONResolver.java @@ -23,7 +23,7 @@ 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.PageResolver; -import com.djrapitops.plan.delivery.webserver.response.Response; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse; import com.djrapitops.plan.exceptions.WebUserAuthException; @@ -45,7 +45,7 @@ public class NetworkTabJSONResolver implements PageResolver { } @Override - public Response resolve(Request request, RequestTarget target) { + public Response_old resolve(Request request, RequestTarget target) { return JSONCache.getOrCache(dataID, () -> new JSONResponse(jsonCreator.get())); } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/PlayerJSONResolver.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/PlayerJSONResolver.java index a83462b1e..eb9248ea4 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/PlayerJSONResolver.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/PlayerJSONResolver.java @@ -16,13 +16,13 @@ */ package com.djrapitops.plan.delivery.webserver.pages.json; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.delivery.rendering.json.PlayerJSONCreator; import com.djrapitops.plan.delivery.webserver.Request; import com.djrapitops.plan.delivery.webserver.RequestTarget; import com.djrapitops.plan.delivery.webserver.auth.Authentication; import com.djrapitops.plan.delivery.webserver.pages.PageResolver; -import com.djrapitops.plan.delivery.webserver.response.Response; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse; import com.djrapitops.plan.exceptions.WebUserAuthException; import com.djrapitops.plan.exceptions.connection.WebException; @@ -45,14 +45,14 @@ public class PlayerJSONResolver implements PageResolver { } @Override - public Response resolve(Request request, RequestTarget target) throws WebException { + public Response_old resolve(Request request, RequestTarget target) throws WebException { UUID playerUUID = identifiers.getPlayerUUID(target); // Can throw BadRequestException return new JSONResponse(jsonCreator.createJSONAsMap(playerUUID)); } @Override public boolean isAuthorized(Authentication auth, RequestTarget target) throws WebUserAuthException { - WebUser webUser = auth.getWebUser(); + WebUser_old webUser = auth.getWebUser(); return webUser.getPermLevel() <= 1 || webUser.getName().equalsIgnoreCase(target.get(target.size() - 1)); } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/PlayerKillsJSONResolver.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/PlayerKillsJSONResolver.java index 912456a98..77fb3e7e0 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/PlayerKillsJSONResolver.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/PlayerKillsJSONResolver.java @@ -23,7 +23,7 @@ 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.PageResolver; -import com.djrapitops.plan.delivery.webserver.response.Response; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse; import com.djrapitops.plan.exceptions.WebUserAuthException; import com.djrapitops.plan.exceptions.connection.WebException; @@ -55,7 +55,7 @@ public class PlayerKillsJSONResolver implements PageResolver { } @Override - public Response resolve(Request request, RequestTarget target) throws WebException { + public Response_old resolve(Request request, RequestTarget target) throws WebException { UUID serverUUID = identifiers.getServerUUID(target); return JSONCache.getOrCache(DataID.KILLS, serverUUID, () -> new JSONResponse(Collections.singletonMap("player_kills", jsonFactory.serverPlayerKillsAsJSONMap(serverUUID))) diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/PlayersTableJSONResolver.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/PlayersTableJSONResolver.java index bb74500c5..7142b0762 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/PlayersTableJSONResolver.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/PlayersTableJSONResolver.java @@ -23,7 +23,7 @@ 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.PageResolver; -import com.djrapitops.plan.delivery.webserver.response.Response; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse; import com.djrapitops.plan.exceptions.WebUserAuthException; import com.djrapitops.plan.exceptions.connection.WebException; @@ -54,7 +54,7 @@ public class PlayersTableJSONResolver implements PageResolver { } @Override - public Response resolve(Request request, RequestTarget target) throws WebException { + public Response_old resolve(Request request, RequestTarget target) throws WebException { if (target.getParameter("server").isPresent()) { UUID serverUUID = identifiers.getServerUUID(target); // Can throw BadRequestException return JSONCache.getOrCache(DataID.PLAYERS, serverUUID, () -> new JSONResponse(jsonFactory.serverPlayersTableJSON(serverUUID))); diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/ServerTabJSONResolver.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/ServerTabJSONResolver.java index cac1458aa..7c8fd7ee0 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/ServerTabJSONResolver.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/ServerTabJSONResolver.java @@ -23,7 +23,7 @@ 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.PageResolver; -import com.djrapitops.plan.delivery.webserver.response.Response; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse; import com.djrapitops.plan.exceptions.WebUserAuthException; import com.djrapitops.plan.exceptions.connection.WebException; @@ -54,7 +54,7 @@ public class ServerTabJSONResolver implements PageResolver { } @Override - public Response resolve(Request request, RequestTarget target) throws WebException { + public Response_old resolve(Request request, RequestTarget target) throws WebException { UUID serverUUID = identifiers.getServerUUID(target); // Can throw BadRequestException return JSONCache.getOrCache(dataID, serverUUID, () -> new JSONResponse(jsonCreator.apply(serverUUID))); } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/SessionsJSONResolver.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/SessionsJSONResolver.java index b6dae4fbf..12cf02753 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/SessionsJSONResolver.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/pages/json/SessionsJSONResolver.java @@ -23,7 +23,7 @@ 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.PageResolver; -import com.djrapitops.plan.delivery.webserver.response.Response; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.delivery.webserver.response.data.JSONResponse; import com.djrapitops.plan.exceptions.WebUserAuthException; import com.djrapitops.plan.exceptions.connection.WebException; @@ -55,7 +55,7 @@ public class SessionsJSONResolver implements PageResolver { } @Override - public Response resolve(Request request, RequestTarget target) throws WebException { + public Response_old resolve(Request request, RequestTarget target) throws WebException { if (target.getParameter("server").isPresent()) { UUID serverUUID = identifiers.getServerUUID(target); return JSONCache.getOrCache(DataID.SESSIONS, serverUUID, () -> diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/ByteResponse.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/ByteResponse.java index 3ca48c558..28d6f7119 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/ByteResponse.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/ByteResponse.java @@ -26,11 +26,11 @@ import java.io.InputStream; import java.io.OutputStream; /** - * {@link Response} for raw bytes. + * {@link Response_old} for raw bytes. * * @author Rsl1122 */ -public class ByteResponse extends Response { +public class ByteResponse extends Response_old { private final PlanFiles files; private final String fileName; diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/FileResponse.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/FileResponse.java index 94a9202b3..eef72d07b 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/FileResponse.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/FileResponse.java @@ -29,7 +29,7 @@ import java.io.IOException; * * @author Rsl1122 */ -public class FileResponse extends Response { +public class FileResponse extends Response_old { public FileResponse(String fileName, PlanFiles files) throws IOException { super.setHeader("HTTP/1.1 200 OK"); diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/OptionsResponse.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/OptionsResponse.java index f108fc6c2..b9b94f977 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/OptionsResponse.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/OptionsResponse.java @@ -22,7 +22,7 @@ package com.djrapitops.plan.delivery.webserver.response; * * @author Rsl1122 */ -public class OptionsResponse extends Response { +public class OptionsResponse extends Response_old { public OptionsResponse() { setHeader("HTTP/1.1 204 No Content"); diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/RedirectResponse.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/RedirectResponse.java index ea3a9d561..45b10d733 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/RedirectResponse.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/RedirectResponse.java @@ -25,7 +25,7 @@ import java.io.IOException; /** * @author Rsl1122 */ -public class RedirectResponse extends Response { +public class RedirectResponse extends Response_old { private final String direct; diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/ResponseFactory.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/ResponseFactory.java index da45a618d..2eb7938b0 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/ResponseFactory.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/ResponseFactory.java @@ -16,10 +16,12 @@ */ package com.djrapitops.plan.delivery.webserver.response; +import com.djrapitops.plan.delivery.rendering.pages.Page; import com.djrapitops.plan.delivery.rendering.pages.PageFactory; +import com.djrapitops.plan.delivery.web.resolver.MimeType; +import com.djrapitops.plan.delivery.web.resolver.Response; import com.djrapitops.plan.delivery.webserver.response.errors.*; import com.djrapitops.plan.delivery.webserver.response.pages.*; -import com.djrapitops.plan.exceptions.GenerationException; import com.djrapitops.plan.exceptions.WebUserAuthException; import com.djrapitops.plan.exceptions.connection.NotFoundException; import com.djrapitops.plan.settings.locale.Locale; @@ -35,7 +37,7 @@ import java.io.IOException; import java.util.UUID; /** - * Factory for creating different {@link Response} objects. + * Factory for creating different {@link Response_old} objects. * * @author Rsl1122 */ @@ -64,6 +66,28 @@ public class ResponseFactory { } public Response debugPageResponse() { + try { + return forPage(pageFactory.debugPage()); + } catch (IOException e) { + return forInternalError("Failed to generate debug page", e); + } + } + + public Response forPage(Page page) throws IOException { + return Response.builder().setContent(page.toHtml()) + .setMimeType(MimeType.HTML) + .build(); + } + + public Response forInternalError(String cause, Throwable error) { + return Response.builder().setContent(pageFactory.internalErrorPage(cause, error).toHtml()) + .setMimeType(MimeType.HTML) + .setStatus(500) + .build(); + } + + @Deprecated + public Response_old debugPageResponse_old() { try { return new DebugPageResponse(pageFactory.debugPage(), versionCheckSystem, files); } catch (IOException e) { @@ -71,10 +95,10 @@ public class ResponseFactory { } } - public Response playersPageResponse() { + public Response_old playersPageResponse() { try { return new PlayersPageResponse(pageFactory.playersPage()); - } catch (GenerationException e) { + } catch (IOException e) { return internalErrorResponse(e, "Failed to generate players page"); } } @@ -91,18 +115,18 @@ public class ResponseFactory { } } - public Response networkPageResponse() { + public Response_old networkPageResponse() { try { return new PageResponse(pageFactory.networkPage()); - } catch (GenerationException e) { + } catch (IOException e) { return internalErrorResponse(e, "Failed to generate network page"); } } - public Response serverPageResponse(UUID serverUUID) throws NotFoundException { + public Response_old serverPageResponse(UUID serverUUID) throws NotFoundException { try { return new PageResponse(pageFactory.serverPage(serverUUID)); - } catch (GenerationException e) { + } catch (IOException e) { return internalErrorResponse(e, "Failed to generate server page"); } } @@ -111,7 +135,7 @@ public class ResponseFactory { return new RawPlayerDataResponse(dbSystem.getDatabase().query(ContainerFetchQueries.fetchPlayerContainer(uuid))); } - public Response javaScriptResponse(String fileName) { + public Response_old javaScriptResponse(String fileName) { try { return new JavaScriptResponse(fileName, files, locale); } catch (IOException e) { @@ -119,7 +143,7 @@ public class ResponseFactory { } } - public Response cssResponse(String fileName) { + public Response_old cssResponse(String fileName) { try { return new CSSResponse(fileName, files); } catch (IOException e) { @@ -127,11 +151,11 @@ public class ResponseFactory { } } - public Response imageResponse(String fileName) { + public Response_old imageResponse(String fileName) { return new ByteResponse(ResponseType.IMAGE, FileResponse.format(fileName), files); } - public Response fontResponse(String fileName) { + public Response_old fontResponse(String fileName) { ResponseType type = ResponseType.FONT_BYTESTREAM; if (fileName.endsWith(".woff")) { type = ResponseType.FONT_WOFF; @@ -151,11 +175,11 @@ public class ResponseFactory { * @param location Starts with '/' * @return Redirection response. */ - public Response redirectResponse(String location) { + public Response_old redirectResponse(String location) { return new RedirectResponse(location); } - public Response faviconResponse() { + public Response_old faviconResponse() { return new ByteResponse(ResponseType.X_ICON, "web/favicon.ico", files); } @@ -212,12 +236,12 @@ public class ResponseFactory { return new BadRequestResponse(errorMessage + " (when requesting '" + target + "')"); } - public Response playerPageResponse(UUID playerUUID) { + public Response_old playerPageResponse(UUID playerUUID) { try { return new PageResponse(pageFactory.playerPage(playerUUID)); } catch (IllegalStateException e) { return playerNotFound404(); - } catch (GenerationException e) { + } catch (IOException e) { return internalErrorResponse(e, "Failed to generate player page"); } } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/Response.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/Response_old.java similarity index 83% rename from Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/Response.java rename to Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/Response_old.java index 1394ca43c..99251debf 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/Response.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/Response_old.java @@ -25,6 +25,7 @@ import org.apache.commons.lang3.StringUtils; import java.io.ByteArrayInputStream; import java.io.IOException; import java.nio.charset.StandardCharsets; +import java.util.Map; import java.util.Objects; import java.util.Optional; import java.util.function.Function; @@ -33,7 +34,8 @@ import java.util.zip.GZIPOutputStream; /** * @author Rsl1122 */ -public abstract class Response { +@Deprecated +public abstract class Response_old { private String type; private String header; @@ -41,14 +43,14 @@ public abstract class Response { protected Headers responseHeaders; - public Response(ResponseType type) { + public Response_old(ResponseType type) { this.type = type.get(); } /** * Default Response constructor that defaults ResponseType to HTML. */ - public Response() { + public Response_old() { this(ResponseType.HTML); } @@ -94,13 +96,16 @@ public abstract class Response { return getHeader(null).map(h -> Integer.parseInt(StringUtils.split(h, ' ')[1])).orElse(500); } - @Override - public boolean equals(Object o) { - if (this == o) return true; - if (o == null || getClass() != o.getClass()) return false; - Response response = (Response) o; - return Objects.equals(header, response.header) && - Objects.equals(content, response.content); + @Deprecated + public static Response_old from(com.djrapitops.plan.delivery.web.resolver.Response apiResponse) { + Response_old response = new Response_old() {}; + response.setContent(apiResponse.getCharset().map(charset -> new String(apiResponse.getBytes(), charset)) + .orElse(new String(apiResponse.getBytes()))); + response.setHeader("HTTP/1.1 " + apiResponse.getCode() + " "); + for (Map.Entry header : apiResponse.getHeaders().entrySet()) { + response.header += header.getKey() + ": " + header.getValue() + ";\r\n"; + } + return response; } @Override @@ -145,4 +150,13 @@ public abstract class Response { public String toString() { return header + " | " + getResponse(); } + + @Override + public boolean equals(Object o) { + if (this == o) return true; + if (o == null || getClass() != o.getClass()) return false; + Response_old response = (Response_old) o; + return Objects.equals(header, response.header) && + Objects.equals(content, response.content); + } } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/TextResponse.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/TextResponse.java index f56558e49..1b5bfe80c 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/TextResponse.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/TextResponse.java @@ -21,7 +21,7 @@ package com.djrapitops.plan.delivery.webserver.response; * * @author Rsl1122 */ -public class TextResponse extends Response { +public class TextResponse extends Response_old { public TextResponse(String content) { setHeader("HTTP/1.1 200 OK"); diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/data/JSONResponse.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/data/JSONResponse.java index df754d95b..c855ed707 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/data/JSONResponse.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/data/JSONResponse.java @@ -16,8 +16,8 @@ */ package com.djrapitops.plan.delivery.webserver.response.data; -import com.djrapitops.plan.delivery.webserver.response.Response; import com.djrapitops.plan.delivery.webserver.response.ResponseType; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.google.gson.Gson; import com.google.gson.JsonElement; @@ -28,7 +28,7 @@ import com.google.gson.JsonElement; * * @author Rsl1122 */ -public class JSONResponse extends Response { +public class JSONResponse extends Response_old { public JSONResponse(Object object) { this(new Gson().toJson(object)); diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/errors/BadRequestResponse.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/errors/BadRequestResponse.java index 2fbdfcb83..0ef06c70d 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/errors/BadRequestResponse.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/errors/BadRequestResponse.java @@ -16,12 +16,12 @@ */ package com.djrapitops.plan.delivery.webserver.response.errors; -import com.djrapitops.plan.delivery.webserver.response.Response; +import com.djrapitops.plan.delivery.webserver.response.Response_old; /** * @author Fuzzlemann */ -public class BadRequestResponse extends Response { +public class BadRequestResponse extends Response_old { public BadRequestResponse(String error) { super.setHeader("HTTP/1.1 400 Bad Request " + error); diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/pages/PageResponse.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/pages/PageResponse.java index e114f6d2d..d111efb76 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/pages/PageResponse.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/pages/PageResponse.java @@ -17,9 +17,8 @@ package com.djrapitops.plan.delivery.webserver.response.pages; import com.djrapitops.plan.delivery.rendering.pages.Page; -import com.djrapitops.plan.delivery.webserver.response.Response; import com.djrapitops.plan.delivery.webserver.response.ResponseType; -import com.djrapitops.plan.exceptions.GenerationException; +import com.djrapitops.plan.delivery.webserver.response.Response_old; import com.djrapitops.plan.settings.locale.Locale; import com.djrapitops.plan.settings.theme.Theme; import com.googlecode.htmlcompressor.compressor.HtmlCompressor; @@ -32,7 +31,7 @@ import java.io.IOException; * * @author Rsl1122 */ -public class PageResponse extends Response { +public class PageResponse extends Response_old { private static final HtmlCompressor HTML_COMPRESSOR = new HtmlCompressor(); @@ -44,7 +43,7 @@ public class PageResponse extends Response { super(type); } - public PageResponse(Page page) throws GenerationException { + public PageResponse(Page page) { this(ResponseType.HTML); super.setHeader("HTTP/1.1 200 OK"); setContent(page.toHtml()); diff --git a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/pages/PlayersPageResponse.java b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/pages/PlayersPageResponse.java index 00bc14bc1..e5cb3a4af 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/pages/PlayersPageResponse.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/delivery/webserver/response/pages/PlayersPageResponse.java @@ -17,14 +17,13 @@ package com.djrapitops.plan.delivery.webserver.response.pages; import com.djrapitops.plan.delivery.rendering.pages.PlayersPage; -import com.djrapitops.plan.exceptions.GenerationException; /** * @author Rsl1122 */ public class PlayersPageResponse extends PageResponse { - public PlayersPageResponse(PlayersPage playersPage) throws GenerationException { + public PlayersPageResponse(PlayersPage playersPage) { setHeader("HTTP/1.1 200 OK"); setContent(playersPage.toHtml()); } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/exceptions/GenerationException.java b/Plan/common/src/main/java/com/djrapitops/plan/exceptions/GenerationException.java deleted file mode 100644 index 5d808ced4..000000000 --- a/Plan/common/src/main/java/com/djrapitops/plan/exceptions/GenerationException.java +++ /dev/null @@ -1,29 +0,0 @@ -/* - * This file is part of Player Analytics (Plan). - * - * Plan is free software: you can redistribute it and/or modify - * it under the terms of the GNU Lesser General Public License v3 as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * Plan is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public License - * along with Plan. If not, see . - */ -package com.djrapitops.plan.exceptions; - -/** - * Exception thrown when Page encounters an Exception. - * - * @author Rsl1122 - */ -public class GenerationException extends Exception { - - public GenerationException(Throwable cause) { - super(cause); - } -} diff --git a/Plan/common/src/main/java/com/djrapitops/plan/extension/ExtensionSvc.java b/Plan/common/src/main/java/com/djrapitops/plan/extension/ExtensionSvc.java index df28f6aec..9ce3c4943 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/extension/ExtensionSvc.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/extension/ExtensionSvc.java @@ -78,11 +78,13 @@ public class ExtensionSvc implements ExtensionService { this.errorHandler = errorHandler; extensionGatherers = new HashMap<>(); - - Holder.set(this); } public void register() { + Holder.set(this); + } + + public void registerExtensions() { try { extensionRegister.registerBuiltInExtensions(config.getExtensionSettings().getDisabled()); } catch (IllegalStateException failedToRegisterOne) { diff --git a/Plan/common/src/main/java/com/djrapitops/plan/settings/SettingsSvc.java b/Plan/common/src/main/java/com/djrapitops/plan/settings/SettingsSvc.java index e10581552..f233cf4a6 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/settings/SettingsSvc.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/settings/SettingsSvc.java @@ -49,7 +49,7 @@ public class SettingsSvc implements SettingsService { } public void register() { - SettingsService.SettingsServiceHolder.set(this); + Holder.set(this); } @Override diff --git a/Plan/common/src/main/java/com/djrapitops/plan/storage/database/queries/LargeStoreQueries.java b/Plan/common/src/main/java/com/djrapitops/plan/storage/database/queries/LargeStoreQueries.java index 2f12a8e09..3484e76b2 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/storage/database/queries/LargeStoreQueries.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/storage/database/queries/LargeStoreQueries.java @@ -17,7 +17,7 @@ package com.djrapitops.plan.storage.database.queries; import com.djrapitops.plan.delivery.domain.Nickname; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.delivery.domain.keys.SessionKeys; import com.djrapitops.plan.gathering.domain.*; import com.djrapitops.plan.identification.Server; @@ -119,7 +119,7 @@ public class LargeStoreQueries { * @param users Collection of Plan WebUsers. * @return Executable, use inside a {@link com.djrapitops.plan.storage.database.transactions.Transaction} */ - public static Executable storeAllPlanWebUsers(Collection users) { + public static Executable storeAllPlanWebUsers(Collection users) { if (Verify.isEmpty(users)) { return Executable.empty(); } @@ -127,7 +127,7 @@ public class LargeStoreQueries { return new ExecBatchStatement(SecurityTable.INSERT_STATEMENT) { @Override public void prepare(PreparedStatement statement) throws SQLException { - for (WebUser user : users) { + for (WebUser_old user : users) { String userName = user.getName(); String pass = user.getSaltedPassHash(); int permLvl = user.getPermLevel(); diff --git a/Plan/common/src/main/java/com/djrapitops/plan/storage/database/queries/objects/PingQueries.java b/Plan/common/src/main/java/com/djrapitops/plan/storage/database/queries/objects/PingQueries.java index 4a301fc60..5a0146017 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/storage/database/queries/objects/PingQueries.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/storage/database/queries/objects/PingQueries.java @@ -16,7 +16,7 @@ */ package com.djrapitops.plan.storage.database.queries.objects; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.gathering.domain.Ping; import com.djrapitops.plan.storage.database.queries.Query; import com.djrapitops.plan.storage.database.queries.QueryAllStatement; @@ -33,7 +33,7 @@ import java.util.*; import static com.djrapitops.plan.storage.database.sql.building.Sql.*; /** - * Queries for {@link WebUser} objects. + * Queries for {@link WebUser_old} objects. * * @author Rsl1122 */ diff --git a/Plan/common/src/main/java/com/djrapitops/plan/storage/database/queries/objects/WebUserQueries.java b/Plan/common/src/main/java/com/djrapitops/plan/storage/database/queries/objects/WebUserQueries.java index 085b77caa..601750e5e 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/storage/database/queries/objects/WebUserQueries.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/storage/database/queries/objects/WebUserQueries.java @@ -16,7 +16,7 @@ */ package com.djrapitops.plan.storage.database.queries.objects; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.storage.database.queries.Query; import com.djrapitops.plan.storage.database.queries.QueryAllStatement; import com.djrapitops.plan.storage.database.queries.QueryStatement; @@ -32,7 +32,7 @@ import java.util.Optional; import static com.djrapitops.plan.storage.database.sql.building.Sql.*; /** - * Queries for {@link WebUser} objects. + * Queries for {@link WebUser_old} objects. * * @author Rsl1122 */ @@ -47,18 +47,18 @@ public class WebUserQueries { * * @return List of Plan WebUsers. */ - public static Query> fetchAllPlanWebUsers() { + public static Query> fetchAllPlanWebUsers() { String sql = SELECT + '*' + FROM + SecurityTable.TABLE_NAME + ORDER_BY + SecurityTable.PERMISSION_LEVEL + " ASC"; - return new QueryAllStatement>(sql, 5000) { + return new QueryAllStatement>(sql, 5000) { @Override - public List processResults(ResultSet set) throws SQLException { - List list = new ArrayList<>(); + public List processResults(ResultSet set) throws SQLException { + List list = new ArrayList<>(); while (set.next()) { String user = set.getString(SecurityTable.USERNAME); String saltedPassHash = set.getString(SecurityTable.SALT_PASSWORD_HASH); int permissionLevel = set.getInt(SecurityTable.PERMISSION_LEVEL); - WebUser info = new WebUser(user, saltedPassHash, permissionLevel); + WebUser_old info = new WebUser_old(user, saltedPassHash, permissionLevel); list.add(info); } return list; @@ -66,21 +66,21 @@ public class WebUserQueries { }; } - public static Query> fetchWebUser(String called) { + public static Query> fetchWebUser(String called) { String sql = SELECT + '*' + FROM + SecurityTable.TABLE_NAME + WHERE + SecurityTable.USERNAME + "=? LIMIT 1"; - return new QueryStatement>(sql) { + return new QueryStatement>(sql) { @Override public void prepare(PreparedStatement statement) throws SQLException { statement.setString(1, called); } @Override - public Optional processResults(ResultSet set) throws SQLException { + public Optional processResults(ResultSet set) throws SQLException { if (set.next()) { String saltedPassHash = set.getString(SecurityTable.SALT_PASSWORD_HASH); int permissionLevel = set.getInt(SecurityTable.PERMISSION_LEVEL); - return Optional.of(new WebUser(called, saltedPassHash, permissionLevel)); + return Optional.of(new WebUser_old(called, saltedPassHash, permissionLevel)); } return Optional.empty(); } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/storage/database/transactions/commands/RegisterWebUserTransaction.java b/Plan/common/src/main/java/com/djrapitops/plan/storage/database/transactions/commands/RegisterWebUserTransaction.java index 4dd004a37..6a762818d 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/storage/database/transactions/commands/RegisterWebUserTransaction.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/storage/database/transactions/commands/RegisterWebUserTransaction.java @@ -16,7 +16,7 @@ */ package com.djrapitops.plan.storage.database.transactions.commands; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.storage.database.sql.tables.SecurityTable; import com.djrapitops.plan.storage.database.transactions.ExecStatement; import com.djrapitops.plan.storage.database.transactions.Transaction; @@ -25,15 +25,15 @@ import java.sql.PreparedStatement; import java.sql.SQLException; /** - * Transaction to save a new Plan {@link WebUser} to the database. + * Transaction to save a new Plan {@link WebUser_old} to the database. * * @author Rsl1122 */ public class RegisterWebUserTransaction extends Transaction { - private final WebUser webUser; + private final WebUser_old webUser; - public RegisterWebUserTransaction(WebUser webUser) { + public RegisterWebUserTransaction(WebUser_old webUser) { this.webUser = webUser; } diff --git a/Plan/common/src/main/java/com/djrapitops/plan/storage/database/transactions/commands/RemoveWebUserTransaction.java b/Plan/common/src/main/java/com/djrapitops/plan/storage/database/transactions/commands/RemoveWebUserTransaction.java index d2ee58f72..e5c984b3f 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/storage/database/transactions/commands/RemoveWebUserTransaction.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/storage/database/transactions/commands/RemoveWebUserTransaction.java @@ -16,7 +16,7 @@ */ package com.djrapitops.plan.storage.database.transactions.commands; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.storage.database.sql.tables.SecurityTable; import com.djrapitops.plan.storage.database.transactions.ExecStatement; import com.djrapitops.plan.storage.database.transactions.Transaction; @@ -28,7 +28,7 @@ import static com.djrapitops.plan.storage.database.sql.building.Sql.DELETE_FROM; import static com.djrapitops.plan.storage.database.sql.building.Sql.WHERE; /** - * Transaction to remove a Plan {@link WebUser} from the database. + * Transaction to remove a Plan {@link WebUser_old} from the database. * * @author Rsl1122 */ diff --git a/Plan/common/src/main/java/com/djrapitops/plan/utilities/comparators/WebUserComparator.java b/Plan/common/src/main/java/com/djrapitops/plan/utilities/comparators/WebUserComparator.java index 856274b15..8d6e009d8 100644 --- a/Plan/common/src/main/java/com/djrapitops/plan/utilities/comparators/WebUserComparator.java +++ b/Plan/common/src/main/java/com/djrapitops/plan/utilities/comparators/WebUserComparator.java @@ -16,7 +16,7 @@ */ package com.djrapitops.plan.utilities.comparators; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import java.util.Comparator; @@ -25,10 +25,10 @@ import java.util.Comparator; * * @author Rsl1122 */ -public class WebUserComparator implements Comparator { +public class WebUserComparator implements Comparator { @Override - public int compare(WebUser o1, WebUser o2) { + public int compare(WebUser_old o1, WebUser_old o2) { return Integer.compare(o2.getPermLevel(), o1.getPermLevel()); } diff --git a/Plan/common/src/test/java/com/djrapitops/plan/delivery/webserver/JksHttpsServerTest.java b/Plan/common/src/test/java/com/djrapitops/plan/delivery/webserver/JksHttpsServerTest.java index b32398329..fc2eb2993 100644 --- a/Plan/common/src/test/java/com/djrapitops/plan/delivery/webserver/JksHttpsServerTest.java +++ b/Plan/common/src/test/java/com/djrapitops/plan/delivery/webserver/JksHttpsServerTest.java @@ -17,7 +17,7 @@ package com.djrapitops.plan.delivery.webserver; import com.djrapitops.plan.PlanSystem; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.settings.config.PlanConfig; import com.djrapitops.plan.settings.config.paths.WebserverSettings; import com.djrapitops.plan.storage.database.transactions.commands.RegisterWebUserTransaction; @@ -61,7 +61,7 @@ class JksHttpsServerTest implements HttpsServerTest { system.enable(); - WebUser webUser = new WebUser("test", PassEncryptUtil.createHash("testPass"), 0); + WebUser_old webUser = new WebUser_old("test", PassEncryptUtil.createHash("testPass"), 0); system.getDatabaseSystem().getDatabase().executeTransaction(new RegisterWebUserTransaction(webUser)); } diff --git a/Plan/common/src/test/java/com/djrapitops/plan/delivery/webserver/Pkcs12HttpsServerTest.java b/Plan/common/src/test/java/com/djrapitops/plan/delivery/webserver/Pkcs12HttpsServerTest.java index 3ec52abdb..2f935a3ac 100644 --- a/Plan/common/src/test/java/com/djrapitops/plan/delivery/webserver/Pkcs12HttpsServerTest.java +++ b/Plan/common/src/test/java/com/djrapitops/plan/delivery/webserver/Pkcs12HttpsServerTest.java @@ -17,7 +17,7 @@ package com.djrapitops.plan.delivery.webserver; import com.djrapitops.plan.PlanSystem; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.settings.config.PlanConfig; import com.djrapitops.plan.settings.config.changes.ConfigUpdater; import com.djrapitops.plan.settings.config.paths.WebserverSettings; @@ -66,7 +66,7 @@ class Pkcs12HttpsServerTest implements HttpsServerTest { system.enable(); - WebUser webUser = new WebUser("test", PassEncryptUtil.createHash("testPass"), 0); + WebUser_old webUser = new WebUser_old("test", PassEncryptUtil.createHash("testPass"), 0); system.getDatabaseSystem().getDatabase().executeTransaction(new RegisterWebUserTransaction(webUser)); } diff --git a/Plan/common/src/test/java/com/djrapitops/plan/storage/database/DatabaseTest.java b/Plan/common/src/test/java/com/djrapitops/plan/storage/database/DatabaseTest.java index 900b0cb4b..0fbb29415 100644 --- a/Plan/common/src/test/java/com/djrapitops/plan/storage/database/DatabaseTest.java +++ b/Plan/common/src/test/java/com/djrapitops/plan/storage/database/DatabaseTest.java @@ -21,7 +21,7 @@ import com.djrapitops.plan.data.element.TableContainer; import com.djrapitops.plan.delivery.domain.DateObj; import com.djrapitops.plan.delivery.domain.Nickname; import com.djrapitops.plan.delivery.domain.TablePlayer; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.delivery.domain.container.PlayerContainer; import com.djrapitops.plan.delivery.domain.container.ServerContainer; import com.djrapitops.plan.delivery.domain.keys.Key; @@ -208,11 +208,11 @@ public interface DatabaseTest { @Test default void webUserIsRegistered() { - WebUser expected = new WebUser(TestConstants.PLAYER_ONE_NAME, "RandomGarbageBlah", 0); + WebUser_old expected = new WebUser_old(TestConstants.PLAYER_ONE_NAME, "RandomGarbageBlah", 0); db().executeTransaction(new RegisterWebUserTransaction(expected)); commitTest(); - Optional found = db().query(WebUserQueries.fetchWebUser(TestConstants.PLAYER_ONE_NAME)); + Optional found = db().query(WebUserQueries.fetchWebUser(TestConstants.PLAYER_ONE_NAME)); assertTrue(found.isPresent()); assertEquals(expected, found.get()); } @@ -500,7 +500,7 @@ public interface DatabaseTest { Collections.singletonList(new DateObj<>(System.currentTimeMillis(), r.nextInt()))) ); - WebUser webUser = new WebUser(TestConstants.PLAYER_ONE_NAME, "RandomGarbageBlah", 0); + WebUser_old webUser = new WebUser_old(TestConstants.PLAYER_ONE_NAME, "RandomGarbageBlah", 0); db().executeTransaction(new RegisterWebUserTransaction(webUser)); } diff --git a/Plan/common/src/test/java/com/djrapitops/plan/utilities/comparators/ComparatorTest.java b/Plan/common/src/test/java/com/djrapitops/plan/utilities/comparators/ComparatorTest.java index df7d8a6ef..4505f07b0 100644 --- a/Plan/common/src/test/java/com/djrapitops/plan/utilities/comparators/ComparatorTest.java +++ b/Plan/common/src/test/java/com/djrapitops/plan/utilities/comparators/ComparatorTest.java @@ -16,7 +16,7 @@ */ package com.djrapitops.plan.utilities.comparators; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.delivery.domain.keys.SessionKeys; import com.djrapitops.plan.delivery.rendering.json.graphs.line.Point; import com.djrapitops.plan.gathering.domain.GeoInfo; @@ -83,14 +83,14 @@ class ComparatorTest { @Test void webUserComparator() throws PassEncryptUtil.CannotPerformOperationException { - List webUsers = RandomData.randomWebUsers(); + List webUsers = RandomData.randomWebUsers(); - List expected = webUsers.stream().map(WebUser::getPermLevel) + List expected = webUsers.stream().map(WebUser_old::getPermLevel) .sorted(Integer::compare).collect(Collectors.toList()); Collections.reverse(expected); webUsers.sort(new WebUserComparator()); - List result = Lists.map(webUsers, WebUser::getPermLevel); + List result = Lists.map(webUsers, WebUser_old::getPermLevel); assertEquals(expected, result); } diff --git a/Plan/common/src/test/java/utilities/RandomData.java b/Plan/common/src/test/java/utilities/RandomData.java index f2a5f077c..fa20db9af 100644 --- a/Plan/common/src/test/java/utilities/RandomData.java +++ b/Plan/common/src/test/java/utilities/RandomData.java @@ -16,7 +16,7 @@ */ package utilities; -import com.djrapitops.plan.delivery.domain.WebUser; +import com.djrapitops.plan.delivery.domain.WebUser_old; import com.djrapitops.plan.delivery.rendering.json.graphs.line.Point; import com.djrapitops.plan.gathering.domain.GeoInfo; import com.djrapitops.plan.gathering.domain.Session; @@ -51,10 +51,10 @@ public class RandomData { return RandomStringUtils.randomAlphanumeric(size); } - public static List randomWebUsers() throws PassEncryptUtil.CannotPerformOperationException { - List test = new ArrayList<>(); + public static List randomWebUsers() throws PassEncryptUtil.CannotPerformOperationException { + List test = new ArrayList<>(); for (int i = 0; i < 20; i++) { - test.add(new WebUser(randomString(5), PassEncryptUtil.createHash(randomString(7)), r.nextInt())); + test.add(new WebUser_old(randomString(5), PassEncryptUtil.createHash(randomString(7)), r.nextInt())); } return test; }