mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2024-10-27 13:59:56 +01:00
Added Response codes to WebExceptions to get rid of an instanceof chain.
This commit is contained in:
parent
d9fdad0086
commit
f2cdd3804b
@ -4,6 +4,8 @@
|
||||
*/
|
||||
package com.djrapitops.plan.api.exceptions.connection;
|
||||
|
||||
import com.djrapitops.plan.system.webserver.response.ResponseCode;
|
||||
|
||||
/**
|
||||
* Thrown when connection is returned 401 Bad Request.
|
||||
*
|
||||
@ -12,6 +14,6 @@ package com.djrapitops.plan.api.exceptions.connection;
|
||||
public class BadRequestException extends WebException {
|
||||
|
||||
public BadRequestException(String message) {
|
||||
super(message);
|
||||
super(message, ResponseCode.BAD_REQUEST);
|
||||
}
|
||||
}
|
@ -4,6 +4,8 @@
|
||||
*/
|
||||
package com.djrapitops.plan.api.exceptions.connection;
|
||||
|
||||
import com.djrapitops.plan.system.webserver.response.ResponseCode;
|
||||
|
||||
/**
|
||||
* Thrown when Connection fails to connect to an address.
|
||||
*
|
||||
@ -12,10 +14,10 @@ package com.djrapitops.plan.api.exceptions.connection;
|
||||
public class ConnectionFailException extends WebException {
|
||||
|
||||
public ConnectionFailException(String message, Throwable cause) {
|
||||
super(message, cause);
|
||||
super(message, cause, ResponseCode.CONNECTION_REFUSED);
|
||||
}
|
||||
|
||||
public ConnectionFailException(Throwable cause) {
|
||||
super(cause);
|
||||
super(cause, ResponseCode.CONNECTION_REFUSED);
|
||||
}
|
||||
}
|
@ -4,6 +4,8 @@
|
||||
*/
|
||||
package com.djrapitops.plan.api.exceptions.connection;
|
||||
|
||||
import com.djrapitops.plan.system.webserver.response.ResponseCode;
|
||||
|
||||
/**
|
||||
* Thrown when Connection gets a 403 response.
|
||||
*
|
||||
@ -11,6 +13,6 @@ package com.djrapitops.plan.api.exceptions.connection;
|
||||
*/
|
||||
public class ForbiddenException extends WebFailException {
|
||||
public ForbiddenException(String url) {
|
||||
super("Forbidden: " + url);
|
||||
super("Forbidden: " + url, ResponseCode.FORBIDDEN);
|
||||
}
|
||||
}
|
@ -4,6 +4,8 @@
|
||||
*/
|
||||
package com.djrapitops.plan.api.exceptions.connection;
|
||||
|
||||
import com.djrapitops.plan.system.webserver.response.ResponseCode;
|
||||
|
||||
/**
|
||||
* Thrown when InfoRequest can not connect to the other server.
|
||||
*
|
||||
@ -12,14 +14,6 @@ package com.djrapitops.plan.api.exceptions.connection;
|
||||
public class GatewayException extends WebException {
|
||||
|
||||
public GatewayException(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
public GatewayException(String message, Throwable cause) {
|
||||
super(message, cause);
|
||||
}
|
||||
|
||||
public GatewayException(Throwable cause) {
|
||||
super(cause);
|
||||
super(message, ResponseCode.GATEWAY_ERROR);
|
||||
}
|
||||
}
|
@ -4,6 +4,8 @@
|
||||
*/
|
||||
package com.djrapitops.plan.api.exceptions.connection;
|
||||
|
||||
import com.djrapitops.plan.system.webserver.response.ResponseCode;
|
||||
|
||||
/**
|
||||
* Thrown when Connection returns 500.
|
||||
*
|
||||
@ -11,10 +13,10 @@ package com.djrapitops.plan.api.exceptions.connection;
|
||||
*/
|
||||
public class InternalErrorException extends WebFailException {
|
||||
public InternalErrorException() {
|
||||
super("Internal Error occurred on receiving server");
|
||||
super("Internal Error occurred on receiving server", ResponseCode.INTERNAL_ERROR);
|
||||
}
|
||||
|
||||
public InternalErrorException(String message, Throwable cause) {
|
||||
super(message, cause);
|
||||
super(message, cause, ResponseCode.INTERNAL_ERROR);
|
||||
}
|
||||
}
|
@ -4,6 +4,8 @@
|
||||
*/
|
||||
package com.djrapitops.plan.api.exceptions.connection;
|
||||
|
||||
import com.djrapitops.plan.system.webserver.response.ResponseCode;
|
||||
|
||||
/**
|
||||
* Thrown when Connection returns 404, when page is not found.
|
||||
*
|
||||
@ -11,6 +13,6 @@ package com.djrapitops.plan.api.exceptions.connection;
|
||||
*/
|
||||
public class NotFoundException extends WebFailException {
|
||||
public NotFoundException(String message) {
|
||||
super(message);
|
||||
super(message, ResponseCode.NOT_FOUND);
|
||||
}
|
||||
}
|
@ -4,6 +4,8 @@
|
||||
*/
|
||||
package com.djrapitops.plan.api.exceptions.connection;
|
||||
|
||||
import com.djrapitops.plan.system.webserver.response.ResponseCode;
|
||||
|
||||
/**
|
||||
* Thrown when Connection gets a 412 response due to ServerUUID not being in the database.
|
||||
*
|
||||
@ -12,14 +14,14 @@ package com.djrapitops.plan.api.exceptions.connection;
|
||||
public class UnauthorizedServerException extends WebFailException {
|
||||
|
||||
public UnauthorizedServerException(String message) {
|
||||
super(message);
|
||||
super(message, ResponseCode.PRECONDITION_FAILED);
|
||||
}
|
||||
|
||||
public UnauthorizedServerException(String message, Throwable cause) {
|
||||
super(message, cause);
|
||||
super(message, cause, ResponseCode.PRECONDITION_FAILED);
|
||||
}
|
||||
|
||||
public UnauthorizedServerException(Throwable cause) {
|
||||
super(cause);
|
||||
super(cause, ResponseCode.PRECONDITION_FAILED);
|
||||
}
|
||||
}
|
@ -4,6 +4,8 @@
|
||||
*/
|
||||
package com.djrapitops.plan.api.exceptions.connection;
|
||||
|
||||
import com.djrapitops.plan.system.webserver.response.ResponseCode;
|
||||
|
||||
/**
|
||||
* Thrown when Connection POST-request fails, general Exception.
|
||||
*
|
||||
@ -11,18 +13,47 @@ package com.djrapitops.plan.api.exceptions.connection;
|
||||
*/
|
||||
public class WebException extends Exception {
|
||||
|
||||
private final ResponseCode responseCode;
|
||||
|
||||
public WebException() {
|
||||
responseCode = ResponseCode.NONE;
|
||||
}
|
||||
|
||||
public WebException(String message) {
|
||||
super(message);
|
||||
responseCode = ResponseCode.NONE;
|
||||
}
|
||||
|
||||
public WebException(String message, Throwable cause) {
|
||||
super(message, cause);
|
||||
responseCode = ResponseCode.NONE;
|
||||
}
|
||||
|
||||
public WebException(Throwable cause) {
|
||||
super(cause);
|
||||
responseCode = ResponseCode.NONE;
|
||||
}
|
||||
|
||||
public WebException(ResponseCode responseCode) {
|
||||
this.responseCode = responseCode;
|
||||
}
|
||||
|
||||
public WebException(String message, ResponseCode responseCode) {
|
||||
super(message);
|
||||
this.responseCode = responseCode;
|
||||
}
|
||||
|
||||
public WebException(String message, Throwable cause, ResponseCode responseCode) {
|
||||
super(message, cause);
|
||||
this.responseCode = responseCode;
|
||||
}
|
||||
|
||||
public WebException(Throwable cause, ResponseCode responseCode) {
|
||||
super(cause);
|
||||
this.responseCode = responseCode;
|
||||
}
|
||||
|
||||
public ResponseCode getResponseCode() {
|
||||
return responseCode;
|
||||
}
|
||||
}
|
@ -4,6 +4,8 @@
|
||||
*/
|
||||
package com.djrapitops.plan.api.exceptions.connection;
|
||||
|
||||
import com.djrapitops.plan.system.webserver.response.ResponseCode;
|
||||
|
||||
/**
|
||||
* Group of WebExceptions that can be considered a failed connection state on some occasions.
|
||||
*
|
||||
@ -11,18 +13,19 @@ package com.djrapitops.plan.api.exceptions.connection;
|
||||
*/
|
||||
public class WebFailException extends WebException {
|
||||
|
||||
public WebFailException() {
|
||||
}
|
||||
|
||||
public WebFailException(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
public WebFailException(String message, Throwable cause) {
|
||||
super(message, cause);
|
||||
}
|
||||
|
||||
public WebFailException(Throwable cause) {
|
||||
super(cause);
|
||||
public WebFailException(String message, ResponseCode responseCode) {
|
||||
super(message, responseCode);
|
||||
}
|
||||
|
||||
public WebFailException(String message, Throwable cause, ResponseCode responseCode) {
|
||||
super(message, cause, responseCode);
|
||||
}
|
||||
|
||||
public WebFailException(Throwable cause, ResponseCode responseCode) {
|
||||
super(cause, responseCode);
|
||||
}
|
||||
}
|
@ -4,7 +4,8 @@
|
||||
*/
|
||||
package com.djrapitops.plan.system.info.connection;
|
||||
|
||||
import com.djrapitops.plan.api.exceptions.connection.*;
|
||||
import com.djrapitops.plan.api.exceptions.connection.NotFoundException;
|
||||
import com.djrapitops.plan.api.exceptions.connection.WebException;
|
||||
import com.djrapitops.plan.system.info.request.InfoRequest;
|
||||
import com.djrapitops.plan.system.webserver.Request;
|
||||
import com.djrapitops.plan.system.webserver.pages.PageHandler;
|
||||
@ -54,22 +55,6 @@ public class InfoRequestPageHandler extends PageHandler {
|
||||
}
|
||||
|
||||
private int getResponseCodeFor(WebException e) {
|
||||
if (e instanceof BadRequestException) {
|
||||
return 400;
|
||||
} else if (e instanceof ForbiddenException) {
|
||||
return 403;
|
||||
} else if (e instanceof NotFoundException) {
|
||||
return 404;
|
||||
} else if (e instanceof UnauthorizedServerException) {
|
||||
return 412;
|
||||
} else if (e instanceof InternalErrorException) {
|
||||
return 500;
|
||||
} else if (e instanceof GatewayException) {
|
||||
return 504;
|
||||
} else if (e instanceof ConnectionFailException) {
|
||||
return -1;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
return e.getResponseCode().getCode();
|
||||
}
|
||||
}
|
@ -0,0 +1,29 @@
|
||||
package com.djrapitops.plan.system.webserver.response;
|
||||
|
||||
/**
|
||||
* Enum for HTTP response codes.
|
||||
*
|
||||
* @author Rsl1122
|
||||
*/
|
||||
public enum ResponseCode {
|
||||
NONE(0),
|
||||
CONNECTION_REFUSED(-1),
|
||||
SUCCESS(200),
|
||||
BAD_REQUEST(400),
|
||||
UNAUTHORIZED(401),
|
||||
FORBIDDEN(403),
|
||||
NOT_FOUND(404),
|
||||
PRECONDITION_FAILED(412),
|
||||
INTERNAL_ERROR(500),
|
||||
GATEWAY_ERROR(504);
|
||||
|
||||
private final int code;
|
||||
|
||||
ResponseCode(int code) {
|
||||
this.code = code;
|
||||
}
|
||||
|
||||
public int getCode() {
|
||||
return code;
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user