mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2025-01-01 14:07:54 +01:00
Finished basic responses for ResponseHandler
This commit is contained in:
parent
65b45ce92c
commit
15c6e17173
@ -3,6 +3,7 @@ package com.djrapitops.plan.command.commands.manage;
|
|||||||
import com.djrapitops.plan.Plan;
|
import com.djrapitops.plan.Plan;
|
||||||
import com.djrapitops.plan.api.exceptions.database.DBException;
|
import com.djrapitops.plan.api.exceptions.database.DBException;
|
||||||
import com.djrapitops.plan.api.exceptions.database.DBInitException;
|
import com.djrapitops.plan.api.exceptions.database.DBInitException;
|
||||||
|
import com.djrapitops.plan.api.exceptions.database.FatalDBException;
|
||||||
import com.djrapitops.plan.data.container.Session;
|
import com.djrapitops.plan.data.container.Session;
|
||||||
import com.djrapitops.plan.settings.locale.Locale;
|
import com.djrapitops.plan.settings.locale.Locale;
|
||||||
import com.djrapitops.plan.settings.locale.Msg;
|
import com.djrapitops.plan.settings.locale.Msg;
|
||||||
@ -95,9 +96,13 @@ public class ManageClearCommand extends SubCommand {
|
|||||||
new Session(now, player.getWorld().getName(), player.getGameMode().name()))
|
new Session(now, player.getWorld().getName(), player.getGameMode().name()))
|
||||||
);
|
);
|
||||||
sender.sendMessage(Locale.get(Msg.MANAGE_INFO_CLEAR_SUCCESS).toString());
|
sender.sendMessage(Locale.get(Msg.MANAGE_INFO_CLEAR_SUCCESS).toString());
|
||||||
|
} catch (FatalDBException e) {
|
||||||
|
sender.sendMessage(Locale.get(Msg.MANAGE_INFO_FAIL).toString()
|
||||||
|
+ " Error was fatal, so all information may not have been removed.");
|
||||||
|
Log.toLog(this.getClass(), e);
|
||||||
} catch (DBException e) {
|
} catch (DBException e) {
|
||||||
sender.sendMessage(Locale.get(Msg.MANAGE_INFO_FAIL).toString());
|
sender.sendMessage(Locale.get(Msg.MANAGE_INFO_FAIL).toString());
|
||||||
Log.toLog(this.getClass().getSimpleName() + "/" + this.getTaskName(), e);
|
Log.toLog(this.getClass(), e);
|
||||||
} finally {
|
} finally {
|
||||||
this.cancel();
|
this.cancel();
|
||||||
}
|
}
|
||||||
|
@ -5,6 +5,7 @@ import com.djrapitops.plan.data.PlayerProfile;
|
|||||||
import com.djrapitops.plan.data.ServerProfile;
|
import com.djrapitops.plan.data.ServerProfile;
|
||||||
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.Optional;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
@ -19,4 +20,6 @@ public interface FetchOperations {
|
|||||||
Set<UUID> getSavedUUIDs(UUID server) throws DBException;
|
Set<UUID> getSavedUUIDs(UUID server) throws DBException;
|
||||||
|
|
||||||
Map<UUID, String> getServerNames() throws DBException;
|
Map<UUID, String> getServerNames() throws DBException;
|
||||||
|
|
||||||
|
Optional<UUID> getServerUUID(String serverName) throws DBException;
|
||||||
}
|
}
|
||||||
|
@ -9,6 +9,10 @@ import com.djrapitops.plan.system.database.databases.operation.BackupOperations;
|
|||||||
import com.djrapitops.plan.system.database.databases.operation.CheckOperations;
|
import com.djrapitops.plan.system.database.databases.operation.CheckOperations;
|
||||||
import com.djrapitops.plan.system.database.databases.operation.FetchOperations;
|
import com.djrapitops.plan.system.database.databases.operation.FetchOperations;
|
||||||
import com.djrapitops.plan.system.database.databases.operation.RemoveOperations;
|
import com.djrapitops.plan.system.database.databases.operation.RemoveOperations;
|
||||||
|
import com.djrapitops.plan.system.database.databases.sql.operation.SQLBackupOps;
|
||||||
|
import com.djrapitops.plan.system.database.databases.sql.operation.SQLCheckOps;
|
||||||
|
import com.djrapitops.plan.system.database.databases.sql.operation.SQLFetchOps;
|
||||||
|
import com.djrapitops.plan.system.database.databases.sql.operation.SQLRemoveOps;
|
||||||
import com.djrapitops.plan.system.database.databases.sql.tables.*;
|
import com.djrapitops.plan.system.database.databases.sql.tables.*;
|
||||||
import com.djrapitops.plan.system.database.databases.sql.tables.move.Version8TransferTable;
|
import com.djrapitops.plan.system.database.databases.sql.tables.move.Version8TransferTable;
|
||||||
import com.djrapitops.plan.utilities.MiscUtils;
|
import com.djrapitops.plan.utilities.MiscUtils;
|
||||||
|
@ -1,7 +1,8 @@
|
|||||||
package com.djrapitops.plan.system.database.databases.sql;
|
package com.djrapitops.plan.system.database.databases.sql.operation;
|
||||||
|
|
||||||
import com.djrapitops.plan.system.database.databases.Database;
|
import com.djrapitops.plan.system.database.databases.Database;
|
||||||
import com.djrapitops.plan.system.database.databases.operation.BackupOperations;
|
import com.djrapitops.plan.system.database.databases.operation.BackupOperations;
|
||||||
|
import com.djrapitops.plan.system.database.databases.sql.SQLDB;
|
||||||
|
|
||||||
public class SQLBackupOps implements BackupOperations {
|
public class SQLBackupOps implements BackupOperations {
|
||||||
|
|
@ -1,7 +1,9 @@
|
|||||||
package com.djrapitops.plan.system.database.databases.sql;
|
package com.djrapitops.plan.system.database.databases.sql.operation;
|
||||||
|
|
||||||
import com.djrapitops.plan.api.exceptions.database.DBException;
|
import com.djrapitops.plan.api.exceptions.database.DBException;
|
||||||
import com.djrapitops.plan.system.database.databases.operation.CheckOperations;
|
import com.djrapitops.plan.system.database.databases.operation.CheckOperations;
|
||||||
|
import com.djrapitops.plan.system.database.databases.sql.ErrorUtil;
|
||||||
|
import com.djrapitops.plan.system.database.databases.sql.SQLDB;
|
||||||
|
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
@ -1,4 +1,4 @@
|
|||||||
package com.djrapitops.plan.system.database.databases.sql;
|
package com.djrapitops.plan.system.database.databases.sql.operation;
|
||||||
|
|
||||||
import com.djrapitops.plan.api.exceptions.database.DBException;
|
import com.djrapitops.plan.api.exceptions.database.DBException;
|
||||||
import com.djrapitops.plan.data.PlayerProfile;
|
import com.djrapitops.plan.data.PlayerProfile;
|
||||||
@ -6,6 +6,8 @@ import com.djrapitops.plan.data.ServerProfile;
|
|||||||
import com.djrapitops.plan.data.container.Session;
|
import com.djrapitops.plan.data.container.Session;
|
||||||
import com.djrapitops.plan.data.container.UserInfo;
|
import com.djrapitops.plan.data.container.UserInfo;
|
||||||
import com.djrapitops.plan.system.database.databases.operation.FetchOperations;
|
import com.djrapitops.plan.system.database.databases.operation.FetchOperations;
|
||||||
|
import com.djrapitops.plan.system.database.databases.sql.ErrorUtil;
|
||||||
|
import com.djrapitops.plan.system.database.databases.sql.SQLDB;
|
||||||
|
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
@ -97,4 +99,13 @@ public class SQLFetchOps extends SQLOps implements FetchOperations {
|
|||||||
throw ErrorUtil.getExceptionFor(e);
|
throw ErrorUtil.getExceptionFor(e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Optional<UUID> getServerUUID(String serverName) throws DBException {
|
||||||
|
try {
|
||||||
|
return serverTable.getServerUUID(serverName);
|
||||||
|
} catch (SQLException e) {
|
||||||
|
throw ErrorUtil.getExceptionFor(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
@ -1,5 +1,6 @@
|
|||||||
package com.djrapitops.plan.system.database.databases.sql;
|
package com.djrapitops.plan.system.database.databases.sql.operation;
|
||||||
|
|
||||||
|
import com.djrapitops.plan.system.database.databases.sql.SQLDB;
|
||||||
import com.djrapitops.plan.system.database.databases.sql.tables.*;
|
import com.djrapitops.plan.system.database.databases.sql.tables.*;
|
||||||
|
|
||||||
public class SQLOps {
|
public class SQLOps {
|
@ -1,8 +1,10 @@
|
|||||||
package com.djrapitops.plan.system.database.databases.sql;
|
package com.djrapitops.plan.system.database.databases.sql.operation;
|
||||||
|
|
||||||
import com.djrapitops.plan.api.exceptions.database.DBException;
|
import com.djrapitops.plan.api.exceptions.database.DBException;
|
||||||
import com.djrapitops.plan.api.exceptions.database.FatalDBException;
|
import com.djrapitops.plan.api.exceptions.database.FatalDBException;
|
||||||
import com.djrapitops.plan.system.database.databases.operation.RemoveOperations;
|
import com.djrapitops.plan.system.database.databases.operation.RemoveOperations;
|
||||||
|
import com.djrapitops.plan.system.database.databases.sql.ErrorUtil;
|
||||||
|
import com.djrapitops.plan.system.database.databases.sql.SQLDB;
|
||||||
import com.djrapitops.plan.system.database.databases.sql.tables.Table;
|
import com.djrapitops.plan.system.database.databases.sql.tables.Table;
|
||||||
import com.djrapitops.plan.system.database.databases.sql.tables.UserIDTable;
|
import com.djrapitops.plan.system.database.databases.sql.tables.UserIDTable;
|
||||||
import com.djrapitops.plugin.api.Benchmark;
|
import com.djrapitops.plugin.api.Benchmark;
|
||||||
@ -59,7 +61,7 @@ public class SQLRemoveOps extends SQLOps implements RemoveOperations {
|
|||||||
table.removeAllData();
|
table.removeAllData();
|
||||||
}
|
}
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
throw ErrorUtil.getExceptionFor(e);
|
throw ErrorUtil.getFatalExceptionFor(e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -68,7 +70,7 @@ public class SQLRemoveOps extends SQLOps implements RemoveOperations {
|
|||||||
try {
|
try {
|
||||||
securityTable.removeUser(userName);
|
securityTable.removeUser(userName);
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
throw ErrorUtil.getExceptionFor(e);
|
throw ErrorUtil.getFatalExceptionFor(e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,54 +0,0 @@
|
|||||||
/*
|
|
||||||
* Licence is provided in the jar as license.yml also here:
|
|
||||||
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
|
||||||
*/
|
|
||||||
package com.djrapitops.plan.system.webserver;
|
|
||||||
|
|
||||||
import com.djrapitops.plan.system.settings.Settings;
|
|
||||||
import com.djrapitops.plan.system.webserver.response.Response;
|
|
||||||
import com.djrapitops.plan.system.webserver.webapi.WebAPIManager;
|
|
||||||
import com.djrapitops.plugin.api.Benchmark;
|
|
||||||
import com.djrapitops.plugin.api.utility.log.Log;
|
|
||||||
import com.sun.net.httpserver.Headers;
|
|
||||||
import com.sun.net.httpserver.HttpExchange;
|
|
||||||
import com.sun.net.httpserver.HttpHandler;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* HttpHandler for webserver request management.
|
|
||||||
*
|
|
||||||
* @author Rsl1122
|
|
||||||
*/
|
|
||||||
public class APIRequestHandler implements HttpHandler {
|
|
||||||
|
|
||||||
private final APIResponseHandler responseHandler;
|
|
||||||
|
|
||||||
APIRequestHandler(WebAPIManager webAPI) {
|
|
||||||
responseHandler = new APIResponseHandler(webAPI);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void handle(HttpExchange exchange) {
|
|
||||||
Headers responseHeaders = exchange.getResponseHeaders();
|
|
||||||
Request request = new Request(exchange);
|
|
||||||
String requestString = request.toString();
|
|
||||||
Benchmark.start("", requestString);
|
|
||||||
int responseCode = -1;
|
|
||||||
try {
|
|
||||||
Response response = responseHandler.getAPIResponse(request);
|
|
||||||
responseCode = response.getCode();
|
|
||||||
response.setResponseHeaders(responseHeaders);
|
|
||||||
response.send(exchange);
|
|
||||||
} catch (Exception e) {
|
|
||||||
if (Settings.DEV_MODE.isTrue()) {
|
|
||||||
Log.toLog(this.getClass().getName(), e);
|
|
||||||
}
|
|
||||||
} finally {
|
|
||||||
exchange.close();
|
|
||||||
if (Settings.DEV_MODE.isTrue()) {
|
|
||||||
Log.debug(requestString + " Response code: " + responseCode + " took " + Benchmark.stop("", requestString) + " ms");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
@ -1,167 +0,0 @@
|
|||||||
/*
|
|
||||||
* Licence is provided in the jar as license.yml also here:
|
|
||||||
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
|
||||||
*/
|
|
||||||
package com.djrapitops.plan.system.webserver;
|
|
||||||
|
|
||||||
import com.djrapitops.plan.system.webserver.pagecache.PageId;
|
|
||||||
import com.djrapitops.plan.system.webserver.pagecache.ResponseCache;
|
|
||||||
import com.djrapitops.plan.system.webserver.response.CSSResponse;
|
|
||||||
import com.djrapitops.plan.system.webserver.response.JavaScriptResponse;
|
|
||||||
import com.djrapitops.plan.system.webserver.response.RedirectResponse;
|
|
||||||
import com.djrapitops.plan.system.webserver.response.Response;
|
|
||||||
import com.djrapitops.plan.system.webserver.response.api.BadRequestResponse;
|
|
||||||
import com.djrapitops.plan.system.webserver.response.errors.ForbiddenResponse;
|
|
||||||
import com.djrapitops.plan.system.webserver.response.errors.NotFoundResponse;
|
|
||||||
import com.djrapitops.plan.system.webserver.response.pages.DebugPageResponse;
|
|
||||||
import com.djrapitops.plan.system.webserver.webapi.WebAPI;
|
|
||||||
import com.djrapitops.plan.system.webserver.webapi.WebAPIManager;
|
|
||||||
import com.djrapitops.plan.utilities.html.Html;
|
|
||||||
import com.djrapitops.plugin.api.utility.log.Log;
|
|
||||||
|
|
||||||
import java.io.ByteArrayOutputStream;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStream;
|
|
||||||
import java.nio.charset.StandardCharsets;
|
|
||||||
import java.sql.SQLException;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Handles choosing of the correct API response to an API request.
|
|
||||||
*
|
|
||||||
* @author Rsl1122
|
|
||||||
*/
|
|
||||||
public class APIResponseHandler {
|
|
||||||
|
|
||||||
private final WebAPIManager webAPI;
|
|
||||||
|
|
||||||
public APIResponseHandler(WebAPIManager webAPI) {
|
|
||||||
this.webAPI = webAPI;
|
|
||||||
}
|
|
||||||
|
|
||||||
Response getAPIResponse(Request request) throws IOException {
|
|
||||||
String target = request.getTarget();
|
|
||||||
String[] args = target.split("/");
|
|
||||||
|
|
||||||
if ("/favicon.ico".equalsIgnoreCase(target)) {
|
|
||||||
return ResponseCache.loadResponse(PageId.FAVICON_REDIRECT.id(), () -> new RedirectResponse("https://puu.sh/tK0KL/6aa2ba141b.ico"));
|
|
||||||
}
|
|
||||||
if ("/debug".equalsIgnoreCase(target)) {
|
|
||||||
return new DebugPageResponse();
|
|
||||||
}
|
|
||||||
if (target.endsWith(".css")) {
|
|
||||||
return ResponseCache.loadResponse(PageId.CSS.of(target), () -> new CSSResponse(target));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (target.endsWith(".js")) {
|
|
||||||
return ResponseCache.loadResponse(PageId.JS.of(target), () -> new JavaScriptResponse(target));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (args.length < 2 || !"api".equals(args[1])) {
|
|
||||||
String address = PlanPlugin.getInstance().getInfoManager().getWebServerAddress() + target;
|
|
||||||
String link = Html.LINK.parse(address, address);
|
|
||||||
return ResponseCache.loadResponse(PageId.ERROR.of("Non-API Request"), () -> new NotFoundResponse("WebServer is in WebAPI-only mode, " +
|
|
||||||
"connect to the Bungee server instead: " + link));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (args.length < 3) {
|
|
||||||
String error = "API Method not specified";
|
|
||||||
return ResponseCache.loadResponse(PageId.ERROR.of(error), () -> new BadRequestResponse(error));
|
|
||||||
}
|
|
||||||
|
|
||||||
String method = args[2];
|
|
||||||
String requestBody;
|
|
||||||
try (InputStream inputStream = request.getRequestBody()) {
|
|
||||||
requestBody = readPOSTRequest(inputStream);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (requestBody == null) {
|
|
||||||
String error = "Error at reading the POST request." +
|
|
||||||
"Note that the Encoding must be ISO-8859-1.";
|
|
||||||
return ResponseCache.loadResponse(PageId.ERROR.of(error), () -> new BadRequestResponse(error));
|
|
||||||
}
|
|
||||||
|
|
||||||
Map<String, String> variables = WebAPI.readVariables(requestBody);
|
|
||||||
String sender = variables.get("sender");
|
|
||||||
Log.debug("Received WebAPI Request" + target + " from " + sender);
|
|
||||||
|
|
||||||
boolean isPing = "pingwebapi".equalsIgnoreCase(method);
|
|
||||||
boolean isSetupRequest = "requestsetupwebapi".equalsIgnoreCase(method);
|
|
||||||
boolean isPostOriginalSettings = "postoriginalbukkitsettingswebapi".equalsIgnoreCase(method);
|
|
||||||
boolean skipAuthCheck = isPing || isSetupRequest || isPostOriginalSettings;
|
|
||||||
|
|
||||||
// TODO refactor to more methods
|
|
||||||
if (!skipAuthCheck) {
|
|
||||||
String accessKey = variables.get("accessKey");
|
|
||||||
if (accessKey == null) {
|
|
||||||
if (!checkKey(sender)) {
|
|
||||||
String error = "Server Key not given or invalid";
|
|
||||||
Log.debug("Request had invalid Server key: " + sender);
|
|
||||||
return ResponseCache.loadResponse(PageId.ERROR.of(error), () -> {
|
|
||||||
ForbiddenResponse forbidden = new ForbiddenResponse();
|
|
||||||
forbidden.setContent(error);
|
|
||||||
return forbidden;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (!webAPI.isAuthorized(accessKey)) {
|
|
||||||
String error = "Access Key invalid";
|
|
||||||
Log.debug("Request had invalid Access key: " + accessKey);
|
|
||||||
return ResponseCache.loadResponse(PageId.ERROR.of(error), () -> {
|
|
||||||
ForbiddenResponse forbidden = new ForbiddenResponse();
|
|
||||||
forbidden.setContent(error);
|
|
||||||
return forbidden;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
WebAPI api = webAPI.getAPI(method);
|
|
||||||
|
|
||||||
if (api == null) {
|
|
||||||
String error = "API Method not found";
|
|
||||||
Log.debug(error);
|
|
||||||
return ResponseCache.loadResponse(PageId.ERROR.of(error), () -> new BadRequestResponse(error));
|
|
||||||
}
|
|
||||||
|
|
||||||
Response response = api.processRequest(PlanPlugin.getInstance(), variables);
|
|
||||||
|
|
||||||
Log.debug("Response: " + response.getResponse().split("\r\n")[0]);
|
|
||||||
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
private String readPOSTRequest(InputStream in) throws IOException {
|
|
||||||
byte[] bytes;
|
|
||||||
|
|
||||||
ByteArrayOutputStream out = new ByteArrayOutputStream();
|
|
||||||
byte[] buf = new byte[4096];
|
|
||||||
for (int n = in.read(buf); n > 0; n = in.read(buf)) {
|
|
||||||
out.write(buf, 0, n);
|
|
||||||
}
|
|
||||||
|
|
||||||
bytes = out.toByteArray();
|
|
||||||
|
|
||||||
try {
|
|
||||||
return new String(bytes, StandardCharsets.ISO_8859_1);
|
|
||||||
} catch (Exception e) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean checkKey(String sender) {
|
|
||||||
if (sender == null) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
List<UUID> uuids = PlanPlugin.getInstance().getDB().getServerTable().getServerUUIDs();
|
|
||||||
UUID keyUUID = UUID.fromString(sender);
|
|
||||||
return uuids.contains(keyUUID);
|
|
||||||
} catch (SQLException | IllegalArgumentException e) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -75,4 +75,7 @@ public class RequestHandler implements HttpHandler {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ResponseHandler getResponseHandler() {
|
||||||
|
return responseHandler;
|
||||||
|
}
|
||||||
}
|
}
|
@ -4,9 +4,7 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.system.webserver;
|
package com.djrapitops.plan.system.webserver;
|
||||||
|
|
||||||
import com.djrapitops.plan.PlanPlugin;
|
|
||||||
import com.djrapitops.plan.api.exceptions.WebUserAuthException;
|
import com.djrapitops.plan.api.exceptions.WebUserAuthException;
|
||||||
import com.djrapitops.plan.data.WebUser;
|
|
||||||
import com.djrapitops.plan.system.webserver.auth.Authentication;
|
import com.djrapitops.plan.system.webserver.auth.Authentication;
|
||||||
import com.djrapitops.plan.system.webserver.pagecache.PageId;
|
import com.djrapitops.plan.system.webserver.pagecache.PageId;
|
||||||
import com.djrapitops.plan.system.webserver.pagecache.ResponseCache;
|
import com.djrapitops.plan.system.webserver.pagecache.ResponseCache;
|
||||||
@ -14,17 +12,11 @@ import com.djrapitops.plan.system.webserver.pages.*;
|
|||||||
import com.djrapitops.plan.system.webserver.response.*;
|
import com.djrapitops.plan.system.webserver.response.*;
|
||||||
import com.djrapitops.plan.system.webserver.response.errors.ForbiddenResponse;
|
import com.djrapitops.plan.system.webserver.response.errors.ForbiddenResponse;
|
||||||
import com.djrapitops.plan.system.webserver.response.errors.InternalErrorResponse;
|
import com.djrapitops.plan.system.webserver.response.errors.InternalErrorResponse;
|
||||||
import com.djrapitops.plan.system.webserver.response.errors.NotFoundResponse;
|
|
||||||
import com.djrapitops.plan.system.webserver.response.pages.AnalysisPageResponse;
|
|
||||||
import com.djrapitops.plan.system.webserver.response.pages.DebugPageResponse;
|
|
||||||
import com.djrapitops.plan.system.webserver.response.pages.PlayersPageResponse;
|
|
||||||
import com.djrapitops.plan.systems.webserver.response.*;
|
|
||||||
import com.djrapitops.plugin.api.utility.log.Log;
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handles choosing of the correct response to a request.
|
* Handles choosing of the correct response to a request.
|
||||||
@ -34,7 +26,6 @@ import java.util.UUID;
|
|||||||
public class ResponseHandler extends TreePageHandler {
|
public class ResponseHandler extends TreePageHandler {
|
||||||
|
|
||||||
private final boolean authRequired;
|
private final boolean authRequired;
|
||||||
|
|
||||||
private final boolean usingHttps;
|
private final boolean usingHttps;
|
||||||
|
|
||||||
public ResponseHandler(WebServer webServer) {
|
public ResponseHandler(WebServer webServer) {
|
||||||
@ -43,7 +34,7 @@ public class ResponseHandler extends TreePageHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void registerDefaultPages() {
|
public void registerDefaultPages() {
|
||||||
registerPage("favicon.ico", new RedirectResponse("https://puu.sh/tK0KL/6aa2ba141b.ico"));
|
registerPage("favicon.ico", new RedirectResponse("https://puu.sh/tK0KL/6aa2ba141b.ico"), 5);
|
||||||
registerPage("debug", new DebugPageHandler());
|
registerPage("debug", new DebugPageHandler());
|
||||||
registerPage("players", new PlayersPageHandler());
|
registerPage("players", new PlayersPageHandler());
|
||||||
registerPage("player", new PlayerPageHandler());
|
registerPage("player", new PlayerPageHandler());
|
||||||
@ -51,10 +42,35 @@ public class ResponseHandler extends TreePageHandler {
|
|||||||
ServerPageHandler serverPageHandler = new ServerPageHandler();
|
ServerPageHandler serverPageHandler = new ServerPageHandler();
|
||||||
registerPage("network", serverPageHandler);
|
registerPage("network", serverPageHandler);
|
||||||
registerPage("server", serverPageHandler);
|
registerPage("server", serverPageHandler);
|
||||||
|
if (authRequired) {
|
||||||
|
registerPage("", new RootPageHandler(this));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void registerWebAPIPages() {
|
public void registerWebAPIPages() {
|
||||||
|
// TODO WebAPIPageHandler
|
||||||
|
// private void registerWebAPIs() {
|
||||||
|
// webAPI.registerNewAPI(
|
||||||
|
// new AnalysisReadyWebAPI(),
|
||||||
|
// new AnalyzeWebAPI(),
|
||||||
|
// new ConfigurationWebAPI(),
|
||||||
|
// new InspectWebAPI(),
|
||||||
|
// new IsOnlineWebAPI(),
|
||||||
|
// new RequestInspectPluginsTabBukkitWebAPI(),
|
||||||
|
// new PingWebAPI()
|
||||||
|
// );
|
||||||
|
//
|
||||||
|
// webAPI.registerNewAPI(
|
||||||
|
// new IsCachedWebAPI(),
|
||||||
|
// new PostHtmlWebAPI(),
|
||||||
|
// new PostInspectPluginsTabWebAPI(),
|
||||||
|
// new PostNetworkPageContentWebAPI(),
|
||||||
|
// new PostOriginalBukkitSettingsWebAPI(),
|
||||||
|
// new RequestPluginsTabWebAPI(),
|
||||||
|
// new RequestSetupWebAPI()
|
||||||
|
// );
|
||||||
|
// }
|
||||||
|
//Log.infoColor("§aWebServer Running in WebAPI-only Mode");
|
||||||
}
|
}
|
||||||
|
|
||||||
public Response getResponse(Request request) {
|
public Response getResponse(Request request) {
|
||||||
@ -65,14 +81,14 @@ public class ResponseHandler extends TreePageHandler {
|
|||||||
Optional<Authentication> authentication = Optional.empty();
|
Optional<Authentication> authentication = Optional.empty();
|
||||||
if (authRequired) {
|
if (authRequired) {
|
||||||
authentication = request.getAuth();
|
authentication = request.getAuth();
|
||||||
if (!authentication.isPresent() && usingHttps) {
|
if (!authentication.isPresent()) {
|
||||||
|
if (usingHttps) {
|
||||||
return DefaultResponses.BASIC_AUTH.get();
|
return DefaultResponses.BASIC_AUTH.get();
|
||||||
}
|
} else {
|
||||||
|
|
||||||
if (authentication.isPresent() && !authentication.get().isAuthorized(null)) {
|
|
||||||
return forbiddenResponse(0, 0);
|
return forbiddenResponse(0, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
PageHandler pageHandler = getPageHandler(target);
|
PageHandler pageHandler = getPageHandler(target);
|
||||||
if (pageHandler == null) {
|
if (pageHandler == null) {
|
||||||
@ -84,7 +100,7 @@ public class ResponseHandler extends TreePageHandler {
|
|||||||
}
|
}
|
||||||
return DefaultResponses.NOT_FOUND.get();
|
return DefaultResponses.NOT_FOUND.get();
|
||||||
} else {
|
} else {
|
||||||
if (authentication.isPresent() && authentication.get().isAuthorized(pageHandler.getPermission())) {
|
if (authentication.isPresent() && pageHandler.isAuthorized(authentication.get(), target)) {
|
||||||
return forbiddenResponse(0, 0);
|
return forbiddenResponse(0, 0);
|
||||||
}
|
}
|
||||||
return pageHandler.getResponse(request, target);
|
return pageHandler.getResponse(request, target);
|
||||||
@ -93,142 +109,15 @@ public class ResponseHandler extends TreePageHandler {
|
|||||||
return PromptAuthorizationResponse.getBasicAuthResponse(e);
|
return PromptAuthorizationResponse.getBasicAuthResponse(e);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
Log.toLog(this.getClass().getName(), e);
|
Log.toLog(this.getClass().getName(), e);
|
||||||
return new InternalErrorResponse(e, request.getTarget());
|
return new InternalErrorResponse(request.getTarget(), e);
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
if ("/favicon.ico".equals(targetString)) {
|
|
||||||
return ResponseCache.loadResponse(PageId.FAVICON_REDIRECT.id(), () -> new RedirectResponse("https://puu.sh/tK0KL/6aa2ba141b.ico"));
|
|
||||||
}
|
|
||||||
if (request.isAPIRequest()) {
|
|
||||||
return getAPIResponse(request);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
UUID serverUUID = PlanPlugin.getInstance().getServerUuid();
|
|
||||||
|
|
||||||
if (usingHttps) {
|
|
||||||
if (!request.hasAuth()) {
|
|
||||||
throw new WebUserAuthException("No Authorization");
|
|
||||||
}
|
|
||||||
|
|
||||||
WebUser user = getUser(request.getAuth());
|
|
||||||
int required = getRequiredPermLevel(targetString, user.getName());
|
|
||||||
int permLevel = user.getPermLevel();
|
|
||||||
|
|
||||||
if (!isAuthorized(required, permLevel)) {
|
|
||||||
return forbiddenResponse(required, permLevel);
|
|
||||||
}
|
|
||||||
if (args.length < 2) {
|
|
||||||
return rootPageResponse(user, serverUUID);
|
|
||||||
}
|
|
||||||
} else if (args.length < 2) {
|
|
||||||
return notFoundResponse();
|
|
||||||
}
|
|
||||||
|
|
||||||
String page = args[1];
|
|
||||||
switch (page) {
|
|
||||||
case "debug":
|
|
||||||
return new DebugPageResponse();
|
|
||||||
case "players":
|
|
||||||
return ResponseCache.loadResponse(PageId.PLAYERS.id(), PlayersPageResponse::new);
|
|
||||||
case "player":
|
|
||||||
return playerResponse(args);
|
|
||||||
case "network":
|
|
||||||
case "server":
|
|
||||||
if (args.length > 2) {
|
|
||||||
try {
|
|
||||||
Optional<UUID> serverUUIDOptional = PlanPlugin.getInstance().getDB().getServerTable().getServerUUID(args[2].replace("%20", " "));
|
|
||||||
if (serverUUIDOptional.isPresent()) {
|
|
||||||
serverUUID = serverUUIDOptional.get();
|
|
||||||
}
|
|
||||||
} catch (IllegalArgumentException ignore) {
|
|
||||||
/*ignored*/
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return serverResponse(serverUUID);
|
|
||||||
default:
|
|
||||||
return notFoundResponse();
|
|
||||||
}
|
|
||||||
|
|
||||||
} catch (WebUserAuthException e) {
|
|
||||||
return ResponseCache.loadResponse(PageId.AUTH_PROMPT.id(), PromptAuthorizationResponse::getBasicAuthResponse);
|
|
||||||
} catch (Exception e) {
|
|
||||||
Log.toLog(this.getClass().getName(), e);
|
|
||||||
return new InternalErrorResponse(e, request.getTarget());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private Response forbiddenResponse(int required, int permLevel) {
|
public Response forbiddenResponse(int required, int permLevel) {
|
||||||
return ResponseCache.loadResponse(PageId.FORBIDDEN.of(required + "/" + permLevel), () ->
|
return ResponseCache.loadResponse(PageId.FORBIDDEN.of(required + "/" + permLevel), () ->
|
||||||
new ForbiddenResponse("Unauthorized User.<br>"
|
new ForbiddenResponse("Unauthorized User.<br>"
|
||||||
+ "Make sure your user has the correct access level.<br>"
|
+ "Make sure your user has the correct access level.<br>"
|
||||||
+ "This page requires permission level of " + required + ",<br>"
|
+ "This page requires permission level of " + required + ",<br>"
|
||||||
+ "This user has permission level of " + permLevel));
|
+ "This user has permission level of " + permLevel));
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isAuthorized(int requiredPermLevel, int permLevel) {
|
|
||||||
return permLevel <= requiredPermLevel;
|
|
||||||
}
|
|
||||||
|
|
||||||
private int getRequiredPermLevel(String target, String user) {
|
|
||||||
String[] t = target.split("/");
|
|
||||||
if (t.length < 2) {
|
|
||||||
return 100;
|
|
||||||
}
|
|
||||||
if (t.length > 3) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
String page = t[1];
|
|
||||||
switch (page) {
|
|
||||||
case "players":
|
|
||||||
return 1;
|
|
||||||
case "player":
|
|
||||||
// /player/ - 404 for perm lvl 1
|
|
||||||
if (t.length < 3) {
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
final String wantedUser = t[2].toLowerCase().trim();
|
|
||||||
final String theUser = user.trim().toLowerCase();
|
|
||||||
|
|
||||||
return wantedUser.equals(theUser) ? 2 : 1;
|
|
||||||
default:
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private Response rootPageResponse(WebUser user, UUID serverUUID) {
|
|
||||||
if (user == null) {
|
|
||||||
return notFoundResponse();
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (user.getPermLevel()) {
|
|
||||||
case 0:
|
|
||||||
return serverResponse(serverUUID);
|
|
||||||
case 1:
|
|
||||||
return ResponseCache.loadResponse(PageId.PLAYERS.id(), PlayersPageResponse::new);
|
|
||||||
case 2:
|
|
||||||
return playerResponse(new String[]{"", "", user.getName()});
|
|
||||||
default:
|
|
||||||
return forbiddenResponse(user.getPermLevel(), 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private Response serverResponse(UUID serverUUID) {
|
|
||||||
return ResponseCache.loadResponse(PageId.SERVER.of(serverUUID), () -> new AnalysisPageResponse(plugin.getInfoManager()));
|
|
||||||
}
|
|
||||||
|
|
||||||
private Response notFoundResponse() {
|
|
||||||
String error = "404 Not Found";
|
|
||||||
return ResponseCache.loadResponse(PageId.NOT_FOUND.of("Wrong Page"), () -> {
|
|
||||||
String url = plugin.getInfoManager().getWebServerAddress();
|
|
||||||
return new NotFoundResponse("Make sure you're accessing a link given by a command, Examples:</p>"
|
|
||||||
+ "<p>" + url + "/player/Playername<br>" +
|
|
||||||
url + "/server</p>");
|
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
@ -40,15 +40,19 @@ public class WebServer implements SubSystem {
|
|||||||
|
|
||||||
private boolean usingHttps = false;
|
private boolean usingHttps = false;
|
||||||
|
|
||||||
|
private RequestHandler requestHandler;
|
||||||
|
private ResponseHandler responseHandler;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void enable() {
|
public void enable() {
|
||||||
this.port = Settings.WEBSERVER_PORT.getNumber();
|
this.port = Settings.WEBSERVER_PORT.getNumber();
|
||||||
|
|
||||||
PlanPlugin plugin = PlanPlugin.getInstance();
|
PlanPlugin plugin = PlanPlugin.getInstance();
|
||||||
StaticHolder.saveInstance(APIRequestHandler.class, plugin.getClass());
|
|
||||||
StaticHolder.saveInstance(RequestHandler.class, plugin.getClass());
|
StaticHolder.saveInstance(RequestHandler.class, plugin.getClass());
|
||||||
StaticHolder.saveInstance(ResponseHandler.class, plugin.getClass());
|
StaticHolder.saveInstance(ResponseHandler.class, plugin.getClass());
|
||||||
StaticHolder.saveInstance(APIResponseHandler.class, plugin.getClass());
|
|
||||||
|
requestHandler = new RequestHandler(this);
|
||||||
|
responseHandler = requestHandler.getResponseHandler();
|
||||||
|
|
||||||
initServer();
|
initServer();
|
||||||
}
|
}
|
||||||
@ -58,30 +62,6 @@ public class WebServer implements SubSystem {
|
|||||||
stop();
|
stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO WebAPIPageHandler
|
|
||||||
// private void registerWebAPIs() {
|
|
||||||
// webAPI.registerNewAPI(
|
|
||||||
// new AnalysisReadyWebAPI(),
|
|
||||||
// new AnalyzeWebAPI(),
|
|
||||||
// new ConfigurationWebAPI(),
|
|
||||||
// new InspectWebAPI(),
|
|
||||||
// new IsOnlineWebAPI(),
|
|
||||||
// new RequestInspectPluginsTabBukkitWebAPI(),
|
|
||||||
// new PingWebAPI()
|
|
||||||
// );
|
|
||||||
//
|
|
||||||
// webAPI.registerNewAPI(
|
|
||||||
// new IsCachedWebAPI(),
|
|
||||||
// new PostHtmlWebAPI(),
|
|
||||||
// new PostInspectPluginsTabWebAPI(),
|
|
||||||
// new PostNetworkPageContentWebAPI(),
|
|
||||||
// new PostOriginalBukkitSettingsWebAPI(),
|
|
||||||
// new RequestPluginsTabWebAPI(),
|
|
||||||
// new RequestSetupWebAPI()
|
|
||||||
// );
|
|
||||||
// }
|
|
||||||
//Log.infoColor("§aWebServer Running in WebAPI-only Mode");
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Starts up the WebServer in a new Thread Pool.
|
* Starts up the WebServer in a new Thread Pool.
|
||||||
*/
|
*/
|
||||||
@ -107,7 +87,7 @@ public class WebServer implements SubSystem {
|
|||||||
server = HttpServer.create(new InetSocketAddress(Settings.WEBSERVER_IP.toString(), port), 10);
|
server = HttpServer.create(new InetSocketAddress(Settings.WEBSERVER_IP.toString(), port), 10);
|
||||||
}
|
}
|
||||||
|
|
||||||
server.createContext("/", new RequestHandler(this));
|
server.createContext("/", requestHandler);
|
||||||
|
|
||||||
server.setExecutor(new ThreadPoolExecutor(4, 8, 30, TimeUnit.SECONDS, new ArrayBlockingQueue<>(100)));
|
server.setExecutor(new ThreadPoolExecutor(4, 8, 30, TimeUnit.SECONDS, new ArrayBlockingQueue<>(100)));
|
||||||
server.start();
|
server.start();
|
||||||
@ -213,4 +193,12 @@ public class WebServer implements SubSystem {
|
|||||||
public String getAccessAddress() {
|
public String getAccessAddress() {
|
||||||
return isEnabled() ? getProtocol() + "://" + HtmlUtils.getIP() : Settings.EXTERNAL_WEBSERVER_LINK.toString();
|
return isEnabled() ? getProtocol() + "://" + HtmlUtils.getIP() : Settings.EXTERNAL_WEBSERVER_LINK.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public RequestHandler getRequestHandler() {
|
||||||
|
return requestHandler;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ResponseHandler getResponseHandler() {
|
||||||
|
return responseHandler;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -28,11 +28,14 @@ public class WebServerSystem implements SubSystem {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void enable() throws EnableException {
|
public void enable() throws EnableException {
|
||||||
webServer = new WebServer(PlanPlugin.getInstance());
|
webServer = new WebServer();
|
||||||
webServer.initServer();
|
webServer.initServer();
|
||||||
if (Check.isBungeeAvailable() && !webServer.isEnabled()) {
|
if (Check.isBungeeAvailable() && !webServer.isEnabled()) {
|
||||||
throw new EnableException("WebServer did not initialize!");
|
throw new EnableException("WebServer did not initialize!");
|
||||||
}
|
}
|
||||||
|
ResponseHandler responseHandler = webServer.getResponseHandler();
|
||||||
|
responseHandler.registerWebAPIPages();
|
||||||
|
responseHandler.registerDefaultPages();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
package com.djrapitops.plan.system.webserver.auth;
|
package com.djrapitops.plan.system.webserver.auth;
|
||||||
|
|
||||||
import com.djrapitops.plan.api.exceptions.WebUserAuthException;
|
import com.djrapitops.plan.api.exceptions.WebUserAuthException;
|
||||||
|
import com.djrapitops.plan.data.WebUser;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* //TODO Class Javadoc Comment
|
* //TODO Class Javadoc Comment
|
||||||
@ -13,6 +14,6 @@ import com.djrapitops.plan.api.exceptions.WebUserAuthException;
|
|||||||
*/
|
*/
|
||||||
public interface Authentication {
|
public interface Authentication {
|
||||||
|
|
||||||
boolean isAuthorized(String permission) throws WebUserAuthException;
|
WebUser getWebUser() throws WebUserAuthException;
|
||||||
|
|
||||||
}
|
}
|
@ -4,7 +4,10 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.system.webserver.pages;
|
package com.djrapitops.plan.system.webserver.pages;
|
||||||
|
|
||||||
|
import com.djrapitops.plan.api.exceptions.WebUserAuthException;
|
||||||
|
import com.djrapitops.plan.data.WebUser;
|
||||||
import com.djrapitops.plan.system.webserver.Request;
|
import com.djrapitops.plan.system.webserver.Request;
|
||||||
|
import com.djrapitops.plan.system.webserver.auth.Authentication;
|
||||||
import com.djrapitops.plan.system.webserver.response.Response;
|
import com.djrapitops.plan.system.webserver.response.Response;
|
||||||
import com.djrapitops.plan.system.webserver.response.pages.DebugPageResponse;
|
import com.djrapitops.plan.system.webserver.response.pages.DebugPageResponse;
|
||||||
|
|
||||||
@ -21,4 +24,10 @@ public class DebugPageHandler extends PageHandler {
|
|||||||
public Response getResponse(Request request, List<String> target) {
|
public Response getResponse(Request request, List<String> target) {
|
||||||
return new DebugPageResponse();
|
return new DebugPageResponse();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isAuthorized(Authentication auth, List<String> target) throws WebUserAuthException {
|
||||||
|
WebUser webUser = auth.getWebUser();
|
||||||
|
return webUser.getPermLevel() == 0;
|
||||||
|
}
|
||||||
}
|
}
|
@ -4,7 +4,9 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.system.webserver.pages;
|
package com.djrapitops.plan.system.webserver.pages;
|
||||||
|
|
||||||
|
import com.djrapitops.plan.api.exceptions.WebUserAuthException;
|
||||||
import com.djrapitops.plan.system.webserver.Request;
|
import com.djrapitops.plan.system.webserver.Request;
|
||||||
|
import com.djrapitops.plan.system.webserver.auth.Authentication;
|
||||||
import com.djrapitops.plan.system.webserver.response.Response;
|
import com.djrapitops.plan.system.webserver.response.Response;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -16,11 +18,17 @@ import java.util.List;
|
|||||||
*/
|
*/
|
||||||
public abstract class PageHandler {
|
public abstract class PageHandler {
|
||||||
|
|
||||||
protected String permission = "*";
|
/**
|
||||||
|
* Get the Response of a PageHandler.
|
||||||
|
*
|
||||||
|
* @param request Request in case it is useful for choosing page.
|
||||||
|
* @param target Rest of the target coordinates after this page has been solved.
|
||||||
|
* @return Response appropriate to the PageHandler.
|
||||||
|
*/
|
||||||
public abstract Response getResponse(Request request, List<String> target);
|
public abstract Response getResponse(Request request, List<String> target);
|
||||||
|
|
||||||
public String getPermission() {
|
public boolean isAuthorized(Authentication auth, List<String> target) throws WebUserAuthException {
|
||||||
return permission;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -6,8 +6,12 @@ package com.djrapitops.plan.system.webserver.pages;
|
|||||||
|
|
||||||
import com.djrapitops.plan.PlanPlugin;
|
import com.djrapitops.plan.PlanPlugin;
|
||||||
import com.djrapitops.plan.api.exceptions.ParseException;
|
import com.djrapitops.plan.api.exceptions.ParseException;
|
||||||
|
import com.djrapitops.plan.api.exceptions.WebUserAuthException;
|
||||||
|
import com.djrapitops.plan.api.exceptions.database.DBException;
|
||||||
|
import com.djrapitops.plan.data.WebUser;
|
||||||
import com.djrapitops.plan.system.database.databases.Database;
|
import com.djrapitops.plan.system.database.databases.Database;
|
||||||
import com.djrapitops.plan.system.webserver.Request;
|
import com.djrapitops.plan.system.webserver.Request;
|
||||||
|
import com.djrapitops.plan.system.webserver.auth.Authentication;
|
||||||
import com.djrapitops.plan.system.webserver.pagecache.PageId;
|
import com.djrapitops.plan.system.webserver.pagecache.PageId;
|
||||||
import com.djrapitops.plan.system.webserver.pagecache.ResponseCache;
|
import com.djrapitops.plan.system.webserver.pagecache.ResponseCache;
|
||||||
import com.djrapitops.plan.system.webserver.response.Response;
|
import com.djrapitops.plan.system.webserver.response.Response;
|
||||||
@ -15,6 +19,7 @@ import com.djrapitops.plan.system.webserver.response.errors.InternalErrorRespons
|
|||||||
import com.djrapitops.plan.system.webserver.response.errors.NotFoundResponse;
|
import com.djrapitops.plan.system.webserver.response.errors.NotFoundResponse;
|
||||||
import com.djrapitops.plan.system.webserver.response.pages.InspectPageResponse;
|
import com.djrapitops.plan.system.webserver.response.pages.InspectPageResponse;
|
||||||
import com.djrapitops.plan.utilities.uuid.UUIDUtility;
|
import com.djrapitops.plan.utilities.uuid.UUIDUtility;
|
||||||
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
@ -26,10 +31,6 @@ import java.util.UUID;
|
|||||||
*/
|
*/
|
||||||
public class PlayerPageHandler extends PageHandler {
|
public class PlayerPageHandler extends PageHandler {
|
||||||
|
|
||||||
public PlayerPageHandler() {
|
|
||||||
permission = "special_player";
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Response getResponse(Request request, List<String> target) {
|
public Response getResponse(Request request, List<String> target) {
|
||||||
if (target.isEmpty()) {
|
if (target.isEmpty()) {
|
||||||
@ -43,6 +44,7 @@ public class PlayerPageHandler extends PageHandler {
|
|||||||
return notFound("Player has no UUID");
|
return notFound("Player has no UUID");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
if (Database.getActive().check().isPlayerRegistered(uuid)) {
|
if (Database.getActive().check().isPlayerRegistered(uuid)) {
|
||||||
PlanPlugin.getInstance().getInfoManager().cachePlayer(uuid);
|
PlanPlugin.getInstance().getInfoManager().cachePlayer(uuid);
|
||||||
Response response = ResponseCache.loadResponse(PageId.PLAYER.of(uuid));
|
Response response = ResponseCache.loadResponse(PageId.PLAYER.of(uuid));
|
||||||
@ -59,10 +61,19 @@ public class PlayerPageHandler extends PageHandler {
|
|||||||
}
|
}
|
||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
|
} catch (DBException e) {
|
||||||
|
Log.toLog(this.getClass().getName(), e);
|
||||||
|
}
|
||||||
return notFound("Player has not played on this server.");
|
return notFound("Player has not played on this server.");
|
||||||
}
|
}
|
||||||
|
|
||||||
private Response notFound(String error) {
|
private Response notFound(String error) {
|
||||||
return ResponseCache.loadResponse(PageId.NOT_FOUND.of(error), () -> new NotFoundResponse(error));
|
return ResponseCache.loadResponse(PageId.NOT_FOUND.of(error), () -> new NotFoundResponse(error));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isAuthorized(Authentication auth, List<String> target) throws WebUserAuthException {
|
||||||
|
WebUser webUser = auth.getWebUser();
|
||||||
|
return webUser.getPermLevel() <= 1 || webUser.getName().equalsIgnoreCase(target.get(target.size() - 1));
|
||||||
|
}
|
||||||
}
|
}
|
@ -4,7 +4,9 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.system.webserver.pages;
|
package com.djrapitops.plan.system.webserver.pages;
|
||||||
|
|
||||||
|
import com.djrapitops.plan.api.exceptions.WebUserAuthException;
|
||||||
import com.djrapitops.plan.system.webserver.Request;
|
import com.djrapitops.plan.system.webserver.Request;
|
||||||
|
import com.djrapitops.plan.system.webserver.auth.Authentication;
|
||||||
import com.djrapitops.plan.system.webserver.pagecache.PageId;
|
import com.djrapitops.plan.system.webserver.pagecache.PageId;
|
||||||
import com.djrapitops.plan.system.webserver.pagecache.ResponseCache;
|
import com.djrapitops.plan.system.webserver.pagecache.ResponseCache;
|
||||||
import com.djrapitops.plan.system.webserver.response.Response;
|
import com.djrapitops.plan.system.webserver.response.Response;
|
||||||
@ -19,12 +21,13 @@ import java.util.List;
|
|||||||
*/
|
*/
|
||||||
public class PlayersPageHandler extends PageHandler {
|
public class PlayersPageHandler extends PageHandler {
|
||||||
|
|
||||||
public PlayersPageHandler() {
|
|
||||||
permission = "players";
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Response getResponse(Request request, List<String> target) {
|
public Response getResponse(Request request, List<String> target) {
|
||||||
return ResponseCache.loadResponse(PageId.PLAYERS.id(), PlayersPageResponse::new);
|
return ResponseCache.loadResponse(PageId.PLAYERS.id(), PlayersPageResponse::new);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isAuthorized(Authentication auth, List<String> target) throws WebUserAuthException {
|
||||||
|
return auth.getWebUser().getPermLevel() <= 1;
|
||||||
|
}
|
||||||
}
|
}
|
@ -0,0 +1,64 @@
|
|||||||
|
/*
|
||||||
|
* Licence is provided in the jar as license.yml also here:
|
||||||
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/license.yml
|
||||||
|
*/
|
||||||
|
package com.djrapitops.plan.system.webserver.pages;
|
||||||
|
|
||||||
|
import com.djrapitops.plan.api.exceptions.WebUserAuthException;
|
||||||
|
import com.djrapitops.plan.data.WebUser;
|
||||||
|
import com.djrapitops.plan.system.webserver.Request;
|
||||||
|
import com.djrapitops.plan.system.webserver.ResponseHandler;
|
||||||
|
import com.djrapitops.plan.system.webserver.auth.Authentication;
|
||||||
|
import com.djrapitops.plan.system.webserver.response.Response;
|
||||||
|
import com.djrapitops.plan.system.webserver.response.errors.InternalErrorResponse;
|
||||||
|
import com.djrapitops.plugin.api.utility.log.Log;
|
||||||
|
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* //TODO Class Javadoc Comment
|
||||||
|
*
|
||||||
|
* @author Rsl1122
|
||||||
|
*/
|
||||||
|
public class RootPageHandler extends PageHandler {
|
||||||
|
|
||||||
|
private final ResponseHandler responseHandler;
|
||||||
|
|
||||||
|
public RootPageHandler(ResponseHandler responseHandler) {
|
||||||
|
this.responseHandler = responseHandler;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response getResponse(Request request, List<String> target) {
|
||||||
|
Optional<Authentication> auth = request.getAuth();
|
||||||
|
if (!auth.isPresent()) {
|
||||||
|
return DefaultResponses.BASIC_AUTH.get();
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
WebUser webUser = auth.get().getWebUser();
|
||||||
|
|
||||||
|
int permLevel = webUser.getPermLevel();
|
||||||
|
switch (permLevel) {
|
||||||
|
case 0:
|
||||||
|
return responseHandler.getPageHandler("server").getResponse(request, Collections.emptyList());
|
||||||
|
case 1:
|
||||||
|
return responseHandler.getPageHandler("players").getResponse(request, Collections.emptyList());
|
||||||
|
case 2:
|
||||||
|
return responseHandler.getPageHandler("player").getResponse(request, Collections.singletonList(webUser.getName()));
|
||||||
|
default:
|
||||||
|
return responseHandler.forbiddenResponse(permLevel, 0);
|
||||||
|
}
|
||||||
|
} catch (WebUserAuthException e) {
|
||||||
|
Log.toLog(this.getClass(), e);
|
||||||
|
return new InternalErrorResponse("/", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isAuthorized(Authentication auth, List<String> target) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
@ -4,24 +4,53 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.system.webserver.pages;
|
package com.djrapitops.plan.system.webserver.pages;
|
||||||
|
|
||||||
|
import com.djrapitops.plan.PlanPlugin;
|
||||||
|
import com.djrapitops.plan.api.exceptions.WebUserAuthException;
|
||||||
|
import com.djrapitops.plan.system.database.databases.Database;
|
||||||
import com.djrapitops.plan.system.webserver.Request;
|
import com.djrapitops.plan.system.webserver.Request;
|
||||||
|
import com.djrapitops.plan.system.webserver.auth.Authentication;
|
||||||
|
import com.djrapitops.plan.system.webserver.pagecache.PageId;
|
||||||
|
import com.djrapitops.plan.system.webserver.pagecache.ResponseCache;
|
||||||
import com.djrapitops.plan.system.webserver.response.Response;
|
import com.djrapitops.plan.system.webserver.response.Response;
|
||||||
|
import com.djrapitops.plan.system.webserver.response.pages.AnalysisPageResponse;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* //TODO Class Javadoc Comment
|
* PageHandler for /server and /network pages.
|
||||||
*
|
*
|
||||||
* @author Rsl1122
|
* @author Rsl1122
|
||||||
*/
|
*/
|
||||||
public class ServerPageHandler extends PageHandler {
|
public class ServerPageHandler extends PageHandler {
|
||||||
|
|
||||||
public ServerPageHandler() {
|
@Override
|
||||||
permission = "server";
|
public Response getResponse(Request request, List<String> target) {
|
||||||
|
UUID serverUUID = getServerUUID(target);
|
||||||
|
return ResponseCache.loadResponse(PageId.SERVER.of(serverUUID),
|
||||||
|
() -> new AnalysisPageResponse(PlanPlugin.getInstance().getInfoManager())
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
private UUID getServerUUID(List<String> target) {
|
||||||
|
UUID serverUUID = PlanPlugin.getInstance().getServerUuid();
|
||||||
|
if (!target.isEmpty()) {
|
||||||
|
try {
|
||||||
|
String serverName = target.get(0).replace("%20", " ");
|
||||||
|
Optional<UUID> serverUUIDOptional = Database.getActive().fetch().getServerUUID(serverName);
|
||||||
|
if (serverUUIDOptional.isPresent()) {
|
||||||
|
serverUUID = serverUUIDOptional.get();
|
||||||
|
}
|
||||||
|
} catch (IllegalArgumentException ignore) {
|
||||||
|
/*ignored*/
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return serverUUID;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Response getResponse(Request request, List<String> target) {
|
public boolean isAuthorized(Authentication auth, List<String> target) throws WebUserAuthException {
|
||||||
return null;
|
return auth.getWebUser().getPermLevel() <= 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -4,7 +4,9 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.system.webserver.pages;
|
package com.djrapitops.plan.system.webserver.pages;
|
||||||
|
|
||||||
|
import com.djrapitops.plan.api.exceptions.WebUserAuthException;
|
||||||
import com.djrapitops.plan.system.webserver.Request;
|
import com.djrapitops.plan.system.webserver.Request;
|
||||||
|
import com.djrapitops.plan.system.webserver.auth.Authentication;
|
||||||
import com.djrapitops.plan.system.webserver.response.Response;
|
import com.djrapitops.plan.system.webserver.response.Response;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
@ -28,12 +30,17 @@ public abstract class TreePageHandler extends PageHandler {
|
|||||||
pages.put(targetPage, handler);
|
pages.put(targetPage, handler);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void registerPage(String targetPage, Response response) {
|
public void registerPage(String targetPage, Response response, int requiredPerm) {
|
||||||
pages.put(targetPage, new PageHandler() {
|
pages.put(targetPage, new PageHandler() {
|
||||||
@Override
|
@Override
|
||||||
public Response getResponse(Request request, List<String> target) {
|
public Response getResponse(Request request, List<String> target) {
|
||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isAuthorized(Authentication auth, List<String> target) throws WebUserAuthException {
|
||||||
|
return auth.getWebUser().getPermLevel() <= requiredPerm;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -46,8 +53,15 @@ public abstract class TreePageHandler extends PageHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public PageHandler getPageHandler(List<String> target) {
|
public PageHandler getPageHandler(List<String> target) {
|
||||||
|
if (target.isEmpty()) {
|
||||||
|
return pages.get("");
|
||||||
|
}
|
||||||
String targetPage = target.get(0);
|
String targetPage = target.get(0);
|
||||||
target.remove(0);
|
target.remove(0);
|
||||||
return pages.get(targetPage);
|
return pages.get(targetPage);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public PageHandler getPageHandler(String targetPage) {
|
||||||
|
return pages.get(targetPage);
|
||||||
|
}
|
||||||
}
|
}
|
@ -12,6 +12,11 @@ import com.djrapitops.plan.utilities.html.Html;
|
|||||||
*/
|
*/
|
||||||
public class PromptAuthorizationResponse extends ErrorResponse {
|
public class PromptAuthorizationResponse extends ErrorResponse {
|
||||||
|
|
||||||
|
private static final String TIPS = "<br>- Ensure you have registered a user with <b>/plan register</b><br>"
|
||||||
|
+ "- Check that the username and password are correct<br>"
|
||||||
|
+ "- Username and password are case-sensitive<br>"
|
||||||
|
+ "<br>If you have forgotten your password, ask a staff member to delete your old user and re-register.";
|
||||||
|
|
||||||
private PromptAuthorizationResponse() {
|
private PromptAuthorizationResponse() {
|
||||||
super.setTitle(Html.FONT_AWESOME_ICON.parse("lock") + " 401 Unauthorized");
|
super.setTitle(Html.FONT_AWESOME_ICON.parse("lock") + " 401 Unauthorized");
|
||||||
}
|
}
|
||||||
@ -20,11 +25,8 @@ public class PromptAuthorizationResponse extends ErrorResponse {
|
|||||||
PromptAuthorizationResponse response = new PromptAuthorizationResponse();
|
PromptAuthorizationResponse response = new PromptAuthorizationResponse();
|
||||||
response.setHeader("HTTP/1.1 401 Access Denied\r\n"
|
response.setHeader("HTTP/1.1 401 Access Denied\r\n"
|
||||||
+ "WWW-Authenticate: Basic realm=\"/\";");
|
+ "WWW-Authenticate: Basic realm=\"/\";");
|
||||||
response.setParagraph("Authentication Failed.<br>"
|
|
||||||
+ "- Ensure you have registered a user with <b>/plan register</b><br>"
|
response.setParagraph("Authentication Failed." + TIPS);
|
||||||
+ "- Check that the username and password are correct<br>"
|
|
||||||
+ "- Username and password are case-sensitive<br>"
|
|
||||||
+ "<br>If you have forgotten your password, ask a staff member to delete your old user and re-register.");
|
|
||||||
response.replacePlaceholders();
|
response.replacePlaceholders();
|
||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
@ -47,7 +49,7 @@ public class PromptAuthorizationResponse extends ErrorResponse {
|
|||||||
reason += errorBuilder.toString();
|
reason += errorBuilder.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
response.setParagraph("Authentication Failed.<br>Reason: " + reason);
|
response.setParagraph("Authentication Failed.<br>Reason: " + reason + TIPS);
|
||||||
response.replacePlaceholders();
|
response.replacePlaceholders();
|
||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
|
@ -8,7 +8,7 @@ import com.djrapitops.plan.utilities.html.Html;
|
|||||||
*/
|
*/
|
||||||
public class InternalErrorResponse extends ErrorResponse {
|
public class InternalErrorResponse extends ErrorResponse {
|
||||||
|
|
||||||
public InternalErrorResponse(Throwable e, String cause) {
|
public InternalErrorResponse(String cause, Throwable e) {
|
||||||
super.setHeader("HTTP/1.1 500 Internal Error");
|
super.setHeader("HTTP/1.1 500 Internal Error");
|
||||||
|
|
||||||
super.setTitle(Html.FONT_AWESOME_ICON.parse("bug") + " 500 Internal Error occurred");
|
super.setTitle(Html.FONT_AWESOME_ICON.parse("bug") + " 500 Internal Error occurred");
|
||||||
@ -33,6 +33,11 @@ public class InternalErrorResponse extends ErrorResponse {
|
|||||||
super.replacePlaceholders();
|
super.replacePlaceholders();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Deprecated
|
||||||
|
public InternalErrorResponse(Throwable e, String cause) {
|
||||||
|
this(cause, e);
|
||||||
|
}
|
||||||
|
|
||||||
private void appendCause(Throwable cause, StringBuilder paragraph) {
|
private void appendCause(Throwable cause, StringBuilder paragraph) {
|
||||||
paragraph.append("<br>Caused by: ").append(cause);
|
paragraph.append("<br>Caused by: ").append(cause);
|
||||||
for (StackTraceElement element : cause.getStackTrace()) {
|
for (StackTraceElement element : cause.getStackTrace()) {
|
||||||
|
Loading…
Reference in New Issue
Block a user