diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/HttpRequester.java b/LaunchServer/src/main/java/pro/gravit/launchserver/HttpRequester.java index 0545b615..6228e0d6 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/HttpRequester.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/HttpRequester.java @@ -17,25 +17,6 @@ public class HttpRequester { public HttpRequester() { } - public static class SimpleErrorHandler implements HttpHelper.HttpJsonErrorHandler { - private final Type type; - - private SimpleErrorHandler(Type type) { - this.type = type; - } - - @Override - public HttpHelper.HttpOptional applyJson(JsonElement response, int statusCode) { - if(statusCode < 200 || statusCode >= 300) { - return new HttpHelper.HttpOptional<>(null, Launcher.gsonManager.gson.fromJson(response, SimpleError.class), statusCode); - } - if(type == Void.class) { - return new HttpHelper.HttpOptional<>(null, null, statusCode); - } - return new HttpHelper.HttpOptional<>(Launcher.gsonManager.gson.fromJson(response, type), null, statusCode); - } - } - public SimpleErrorHandler makeEH(Class clazz) { return new SimpleErrorHandler<>(clazz); } @@ -48,7 +29,7 @@ public HttpRequest get(String url, String token) { .header("Content-Type", "application/json; charset=UTF-8") .header("Accept", "application/json") .timeout(Duration.ofMillis(10000)); - if(token != null) { + if (token != null) { requestBuilder.header("Authorization", "Bearer ".concat(token)); } return requestBuilder.build(); @@ -65,7 +46,7 @@ public HttpRequest post(String url, T request, String token) { .header("Content-Type", "application/json; charset=UTF-8") .header("Accept", "application/json") .timeout(Duration.ofMillis(10000)); - if(token != null) { + if (token != null) { requestBuilder.header("Authorization", "Bearer ".concat(token)); } return requestBuilder.build(); @@ -78,6 +59,25 @@ public HttpHelper.HttpOptional send(HttpRequest request, Cla return HttpHelper.send(httpClient, request, makeEH(clazz)); } + public static class SimpleErrorHandler implements HttpHelper.HttpJsonErrorHandler { + private final Type type; + + private SimpleErrorHandler(Type type) { + this.type = type; + } + + @Override + public HttpHelper.HttpOptional applyJson(JsonElement response, int statusCode) { + if (statusCode < 200 || statusCode >= 300) { + return new HttpHelper.HttpOptional<>(null, Launcher.gsonManager.gson.fromJson(response, SimpleError.class), statusCode); + } + if (type == Void.class) { + return new HttpHelper.HttpOptional<>(null, null, statusCode); + } + return new HttpHelper.HttpOptional<>(Launcher.gsonManager.gson.fromJson(response, type), null, statusCode); + } + } + public static class SimpleError { public String error; public int code; diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/LaunchServer.java b/LaunchServer/src/main/java/pro/gravit/launchserver/LaunchServer.java index d4c88e81..33f077b6 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/LaunchServer.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/LaunchServer.java @@ -8,7 +8,6 @@ import pro.gravit.launcher.managers.ConfigManager; import pro.gravit.launcher.modules.events.ClosePhase; import pro.gravit.launcher.profiles.ClientProfile; -import pro.gravit.launcher.request.Request; import pro.gravit.launchserver.auth.AuthProviderPair; import pro.gravit.launchserver.auth.core.RejectAuthCoreProvider; import pro.gravit.launchserver.binary.EXEL4JLauncherBinary; @@ -379,18 +378,18 @@ public void syncProfilesDir() throws IOException { // Sort and set new profiles newProfies.sort(Comparator.comparing(a -> a)); profilesList = Set.copyOf(newProfies); - if(config.netty.sendProfileUpdatesEvent) { + if (config.netty.sendProfileUpdatesEvent) { sendUpdateProfilesEvent(); } } private void sendUpdateProfilesEvent() { - if(nettyServerSocketHandler == null || nettyServerSocketHandler.nettyServer == null || nettyServerSocketHandler.nettyServer.service == null) { + if (nettyServerSocketHandler == null || nettyServerSocketHandler.nettyServer == null || nettyServerSocketHandler.nettyServer.service == null) { return; } nettyServerSocketHandler.nettyServer.service.forEachActiveChannels((ch, handler) -> { Client client = handler.getClient(); - if(client == null || !client.isAuth) { + if (client == null || !client.isAuth) { return; } ProfilesRequestEvent event = new ProfilesRequestEvent(ProfilesResponse.getListVisibleProfiles(this, client)); diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/asm/InjectClassAcceptor.java b/LaunchServer/src/main/java/pro/gravit/launchserver/asm/InjectClassAcceptor.java index 8bad18d9..2beaa2e5 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/asm/InjectClassAcceptor.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/asm/InjectClassAcceptor.java @@ -67,7 +67,7 @@ private static void visit(ClassNode classNode, Map values) { List constructors = classNode.methods.stream().filter(method -> "".equals(method.name)) .collect(Collectors.toList()); MethodNode initMethod = constructors.stream().filter(method -> method.invisibleAnnotations != null - && method.invisibleAnnotations.stream().anyMatch(annotation -> INJECTED_CONSTRUCTOR_DESC.equals(annotation.desc))).findFirst() + && method.invisibleAnnotations.stream().anyMatch(annotation -> INJECTED_CONSTRUCTOR_DESC.equals(annotation.desc))).findFirst() .orElseGet(() -> constructors.stream().filter(method -> method.desc.equals("()V")).findFirst().orElse(null)); classNode.fields.forEach(field -> { // Notice that fields that will be used with this algo should not have default diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/AuthProviderPair.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/AuthProviderPair.java index 296717a9..ca25cb89 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/AuthProviderPair.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/AuthProviderPair.java @@ -38,15 +38,6 @@ public static Set getFeatures(Class clazz) { return list; } - public void internalShowOAuthWarnMessage() { - if(!warnOAuthShow) { - if(!(core instanceof MySQLCoreProvider) && !(core instanceof PostgresSQLCoreProvider)) { // MySQL and PostgreSQL upgraded later - logger.warn("AuthCoreProvider {} ({}) not supported OAuth. Legacy session system may be removed in next release", name, core.getClass().getName()); - } - warnOAuthShow = true; - } - } - public static void getFeatures(Class clazz, Set list) { Features features = clazz.getAnnotation(Features.class); if (features != null) { @@ -64,6 +55,15 @@ public static void getFeatures(Class clazz, Set list) { } } + public void internalShowOAuthWarnMessage() { + if (!warnOAuthShow) { + if (!(core instanceof MySQLCoreProvider) && !(core instanceof PostgresSQLCoreProvider)) { // MySQL and PostgreSQL upgraded later + logger.warn("AuthCoreProvider {} ({}) not supported OAuth. Legacy session system may be removed in next release", name, core.getClass().getName()); + } + warnOAuthShow = true; + } + } + public final T isSupport(Class clazz) { if (core == null) return null; T result = null; diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/SQLSourceConfig.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/SQLSourceConfig.java index e6a1257b..eb93aa7e 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/SQLSourceConfig.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/SQLSourceConfig.java @@ -5,5 +5,6 @@ public interface SQLSourceConfig { Connection getConnection() throws SQLException; + void close(); } diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/AbstractSQLCoreProvider.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/AbstractSQLCoreProvider.java index 8e6abc72..2cb8aa7e 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/AbstractSQLCoreProvider.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/AbstractSQLCoreProvider.java @@ -231,7 +231,7 @@ public ClientPermissions requestPermissions(String uuid) throws SQLException { } public boolean isEnabledPermissions() { - return permissionsTable != null && permissionsPermissionColumn != null && permissionsUUIDColumn != null; + return permissionsPermissionColumn != null; } private User query(String sql, String value) throws IOException { diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/AuthCoreProvider.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/AuthCoreProvider.java index 84d5f90e..c43e3210 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/AuthCoreProvider.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/AuthCoreProvider.java @@ -91,7 +91,7 @@ public Map getCommands() { public void invoke(String... args) throws Exception { verifyArgs(args, 1); AuthRequest.AuthPasswordInterface password = null; - if(args.length > 1) { + if (args.length > 1) { if (args[1].startsWith("{")) { password = Launcher.gsonManager.gson.fromJson(args[1], AuthRequest.AuthPasswordInterface.class); } else { diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/HttpAuthCoreProvider.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/HttpAuthCoreProvider.java index b204d2ab..41258549 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/HttpAuthCoreProvider.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/HttpAuthCoreProvider.java @@ -28,7 +28,6 @@ public class HttpAuthCoreProvider extends AuthCoreProvider implements AuthSupportHardware, AuthSupportRemoteClientAccess { private transient final Logger logger = LogManager.getLogger(); - private transient HttpRequester requester; public String bearerToken; public String getUserByUsernameUrl; public String getUserByLoginUrl; @@ -52,6 +51,7 @@ public class HttpAuthCoreProvider extends AuthCoreProvider implements AuthSuppor public String unbanHardwareUrl; public String apiUrl; public List apiFeatures; + private transient HttpRequester requester; @Override public User getUserByUsername(String username) { @@ -65,7 +65,7 @@ public User getUserByUsername(String username) { @Override public User getUserByLogin(String login) { - if(getUserByLoginUrl != null) { + if (getUserByLoginUrl != null) { try { return requester.send(requester.get(CommonHelper.replace(getUserByLoginUrl, "login", login), null), HttpUser.class).getOrThrow(); } catch (IOException e) { @@ -88,7 +88,7 @@ public User getUserByUUID(UUID uuid) { @Override public List getDetails(Client client) { - if(getAuthDetailsUrl == null) { + if (getAuthDetailsUrl == null) { return super.getDetails(client); } try { @@ -102,14 +102,14 @@ public List getDetails( @Override public UserSession getUserSessionByOAuthAccessToken(String accessToken) throws OAuthAccessTokenExpired { - if(getUserByTokenUrl == null) { + if (getUserByTokenUrl == null) { return null; } try { var result = requester.send(requester.get(getUserByTokenUrl, accessToken), HttpUserSession.class); - if(!result.isSuccessful()) { + if (!result.isSuccessful()) { var error = result.error().error; - if(error.equals(AuthRequestEvent.OAUTH_TOKEN_EXPIRE)) { + if (error.equals(AuthRequestEvent.OAUTH_TOKEN_EXPIRE)) { throw new OAuthAccessTokenExpired(); } return null; @@ -123,7 +123,7 @@ public UserSession getUserSessionByOAuthAccessToken(String accessToken) throws O @Override public AuthManager.AuthReport refreshAccessToken(String refreshToken, AuthResponse.AuthContext context) { - if(refreshTokenUrl == null) { + if (refreshTokenUrl == null) { return null; } try { @@ -139,9 +139,9 @@ public AuthManager.AuthReport refreshAccessToken(String refreshToken, AuthRespon public AuthManager.AuthReport authorize(String login, AuthResponse.AuthContext context, AuthRequest.AuthPasswordInterface password, boolean minecraftAccess) throws IOException { var result = requester.send(requester.post(authorizeUrl, new AuthorizeRequest(login, context, password, minecraftAccess), bearerToken), HttpAuthReport.class); - if(!result.isSuccessful()) { + if (!result.isSuccessful()) { var error = result.error().error; - if(error != null) { + if (error != null) { throw new AuthException(error); } } @@ -150,7 +150,7 @@ public AuthManager.AuthReport authorize(String login, AuthResponse.AuthContext c @Override public UserHardware getHardwareInfoByPublicKey(byte[] publicKey) { - if(getHardwareInfoByPublicKeyUrl == null) { + if (getHardwareInfoByPublicKeyUrl == null) { return null; } try { @@ -164,7 +164,7 @@ public UserHardware getHardwareInfoByPublicKey(byte[] publicKey) { @Override public UserHardware getHardwareInfoByData(HardwareReportRequest.HardwareInfo info) { - if(getHardwareInfoByDataUrl == null) { + if (getHardwareInfoByDataUrl == null) { return null; } try { @@ -182,7 +182,7 @@ public UserHardware getHardwareInfoByData(HardwareReportRequest.HardwareInfo inf @Override public UserHardware getHardwareInfoById(String id) { - if(getHardwareInfoByIdUrl == null) { + if (getHardwareInfoByIdUrl == null) { return null; } try { @@ -196,7 +196,7 @@ public UserHardware getHardwareInfoById(String id) { @Override public UserHardware createHardwareInfo(HardwareReportRequest.HardwareInfo info, byte[] publicKey) { - if(createHardwareInfoUrl == null) { + if (createHardwareInfoUrl == null) { return null; } try { @@ -210,7 +210,7 @@ public UserHardware createHardwareInfo(HardwareReportRequest.HardwareInfo info, @Override public void connectUserAndHardware(UserSession userSession, UserHardware hardware) { - if(connectUserAndHardwareUrl == null) { + if (connectUserAndHardwareUrl == null) { return; } try { @@ -222,11 +222,11 @@ public void connectUserAndHardware(UserSession userSession, UserHardware hardwar @Override public void addPublicKeyToHardwareInfo(UserHardware hardware, byte[] publicKey) { - if(addPublicKeyToHardwareInfoUrl == null) { + if (addPublicKeyToHardwareInfoUrl == null) { return; } try { - requester.send(requester.post(addPublicKeyToHardwareInfoUrl, new HardwareRequest((HttpUserHardware)hardware, publicKey), bearerToken), Void.class); + requester.send(requester.post(addPublicKeyToHardwareInfoUrl, new HardwareRequest((HttpUserHardware) hardware, publicKey), bearerToken), Void.class); } catch (IOException e) { logger.error(e); } @@ -234,7 +234,7 @@ public void addPublicKeyToHardwareInfo(UserHardware hardware, byte[] publicKey) @Override public Iterable getUsersByHardwareInfo(UserHardware hardware) { - if(getUsersByHardwareInfoUrl == null) { + if (getUsersByHardwareInfoUrl == null) { return null; } try { @@ -248,7 +248,7 @@ public Iterable getUsersByHardwareInfo(UserHardware hardware) { @Override public void banHardware(UserHardware hardware) { - if(banHardwareUrl == null) { + if (banHardwareUrl == null) { return; } try { @@ -260,7 +260,7 @@ public void banHardware(UserHardware hardware) { @Override public void unbanHardware(UserHardware hardware) { - if(unbanHardwareUrl == null) { + if (unbanHardwareUrl == null) { return; } try { @@ -280,14 +280,6 @@ public List getClientApiFeatures() { return apiFeatures; } - public record HttpAuthReport(String minecraftAccessToken, String oauthAccessToken, - String oauthRefreshToken, long oauthExpire, - HttpUserSession session) { - public AuthManager.AuthReport toAuthReport() { - return new AuthManager.AuthReport(minecraftAccessToken, oauthAccessToken, oauthRefreshToken, oauthExpire, session); - } - } - @Override protected boolean updateServerID(User user, String serverID) throws IOException { var result = requester.send(requester.post(updateServerIdUrl, new UpdateServerIdRequest(user.getUsername(), user.getUUID(), serverID), @@ -306,6 +298,36 @@ public boolean joinServer(Client client, String username, String accessToken, St return result.isSuccessful(); } + @Override + public void init(LaunchServer server) { + requester = new HttpRequester(); + if (getUserByUsernameUrl == null) { + throw new IllegalArgumentException("'getUserByUsernameUrl' can't be null"); + } + if (getUserByUUIDUrl == null) { + throw new IllegalArgumentException("'getUserByUUIDUrl' can't be null"); + } + if (authorizeUrl == null) { + throw new IllegalArgumentException("'authorizeUrl' can't be null"); + } + if (checkServerUrl == null && joinServerUrl == null && updateServerIdUrl == null) { + throw new IllegalArgumentException("Please set 'checkServerUrl' and 'joinServerUrl' or 'updateServerIdUrl'"); + } + } + + @Override + public void close() throws IOException { + + } + + public record HttpAuthReport(String minecraftAccessToken, String oauthAccessToken, + String oauthRefreshToken, long oauthExpire, + HttpUserSession session) { + public AuthManager.AuthReport toAuthReport() { + return new AuthManager.AuthReport(minecraftAccessToken, oauthAccessToken, oauthRefreshToken, oauthExpire, session); + } + } + public static class UpdateServerIdRequest { public String username; public UUID uuid; @@ -344,28 +366,6 @@ public JoinServerRequest(String username, String accessToken, String serverId) { } } - @Override - public void init(LaunchServer server) { - requester = new HttpRequester(); - if(getUserByUsernameUrl == null) { - throw new IllegalArgumentException("'getUserByUsernameUrl' can't be null"); - } - if(getUserByUUIDUrl == null) { - throw new IllegalArgumentException("'getUserByUUIDUrl' can't be null"); - } - if(authorizeUrl == null) { - throw new IllegalArgumentException("'authorizeUrl' can't be null"); - } - if(checkServerUrl == null && joinServerUrl == null && updateServerIdUrl == null) { - throw new IllegalArgumentException("Please set 'checkServerUrl' and 'joinServerUrl' or 'updateServerIdUrl'"); - } - } - - @Override - public void close() throws IOException { - - } - public static class AuthorizeRequest { public String login; public AuthResponse.AuthContext context; @@ -413,153 +413,6 @@ public HardwareRequest(byte[] key) { } - public class HttpUser implements User, UserSupportTextures, UserSupportProperties, UserSupportHardware { - private String username; - private UUID uuid; - private String serverId; - private String accessToken; - private ClientPermissions permissions; - @Deprecated - private Texture skin; - @Deprecated - private Texture cloak; - private Map assets; - private Map properties; - private long hwidId; - private transient HttpUserHardware hardware; - - public HttpUser() { - } - - public HttpUser(String username, UUID uuid, String serverId, String accessToken, ClientPermissions permissions, long hwidId) { - this.username = username; - this.uuid = uuid; - this.serverId = serverId; - this.accessToken = accessToken; - this.permissions = permissions; - this.hwidId = hwidId; - } - - public HttpUser(String username, UUID uuid, String serverId, String accessToken, ClientPermissions permissions, Texture skin, Texture cloak, long hwidId) { - this.username = username; - this.uuid = uuid; - this.serverId = serverId; - this.accessToken = accessToken; - this.permissions = permissions; - this.skin = skin; - this.cloak = cloak; - this.hwidId = hwidId; - } - - public HttpUser(String username, UUID uuid, String serverId, String accessToken, ClientPermissions permissions, Texture skin, Texture cloak, Map properties, long hwidId) { - this.username = username; - this.uuid = uuid; - this.serverId = serverId; - this.accessToken = accessToken; - this.permissions = permissions; - this.skin = skin; - this.cloak = cloak; - this.properties = properties; - this.hwidId = hwidId; - } - - public HttpUser(String username, UUID uuid, String serverId, String accessToken, ClientPermissions permissions, Map assets, Map properties, long hwidId) { - this.username = username; - this.uuid = uuid; - this.serverId = serverId; - this.accessToken = accessToken; - this.permissions = permissions; - this.assets = assets; - this.properties = properties; - this.hwidId = hwidId; - } - - @Override - public String getUsername() { - return username; - } - - @Override - public UUID getUUID() { - return uuid; - } - - @Override - public String getServerId() { - return serverId; - } - - @Override - public String getAccessToken() { - return accessToken; - } - - @Override - public ClientPermissions getPermissions() { - return permissions; - } - - @Override - public Texture getSkinTexture() { - if(assets == null) { - return skin; - } - return assets.get("SKIN"); - } - - @Override - public Texture getCloakTexture() { - if(assets == null) { - return cloak; - } - return assets.get("CAPE"); - } - - public Map getAssets() { - if(assets == null) { - Map map = new HashMap<>(); - if(skin != null) { - map.put("SKIN", skin); - } - if(cloak != null) { - map.put("CAPE", cloak); - } - return map; - } - return assets; - } - - @Override - public Map getProperties() { - if(properties == null) { - return new HashMap<>(); - } - return properties; - } - - @Override - public String toString() { - return "HttpUser{" + - "username='" + username + '\'' + - ", uuid=" + uuid + - ", serverId='" + serverId + '\'' + - ", accessToken='" + accessToken + '\'' + - ", permissions=" + permissions + - ", assets=" + getAssets() + - ", properties=" + properties + - ", hwidId=" + hwidId + - '}'; - } - - @Override - public UserHardware getHardware() { - if (hardware != null) return hardware; - HttpAuthCoreProvider.HttpUserHardware result = (HttpUserHardware) getHardwareInfoById(String.valueOf(hwidId)); - hardware = result; - return result; - } - } - public static class HttpUserSession implements UserSession { private String id; private HttpUser user; @@ -659,4 +512,151 @@ public String toString() { '}'; } } + + public class HttpUser implements User, UserSupportTextures, UserSupportProperties, UserSupportHardware { + private String username; + private UUID uuid; + private String serverId; + private String accessToken; + private ClientPermissions permissions; + @Deprecated + private Texture skin; + @Deprecated + private Texture cloak; + private Map assets; + private Map properties; + private long hwidId; + private transient HttpUserHardware hardware; + + public HttpUser() { + } + + public HttpUser(String username, UUID uuid, String serverId, String accessToken, ClientPermissions permissions, long hwidId) { + this.username = username; + this.uuid = uuid; + this.serverId = serverId; + this.accessToken = accessToken; + this.permissions = permissions; + this.hwidId = hwidId; + } + + public HttpUser(String username, UUID uuid, String serverId, String accessToken, ClientPermissions permissions, Texture skin, Texture cloak, long hwidId) { + this.username = username; + this.uuid = uuid; + this.serverId = serverId; + this.accessToken = accessToken; + this.permissions = permissions; + this.skin = skin; + this.cloak = cloak; + this.hwidId = hwidId; + } + + public HttpUser(String username, UUID uuid, String serverId, String accessToken, ClientPermissions permissions, Texture skin, Texture cloak, Map properties, long hwidId) { + this.username = username; + this.uuid = uuid; + this.serverId = serverId; + this.accessToken = accessToken; + this.permissions = permissions; + this.skin = skin; + this.cloak = cloak; + this.properties = properties; + this.hwidId = hwidId; + } + + public HttpUser(String username, UUID uuid, String serverId, String accessToken, ClientPermissions permissions, Map assets, Map properties, long hwidId) { + this.username = username; + this.uuid = uuid; + this.serverId = serverId; + this.accessToken = accessToken; + this.permissions = permissions; + this.assets = assets; + this.properties = properties; + this.hwidId = hwidId; + } + + @Override + public String getUsername() { + return username; + } + + @Override + public UUID getUUID() { + return uuid; + } + + @Override + public String getServerId() { + return serverId; + } + + @Override + public String getAccessToken() { + return accessToken; + } + + @Override + public ClientPermissions getPermissions() { + return permissions; + } + + @Override + public Texture getSkinTexture() { + if (assets == null) { + return skin; + } + return assets.get("SKIN"); + } + + @Override + public Texture getCloakTexture() { + if (assets == null) { + return cloak; + } + return assets.get("CAPE"); + } + + public Map getAssets() { + if (assets == null) { + Map map = new HashMap<>(); + if (skin != null) { + map.put("SKIN", skin); + } + if (cloak != null) { + map.put("CAPE", cloak); + } + return map; + } + return assets; + } + + @Override + public Map getProperties() { + if (properties == null) { + return new HashMap<>(); + } + return properties; + } + + @Override + public String toString() { + return "HttpUser{" + + "username='" + username + '\'' + + ", uuid=" + uuid + + ", serverId='" + serverId + '\'' + + ", accessToken='" + accessToken + '\'' + + ", permissions=" + permissions + + ", assets=" + getAssets() + + ", properties=" + properties + + ", hwidId=" + hwidId + + '}'; + } + + @Override + public UserHardware getHardware() { + if (hardware != null) return hardware; + HttpAuthCoreProvider.HttpUserHardware result = (HttpUserHardware) getHardwareInfoById(String.valueOf(hwidId)); + hardware = result; + return result; + } + } } diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/MemoryAuthCoreProvider.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/MemoryAuthCoreProvider.java index 14d17bb7..f572dce5 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/MemoryAuthCoreProvider.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/MemoryAuthCoreProvider.java @@ -13,15 +13,19 @@ import java.io.IOException; import java.nio.charset.StandardCharsets; -import java.util.*; +import java.util.ArrayList; +import java.util.List; +import java.util.Objects; +import java.util.UUID; public class MemoryAuthCoreProvider extends AuthCoreProvider { private transient final List memory = new ArrayList<>(16); + @Override public User getUserByUsername(String username) { synchronized (memory) { - for(MemoryUser u : memory) { - if(u.username.equals(username)) { + for (MemoryUser u : memory) { + if (u.username.equals(username)) { return u; } } @@ -39,8 +43,8 @@ public List getDetails( @Override public User getUserByUUID(UUID uuid) { synchronized (memory) { - for(MemoryUser u : memory) { - if(u.uuid.equals(uuid)) { + for (MemoryUser u : memory) { + if (u.uuid.equals(uuid)) { return u; } } @@ -51,8 +55,8 @@ public User getUserByUUID(UUID uuid) { @Override public UserSession getUserSessionByOAuthAccessToken(String accessToken) throws OAuthAccessTokenExpired { synchronized (memory) { - for(MemoryUser u : memory) { - if(u.accessToken.equals(accessToken)) { + for (MemoryUser u : memory) { + if (u.accessToken.equals(accessToken)) { return new MemoryUserSession(u); } } @@ -67,23 +71,23 @@ public AuthManager.AuthReport refreshAccessToken(String refreshToken, AuthRespon @Override public AuthManager.AuthReport authorize(String login, AuthResponse.AuthContext context, AuthRequest.AuthPasswordInterface password, boolean minecraftAccess) throws IOException { - if(login == null) { + if (login == null) { throw AuthException.userNotFound(); } MemoryUser user = null; synchronized (memory) { - for(MemoryUser u : memory) { - if(u.username.equals(login)) { + for (MemoryUser u : memory) { + if (u.username.equals(login)) { user = u; break; } } - if(user == null) { + if (user == null) { user = new MemoryUser(login); memory.add(user); } } - if(!minecraftAccess) { + if (!minecraftAccess) { return AuthManager.AuthReport.ofOAuth(user.accessToken, null, 0, new MemoryUserSession(user)); } else { return AuthManager.AuthReport.ofOAuthWithMinecraft(user.accessToken, user.accessToken, null, 0, new MemoryUserSession(user)); @@ -100,8 +104,8 @@ protected boolean updateServerID(User user, String serverID) throws IOException @Override public User checkServer(Client client, String username, String serverID) throws IOException { synchronized (memory) { - for(MemoryUser u : memory) { - if(u.username.equals(username)) { + for (MemoryUser u : memory) { + if (u.username.equals(username)) { return u; } } diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/MySQLCoreProvider.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/MySQLCoreProvider.java index 8f8a7c6c..427efcbb 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/MySQLCoreProvider.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/MySQLCoreProvider.java @@ -1,33 +1,18 @@ package pro.gravit.launchserver.auth.core; -import io.jsonwebtoken.ExpiredJwtException; -import io.jsonwebtoken.JwtException; -import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; import pro.gravit.launcher.ClientPermissions; -import pro.gravit.launcher.request.auth.AuthRequest; -import pro.gravit.launcher.request.auth.password.AuthPlainPassword; import pro.gravit.launcher.request.secure.HardwareReportRequest; import pro.gravit.launchserver.LaunchServer; -import pro.gravit.launchserver.auth.AuthException; import pro.gravit.launchserver.auth.MySQLSourceConfig; import pro.gravit.launchserver.auth.SQLSourceConfig; import pro.gravit.launchserver.auth.core.interfaces.UserHardware; import pro.gravit.launchserver.auth.core.interfaces.provider.AuthSupportHardware; import pro.gravit.launchserver.auth.core.interfaces.user.UserSupportHardware; -import pro.gravit.launchserver.auth.password.PasswordVerifier; -import pro.gravit.launchserver.helper.LegacySessionHelper; -import pro.gravit.launchserver.manangers.AuthManager; -import pro.gravit.launchserver.socket.response.auth.AuthResponse; import pro.gravit.utils.helper.IOHelper; -import pro.gravit.utils.helper.SecurityHelper; import java.io.ByteArrayInputStream; import java.io.IOException; import java.sql.*; -import java.time.Clock; -import java.time.Duration; -import java.time.LocalDateTime; import java.util.Base64; import java.util.LinkedList; import java.util.List; @@ -108,6 +93,7 @@ private void setUserHardwareId(Connection connection, UUID uuid, long hwidId) th s.setString(2, uuid.toString()); s.executeUpdate(); } + @Override public UserHardware getHardwareInfoByPublicKey(byte[] publicKey) { try (Connection connection = mySQLHolder.getConnection()) { @@ -320,6 +306,7 @@ public MySQLUser(UUID uuid, String username, String accessToken, String serverId super(uuid, username, accessToken, serverId, password, permissions); this.hwidId = hwidId; } + @Override public UserHardware getHardware() { if (hardware != null) return hardware; diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/PostgresSQLCoreProvider.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/PostgresSQLCoreProvider.java index 0e5d9b67..98e36940 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/PostgresSQLCoreProvider.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/PostgresSQLCoreProvider.java @@ -1,6 +1,5 @@ package pro.gravit.launchserver.auth.core; -import pro.gravit.launchserver.LaunchServer; import pro.gravit.launchserver.auth.PostgreSQLSourceConfig; import pro.gravit.launchserver.auth.SQLSourceConfig; diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/interfaces/provider/AuthSupportRemoteClientAccess.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/interfaces/provider/AuthSupportRemoteClientAccess.java index 5b5b0b64..6fa5d411 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/interfaces/provider/AuthSupportRemoteClientAccess.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/interfaces/provider/AuthSupportRemoteClientAccess.java @@ -4,5 +4,6 @@ public interface AuthSupportRemoteClientAccess { String getClientApiUrl(); + List getClientApiFeatures(); } diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/interfaces/session/UserSessionSupportKeys.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/interfaces/session/UserSessionSupportKeys.java index 7da7bb2a..78f3d3e0 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/interfaces/session/UserSessionSupportKeys.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/interfaces/session/UserSessionSupportKeys.java @@ -5,7 +5,9 @@ public interface UserSessionSupportKeys { ClientProfileKeys getClientProfileKeys(); - record ClientProfileKeys(PublicKey publicKey, PrivateKey privateKey, byte[] signature /* V2 */, long expiresAt, long refreshedAfter) { + + record ClientProfileKeys(PublicKey publicKey, PrivateKey privateKey, byte[] signature /* V2 */, long expiresAt, + long refreshedAfter) { } } diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/interfaces/user/UserSupportTextures.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/interfaces/user/UserSupportTextures.java index 07b08148..214d759c 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/interfaces/user/UserSupportTextures.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/core/interfaces/user/UserSupportTextures.java @@ -23,10 +23,10 @@ default Map getUserAssets() { var skin = getSkinTexture(); var cape = getCloakTexture(); Map map = new HashMap<>(); - if(skin != null) { + if (skin != null) { map.put("SKIN", skin); } - if(cape != null) { + if (cape != null) { map.put("CAPE", cape); } return map; diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/password/BCryptPasswordVerifier.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/password/BCryptPasswordVerifier.java index b7df788f..a9f3af28 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/password/BCryptPasswordVerifier.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/password/BCryptPasswordVerifier.java @@ -5,6 +5,7 @@ public class BCryptPasswordVerifier extends PasswordVerifier { public int cost = 10; + @Override public boolean check(String encryptedPassword, String password) { return OpenBSDBCrypt.checkPassword(encryptedPassword, password.toCharArray()); diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/password/JsonPasswordVerifier.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/password/JsonPasswordVerifier.java index 171a5769..339b8447 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/password/JsonPasswordVerifier.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/password/JsonPasswordVerifier.java @@ -19,29 +19,6 @@ public class JsonPasswordVerifier extends PasswordVerifier { public String url; public String bearerToken; - @Override - public boolean check(String encryptedPassword, String password) { - JsonPasswordResponse response = jsonRequest(new JsonPasswordRequest(encryptedPassword, password), url, bearerToken, JsonPasswordResponse.class, client); - if (response != null) { - return response.success; - } - return false; - } - - public static class JsonPasswordRequest { - public String encryptedPassword; - public String password; - - public JsonPasswordRequest(String encryptedPassword, String password) { - this.encryptedPassword = encryptedPassword; - this.password = password; - } - } - - public static class JsonPasswordResponse { - public boolean success; - } - public static R jsonRequest(T request, String url, String bearerToken, Class clazz, HttpClient client) { HttpRequest.BodyPublisher publisher; if (request != null) { @@ -78,4 +55,27 @@ public static R jsonRequest(T request, String url, String bearerToken, Cl return null; } } + + @Override + public boolean check(String encryptedPassword, String password) { + JsonPasswordResponse response = jsonRequest(new JsonPasswordRequest(encryptedPassword, password), url, bearerToken, JsonPasswordResponse.class, client); + if (response != null) { + return response.success; + } + return false; + } + + public static class JsonPasswordRequest { + public String encryptedPassword; + public String password; + + public JsonPasswordRequest(String encryptedPassword, String password) { + this.encryptedPassword = encryptedPassword; + this.password = password; + } + } + + public static class JsonPasswordResponse { + public boolean success; + } } diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/protect/AdvancedProtectHandler.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/protect/AdvancedProtectHandler.java index ec587e7b..6b0c7529 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/protect/AdvancedProtectHandler.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/protect/AdvancedProtectHandler.java @@ -7,7 +7,6 @@ import pro.gravit.launcher.events.request.GetSecureLevelInfoRequestEvent; import pro.gravit.launcher.events.request.HardwareReportRequestEvent; import pro.gravit.launcher.events.request.VerifySecureLevelKeyRequestEvent; -import pro.gravit.launcher.request.secure.HardwareReportRequest; import pro.gravit.launchserver.LaunchServer; import pro.gravit.launchserver.auth.AuthProviderPair; import pro.gravit.launchserver.auth.core.interfaces.UserHardware; @@ -157,9 +156,9 @@ public boolean accept(Client client, AuthProviderPair pair, String extendedToken var parse = parser.parseClaimsJws(extendedToken); String hardwareInfoId = parse.getBody().get("hardware", String.class); if (hardwareInfoId == null) return false; - if(client.auth == null) return false; + if (client.auth == null) return false; var hardwareSupport = client.auth.core.isSupport(AuthSupportHardware.class); - if(hardwareSupport == null) return false; + if (hardwareSupport == null) return false; UserHardware hardware = hardwareSupport.getHardwareInfoById(hardwareInfoId); if (client.trustLevel == null) client.trustLevel = new Client.TrustLevel(); client.trustLevel.hardwareInfo = hardware.getHardwareInfo(); diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/protect/StdProtectHandler.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/protect/StdProtectHandler.java index 80e758f1..dd307ddb 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/protect/StdProtectHandler.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/protect/StdProtectHandler.java @@ -27,7 +27,7 @@ public void checkLaunchServerLicense() { @Override public void init(LaunchServer server) { - if(profileWhitelist != null && profileWhitelist.size() > 0) { + if (profileWhitelist != null && profileWhitelist.size() > 0) { logger.warn("profileWhitelist deprecated. Please use permission 'launchserver.profile.PROFILE_UUID.show' and 'launchserver.profile.PROFILE_UUID.enter'"); } } @@ -48,13 +48,13 @@ public boolean canGetUpdates(String updatesDirName, Client client) { } private boolean isWhitelisted(String property, ClientProfile profile, Client client) { - if(client.permissions != null) { + if (client.permissions != null) { String permByUUID = String.format(property, profile.getUUID()); - if(client.permissions.hasPerm(permByUUID)) { + if (client.permissions.hasPerm(permByUUID)) { return true; } String permByTitle = String.format(property, profile.getTitle().toLowerCase(Locale.ROOT)); - if(client.permissions.hasPerm(permByTitle)) { + if (client.permissions.hasPerm(permByTitle)) { return true; } } diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/texture/JsonTextureProvider.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/texture/JsonTextureProvider.java index ff9dba4e..2653a51e 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/texture/JsonTextureProvider.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/texture/JsonTextureProvider.java @@ -15,9 +15,10 @@ import java.util.UUID; public class JsonTextureProvider extends TextureProvider { - public String url; + private transient static final Type MAP_TYPE = new TypeToken>() { + }.getType(); private transient final Logger logger = LogManager.getLogger(); - private transient static final Type MAP_TYPE = new TypeToken>() {}.getType(); + public String url; @Override public void close() throws IOException { @@ -42,14 +43,14 @@ public Map getAssets(UUID uuid, String username, String client) var result = HTTPRequest.jsonRequest(null, "GET", new URL(RequestTextureProvider.getTextureURL(url, uuid, username, client))); Map map = Launcher.gsonManager.gson.fromJson(result, MAP_TYPE); - if(map == null) { + if (map == null) { return new HashMap<>(); } - if(map.get("skin") != null) { // Legacy script + if (map.get("skin") != null) { // Legacy script map.put("SKIN", map.get("skin")); map.remove("skin"); } - if(map.get("cloak") != null) { + if (map.get("cloak") != null) { map.put("CAPE", map.get("cloak")); map.remove("cloak"); } diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/texture/TextureProvider.java b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/texture/TextureProvider.java index f0530b3d..4519512a 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/auth/texture/TextureProvider.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/auth/texture/TextureProvider.java @@ -33,17 +33,6 @@ public static void registerProviders() { public abstract Texture getSkinTexture(UUID uuid, String username, String client) throws IOException; - @Deprecated - public static class SkinAndCloakTextures { - public final Texture skin; - public final Texture cloak; - - public SkinAndCloakTextures(Texture skin, Texture cloak) { - this.skin = skin; - this.cloak = cloak; - } - } - @Deprecated public SkinAndCloakTextures getTextures(UUID uuid, String username, String client) { @@ -83,13 +72,24 @@ public Map getAssets(UUID uuid, String username, String client) } Map map = new HashMap<>(); - if(skin != null) { + if (skin != null) { map.put("SKIN", skin); } - if(cloak != null) { + if (cloak != null) { map.put("CAPE", cloak); } return map; } + + @Deprecated + public static class SkinAndCloakTextures { + public final Texture skin; + public final Texture cloak; + + public SkinAndCloakTextures(Texture skin, Texture cloak) { + this.skin = skin; + this.cloak = cloak; + } + } } diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/binary/BuildContext.java b/LaunchServer/src/main/java/pro/gravit/launchserver/binary/BuildContext.java index bab1cb87..ac538e84 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/binary/BuildContext.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/binary/BuildContext.java @@ -211,7 +211,8 @@ public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) throws IO try { cipher = Cipher.getInstance("AES/CBC/PKCS5Padding"); cipher.init(Cipher.ENCRYPT_MODE, sKeySpec, iKeySpec); - } catch (NoSuchAlgorithmException | NoSuchPaddingException | InvalidKeyException | InvalidAlgorithmParameterException e) { + } catch (NoSuchAlgorithmException | NoSuchPaddingException | InvalidKeyException | + InvalidAlgorithmParameterException e) { throw new RuntimeException(e); } try (OutputStream stream = new CipherOutputStream(new NoCloseOutputStream(output), cipher)) { diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/binary/tasks/SignJarTask.java b/LaunchServer/src/main/java/pro/gravit/launchserver/binary/tasks/SignJarTask.java index a880c863..a2c09d8c 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/binary/tasks/SignJarTask.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/binary/tasks/SignJarTask.java @@ -40,7 +40,7 @@ public static CMSSignedDataGenerator gen(LaunchServerConfig.JarSignerConf config return SignHelper.createSignedDataGenerator(c, config.keyAlias, config.signAlgo, config.keyPass); } catch (CertificateEncodingException | UnrecoverableKeyException | KeyStoreException - | OperatorCreationException | NoSuchAlgorithmException | CMSException e) { + | OperatorCreationException | NoSuchAlgorithmException | CMSException e) { logger.error("Create signedDataGenerator failed", e); return null; } diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/command/basic/DebugCommand.java b/LaunchServer/src/main/java/pro/gravit/launchserver/command/basic/DebugCommand.java index 42dd2f5a..03a7858c 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/command/basic/DebugCommand.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/command/basic/DebugCommand.java @@ -11,6 +11,7 @@ public class DebugCommand extends Command { private transient Logger logger = LogManager.getLogger(); + public DebugCommand(LaunchServer server) { super(server); } @@ -34,7 +35,7 @@ public void invoke(String... args) throws Exception { LoggerConfig loggerConfig = config.getLoggerConfig("pro.gravit"); loggerConfig.setLevel(value ? Level.TRACE : Level.DEBUG); ctx.updateLoggers(); - if(value) { + if (value) { logger.info("Log level TRACE enabled"); } else { logger.info("Log level TRACE disabled"); diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/command/hash/DownloadAssetCommand.java b/LaunchServer/src/main/java/pro/gravit/launchserver/command/hash/DownloadAssetCommand.java index 596186d0..997240a3 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/command/hash/DownloadAssetCommand.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/command/hash/DownloadAssetCommand.java @@ -10,9 +10,7 @@ import pro.gravit.launchserver.command.Command; import pro.gravit.utils.Downloader; import pro.gravit.utils.helper.IOHelper; -import proguard.OutputWriter; -import java.io.OutputStream; import java.io.Writer; import java.nio.file.Files; import java.nio.file.Path; @@ -22,11 +20,9 @@ import java.util.List; public final class DownloadAssetCommand extends Command { - private transient final Logger logger = LogManager.getLogger(); - private static final String MINECRAFT_VERSIONS_URL = "https://launchermeta.mojang.com/mc/game/version_manifest.json"; - private static final String RESOURCES_DOWNLOAD_URL = "https://resources.download.minecraft.net/"; + private transient final Logger logger = LogManager.getLogger(); public DownloadAssetCommand(LaunchServer server) { super(server); @@ -52,23 +48,23 @@ public void invoke(String... args) throws Exception { Path assetDir = server.updatesDir.resolve(dirName); // Create asset dir - if(Files.notExists(assetDir)) { + if (Files.notExists(assetDir)) { logger.info("Creating asset dir: '{}'", dirName); Files.createDirectory(assetDir); } - if(type.equals("mojang")) { + if (type.equals("mojang")) { HttpRequester requester = new HttpRequester(); logger.info("Fetch versions from {}", MINECRAFT_VERSIONS_URL); var versions = requester.send(requester.get(MINECRAFT_VERSIONS_URL, null), MinecraftVersions.class).getOrThrow(); String profileUrl = null; - for(var e : versions.versions) { - if(e.id.equals(versionName)) { + for (var e : versions.versions) { + if (e.id.equals(versionName)) { profileUrl = e.url; break; } } - if(profileUrl == null) { + if (profileUrl == null) { logger.error("Version {} not found", versionName); return; } @@ -76,30 +72,30 @@ public void invoke(String... args) throws Exception { var profileInfo = requester.send(requester.get(profileUrl, null), MiniVersion.class).getOrThrow(); String assetsIndexUrl = profileInfo.assetIndex.url; String assetIndex = profileInfo.assetIndex.id; - Path indexPath = assetDir.resolve("indexes").resolve(assetIndex+".json"); + Path indexPath = assetDir.resolve("indexes").resolve(assetIndex + ".json"); logger.info("Fetch asset index {} from {}", assetIndex, assetsIndexUrl); JsonObject assets = requester.send(requester.get(assetsIndexUrl, null), JsonObject.class).getOrThrow(); JsonObject objects = assets.get("objects").getAsJsonObject(); - try(Writer writer = IOHelper.newWriter(indexPath)) { + try (Writer writer = IOHelper.newWriter(indexPath)) { logger.info("Save {}", indexPath); Launcher.gsonManager.configGson.toJson(assets, writer); } - if(!assetIndex.equals(versionName)) { - Path targetPath = assetDir.resolve("indexes").resolve(versionName+".json"); + if (!assetIndex.equals(versionName)) { + Path targetPath = assetDir.resolve("indexes").resolve(versionName + ".json"); logger.info("Copy {} into {}", indexPath, targetPath); Files.copy(indexPath, targetPath, StandardCopyOption.REPLACE_EXISTING); } List toDownload = new ArrayList<>(128); - for(var e : objects.entrySet()) { + for (var e : objects.entrySet()) { var value = e.getValue().getAsJsonObject(); var hash = value.get("hash").getAsString(); hash = hash.substring(0, 2) + "/" + hash; var size = value.get("size").getAsLong(); var path = "objects/" + hash; var target = assetDir.resolve(path); - if(Files.exists(target)) { + if (Files.exists(target)) { long fileSize = Files.size(target); - if(fileSize != size) { + if (fileSize != size) { logger.warn("File {} corrupted. Size {}, expected {}", target, size, fileSize); } else { continue; diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/command/service/TokenCommand.java b/LaunchServer/src/main/java/pro/gravit/launchserver/command/service/TokenCommand.java index 178c2088..4e27f048 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/command/service/TokenCommand.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/command/service/TokenCommand.java @@ -11,6 +11,7 @@ public class TokenCommand extends Command { private transient final Logger logger = LogManager.getLogger(); + public TokenCommand(LaunchServer server) { super(server); this.childCommands.put("info", new SubCommand("[token]", "print token info") { @@ -27,16 +28,16 @@ public void invoke(String... args) throws Exception { public void invoke(String... args) throws Exception { AuthProviderPair pair = args.length > 1 ? server.config.getAuthProviderPair(args[1]) : server.config.getAuthProviderPair(); ClientProfile profile = null; - for(ClientProfile p : server.getProfiles()) { - if(p.getTitle().equals(args[0]) || p.getUUID().toString().equals(args[0])) { + for (ClientProfile p : server.getProfiles()) { + if (p.getTitle().equals(args[0]) || p.getUUID().toString().equals(args[0])) { profile = p; break; } } - if(profile == null) { + if (profile == null) { logger.warn("Profile {} not found", args[0]); } - if(pair == null) { + if (pair == null) { logger.error("AuthId {} not found", args[1]); return; } diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/components/ProGuardComponent.java b/LaunchServer/src/main/java/pro/gravit/launchserver/components/ProGuardComponent.java index 6ac0f7ec..8951e72e 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/components/ProGuardComponent.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/components/ProGuardComponent.java @@ -13,7 +13,6 @@ import pro.gravit.utils.helper.UnpackHelper; import proguard.Configuration; import proguard.ConfigurationParser; -import proguard.ParseException; import proguard.ProGuard; import java.io.IOException; diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/config/LaunchServerConfig.java b/LaunchServer/src/main/java/pro/gravit/launchserver/config/LaunchServerConfig.java index 875dc460..7bb5fd31 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/config/LaunchServerConfig.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/config/LaunchServerConfig.java @@ -166,9 +166,9 @@ public void verify() { // Mirror check { boolean updateMirror = Boolean.getBoolean("launchserver.config.disableUpdateMirror"); - if(!updateMirror) { - for(int i=0;i < mirrors.length;++i) { - if("https://mirror.gravit.pro/5.2.x/".equals(mirrors[i])) { + if (!updateMirror) { + for (int i = 0; i < mirrors.length; ++i) { + if ("https://mirror.gravit.pro/5.2.x/".equals(mirrors[i])) { logger.warn("Replace mirror 'https://mirror.gravit.pro/5.2.x/' to 'https://mirror.gravit.pro/5.3.x/'. If you really need to use original url, use '-Dlaunchserver.config.disableUpdateMirror=true'"); mirrors[i] = "https://mirror.gravit.pro/5.3.x/"; } diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/helper/HttpHelper.java b/LaunchServer/src/main/java/pro/gravit/launchserver/helper/HttpHelper.java index 436969c7..1dc1acc1 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/helper/HttpHelper.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/helper/HttpHelper.java @@ -23,11 +23,61 @@ public final class HttpHelper { private static transient final Logger logger = LogManager.getLogger(); + private HttpHelper() { throw new UnsupportedOperationException(); } - public static class HttpOptional { + public static HttpOptional send(HttpClient client, HttpRequest request, HttpErrorHandler handler) throws IOException { + try { + var response = client.send(request, HttpResponse.BodyHandlers.ofInputStream()); + return handler.apply(response); + } catch (InterruptedException e) { + throw new IOException(e); + } + } + + public static CompletableFuture> sendAsync(HttpClient client, HttpRequest request, HttpErrorHandler handler) throws IOException { + return client.sendAsync(request, HttpResponse.BodyHandlers.ofInputStream()).thenApply(handler::apply); + } + + public static HttpResponse.BodyHandler ofJsonResult(Class type) { + return ofJsonResult((Type) type); + } + + public static HttpResponse.BodyHandler ofJsonResult(Type type) { + return new JsonBodyHandler<>(HttpResponse.BodyHandlers.ofInputStream(), (input) -> { + try (Reader reader = new InputStreamReader(input)) { + return Launcher.gsonManager.gson.fromJson(reader, type); + } catch (IOException e) { + throw new RuntimeException(e); + } + }); + } + + public static HttpRequest.BodyPublisher jsonBodyPublisher(T obj) { + return HttpRequest.BodyPublishers.ofString(Launcher.gsonManager.gson.toJson(obj)); + } + + + public interface HttpErrorHandler { + HttpOptional apply(HttpResponse response); + } + + public interface HttpJsonErrorHandler extends HttpErrorHandler { + HttpOptional applyJson(JsonElement response, int statusCode); + + default HttpOptional apply(HttpResponse response) { + try (Reader reader = new InputStreamReader(response.body())) { + var element = Launcher.gsonManager.gson.fromJson(reader, JsonElement.class); + return applyJson(element, response.statusCode()); + } catch (IOException e) { + throw new RuntimeException(e); + } + } + } + + public static class HttpOptional { protected final T result; protected final E error; protected final int statusCode; @@ -41,17 +91,21 @@ public HttpOptional(T result, E error, int statusCode) { public T result() { return result; } + public E error() { return error; } + public int statusCode() { return statusCode; } + public boolean isSuccessful() { return statusCode >= 200 && statusCode < 300; } + public T getOrThrow() throws RequestException { - if(isSuccessful()) { + if (isSuccessful()) { return result; } else { throw new RequestException(error == null ? String.format("statusCode %d", statusCode) : error.toString()); @@ -59,22 +113,6 @@ public T getOrThrow() throws RequestException { } } - public interface HttpErrorHandler { - HttpOptional apply(HttpResponse response); - } - - public interface HttpJsonErrorHandler extends HttpErrorHandler { - HttpOptional applyJson(JsonElement response, int statusCode); - default HttpOptional apply(HttpResponse response) { - try(Reader reader = new InputStreamReader(response.body())) { - var element = Launcher.gsonManager.gson.fromJson(reader, JsonElement.class); - return applyJson(element, response.statusCode()); - } catch (IOException e) { - throw new RuntimeException(e); - } - } - } - public static final class BasicJsonHttpErrorHandler implements HttpJsonErrorHandler { private final Class type; @@ -88,38 +126,6 @@ public HttpOptional applyJson(JsonElement response, int statusCode) { } } - public static HttpOptional send(HttpClient client, HttpRequest request, HttpErrorHandler handler) throws IOException { - try { - var response = client.send(request, HttpResponse.BodyHandlers.ofInputStream()); - return handler.apply(response); - } catch (InterruptedException e) { - throw new IOException(e); - } - } - - - public static CompletableFuture> sendAsync(HttpClient client, HttpRequest request, HttpErrorHandler handler) throws IOException { - return client.sendAsync(request, HttpResponse.BodyHandlers.ofInputStream()).thenApply(handler::apply); - } - - public static HttpResponse.BodyHandler ofJsonResult(Class type) { - return ofJsonResult((Type) type); - } - - public static HttpResponse.BodyHandler ofJsonResult(Type type) { - return new JsonBodyHandler<>(HttpResponse.BodyHandlers.ofInputStream(), (input) -> { - try(Reader reader = new InputStreamReader(input)) { - return Launcher.gsonManager.gson.fromJson(reader, type); - } catch (IOException e) { - throw new RuntimeException(e); - } - }); - } - - public static HttpRequest.BodyPublisher jsonBodyPublisher(T obj) { - return HttpRequest.BodyPublishers.ofString(Launcher.gsonManager.gson.toJson(obj)); - } - private static class JsonBodyHandler implements HttpResponse.BodyHandler { private final HttpResponse.BodyHandler delegate; private final Function func; diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/helper/LegacySessionHelper.java b/LaunchServer/src/main/java/pro/gravit/launchserver/helper/LegacySessionHelper.java index c81eaf8a..5de8e25f 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/helper/LegacySessionHelper.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/helper/LegacySessionHelper.java @@ -7,7 +7,6 @@ import java.security.interfaces.ECPrivateKey; import java.security.interfaces.ECPublicKey; import java.time.Clock; -import java.time.Duration; import java.time.LocalDateTime; import java.time.ZoneOffset; import java.util.Date; @@ -20,7 +19,7 @@ public static String makeAccessJwtTokenFromString(User user, LocalDateTime expir .setSubject(user.getUsername()) .claim("uuid", user.getUUID().toString()) .setExpiration(Date.from(expirationTime - .toInstant(ZoneOffset.UTC))) + .toInstant(ZoneOffset.UTC))) .signWith(privateKey) .compact(); } @@ -38,7 +37,7 @@ public static JwtTokenInfo getJwtInfoFromAccessToken(String token, ECPublicKey p } public static String makeRefreshTokenFromPassword(String username, String rawPassword, String secretSalt) { - if(rawPassword == null) { + if (rawPassword == null) { rawPassword = ""; } return SecurityHelper.toHex(SecurityHelper.digest(SecurityHelper.DigestAlgorithm.SHA256, diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/helper/MakeProfileHelper.java b/LaunchServer/src/main/java/pro/gravit/launchserver/helper/MakeProfileHelper.java index f304884c..dc270962 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/helper/MakeProfileHelper.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/helper/MakeProfileHelper.java @@ -18,7 +18,7 @@ public static ClientProfile makeProfile(ClientProfile.Version version, String ti ClientProfileBuilder builder = new ClientProfileBuilder(); builder.setVersion(version.name); builder.setDir(title); - if(findOption(options, MakeProfileOptionGlobalAssets.class).isPresent()) { + if (findOption(options, MakeProfileOptionGlobalAssets.class).isPresent()) { builder.setAssetDir("assets"); } else { builder.setAssetDir("asset" + version.name); @@ -46,10 +46,10 @@ public static ClientProfile makeProfile(ClientProfile.Version version, String ti Set optionals = new HashSet<>(); jvmArgs.add("-XX:+DisableAttachMechanism"); // Official Mojang launcher java arguments - if(version.compareTo(ClientProfile.Version.MC112) <= 0) { + if (version.compareTo(ClientProfile.Version.MC112) <= 0) { jvmArgs.add("-XX:+UseConcMarkSweepGC"); jvmArgs.add("-XX:+CMSIncrementalMode"); - } else if(version.compareTo(ClientProfile.Version.MC118) <= 0) { // 1.13 - 1.16.5 + } else if (version.compareTo(ClientProfile.Version.MC118) <= 0) { // 1.13 - 1.16.5 jvmArgs.add("-XX:+UseG1GC"); jvmArgs.add("-XX:+UnlockExperimentalVMOptions"); } else { // 1.18+ @@ -236,7 +236,7 @@ public static MakeProfileOption[] getMakeProfileOptionsFromDir(Path dir, ClientP if (Files.exists(dir.resolve("libraries/forge/launchwrapper-1.12-launcherfixed.jar.jar")) || Files.exists(dir.resolve("libraries/net/minecraft/launchwrapper"))) { options.add(new MakeProfileOptionLaunchWrapper()); } - if(globalAssets) { + if (globalAssets) { options.add(new MakeProfileOptionGlobalAssets()); } return options.toArray(new MakeProfileOption[0]); diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/manangers/AuthManager.java b/LaunchServer/src/main/java/pro/gravit/launchserver/manangers/AuthManager.java index ece49017..a6495608 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/manangers/AuthManager.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/manangers/AuthManager.java @@ -27,13 +27,7 @@ import pro.gravit.utils.helper.SecurityHelper; import javax.crypto.Cipher; -import java.io.ByteArrayOutputStream; -import java.io.DataOutputStream; import java.io.IOException; -import java.security.KeyPair; -import java.security.SecureRandom; -import java.time.LocalDateTime; -import java.time.ZoneOffset; import java.util.*; public class AuthManager { @@ -60,9 +54,6 @@ public String newCheckServerToken(String serverName, String authId) { .compact(); } - public record CheckServerTokenInfo(String serverName, String authId) { - } - public CheckServerTokenInfo parseCheckServerToken(String token) { try { var jwt = checkServerTokenParser.parseClaimsJws(token).getBody(); @@ -72,29 +63,6 @@ public CheckServerTokenInfo parseCheckServerToken(String token) { } } - public static class CheckServerVerifier implements RestoreResponse.ExtendedTokenProvider { - private final LaunchServer server; - - public CheckServerVerifier(LaunchServer server) { - this.server = server; - } - - @Override - public boolean accept(Client client, AuthProviderPair pair, String extendedToken) { - var info = server.authManager.parseCheckServerToken(extendedToken); - if(info == null) { - return false; - } - client.auth_id = info.authId; - client.auth = server.config.getAuthProviderPair(info.authId); - if(client.permissions == null) client.permissions = new ClientPermissions(); - client.permissions.addPerm("launchserver.checkserver"); - client.permissions.addPerm(String.format("launchserver.profile.%s.show", info.serverName)); - client.setProperty("launchserver.serverName", info.serverName); - return true; - } - } - /** * Create AuthContext * @@ -154,7 +122,7 @@ public AuthReport auth(AuthResponse.AuthContext context, AuthRequest.AuthPasswor String login = context.login; try { AuthReport result = provider.authorize(login, context, password, context.authType == AuthResponse.ConnectTypes.CLIENT && server.config.protectHandler.allowGetAccessToken(context)); - if(result == null || result.session == null || result.session.getUser() == null) { + if (result == null || result.session == null || result.session.getUser() == null) { logger.error("AuthCoreProvider {} method 'authorize' return null", context.pair.name); throw new AuthException("Internal Auth Error"); } @@ -175,7 +143,7 @@ public AuthReport auth(AuthResponse.AuthContext context, AuthRequest.AuthPasswor * Writing authorization information to the Client object */ public void internalAuth(Client client, AuthResponse.ConnectTypes authType, AuthProviderPair pair, String username, UUID uuid, ClientPermissions permissions, boolean oauth) { - if(!oauth) { + if (!oauth) { throw new UnsupportedOperationException("Unsupported legacy session system"); } client.isAuth = true; @@ -265,7 +233,7 @@ public PlayerProfile getPlayerProfile(AuthProviderPair pair, UUID uuid, ClientPr public PlayerProfile getPlayerProfile(AuthProviderPair pair, User user) { Map properties; - if(user instanceof UserSupportProperties userSupportProperties) { + if (user instanceof UserSupportProperties userSupportProperties) { properties = userSupportProperties.getProperties(); } else { properties = new HashMap<>(); @@ -325,6 +293,32 @@ private AuthRequest.AuthPasswordInterface tryDecryptPasswordPlain(AuthRequest.Au return password; } + public record CheckServerTokenInfo(String serverName, String authId) { + } + + public static class CheckServerVerifier implements RestoreResponse.ExtendedTokenProvider { + private final LaunchServer server; + + public CheckServerVerifier(LaunchServer server) { + this.server = server; + } + + @Override + public boolean accept(Client client, AuthProviderPair pair, String extendedToken) { + var info = server.authManager.parseCheckServerToken(extendedToken); + if (info == null) { + return false; + } + client.auth_id = info.authId; + client.auth = server.config.getAuthProviderPair(info.authId); + if (client.permissions == null) client.permissions = new ClientPermissions(); + client.permissions.addPerm("launchserver.checkserver"); + client.permissions.addPerm(String.format("launchserver.profile.%s.show", info.serverName)); + client.setProperty("launchserver.serverName", info.serverName); + return true; + } + } + public static class CheckServerReport { public UUID uuid; public User user; diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/manangers/KeyAgreementManager.java b/LaunchServer/src/main/java/pro/gravit/launchserver/manangers/KeyAgreementManager.java index 8658b907..0ee48ecd 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/manangers/KeyAgreementManager.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/manangers/KeyAgreementManager.java @@ -66,7 +66,7 @@ public KeyAgreementManager(Path keyDirectory) throws IOException, InvalidKeySpec IOHelper.write(rsaPrivateKeyPath, rsaPrivateKey.getEncoded()); } Path legacySaltPath = keyDirectory.resolve("legacySalt"); - if(IOHelper.isFile(legacySaltPath)) { + if (IOHelper.isFile(legacySaltPath)) { legacySalt = new String(IOHelper.read(legacySaltPath), StandardCharsets.UTF_8); } else { legacySalt = SecurityHelper.randomStringToken(); diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/manangers/LaunchServerGsonManager.java b/LaunchServer/src/main/java/pro/gravit/launchserver/manangers/LaunchServerGsonManager.java index 131dacf4..430f2819 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/manangers/LaunchServerGsonManager.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/manangers/LaunchServerGsonManager.java @@ -33,8 +33,8 @@ public LaunchServerGsonManager(LaunchServerModulesManager modulesManager) { public void registerAdapters(GsonBuilder builder) { super.registerAdapters(builder); builder.registerTypeAdapterFactory(RecordTypeAdapterFactory.builder() - .allowMissingComponentValues() - .create()); + .allowMissingComponentValues() + .create()); builder.registerTypeAdapter(TextureProvider.class, new UniversalJsonAdapter<>(TextureProvider.providers)); builder.registerTypeAdapter(AuthCoreProvider.class, new UniversalJsonAdapter<>(AuthCoreProvider.providers)); builder.registerTypeAdapter(PasswordVerifier.class, new UniversalJsonAdapter<>(PasswordVerifier.providers)); diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/manangers/hook/AuthHookManager.java b/LaunchServer/src/main/java/pro/gravit/launchserver/manangers/hook/AuthHookManager.java index 2947cbcd..8148e975 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/manangers/hook/AuthHookManager.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/manangers/hook/AuthHookManager.java @@ -1,6 +1,5 @@ package pro.gravit.launchserver.manangers.hook; -import pro.gravit.launchserver.auth.core.User; import pro.gravit.launchserver.manangers.AuthManager; import pro.gravit.launchserver.socket.Client; import pro.gravit.launchserver.socket.response.auth.AuthResponse; diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/Client.java b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/Client.java index 123d359f..3ac02c04 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/Client.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/Client.java @@ -65,12 +65,12 @@ public void setProperty(String name, T object) { } @SuppressWarnings("unchecked") - public T getStaticProperty(String name) { + public T getStaticProperty(String name) { if (staticProperties == null) staticProperties = new HashMap<>(); return (T) staticProperties.get(name); } - public void setStaticProperty(String name, T value) { + public void setStaticProperty(String name, T value) { if (staticProperties == null) staticProperties = new HashMap<>(); staticProperties.put(name, value); } diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/WebSocketService.java b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/WebSocketService.java index afd24448..172883ca 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/WebSocketService.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/WebSocketService.java @@ -93,6 +93,22 @@ public static void registerResponses() { providers.register("getPublicKey", GetPublicKeyResponse.class); } + public static String getIPFromContext(ChannelHandlerContext ctx) { + var handler = ctx.pipeline().get(WebSocketFrameHandler.class); + if (handler == null || handler.context == null || handler.context.ip == null) { + return IOHelper.getIP(ctx.channel().remoteAddress()); + } + return handler.context.ip; + } + + public static String getIPFromChannel(Channel channel) { + var handler = channel.pipeline().get(WebSocketFrameHandler.class); + if (handler == null || handler.context == null || handler.context.ip == null) { + return IOHelper.getIP(channel.remoteAddress()); + } + return handler.context.ip; + } + public void forEachActiveChannels(BiConsumer callback) { for (Channel channel : channels) { if (channel == null || channel.pipeline() == null) continue; @@ -176,25 +192,9 @@ public void registerClient(Channel channel) { channels.add(channel); } - public static String getIPFromContext(ChannelHandlerContext ctx) { - var handler = ctx.pipeline().get(WebSocketFrameHandler.class); - if(handler == null || handler.context == null || handler.context.ip == null) { - return IOHelper.getIP(ctx.channel().remoteAddress()); - } - return handler.context.ip; - } - - public static String getIPFromChannel(Channel channel) { - var handler = channel.pipeline().get(WebSocketFrameHandler.class); - if(handler == null || handler.context == null || handler.context.ip == null) { - return IOHelper.getIP(channel.remoteAddress()); - } - return handler.context.ip; - } - public void sendObject(ChannelHandlerContext ctx, Object obj) { String msg = gson.toJson(obj, WebSocketEvent.class); - if(logger.isTraceEnabled()) { + if (logger.isTraceEnabled()) { logger.trace("Send to {}: {}", getIPFromContext(ctx), msg); } ctx.writeAndFlush(new TextWebSocketFrame(msg), ctx.voidPromise()); @@ -202,7 +202,7 @@ public void sendObject(ChannelHandlerContext ctx, Object obj) { public void sendObject(ChannelHandlerContext ctx, Object obj, Type type) { String msg = gson.toJson(obj, type); - if(logger.isTraceEnabled()) { + if (logger.isTraceEnabled()) { logger.trace("Send to {}: {}", getIPFromContext(ctx), msg); } ctx.writeAndFlush(new TextWebSocketFrame(msg), ctx.voidPromise()); @@ -210,7 +210,7 @@ public void sendObject(ChannelHandlerContext ctx, Object obj, Type type) { public void sendObject(Channel channel, Object obj) { String msg = gson.toJson(obj, WebSocketEvent.class); - if(logger.isTraceEnabled()) { + if (logger.isTraceEnabled()) { logger.trace("Send to channel {}: {}", getIPFromChannel(channel), msg); } channel.writeAndFlush(new TextWebSocketFrame(msg), channel.voidPromise()); @@ -218,7 +218,7 @@ public void sendObject(Channel channel, Object obj) { public void sendObject(Channel channel, Object obj, Type type) { String msg = gson.toJson(obj, type); - if(logger.isTraceEnabled()) { + if (logger.isTraceEnabled()) { logger.trace("Send to channel {}: {}", getIPFromChannel(channel), msg); } channel.writeAndFlush(new TextWebSocketFrame(msg), channel.voidPromise()); @@ -226,7 +226,7 @@ public void sendObject(Channel channel, Object obj, Type type) { public void sendObjectAll(Object obj) { String msg = gson.toJson(obj, WebSocketEvent.class); - if(logger.isTraceEnabled()) { + if (logger.isTraceEnabled()) { logger.trace("Send to all: {}", msg); } for (Channel ch : channels) { @@ -236,7 +236,7 @@ public void sendObjectAll(Object obj) { public void sendObjectAll(Object obj, Type type) { String msg = gson.toJson(obj, type); - if(logger.isTraceEnabled()) { + if (logger.isTraceEnabled()) { logger.trace("Send to all: {}", msg); } for (Channel ch : channels) { @@ -252,7 +252,7 @@ public void sendObjectToUUID(UUID userUuid, Object obj, Type type) { Client client = wsHandler.getClient(); if (client == null || !userUuid.equals(client.uuid)) continue; String msg = gson.toJson(obj, type); - if(logger.isTraceEnabled()) { + if (logger.isTraceEnabled()) { logger.trace("Send to {}({}): {}", getIPFromChannel(ch), userUuid, msg); } ch.writeAndFlush(new TextWebSocketFrame(msg), ch.voidPromise()); @@ -320,7 +320,7 @@ public boolean kickByIP(String ip, boolean isClose) { public void sendObjectAndClose(ChannelHandlerContext ctx, Object obj) { String msg = gson.toJson(obj, WebSocketEvent.class); - if(logger.isTraceEnabled()) { + if (logger.isTraceEnabled()) { logger.trace("Send and close {}: {}", getIPFromContext(ctx), msg); } ctx.writeAndFlush(new TextWebSocketFrame(msg)).addListener(ChannelFutureListener.CLOSE); @@ -328,7 +328,7 @@ public void sendObjectAndClose(ChannelHandlerContext ctx, Object obj) { public void sendObjectAndClose(ChannelHandlerContext ctx, Object obj, Type type) { String msg = gson.toJson(obj, type); - if(logger.isTraceEnabled()) { + if (logger.isTraceEnabled()) { logger.trace("Send and close {}: {}", getIPFromContext(ctx), msg); } ctx.writeAndFlush(new TextWebSocketFrame(msg)).addListener(ChannelFutureListener.CLOSE); @@ -337,7 +337,7 @@ public void sendObjectAndClose(ChannelHandlerContext ctx, Object obj, Type type) @Deprecated public void sendEvent(EventResult obj) { String msg = gson.toJson(obj, WebSocketEvent.class); - if(logger.isTraceEnabled()) { + if (logger.isTraceEnabled()) { logger.trace("Send event: {}", msg); } channels.writeAndFlush(new TextWebSocketFrame(msg), ChannelMatchers.all(), true); diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/handlers/WebSocketFrameHandler.java b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/handlers/WebSocketFrameHandler.java index 3a4fb5af..dffbbd46 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/handlers/WebSocketFrameHandler.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/handlers/WebSocketFrameHandler.java @@ -64,7 +64,7 @@ protected void channelRead0(ChannelHandlerContext ctx, WebSocketFrame frame) { logger.error("WebSocket frame handler hook error", ex); } if (frame instanceof TextWebSocketFrame) { - if(logger.isTraceEnabled()) { + if (logger.isTraceEnabled()) { logger.trace("Message from {}: {}", context.ip == null ? IOHelper.getIP(ctx.channel().remoteAddress()) : context.ip, ((TextWebSocketFrame) frame).text()); } try { diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/AdditionalDataResponse.java b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/AdditionalDataResponse.java index 03be4b45..7b99818b 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/AdditionalDataResponse.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/AdditionalDataResponse.java @@ -1,7 +1,6 @@ package pro.gravit.launchserver.socket.response.auth; import io.netty.channel.ChannelHandlerContext; -import pro.gravit.launcher.ClientPermissions; import pro.gravit.launcher.events.request.AdditionalDataRequestEvent; import pro.gravit.launchserver.auth.AuthProviderPair; import pro.gravit.launchserver.auth.core.User; diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/AuthResponse.java b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/AuthResponse.java index 7b30f651..be22d53d 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/AuthResponse.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/AuthResponse.java @@ -12,8 +12,6 @@ import pro.gravit.launchserver.socket.response.SimpleResponse; import pro.gravit.utils.HookException; -import java.util.UUID; - public class AuthResponse extends SimpleResponse { private transient final Logger logger = LogManager.getLogger(); public String login; diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/CheckServerResponse.java b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/CheckServerResponse.java index dad489fe..71f5a255 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/CheckServerResponse.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/CheckServerResponse.java @@ -31,7 +31,7 @@ public void execute(ChannelHandlerContext ctx, Client pClient) { try { server.authHookManager.checkServerHook.hook(this, pClient); AuthManager.CheckServerReport report = server.authManager.checkServer(pClient, username, serverID); - if(report == null) { + if (report == null) { sendError("User not verified"); return; } diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/ExitResponse.java b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/ExitResponse.java index 029bfa50..af5d4d42 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/ExitResponse.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/ExitResponse.java @@ -22,7 +22,7 @@ public static void exit(LaunchServer server, WebSocketFrameHandler wsHandler, Ch Client chClient = wsHandler.getClient(); Client newCusClient = new Client(); newCusClient.checkSign = chClient.checkSign; - if(chClient.staticProperties != null) { + if (chClient.staticProperties != null) { newCusClient.staticProperties = new HashMap<>(chClient.staticProperties); } wsHandler.setClient(newCusClient); diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/FetchClientProfileKeyResponse.java b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/FetchClientProfileKeyResponse.java index b217ce61..2e1281d9 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/FetchClientProfileKeyResponse.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/FetchClientProfileKeyResponse.java @@ -2,7 +2,6 @@ import io.netty.channel.ChannelHandlerContext; import pro.gravit.launcher.events.request.FetchClientProfileKeyRequestEvent; -import pro.gravit.launchserver.auth.core.User; import pro.gravit.launchserver.auth.core.UserSession; import pro.gravit.launchserver.auth.core.interfaces.session.UserSessionSupportKeys; import pro.gravit.launchserver.socket.Client; @@ -22,7 +21,7 @@ public void execute(ChannelHandlerContext ctx, Client client) throws Exception { } UserSession session = client.sessionObject; UserSessionSupportKeys.ClientProfileKeys keys; - if(session instanceof UserSessionSupportKeys support) { + if (session instanceof UserSessionSupportKeys support) { keys = support.getClientProfileKeys(); } else { keys = server.authManager.createClientProfileKeys(client.uuid); diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/GetAvailabilityAuthResponse.java b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/GetAvailabilityAuthResponse.java index c89f29aa..c41ae7dc 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/GetAvailabilityAuthResponse.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/GetAvailabilityAuthResponse.java @@ -21,7 +21,7 @@ public void execute(ChannelHandlerContext ctx, Client client) { List list = new ArrayList<>(); for (AuthProviderPair pair : server.config.auth.values()) { var rca = pair.isSupport(AuthSupportRemoteClientAccess.class); - if(rca != null) { + if (rca != null) { list.add(new GetAvailabilityAuthRequestEvent.AuthAvailability(pair.name, pair.displayName, pair.core.getDetails(client), rca.getClientApiUrl(), rca.getClientApiFeatures())); } else { diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/ProfilesResponse.java b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/ProfilesResponse.java index ec602d7f..12ecea6d 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/ProfilesResponse.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/socket/response/auth/ProfilesResponse.java @@ -13,20 +13,6 @@ import java.util.Set; public class ProfilesResponse extends SimpleResponse { - @Override - public String getType() { - return "profiles"; - } - - @Override - public void execute(ChannelHandlerContext ctx, Client client) { - if (server.config.protectHandler instanceof ProfilesProtectHandler && !((ProfilesProtectHandler) server.config.protectHandler).canGetProfiles(client)) { - sendError("Access denied"); - return; - } - sendResult(new ProfilesRequestEvent(getListVisibleProfiles(server, client))); - } - public static List getListVisibleProfiles(LaunchServer server, Client client) { List profileList; Set serverProfiles = server.getProfiles(); @@ -42,4 +28,18 @@ public static List getListVisibleProfiles(LaunchServer server, Cl } return profileList; } + + @Override + public String getType() { + return "profiles"; + } + + @Override + public void execute(ChannelHandlerContext ctx, Client client) { + if (server.config.protectHandler instanceof ProfilesProtectHandler && !((ProfilesProtectHandler) server.config.protectHandler).canGetProfiles(client)) { + sendError("Access denied"); + return; + } + sendResult(new ProfilesRequestEvent(getListVisibleProfiles(server, client))); + } } diff --git a/Launcher/src/main/java/pro/gravit/launcher/BasicLauncherEventHandler.java b/Launcher/src/main/java/pro/gravit/launcher/BasicLauncherEventHandler.java index a1246bb0..c02deec7 100644 --- a/Launcher/src/main/java/pro/gravit/launcher/BasicLauncherEventHandler.java +++ b/Launcher/src/main/java/pro/gravit/launcher/BasicLauncherEventHandler.java @@ -7,7 +7,6 @@ import pro.gravit.launcher.request.Request; import pro.gravit.launcher.request.RequestService; import pro.gravit.launcher.request.WebSocketEvent; -import pro.gravit.launcher.request.websockets.ClientWebSocketService; import pro.gravit.utils.helper.LogHelper; public class BasicLauncherEventHandler implements RequestService.EventHandler { diff --git a/Launcher/src/main/java/pro/gravit/launcher/ClientLauncherWrapper.java b/Launcher/src/main/java/pro/gravit/launcher/ClientLauncherWrapper.java index 6d0ca26b..5b487024 100644 --- a/Launcher/src/main/java/pro/gravit/launcher/ClientLauncherWrapper.java +++ b/Launcher/src/main/java/pro/gravit/launcher/ClientLauncherWrapper.java @@ -140,7 +140,7 @@ public static void main(String[] arguments) throws IOException, InterruptedExcep if (context.memoryLimit != 0) { args.add(String.format("-Xmx%dM", context.memoryLimit)); } - if(customJvmOptions != null) { + if (customJvmOptions != null) { args.addAll(customJvmOptions); } args.add("-cp"); diff --git a/Launcher/src/main/java/pro/gravit/launcher/LauncherEngine.java b/Launcher/src/main/java/pro/gravit/launcher/LauncherEngine.java index 1921c8a2..0294860b 100644 --- a/Launcher/src/main/java/pro/gravit/launcher/LauncherEngine.java +++ b/Launcher/src/main/java/pro/gravit/launcher/LauncherEngine.java @@ -246,14 +246,14 @@ public void start(String... args) throws Throwable { try { service = StdWebSocketService.initWebSockets(address).get(); } catch (Throwable e) { - if(LogHelper.isDebugEnabled()) { + if (LogHelper.isDebugEnabled()) { LogHelper.error(e); } LogHelper.warning("Launcher in offline mode"); service = initOffline(); } Request.setRequestService(service); - if(service instanceof StdWebSocketService) { + if (service instanceof StdWebSocketService) { ((StdWebSocketService) service).reconnectCallback = () -> { LogHelper.debug("WebSocket connect closed. Try reconnect"); diff --git a/Launcher/src/main/java/pro/gravit/launcher/api/SystemService.java b/Launcher/src/main/java/pro/gravit/launcher/api/SystemService.java index 57c60481..dfdd74b3 100644 --- a/Launcher/src/main/java/pro/gravit/launcher/api/SystemService.java +++ b/Launcher/src/main/java/pro/gravit/launcher/api/SystemService.java @@ -1,8 +1,6 @@ package pro.gravit.launcher.api; import pro.gravit.launcher.LauncherEngine; -import pro.gravit.launcher.profiles.ClientProfile; -import pro.gravit.utils.helper.LogHelper; public class SystemService { private SystemService() { diff --git a/Launcher/src/main/java/pro/gravit/launcher/client/ClientLauncherEntryPoint.java b/Launcher/src/main/java/pro/gravit/launcher/client/ClientLauncherEntryPoint.java index ad94d22f..8e88a405 100644 --- a/Launcher/src/main/java/pro/gravit/launcher/client/ClientLauncherEntryPoint.java +++ b/Launcher/src/main/java/pro/gravit/launcher/client/ClientLauncherEntryPoint.java @@ -121,7 +121,7 @@ public static void main(String[] args) throws Throwable { List classpathURLs = classpath.stream().map(IOHelper::toURL).collect(Collectors.toList()); // Start client with WatchService monitoring RequestService service; - if(params.offlineMode) { + if (params.offlineMode) { service = initOffline(LauncherEngine.modulesManager, params); Request.setRequestService(service); } else { @@ -231,13 +231,13 @@ public static RequestService initOffline(LauncherModulesManager modulesManager, public static void applyClientOfflineProcessors(OfflineRequestService service, ClientLauncherProcess.ClientParams params) { service.registerRequestProcessor(ProfileByUsernameRequest.class, (r) -> { - if(params.playerProfile.username.equals(r.username)) { + if (params.playerProfile.username.equals(r.username)) { return new ProfileByUsernameRequestEvent(params.playerProfile); } throw new RequestException("User not found"); }); service.registerRequestProcessor(ProfileByUUIDRequest.class, (r) -> { - if(params.playerProfile.uuid.equals(r.uuid)) { + if (params.playerProfile.uuid.equals(r.uuid)) { return new ProfileByUUIDRequestEvent(params.playerProfile); } throw new RequestException("User not found"); diff --git a/Launcher/src/main/java/pro/gravit/launcher/client/ClientLauncherProcess.java b/Launcher/src/main/java/pro/gravit/launcher/client/ClientLauncherProcess.java index 93e41298..98e2ba96 100644 --- a/Launcher/src/main/java/pro/gravit/launcher/client/ClientLauncherProcess.java +++ b/Launcher/src/main/java/pro/gravit/launcher/client/ClientLauncherProcess.java @@ -3,7 +3,6 @@ import pro.gravit.launcher.Launcher; import pro.gravit.launcher.LauncherConfig; import pro.gravit.launcher.LauncherEngine; -import pro.gravit.launcher.LauncherNetworkAPI; import pro.gravit.launcher.client.events.client.ClientProcessBuilderCreateEvent; import pro.gravit.launcher.client.events.client.ClientProcessBuilderLaunchedEvent; import pro.gravit.launcher.client.events.client.ClientProcessBuilderParamsWrittedEvent; @@ -28,7 +27,6 @@ import java.net.SocketAddress; import java.nio.file.Files; import java.nio.file.Path; -import java.nio.file.Paths; import java.util.*; import java.util.stream.Collectors; @@ -79,7 +77,7 @@ public ClientLauncherProcess(Path clientDir, Path assetDir, JavaHelper.JavaVersi this.params.resourcePackDir = resourcePackDir.toAbsolutePath().toString(); this.params.assetDir = assetDir.toAbsolutePath().toString(); Path nativesPath = workDir.resolve("natives").resolve(JVMHelper.OS_TYPE.name).resolve(javaVersion.arch.name); - if(!Files.isDirectory(nativesPath)) { + if (!Files.isDirectory(nativesPath)) { nativesPath = workDir.resolve("natives"); } this.params.nativesDir = nativesPath.toString(); @@ -158,7 +156,7 @@ public void start(boolean pipeOutput) throws IOException, InterruptedException { .map(Path::toString) .collect(Collectors.toList())); } - if(Launcher.getConfig().environment != LauncherConfig.LauncherEnvironment.PROD) { + if (Launcher.getConfig().environment != LauncherConfig.LauncherEnvironment.PROD) { processArgs.add(JVMHelper.jvmProperty(LogHelper.DEV_PROPERTY, String.valueOf(LogHelper.isDevEnabled()))); processArgs.add(JVMHelper.jvmProperty(LogHelper.DEBUG_PROPERTY, String.valueOf(LogHelper.isDebugEnabled()))); processArgs.add(JVMHelper.jvmProperty(LogHelper.STACKTRACE_PROPERTY, String.valueOf(LogHelper.isStacktraceEnabled()))); @@ -211,7 +209,7 @@ private void applyJava9Params(List processArgs) { if (modulesAdd.length() > 0) modulesAdd.append(","); modulesAdd.append(moduleName); } - for(String modulePath : jvmModulesPaths) { + for (String modulePath : jvmModulesPaths) { if (modulesPath.length() > 0) modulesPath.append(File.pathSeparator); modulesPath.append(modulePath); } diff --git a/Launcher/src/main/java/pro/gravit/launcher/client/ServerPinger.java b/Launcher/src/main/java/pro/gravit/launcher/client/ServerPinger.java index 09ef1511..5cea3f32 100644 --- a/Launcher/src/main/java/pro/gravit/launcher/client/ServerPinger.java +++ b/Launcher/src/main/java/pro/gravit/launcher/client/ServerPinger.java @@ -163,7 +163,7 @@ private Result modernPing(HInput input, HOutput output) throws IOException { // Parse JSON response JsonObject object = JsonParser.parseString(response).getAsJsonObject(); - if(object.has("error")) { + if (object.has("error")) { throw new IOException(object.get("error").getAsString()); } JsonObject playersObject = object.get("players").getAsJsonObject(); diff --git a/Launcher/src/main/java/pro/gravit/launcher/console/ModulesCommand.java b/Launcher/src/main/java/pro/gravit/launcher/console/ModulesCommand.java index dc722cd1..69206700 100644 --- a/Launcher/src/main/java/pro/gravit/launcher/console/ModulesCommand.java +++ b/Launcher/src/main/java/pro/gravit/launcher/console/ModulesCommand.java @@ -24,10 +24,10 @@ public String getUsageDescription() { @Override public void invoke(String... args) throws Exception { - for(LauncherModule module : LauncherEngine.modulesManager.getModules()) { + for (LauncherModule module : LauncherEngine.modulesManager.getModules()) { LauncherModuleInfo info = module.getModuleInfo(); LauncherTrustManager.CheckClassResult checkStatus = module.getCheckResult(); - if(!ConsoleManager.isConsoleUnlock) { + if (!ConsoleManager.isConsoleUnlock) { LogHelper.info("[MODULE] %s v: %s", info.name, info.version.getVersionString()); } else { LogHelper.info("[MODULE] %s v: %s p: %d deps: %s sig: %s", info.name, info.version.getVersionString(), info.priority, Arrays.toString(info.dependencies), checkStatus == null ? "null" : checkStatus.type); diff --git a/Launcher/src/main/java/pro/gravit/launcher/debug/DebugMain.java b/Launcher/src/main/java/pro/gravit/launcher/debug/DebugMain.java index 6c03bd9e..c5559229 100644 --- a/Launcher/src/main/java/pro/gravit/launcher/debug/DebugMain.java +++ b/Launcher/src/main/java/pro/gravit/launcher/debug/DebugMain.java @@ -57,7 +57,7 @@ public static void main(String[] args) throws Throwable { ConsoleManager.initConsole(); LauncherEngine.modulesManager.invokeEvent(new PreConfigPhase()); RequestService service; - if(offlineMode) { + if (offlineMode) { OfflineRequestService offlineRequestService = new OfflineRequestService(); LauncherEngine.applyBasicOfflineProcessors(offlineRequestService); OfflineModeEvent event = new OfflineModeEvent(offlineRequestService); diff --git a/Launcher/src/main/java/pro/gravit/launcher/utils/ApiBridgeService.java b/Launcher/src/main/java/pro/gravit/launcher/utils/ApiBridgeService.java index 99c81596..76cb77d9 100644 --- a/Launcher/src/main/java/pro/gravit/launcher/utils/ApiBridgeService.java +++ b/Launcher/src/main/java/pro/gravit/launcher/utils/ApiBridgeService.java @@ -18,7 +18,7 @@ public static void checkCertificatesSuccess(X509Certificate[] certs) throws Exce } public static String findLibrary(ClassLoader classLoader, String library) { - if(classLoader instanceof ClientClassLoader) { + if (classLoader instanceof ClientClassLoader) { ClientClassLoader clientClassLoader = (ClientClassLoader) classLoader; return clientClassLoader.findLibrary(library); } diff --git a/Launcher/src/main/java/pro/gravit/launcher/utils/LauncherUpdater.java b/Launcher/src/main/java/pro/gravit/launcher/utils/LauncherUpdater.java index 0d4f7c50..b4194ab5 100644 --- a/Launcher/src/main/java/pro/gravit/launcher/utils/LauncherUpdater.java +++ b/Launcher/src/main/java/pro/gravit/launcher/utils/LauncherUpdater.java @@ -1,10 +1,8 @@ package pro.gravit.launcher.utils; import pro.gravit.launcher.AsyncDownloader; -import pro.gravit.launcher.Launcher; import pro.gravit.launcher.LauncherEngine; import pro.gravit.launcher.LauncherInject; -import pro.gravit.launcher.events.request.LauncherRequestEvent; import pro.gravit.launcher.request.update.LauncherRequest; import pro.gravit.utils.helper.IOHelper; import pro.gravit.utils.helper.LogHelper; @@ -13,12 +11,10 @@ import javax.net.ssl.HttpsURLConnection; import java.io.IOException; import java.io.InputStream; -import java.net.MalformedURLException; import java.net.URL; import java.net.URLConnection; import java.nio.file.Files; import java.nio.file.Path; -import java.nio.file.StandardOpenOption; import java.security.KeyManagementException; import java.security.KeyStoreException; import java.security.NoSuchAlgorithmException; @@ -30,14 +26,16 @@ public class LauncherUpdater { @LauncherInject("launcher.certificatePinning") private static boolean isCertificatePinning; + public static void nothing() { } + private static Path getLauncherPath() { Path pathToCore = IOHelper.getCodeSource(IOHelper.class); Path pathToApi = IOHelper.getCodeSource(LauncherRequest.class); Path pathToSelf = IOHelper.getCodeSource(LauncherUpdater.class); - if(pathToCore.equals(pathToApi) && pathToCore.equals(pathToSelf)) { + if (pathToCore.equals(pathToApi) && pathToCore.equals(pathToSelf)) { return pathToCore; } else { throw new SecurityException("Found split-jar launcher"); diff --git a/Launcher/src/main/java/pro/gravit/launcher/utils/NativeJVMHalt.java b/Launcher/src/main/java/pro/gravit/launcher/utils/NativeJVMHalt.java index df22b64b..3d79d20c 100644 --- a/Launcher/src/main/java/pro/gravit/launcher/utils/NativeJVMHalt.java +++ b/Launcher/src/main/java/pro/gravit/launcher/utils/NativeJVMHalt.java @@ -1,11 +1,8 @@ package pro.gravit.launcher.utils; -import pro.gravit.utils.helper.JVMHelper; import pro.gravit.utils.helper.LogHelper; import java.lang.reflect.Method; -import java.security.AccessController; -import java.security.PrivilegedAction; public final class NativeJVMHalt { public final int haltCode; @@ -30,7 +27,7 @@ public static void haltA(int code) { exitMethod.invoke(null, code); } catch (Throwable e) { th[1] = e; - if(LogHelper.isDevEnabled()) { + if (LogHelper.isDevEnabled()) { LogHelper.error(e); } } diff --git a/LauncherAPI/src/main/java/pro/gravit/launcher/ClientPermissions.java b/LauncherAPI/src/main/java/pro/gravit/launcher/ClientPermissions.java index a080c8ad..e42164cc 100644 --- a/LauncherAPI/src/main/java/pro/gravit/launcher/ClientPermissions.java +++ b/LauncherAPI/src/main/java/pro/gravit/launcher/ClientPermissions.java @@ -1,8 +1,5 @@ package pro.gravit.launcher; -import pro.gravit.launcher.serialize.HInput; - -import java.io.IOException; import java.util.*; public class ClientPermissions { @@ -71,7 +68,7 @@ public void addPerm(String perm) { perms = new ArrayList<>(1); } perms.add(perm); - if(available == null) { + if (available == null) { available = new ArrayList<>(1); } available.add(new PermissionPattern(perm)); @@ -81,7 +78,7 @@ public void removePerm(String action) { if (perms == null) { return; } - if(available == null) { + if (available == null) { return; } perms.remove(action); @@ -110,11 +107,11 @@ public static class PermissionPattern { public PermissionPattern(String pattern) { List prepare = new ArrayList<>(); - for(int i=0;true;) { + for (int i = 0; true; ) { int pos = pattern.indexOf("*", i); - if(pos >= 0) { + if (pos >= 0) { prepare.add(pattern.substring(i, pos)); - i = pos+1; + i = pos + 1; } else { prepare.add(pattern.substring(i)); break; @@ -129,23 +126,23 @@ public int getPriority() { } public boolean match(String str) { - if(parts.length == 0) { + if (parts.length == 0) { return true; } - if(parts.length == 1) { + if (parts.length == 1) { return parts[0].equals(str); } int offset = 0; - if(!str.startsWith(parts[0])) { + if (!str.startsWith(parts[0])) { return false; } - if(!str.endsWith(parts[parts.length-1])) { + if (!str.endsWith(parts[parts.length - 1])) { return false; } - for(int i=1;i= 0) { - offset = pos+1; + if (pos >= 0) { + offset = pos + 1; } else { return false; } diff --git a/LauncherAPI/src/main/java/pro/gravit/launcher/profiles/PlayerProfile.java b/LauncherAPI/src/main/java/pro/gravit/launcher/profiles/PlayerProfile.java index 018bb008..3678e0ea 100644 --- a/LauncherAPI/src/main/java/pro/gravit/launcher/profiles/PlayerProfile.java +++ b/LauncherAPI/src/main/java/pro/gravit/launcher/profiles/PlayerProfile.java @@ -1,7 +1,6 @@ package pro.gravit.launcher.profiles; import pro.gravit.utils.helper.IOHelper; -import pro.gravit.utils.helper.VerifyHelper; import java.util.HashMap; import java.util.Map; @@ -30,10 +29,10 @@ public PlayerProfile(UUID uuid, String username, Texture skin, Texture cloak, Ma this.skin = skin; this.cloak = cloak; this.assets = new HashMap<>(); - if(skin != null) { + if (skin != null) { this.assets.put("SKIN", skin); } - if(cloak != null) { + if (cloak != null) { this.assets.put("CAPE", cloak); } this.properties = properties; diff --git a/LauncherAPI/src/main/java/pro/gravit/launcher/profiles/optional/triggers/ArchTrigger.java b/LauncherAPI/src/main/java/pro/gravit/launcher/profiles/optional/triggers/ArchTrigger.java index 1222af88..b507186a 100644 --- a/LauncherAPI/src/main/java/pro/gravit/launcher/profiles/optional/triggers/ArchTrigger.java +++ b/LauncherAPI/src/main/java/pro/gravit/launcher/profiles/optional/triggers/ArchTrigger.java @@ -5,6 +5,7 @@ public class ArchTrigger extends OptionalTrigger { public JVMHelper.ARCH arch; + @Override protected boolean isTriggered(OptionalFile optional, OptionalTriggerContext context) { return context.getJavaVersion().arch == arch; diff --git a/LauncherAPI/src/main/java/pro/gravit/launcher/request/Request.java b/LauncherAPI/src/main/java/pro/gravit/launcher/request/Request.java index cd26f963..b3d4df69 100644 --- a/LauncherAPI/src/main/java/pro/gravit/launcher/request/Request.java +++ b/LauncherAPI/src/main/java/pro/gravit/launcher/request/Request.java @@ -28,17 +28,17 @@ public abstract class Request implements WebSocketRequ public final UUID requestUUID = UUID.randomUUID(); private transient final AtomicBoolean started = new AtomicBoolean(false); - public static void setRequestService(RequestService service) { - requestService = service; - if(service instanceof StdWebSocketService) { - Request.service = (StdWebSocketService) service; - } - } - public static RequestService getRequestService() { return requestService; } + public static void setRequestService(RequestService service) { + requestService = service; + if (service instanceof StdWebSocketService) { + Request.service = (StdWebSocketService) service; + } + } + public static boolean isAvailable() { return requestService != null; } @@ -121,22 +121,10 @@ public static RequestRestoreReport reconnect() throws Exception { return restore(); } - public static class RequestRestoreReport { - public final boolean legacySession; - public final boolean refreshed; - public final List invalidExtendedTokens; - - public RequestRestoreReport(boolean legacySession, boolean refreshed, List invalidExtendedTokens) { - this.legacySession = legacySession; - this.refreshed = refreshed; - this.invalidExtendedTokens = invalidExtendedTokens; - } - } - public static RequestRestoreReport restore() throws Exception { boolean refreshed = false; RestoreRequest request; - if(oauth != null) { + if (oauth != null) { if (isTokenExpired() || oauth.accessToken == null) { RefreshTokenRequest refreshRequest = new RefreshTokenRequest(authId, oauth.refreshToken); RefreshTokenRequestEvent event = refreshRequest.request(); @@ -197,7 +185,7 @@ public void removeOAuthChangeHandler(BiConsumer invalidExtendedTokens; + + public RequestRestoreReport(boolean legacySession, boolean refreshed, List invalidExtendedTokens) { + this.legacySession = legacySession; + this.refreshed = refreshed; + this.invalidExtendedTokens = invalidExtendedTokens; + } + } + } diff --git a/LauncherAPI/src/main/java/pro/gravit/launcher/request/RequestService.java b/LauncherAPI/src/main/java/pro/gravit/launcher/request/RequestService.java index 8d652b85..39cc2f27 100644 --- a/LauncherAPI/src/main/java/pro/gravit/launcher/request/RequestService.java +++ b/LauncherAPI/src/main/java/pro/gravit/launcher/request/RequestService.java @@ -6,9 +6,12 @@ public interface RequestService { CompletableFuture request(Request request) throws IOException; + void registerEventHandler(EventHandler handler); + void unregisterEventHandler(EventHandler handler); - default T requestSync(Request request) throws IOException { + + default T requestSync(Request request) throws IOException { try { return request(request).get(); } catch (InterruptedException e) { diff --git a/LauncherAPI/src/main/java/pro/gravit/launcher/request/update/LauncherRequest.java b/LauncherAPI/src/main/java/pro/gravit/launcher/request/update/LauncherRequest.java index cc79cb9d..b2345410 100644 --- a/LauncherAPI/src/main/java/pro/gravit/launcher/request/update/LauncherRequest.java +++ b/LauncherAPI/src/main/java/pro/gravit/launcher/request/update/LauncherRequest.java @@ -5,21 +5,13 @@ import pro.gravit.launcher.events.request.LauncherRequestEvent; import pro.gravit.launcher.request.Request; import pro.gravit.launcher.request.RequestService; -import pro.gravit.launcher.request.websockets.StdWebSocketService; import pro.gravit.launcher.request.websockets.WebSocketRequest; import pro.gravit.utils.helper.IOHelper; -import pro.gravit.utils.helper.JVMHelper; import pro.gravit.utils.helper.LogHelper; import pro.gravit.utils.helper.SecurityHelper; import java.io.IOException; -import java.io.InputStream; -import java.net.URL; -import java.net.URLConnection; -import java.nio.file.Files; import java.nio.file.Path; -import java.util.ArrayList; -import java.util.List; public final class LauncherRequest extends Request implements WebSocketRequest { public static final Path BINARY_PATH = IOHelper.getCodeSource(Launcher.class); diff --git a/LauncherAPI/src/main/java/pro/gravit/launcher/request/uuid/BatchProfileByUsernameRequest.java b/LauncherAPI/src/main/java/pro/gravit/launcher/request/uuid/BatchProfileByUsernameRequest.java index 20708419..a3f1ab2e 100644 --- a/LauncherAPI/src/main/java/pro/gravit/launcher/request/uuid/BatchProfileByUsernameRequest.java +++ b/LauncherAPI/src/main/java/pro/gravit/launcher/request/uuid/BatchProfileByUsernameRequest.java @@ -5,7 +5,6 @@ import pro.gravit.launcher.request.Request; import pro.gravit.launcher.request.websockets.WebSocketRequest; import pro.gravit.utils.helper.IOHelper; -import pro.gravit.utils.helper.VerifyHelper; import java.io.IOException; diff --git a/LauncherAPI/src/main/java/pro/gravit/launcher/request/uuid/ProfileByUsernameRequest.java b/LauncherAPI/src/main/java/pro/gravit/launcher/request/uuid/ProfileByUsernameRequest.java index 43c5c02a..d164b28e 100644 --- a/LauncherAPI/src/main/java/pro/gravit/launcher/request/uuid/ProfileByUsernameRequest.java +++ b/LauncherAPI/src/main/java/pro/gravit/launcher/request/uuid/ProfileByUsernameRequest.java @@ -4,7 +4,6 @@ import pro.gravit.launcher.events.request.ProfileByUsernameRequestEvent; import pro.gravit.launcher.request.Request; import pro.gravit.launcher.request.websockets.WebSocketRequest; -import pro.gravit.utils.helper.VerifyHelper; public final class ProfileByUsernameRequest extends Request implements WebSocketRequest { @LauncherNetworkAPI diff --git a/LauncherAPI/src/main/java/pro/gravit/launcher/request/websockets/ClientJSONPoint.java b/LauncherAPI/src/main/java/pro/gravit/launcher/request/websockets/ClientJSONPoint.java index 7ef2b881..d4ce4ec0 100644 --- a/LauncherAPI/src/main/java/pro/gravit/launcher/request/websockets/ClientJSONPoint.java +++ b/LauncherAPI/src/main/java/pro/gravit/launcher/request/websockets/ClientJSONPoint.java @@ -24,7 +24,6 @@ import java.security.KeyStoreException; import java.security.NoSuchAlgorithmException; import java.security.cert.CertificateException; -import java.util.concurrent.CompletableFuture; import java.util.concurrent.ThreadFactory; import java.util.concurrent.atomic.AtomicInteger; import java.util.function.Consumer; @@ -112,10 +111,10 @@ public void openAsync(Runnable onConnect, Consumer onFail) { uri, WebSocketVersion.V13, null, false, EmptyHttpHeaders.INSTANCE, 12800000), this); ChannelFuture future = bootstrap.connect(uri.getHost(), port); future.addListener((l) -> { - if(l.isSuccess()) { + if (l.isSuccess()) { ch = future.channel(); webSocketClientHandler.handshakeFuture().addListener((e) -> { - if(e.isSuccess()) { + if (e.isSuccess()) { onConnect.run(); } else { onFail.accept(webSocketClientHandler.handshakeFuture().cause()); diff --git a/LauncherAPI/src/main/java/pro/gravit/launcher/request/websockets/ClientWebSocketService.java b/LauncherAPI/src/main/java/pro/gravit/launcher/request/websockets/ClientWebSocketService.java index 4cd44b77..02959606 100644 --- a/LauncherAPI/src/main/java/pro/gravit/launcher/request/websockets/ClientWebSocketService.java +++ b/LauncherAPI/src/main/java/pro/gravit/launcher/request/websockets/ClientWebSocketService.java @@ -82,7 +82,7 @@ public void registerRequests() { @SuppressWarnings("deprecation") public void registerResults() { - if(!resultsRegistered) { + if (!resultsRegistered) { results.register("auth", AuthRequestEvent.class); results.register("checkServer", CheckServerRequestEvent.class); results.register("joinServer", JoinServerRequestEvent.class); diff --git a/LauncherAPI/src/main/java/pro/gravit/launcher/request/websockets/OfflineRequestService.java b/LauncherAPI/src/main/java/pro/gravit/launcher/request/websockets/OfflineRequestService.java index fd353447..09aee311 100644 --- a/LauncherAPI/src/main/java/pro/gravit/launcher/request/websockets/OfflineRequestService.java +++ b/LauncherAPI/src/main/java/pro/gravit/launcher/request/websockets/OfflineRequestService.java @@ -16,26 +16,27 @@ public class OfflineRequestService implements RequestService { private final HashSet eventHandlers = new HashSet<>(); private final Map, RequestProcessor> processors = new ConcurrentHashMap<>(); + @Override @SuppressWarnings("unchecked") public CompletableFuture request(Request request) throws IOException { RequestProcessor> processor = (RequestProcessor>) processors.get(request.getClass()); CompletableFuture future = new CompletableFuture<>(); - if(processor == null) { + if (processor == null) { future.completeExceptionally(new RequestException(String.format("Offline mode not support '%s'", request.getType()))); return future; } - if(LogHelper.isDevEnabled()) { + if (LogHelper.isDevEnabled()) { LogHelper.dev("Request %s: %s", request.getType(), Launcher.gsonManager.gson.toJson(request)); } try { T event = processor.process(request); - if(LogHelper.isDevEnabled()) { + if (LogHelper.isDevEnabled()) { LogHelper.dev("Response %s: %s", event.getType(), Launcher.gsonManager.gson.toJson(event)); } future.complete(event); } catch (Throwable e) { - if(e instanceof RequestException) { + if (e instanceof RequestException) { future.completeExceptionally(e); } else { future.completeExceptionally(new RequestException(e)); @@ -59,11 +60,11 @@ public boolean isClosed() { return false; } - public void registerRequestProcessor(Class requestClazz, RequestProcessor function) { + public void registerRequestProcessor(Class requestClazz, RequestProcessor function) { processors.put(requestClazz, function); } - public void unregisterRequestProcessor(Class> requestClazz) { + public void unregisterRequestProcessor(Class> requestClazz) { processors.remove(requestClazz); } diff --git a/LauncherAPI/src/main/java/pro/gravit/launcher/request/websockets/StdWebSocketService.java b/LauncherAPI/src/main/java/pro/gravit/launcher/request/websockets/StdWebSocketService.java index 9e395db9..ad6212e1 100644 --- a/LauncherAPI/src/main/java/pro/gravit/launcher/request/websockets/StdWebSocketService.java +++ b/LauncherAPI/src/main/java/pro/gravit/launcher/request/websockets/StdWebSocketService.java @@ -55,7 +55,6 @@ public static CompletableFuture initWebSockets(String addre } - @Deprecated public void registerEventHandler(ClientWebSocketService.EventHandler handler) { legacyEventHandlers.add(handler); diff --git a/LauncherCore/src/main/java/pro/gravit/utils/helper/CommonHelper.java b/LauncherCore/src/main/java/pro/gravit/utils/helper/CommonHelper.java index 43b6db98..ccaeb8ea 100644 --- a/LauncherCore/src/main/java/pro/gravit/utils/helper/CommonHelper.java +++ b/LauncherCore/src/main/java/pro/gravit/utils/helper/CommonHelper.java @@ -4,8 +4,6 @@ import pro.gravit.utils.command.CommandException; import javax.script.ScriptEngine; -import javax.script.ScriptEngineFactory; -import javax.script.ScriptEngineManager; import java.lang.reflect.Type; import java.util.Base64; import java.util.Collection; diff --git a/LauncherCore/src/main/java/pro/gravit/utils/helper/FormatHelper.java b/LauncherCore/src/main/java/pro/gravit/utils/helper/FormatHelper.java index d53b889d..a0229df0 100644 --- a/LauncherCore/src/main/java/pro/gravit/utils/helper/FormatHelper.java +++ b/LauncherCore/src/main/java/pro/gravit/utils/helper/FormatHelper.java @@ -58,9 +58,9 @@ public static String ansiFormatVersion(String product) { fgBright(Ansi.Color.MAGENTA).a("GravitLauncher "). // sashok724's fgBright(Ansi.Color.BLUE).a("(fork sashok724's Launcher) "). fgBright(Ansi.Color.CYAN).a(product). // Product - fgBright(Ansi.Color.WHITE).a(" v").fgBright(Ansi.Color.BLUE).a(Version.getVersion().toString()). // Version - fgBright(Ansi.Color.WHITE).a(" (build #").fgBright(Ansi.Color.RED).a(Version.getVersion().build).fgBright(Ansi.Color.WHITE).a(')'). // Build# - reset().toString(); // To file + fgBright(Ansi.Color.WHITE).a(" v").fgBright(Ansi.Color.BLUE).a(Version.getVersion().toString()). // Version + fgBright(Ansi.Color.WHITE).a(" (build #").fgBright(Ansi.Color.RED).a(Version.getVersion().build).fgBright(Ansi.Color.WHITE).a(')'). // Build# + reset().toString(); // To file } public static String ansiFormatLicense(String product) { diff --git a/LauncherCore/src/main/java/pro/gravit/utils/helper/IOHelper.java b/LauncherCore/src/main/java/pro/gravit/utils/helper/IOHelper.java index ba16d237..2b1812a6 100644 --- a/LauncherCore/src/main/java/pro/gravit/utils/helper/IOHelper.java +++ b/LauncherCore/src/main/java/pro/gravit/utils/helper/IOHelper.java @@ -39,6 +39,7 @@ public final class IOHelper { public static final FileSystem FS = FileSystems.getDefault(); // Platform-dependent public static final String PLATFORM_SEPARATOR = FS.getSeparator(); + private static final Pattern PLATFORM_SEPARATOR_PATTERN = Pattern.compile(PLATFORM_SEPARATOR, Pattern.LITERAL); public static final boolean POSIX = FS.supportedFileAttributeViews().contains("posix") || FS.supportedFileAttributeViews().contains("Posix"); public static final Path JVM_DIR = Paths.get(System.getProperty("java.home")); public static final Path HOME_DIR = Paths.get(System.getProperty("user.home")); @@ -54,7 +55,6 @@ public final class IOHelper { private static final Set WALK_OPTIONS = Collections.singleton(FileVisitOption.FOLLOW_LINKS); // Other constants private static final Pattern CROSS_SEPARATOR_PATTERN = Pattern.compile(CROSS_SEPARATOR, Pattern.LITERAL); - private static final Pattern PLATFORM_SEPARATOR_PATTERN = Pattern.compile(PLATFORM_SEPARATOR, Pattern.LITERAL); private IOHelper() { } diff --git a/LauncherCore/src/main/java/pro/gravit/utils/helper/JVMHelper.java b/LauncherCore/src/main/java/pro/gravit/utils/helper/JVMHelper.java index ac161aa9..43acfbe7 100644 --- a/LauncherCore/src/main/java/pro/gravit/utils/helper/JVMHelper.java +++ b/LauncherCore/src/main/java/pro/gravit/utils/helper/JVMHelper.java @@ -20,12 +20,10 @@ public final class JVMHelper { public static final OperatingSystemMXBean OPERATING_SYSTEM_MXBEAN = ManagementFactory.getOperatingSystemMXBean(); public static final OS OS_TYPE = OS.byName(OPERATING_SYSTEM_MXBEAN.getName()); - // System properties - public static final String OS_VERSION = OPERATING_SYSTEM_MXBEAN.getVersion(); - @Deprecated public static final int OS_BITS = getCorrectOSArch(); - + // System properties + public static final String OS_VERSION = OPERATING_SYSTEM_MXBEAN.getVersion(); public static final ARCH ARCH_TYPE = getArch(System.getProperty("os.arch")); public static final int JVM_BITS = Integer.parseInt(System.getProperty("sun.arch.data.model")); public static final SecurityManager SECURITY_MANAGER = System.getSecurityManager(); @@ -46,21 +44,11 @@ public final class JVMHelper { private JVMHelper() { } - public enum ARCH { - X86("x86"), X86_64("x86-64"), ARM64("arm64"), ARM32("arm32"); - - public final String name; - - ARCH(String name) { - this.name = name; - } - } - public static ARCH getArch(String arch) { - if(arch.equals("amd64") || arch.equals("x86-64") || arch.equals("x86_64")) return ARCH.X86_64; - if(arch.equals("i386") || arch.equals("i686") || arch.equals("x86")) return ARCH.X86; - if(arch.startsWith("armv8") || arch.startsWith("aarch64")) return ARCH.ARM64; - if(arch.startsWith("arm") || arch.startsWith("aarch32")) return ARCH.ARM32; + if (arch.equals("amd64") || arch.equals("x86-64") || arch.equals("x86_64")) return ARCH.X86_64; + if (arch.equals("i386") || arch.equals("i686") || arch.equals("x86")) return ARCH.X86; + if (arch.startsWith("armv8") || arch.startsWith("aarch64")) return ARCH.ARM64; + if (arch.startsWith("arm") || arch.startsWith("aarch32")) return ARCH.ARM32; throw new InternalError(String.format("Unsupported arch '%s'", arch)); } @@ -110,19 +98,16 @@ public static Class firstClass(String... names) throws ClassNotFoundException throw new ClassNotFoundException(Arrays.toString(names)); } - public static void fullGC() { RUNTIME.gc(); RUNTIME.runFinalization(); LogHelper.debug("Used heap: %d MiB", RUNTIME.totalMemory() - RUNTIME.freeMemory() >> 20); } - public static String[] getClassPath() { return System.getProperty("java.class.path").split(File.pathSeparator); } - public static URL[] getClassPathURL() { String[] cp = System.getProperty("java.class.path").split(File.pathSeparator); URL[] list = new URL[cp.length]; @@ -164,35 +149,29 @@ private static int getCorrectOSArch() { return System.getProperty("os.arch").contains("64") ? 64 : 32; } - public static String getEnvPropertyCaseSensitive(String name) { return System.getenv().get(name); } - @Deprecated public static boolean isJVMMatchesSystemArch() { return JVM_BITS == OS_BITS; } - public static String jvmProperty(String name, String value) { return String.format("-D%s=%s", name, value); } - public static String systemToJvmProperty(String name) { return String.format("-D%s=%s", name, System.getProperties().getProperty(name)); } - public static void addSystemPropertyToArgs(Collection args, String name) { String property = System.getProperty(name); if (property != null) args.add(String.format("-D%s=%s", name, property)); } - public static void verifySystemProperties(Class mainClass, boolean requireSystem) { Locale.setDefault(Locale.US); // Verify class loader @@ -204,6 +183,17 @@ public static void verifySystemProperties(Class mainClass, boolean requireSys LogHelper.debug("Verifying JVM architecture"); } + + public enum ARCH { + X86("x86"), X86_64("x86-64"), ARM64("arm64"), ARM32("arm32"); + + public final String name; + + ARCH(String name) { + this.name = name; + } + } + public enum OS { MUSTDIE("mustdie"), LINUX("linux"), MACOSX("macosx"); diff --git a/LauncherCore/src/main/java/pro/gravit/utils/helper/JavaHelper.java b/LauncherCore/src/main/java/pro/gravit/utils/helper/JavaHelper.java index 8676f82e..73be2837 100644 --- a/LauncherCore/src/main/java/pro/gravit/utils/helper/JavaHelper.java +++ b/LauncherCore/src/main/java/pro/gravit/utils/helper/JavaHelper.java @@ -12,6 +12,7 @@ public class JavaHelper { private static List javaVersionsCache; + public static Path tryGetOpenJFXPath(Path jvmDir) { String dirName = jvmDir.getFileName().toString(); Path parent = jvmDir.getParent(); @@ -57,7 +58,7 @@ public static boolean tryAddModule(List paths, String moduleName, StringBu } public synchronized static List findJava() { - if(javaVersionsCache != null) { + if (javaVersionsCache != null) { return javaVersionsCache; } List javaPaths = new ArrayList<>(4); @@ -106,11 +107,11 @@ public synchronized static List findJava() { } private static JavaVersion tryFindJavaByPath(Path path) { - if(javaVersionsCache == null) { + if (javaVersionsCache == null) { return null; } - for(JavaVersion version : javaVersionsCache) { - if(version.jvmDir.equals(path)) { + for (JavaVersion version : javaVersionsCache) { + if (version.jvmDir.equals(path)) { return version; } } @@ -156,8 +157,8 @@ public static JavaVersionAndBuild getJavaVersion(String version) { result.build = Integer.parseInt(version.substring(dot + 1)); } else { try { - if(version.endsWith("-ea")) { - version = version.substring(0, version.length()-3); + if (version.endsWith("-ea")) { + version = version.substring(0, version.length() - 3); } result.version = Integer.parseInt(version); result.build = 0; @@ -232,7 +233,7 @@ private static boolean isCurrentJavaSupportJavaFX() { public static JavaVersion getByPath(Path jvmDir) throws IOException { { JavaVersion version = JavaHelper.tryFindJavaByPath(jvmDir); - if(version != null) { + if (version != null) { return version; } }