mirror of
https://github.com/GravitLauncher/Launcher
synced 2025-01-09 00:59:44 +03:00
[ANY] IDEA Reformat
This commit is contained in:
parent
78c0e0d54d
commit
ef3fbaef18
9 changed files with 60 additions and 84 deletions
|
@ -13,12 +13,10 @@
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.URI;
|
import java.net.URI;
|
||||||
import java.net.URISyntaxException;
|
import java.net.URISyntaxException;
|
||||||
import java.net.URL;
|
|
||||||
import java.net.http.HttpClient;
|
import java.net.http.HttpClient;
|
||||||
import java.net.http.HttpRequest;
|
import java.net.http.HttpRequest;
|
||||||
import java.net.http.HttpResponse;
|
import java.net.http.HttpResponse;
|
||||||
import java.time.Duration;
|
import java.time.Duration;
|
||||||
import java.time.temporal.TemporalUnit;
|
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,5 @@
|
||||||
package pro.gravit.launchserver.command.service;
|
package pro.gravit.launchserver.command.service;
|
||||||
|
|
||||||
import org.bouncycastle.cert.jcajce.JcaCertStore;
|
|
||||||
import org.bouncycastle.util.Store;
|
|
||||||
import org.fusesource.jansi.Ansi;
|
import org.fusesource.jansi.Ansi;
|
||||||
import pro.gravit.launcher.profiles.ClientProfile;
|
import pro.gravit.launcher.profiles.ClientProfile;
|
||||||
import pro.gravit.launchserver.LaunchServer;
|
import pro.gravit.launchserver.LaunchServer;
|
||||||
|
@ -12,17 +10,9 @@
|
||||||
import pro.gravit.launchserver.auth.provider.AcceptAuthProvider;
|
import pro.gravit.launchserver.auth.provider.AcceptAuthProvider;
|
||||||
import pro.gravit.launchserver.command.Command;
|
import pro.gravit.launchserver.command.Command;
|
||||||
import pro.gravit.launchserver.config.LaunchServerConfig;
|
import pro.gravit.launchserver.config.LaunchServerConfig;
|
||||||
import pro.gravit.launchserver.helper.SignHelper;
|
|
||||||
import pro.gravit.utils.helper.FormatHelper;
|
import pro.gravit.utils.helper.FormatHelper;
|
||||||
import pro.gravit.utils.helper.LogHelper;
|
import pro.gravit.utils.helper.LogHelper;
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.security.KeyStore;
|
|
||||||
import java.security.cert.Certificate;
|
|
||||||
import java.security.cert.X509Certificate;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.StringTokenizer;
|
import java.util.StringTokenizer;
|
||||||
|
|
||||||
public class SecurityCheckCommand extends Command {
|
public class SecurityCheckCommand extends Command {
|
||||||
|
@ -44,74 +34,68 @@ public String getUsageDescription() {
|
||||||
public void invoke(String... args) throws Exception {
|
public void invoke(String... args) throws Exception {
|
||||||
LaunchServerConfig config = server.config;
|
LaunchServerConfig config = server.config;
|
||||||
config.auth.forEach((name, pair) -> {
|
config.auth.forEach((name, pair) -> {
|
||||||
if(pair.provider instanceof AcceptAuthProvider) {
|
if (pair.provider instanceof AcceptAuthProvider) {
|
||||||
printCheckResult(LogHelper.Level.INFO, String.format("auth.%s.provider", name), "Accept auth provider", false);
|
printCheckResult(LogHelper.Level.INFO, String.format("auth.%s.provider", name), "Accept auth provider", false);
|
||||||
} else {
|
} else {
|
||||||
printCheckResult(LogHelper.Level.INFO, String.format("auth.%s.provider", name), "", true);
|
printCheckResult(LogHelper.Level.INFO, String.format("auth.%s.provider", name), "", true);
|
||||||
}
|
}
|
||||||
if(pair.handler instanceof MemoryAuthHandler) {
|
if (pair.handler instanceof MemoryAuthHandler) {
|
||||||
printCheckResult(LogHelper.Level.INFO, String.format("auth.%s.handler", name), "MemoryAuthHandler test-only", false);
|
printCheckResult(LogHelper.Level.INFO, String.format("auth.%s.handler", name), "MemoryAuthHandler test-only", false);
|
||||||
} else {
|
} else {
|
||||||
printCheckResult(LogHelper.Level.INFO, String.format("auth.%s.handler", name), "", true);
|
printCheckResult(LogHelper.Level.INFO, String.format("auth.%s.handler", name), "", true);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
if(config.protectHandler instanceof NoProtectHandler) {
|
if (config.protectHandler instanceof NoProtectHandler) {
|
||||||
printCheckResult(LogHelper.Level.INFO, "protectHandler", "protectHandler none", false);
|
printCheckResult(LogHelper.Level.INFO, "protectHandler", "protectHandler none", false);
|
||||||
}
|
} else if (config.protectHandler instanceof AdvancedProtectHandler) {
|
||||||
else if(config.protectHandler instanceof AdvancedProtectHandler) {
|
|
||||||
printCheckResult(LogHelper.Level.INFO, "protectHandler", "", true);
|
printCheckResult(LogHelper.Level.INFO, "protectHandler", "", true);
|
||||||
if(!((AdvancedProtectHandler) config.protectHandler).enableHardwareFeature)
|
if (!((AdvancedProtectHandler) config.protectHandler).enableHardwareFeature) {
|
||||||
{
|
|
||||||
printCheckResult(LogHelper.Level.INFO, "protectHandler.hardwareId", "you can improve security by using hwid provider", null);
|
printCheckResult(LogHelper.Level.INFO, "protectHandler.hardwareId", "you can improve security by using hwid provider", null);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
printCheckResult(LogHelper.Level.INFO, "protectHandler.hardwareId", "", true);
|
printCheckResult(LogHelper.Level.INFO, "protectHandler.hardwareId", "", true);
|
||||||
}
|
}
|
||||||
}
|
} else if (config.protectHandler instanceof StdProtectHandler) {
|
||||||
else if(config.protectHandler instanceof StdProtectHandler) {
|
|
||||||
printCheckResult(LogHelper.Level.INFO, "protectHandler", "you can improve security by using advanced", null);
|
printCheckResult(LogHelper.Level.INFO, "protectHandler", "you can improve security by using advanced", null);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
printCheckResult(LogHelper.Level.INFO, "protectHandler", "unknown protectHandler", null);
|
printCheckResult(LogHelper.Level.INFO, "protectHandler", "unknown protectHandler", null);
|
||||||
}
|
}
|
||||||
if(config.netty.address.startsWith("ws://")) {
|
if (config.netty.address.startsWith("ws://")) {
|
||||||
if(config.netty.ipForwarding)
|
if (config.netty.ipForwarding)
|
||||||
printCheckResult(LogHelper.Level.INFO, "netty.ipForwarding", "ipForwarding may be used to spoofing ip", null);
|
printCheckResult(LogHelper.Level.INFO, "netty.ipForwarding", "ipForwarding may be used to spoofing ip", null);
|
||||||
printCheckResult(LogHelper.Level.INFO, "netty.address", "websocket connection not secure", false);
|
printCheckResult(LogHelper.Level.INFO, "netty.address", "websocket connection not secure", false);
|
||||||
} else if(config.netty.address.startsWith("wss://")) {
|
} else if (config.netty.address.startsWith("wss://")) {
|
||||||
if(!config.netty.ipForwarding)
|
if (!config.netty.ipForwarding)
|
||||||
printCheckResult(LogHelper.Level.INFO, "netty.ipForwarding", "ipForwarding not enabled. authLimiter may be get incorrect ip", null);
|
printCheckResult(LogHelper.Level.INFO, "netty.ipForwarding", "ipForwarding not enabled. authLimiter may be get incorrect ip", null);
|
||||||
printCheckResult(LogHelper.Level.INFO, "netty.address", "", true);
|
printCheckResult(LogHelper.Level.INFO, "netty.address", "", true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(config.netty.sendExceptionEnabled) {
|
if (config.netty.sendExceptionEnabled) {
|
||||||
printCheckResult(LogHelper.Level.INFO, "netty.sendExceptionEnabled", "recommend \"false\" in production", false);
|
printCheckResult(LogHelper.Level.INFO, "netty.sendExceptionEnabled", "recommend \"false\" in production", false);
|
||||||
} else {
|
} else {
|
||||||
printCheckResult(LogHelper.Level.INFO, "netty.sendExceptionEnabled", "", true);
|
printCheckResult(LogHelper.Level.INFO, "netty.sendExceptionEnabled", "", true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(config.netty.launcherURL.startsWith("http://")) {
|
if (config.netty.launcherURL.startsWith("http://")) {
|
||||||
printCheckResult(LogHelper.Level.INFO, "netty.launcherUrl", "launcher jar download connection not secure", false);
|
printCheckResult(LogHelper.Level.INFO, "netty.launcherUrl", "launcher jar download connection not secure", false);
|
||||||
} else if(config.netty.launcherURL.startsWith("https://")) {
|
} else if (config.netty.launcherURL.startsWith("https://")) {
|
||||||
printCheckResult(LogHelper.Level.INFO, "netty.launcherUrl", "", true);
|
printCheckResult(LogHelper.Level.INFO, "netty.launcherUrl", "", true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(config.netty.launcherEXEURL.startsWith("http://")) {
|
if (config.netty.launcherEXEURL.startsWith("http://")) {
|
||||||
printCheckResult(LogHelper.Level.INFO, "netty.launcherExeUrl", "launcher exe download connection not secure", false);
|
printCheckResult(LogHelper.Level.INFO, "netty.launcherExeUrl", "launcher exe download connection not secure", false);
|
||||||
} else if(config.netty.launcherEXEURL.startsWith("https://")) {
|
} else if (config.netty.launcherEXEURL.startsWith("https://")) {
|
||||||
printCheckResult(LogHelper.Level.INFO, "netty.launcherExeUrl", "", true);
|
printCheckResult(LogHelper.Level.INFO, "netty.launcherExeUrl", "", true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(config.netty.downloadURL.startsWith("http://")) {
|
if (config.netty.downloadURL.startsWith("http://")) {
|
||||||
printCheckResult(LogHelper.Level.INFO, "netty.downloadUrl", "assets/clients download connection not secure", false);
|
printCheckResult(LogHelper.Level.INFO, "netty.downloadUrl", "assets/clients download connection not secure", false);
|
||||||
} else if(config.netty.downloadURL.startsWith("https://")) {
|
} else if (config.netty.downloadURL.startsWith("https://")) {
|
||||||
printCheckResult(LogHelper.Level.INFO, "netty.downloadUrl", "", true);
|
printCheckResult(LogHelper.Level.INFO, "netty.downloadUrl", "", true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!config.sign.enabled) {
|
if (!config.sign.enabled) {
|
||||||
printCheckResult(LogHelper.Level.INFO, "sign", "it is recommended to use a signature", null);
|
printCheckResult(LogHelper.Level.INFO, "sign", "it is recommended to use a signature", null);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
/*boolean bad = false;
|
/*boolean bad = false;
|
||||||
KeyStore keyStore = SignHelper.getStore(new File(config.sign.keyStore).toPath(), config.sign.keyStorePass, config.sign.keyStoreType);
|
KeyStore keyStore = SignHelper.getStore(new File(config.sign.keyStore).toPath(), config.sign.keyStorePass, config.sign.keyStoreType);
|
||||||
X509Certificate[] certChain = (X509Certificate[]) keyStore.getCertificateChain(config.sign.keyAlias);
|
X509Certificate[] certChain = (X509Certificate[]) keyStore.getCertificateChain(config.sign.keyAlias);
|
||||||
|
@ -130,22 +114,21 @@ else if(config.protectHandler instanceof StdProtectHandler) {
|
||||||
certificate.checkValidity();
|
certificate.checkValidity();
|
||||||
}
|
}
|
||||||
if(!bad)*/
|
if(!bad)*/
|
||||||
printCheckResult(LogHelper.Level.INFO, "sign", "", true);
|
printCheckResult(LogHelper.Level.INFO, "sign", "", true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!config.launcher.enabledProGuard) {
|
if (!config.launcher.enabledProGuard) {
|
||||||
printCheckResult(LogHelper.Level.INFO, "launcher.enabledProGuard", "proguard not enabled", false);
|
printCheckResult(LogHelper.Level.INFO, "launcher.enabledProGuard", "proguard not enabled", false);
|
||||||
} else {
|
} else {
|
||||||
printCheckResult(LogHelper.Level.INFO, "launcher.enabledProGuard", "", true);
|
printCheckResult(LogHelper.Level.INFO, "launcher.enabledProGuard", "", true);
|
||||||
}
|
}
|
||||||
if(!config.launcher.stripLineNumbers) {
|
if (!config.launcher.stripLineNumbers) {
|
||||||
printCheckResult(LogHelper.Level.INFO, "launcher.stripLineNumbers", "stripLineNumbers not enabled", false);
|
printCheckResult(LogHelper.Level.INFO, "launcher.stripLineNumbers", "stripLineNumbers not enabled", false);
|
||||||
} else {
|
} else {
|
||||||
printCheckResult(LogHelper.Level.INFO, "launcher.stripLineNumbers", "", true);
|
printCheckResult(LogHelper.Level.INFO, "launcher.stripLineNumbers", "", true);
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (config.env)
|
switch (config.env) {
|
||||||
{
|
|
||||||
|
|
||||||
case DEV:
|
case DEV:
|
||||||
printCheckResult(LogHelper.Level.INFO, "env", "found env DEV", false);
|
printCheckResult(LogHelper.Level.INFO, "env", "found env DEV", false);
|
||||||
|
@ -162,50 +145,46 @@ else if(config.protectHandler instanceof StdProtectHandler) {
|
||||||
}
|
}
|
||||||
|
|
||||||
//Profiles
|
//Profiles
|
||||||
for(ClientProfile profile : server.getProfiles())
|
for (ClientProfile profile : server.getProfiles()) {
|
||||||
{
|
|
||||||
boolean bad = false;
|
boolean bad = false;
|
||||||
String profileModuleName = String.format("profiles.%s", profile.getTitle());
|
String profileModuleName = String.format("profiles.%s", profile.getTitle());
|
||||||
for(String exc : profile.getUpdateExclusions())
|
for (String exc : profile.getUpdateExclusions()) {
|
||||||
{
|
|
||||||
StringTokenizer tokenizer = new StringTokenizer(exc, "\\/");
|
StringTokenizer tokenizer = new StringTokenizer(exc, "\\/");
|
||||||
if(exc.endsWith(".jar")) {
|
if (exc.endsWith(".jar")) {
|
||||||
printCheckResult(LogHelper.Level.INFO, profileModuleName, String.format("updateExclusions %s not safe. Cheats may be injected very easy!", exc), false);
|
printCheckResult(LogHelper.Level.INFO, profileModuleName, String.format("updateExclusions %s not safe. Cheats may be injected very easy!", exc), false);
|
||||||
bad = true;
|
bad = true;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if(tokenizer.hasMoreTokens() && tokenizer.nextToken().equals("mods"))
|
if (tokenizer.hasMoreTokens() && tokenizer.nextToken().equals("mods")) {
|
||||||
{
|
if (!tokenizer.hasMoreTokens()) {
|
||||||
if(!tokenizer.hasMoreTokens()) {
|
|
||||||
printCheckResult(LogHelper.Level.INFO, profileModuleName, String.format("updateExclusions %s not safe. Cheats may be injected very easy!", exc), false);
|
printCheckResult(LogHelper.Level.INFO, profileModuleName, String.format("updateExclusions %s not safe. Cheats may be injected very easy!", exc), false);
|
||||||
bad = true;
|
bad = true;
|
||||||
} else {
|
} else {
|
||||||
String nextToken = tokenizer.nextToken();
|
String nextToken = tokenizer.nextToken();
|
||||||
if(nextToken.equals("memory_repo") || nextToken.equals("1.12.2") || nextToken.equals("1.7.10")) {
|
if (nextToken.equals("memory_repo") || nextToken.equals("1.12.2") || nextToken.equals("1.7.10")) {
|
||||||
printCheckResult(LogHelper.Level.INFO, profileModuleName, String.format("updateExclusions %s not safe. Cheats may be injected very easy!", exc), false);
|
printCheckResult(LogHelper.Level.INFO, profileModuleName, String.format("updateExclusions %s not safe. Cheats may be injected very easy!", exc), false);
|
||||||
bad = true;
|
bad = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(!bad)
|
if (!bad)
|
||||||
printCheckResult(LogHelper.Level.INFO, profileModuleName, "", true);
|
printCheckResult(LogHelper.Level.INFO, profileModuleName, "", true);
|
||||||
}
|
}
|
||||||
LogHelper.info("Check completed");
|
LogHelper.info("Check completed");
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void printCheckResult(LogHelper.Level level, String module, String comment, Boolean status)
|
public static void printCheckResult(LogHelper.Level level, String module, String comment, Boolean status) {
|
||||||
{
|
|
||||||
LogHelper.rawLog(() -> FormatHelper.rawFormat(level, LogHelper.getDataTime(), false).concat(String.format("[%s] %s - %s", module, comment, status == null ? "WARN" : (status ? "OK" : "FAIL"))),
|
LogHelper.rawLog(() -> FormatHelper.rawFormat(level, LogHelper.getDataTime(), false).concat(String.format("[%s] %s - %s", module, comment, status == null ? "WARN" : (status ? "OK" : "FAIL"))),
|
||||||
() -> FormatHelper.rawAnsiFormat(level, LogHelper.getDataTime(), false)
|
() -> FormatHelper.rawAnsiFormat(level, LogHelper.getDataTime(), false)
|
||||||
.fgBright(Ansi.Color.WHITE)
|
.fgBright(Ansi.Color.WHITE)
|
||||||
.a("[")
|
.a("[")
|
||||||
.fgBright(Ansi.Color.BLUE)
|
.fgBright(Ansi.Color.BLUE)
|
||||||
.a(module)
|
.a(module)
|
||||||
.fgBright(Ansi.Color.WHITE)
|
.fgBright(Ansi.Color.WHITE)
|
||||||
.a("] ".concat(comment).concat(" - "))
|
.a("] ".concat(comment).concat(" - "))
|
||||||
.fgBright(status == null ? Ansi.Color.YELLOW : (status ? Ansi.Color.GREEN : Ansi.Color.RED))
|
.fgBright(status == null ? Ansi.Color.YELLOW : (status ? Ansi.Color.GREEN : Ansi.Color.RED))
|
||||||
.a(status == null ? "WARN" : (status ? "OK" : "FAIL"))
|
.a(status == null ? "WARN" : (status ? "OK" : "FAIL"))
|
||||||
.reset().toString());
|
.reset().toString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,7 @@ public NettyThreadFactory(String poolName) {
|
||||||
protected Thread newThread(Runnable r, String name) {
|
protected Thread newThread(Runnable r, String name) {
|
||||||
Thread thread = super.newThread(r, name);
|
Thread thread = super.newThread(r, name);
|
||||||
thread.setUncaughtExceptionHandler((th, e) -> {
|
thread.setUncaughtExceptionHandler((th, e) -> {
|
||||||
if(LogHelper.isDebugEnabled())
|
if (LogHelper.isDebugEnabled())
|
||||||
LogHelper.error(e);
|
LogHelper.error(e);
|
||||||
});
|
});
|
||||||
return thread;
|
return thread;
|
||||||
|
|
|
@ -60,22 +60,19 @@ protected void channelRead0(ChannelHandlerContext ctx, WebSocketFrame frame) {
|
||||||
// ping and pong frames already handled
|
// ping and pong frames already handled
|
||||||
try {
|
try {
|
||||||
if (hooks.hook(ctx, frame)) return;
|
if (hooks.hook(ctx, frame)) return;
|
||||||
} catch (Throwable ex)
|
} catch (Throwable ex) {
|
||||||
{
|
|
||||||
LogHelper.error(ex);
|
LogHelper.error(ex);
|
||||||
}
|
}
|
||||||
if (frame instanceof TextWebSocketFrame) {
|
if (frame instanceof TextWebSocketFrame) {
|
||||||
try {
|
try {
|
||||||
service.process(ctx, (TextWebSocketFrame) frame, client, context.ip);
|
service.process(ctx, (TextWebSocketFrame) frame, client, context.ip);
|
||||||
} catch (Throwable ex) {
|
} catch (Throwable ex) {
|
||||||
if(LogHelper.isDebugEnabled()) {
|
if (LogHelper.isDebugEnabled()) {
|
||||||
LogHelper.warning("Client %s send invalid request. Connection force closed.", context.ip == null ? IOHelper.getIP(ctx.channel().remoteAddress()) : context.ip);
|
LogHelper.warning("Client %s send invalid request. Connection force closed.", context.ip == null ? IOHelper.getIP(ctx.channel().remoteAddress()) : context.ip);
|
||||||
if(LogHelper.isDevEnabled())
|
if (LogHelper.isDevEnabled()) {
|
||||||
{
|
|
||||||
LogHelper.dev("Client message: %s", ((TextWebSocketFrame) frame).text());
|
LogHelper.dev("Client message: %s", ((TextWebSocketFrame) frame).text());
|
||||||
}
|
}
|
||||||
if(LogHelper.isStacktraceEnabled())
|
if (LogHelper.isStacktraceEnabled()) {
|
||||||
{
|
|
||||||
LogHelper.error(ex);
|
LogHelper.error(ex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -97,7 +94,7 @@ protected void channelRead0(ChannelHandlerContext ctx, WebSocketFrame frame) {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void channelInactive(ChannelHandlerContext ctx) throws Exception {
|
public void channelInactive(ChannelHandlerContext ctx) throws Exception {
|
||||||
if(future != null) future.cancel(true);
|
if (future != null) future.cancel(true);
|
||||||
super.channelInactive(ctx);
|
super.channelInactive(ctx);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,14 +16,17 @@
|
||||||
import java.net.URISyntaxException;
|
import java.net.URISyntaxException;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.nio.file.Paths;
|
import java.nio.file.Paths;
|
||||||
import java.text.SimpleDateFormat;
|
|
||||||
import java.time.Clock;
|
import java.time.Clock;
|
||||||
import java.time.Instant;
|
import java.time.Instant;
|
||||||
import java.time.LocalDateTime;
|
import java.time.LocalDateTime;
|
||||||
import java.time.ZoneId;
|
import java.time.ZoneId;
|
||||||
import java.time.format.DateTimeFormatter;
|
import java.time.format.DateTimeFormatter;
|
||||||
import java.time.temporal.*;
|
import java.time.temporal.ChronoField;
|
||||||
import java.util.*;
|
import java.time.temporal.ChronoUnit;
|
||||||
|
import java.time.temporal.TemporalAccessor;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Locale;
|
||||||
|
import java.util.Objects;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
import static io.netty.handler.codec.http.HttpMethod.GET;
|
import static io.netty.handler.codec.http.HttpMethod.GET;
|
||||||
|
|
|
@ -57,8 +57,8 @@ public void execute(ChannelHandlerContext ctx, Client clientData) throws Excepti
|
||||||
throw new AuthException("Password decryption error");
|
throw new AuthException("Password decryption error");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(clientData.isAuth) {
|
if (clientData.isAuth) {
|
||||||
if(LogHelper.isDevEnabled()) {
|
if (LogHelper.isDevEnabled()) {
|
||||||
LogHelper.warning("Client %s double auth", clientData.username == null ? ip : clientData.username);
|
LogHelper.warning("Client %s double auth", clientData.username == null ? ip : clientData.username);
|
||||||
}
|
}
|
||||||
sendError("You are already logged in");
|
sendError("You are already logged in");
|
||||||
|
|
|
@ -25,7 +25,7 @@ public void execute(ChannelHandlerContext ctx, Client client) {
|
||||||
sendError("Permissions denied");
|
sendError("Permissions denied");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if(username == null || accessToken == null || serverID == null) {
|
if (username == null || accessToken == null || serverID == null) {
|
||||||
sendError("Invalid request");
|
sendError("Invalid request");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,7 +6,6 @@
|
||||||
import pro.gravit.launchserver.auth.AuthProviderPair;
|
import pro.gravit.launchserver.auth.AuthProviderPair;
|
||||||
import pro.gravit.launchserver.socket.Client;
|
import pro.gravit.launchserver.socket.Client;
|
||||||
import pro.gravit.launchserver.socket.response.SimpleResponse;
|
import pro.gravit.launchserver.socket.response.SimpleResponse;
|
||||||
import pro.gravit.utils.helper.LogHelper;
|
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@ -21,7 +20,7 @@ public String getType() {
|
||||||
@Override
|
@Override
|
||||||
public void execute(ChannelHandlerContext ctx, Client client) throws Exception {
|
public void execute(ChannelHandlerContext ctx, Client client) throws Exception {
|
||||||
BatchProfileByUsernameRequestEvent result = new BatchProfileByUsernameRequestEvent();
|
BatchProfileByUsernameRequestEvent result = new BatchProfileByUsernameRequestEvent();
|
||||||
if(list == null) {
|
if (list == null) {
|
||||||
sendError("Invalid request");
|
sendError("Invalid request");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,7 +23,7 @@ public void execute(ChannelHandlerContext ctx, Client client) {
|
||||||
sendError("Access denied");
|
sendError("Access denied");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if(dirName == null) {
|
if (dirName == null) {
|
||||||
sendError("Invalid request");
|
sendError("Invalid request");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue