mirror of
https://github.com/GravitLauncher/Launcher
synced 2025-01-24 08:09:22 +03:00
Запрос ChangeServer
This commit is contained in:
parent
f79799bee1
commit
9e2a154c50
5 changed files with 75 additions and 2 deletions
|
@ -50,6 +50,7 @@ public static void registerResponses() {
|
||||||
registerResponse(RequestType.PROFILES.getNumber(), ProfilesResponse::new);
|
registerResponse(RequestType.PROFILES.getNumber(), ProfilesResponse::new);
|
||||||
registerResponse(RequestType.SERVERAUTH.getNumber(), AuthServerResponse::new);
|
registerResponse(RequestType.SERVERAUTH.getNumber(), AuthServerResponse::new);
|
||||||
registerResponse(RequestType.SETPROFILE.getNumber(), SetProfileResponse::new);
|
registerResponse(RequestType.SETPROFILE.getNumber(), SetProfileResponse::new);
|
||||||
|
registerResponse(RequestType.CHANGESERVER.getNumber(),ChangeServerResponse::new);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,28 @@
|
||||||
|
package ru.gravit.launchserver.response.auth;
|
||||||
|
|
||||||
|
import ru.gravit.launcher.serialize.HInput;
|
||||||
|
import ru.gravit.launcher.serialize.HOutput;
|
||||||
|
import ru.gravit.launchserver.LaunchServer;
|
||||||
|
import ru.gravit.launchserver.response.Response;
|
||||||
|
|
||||||
|
public class ChangeServerResponse extends Response {
|
||||||
|
public static boolean needChange = false;
|
||||||
|
public static String address;
|
||||||
|
public static int port;
|
||||||
|
|
||||||
|
public ChangeServerResponse(LaunchServer server, long session, HInput input, HOutput output, String ip) {
|
||||||
|
super(server, session, input, output, ip);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void reply() throws Exception {
|
||||||
|
writeNoError(output);
|
||||||
|
output.writeBoolean(needChange);
|
||||||
|
//if true
|
||||||
|
if(needChange)
|
||||||
|
{
|
||||||
|
output.writeString(address,255);
|
||||||
|
output.writeInt(port);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,44 @@
|
||||||
|
package ru.gravit.launcher.request.auth;
|
||||||
|
|
||||||
|
import jdk.nashorn.internal.ir.RuntimeNode;
|
||||||
|
import ru.gravit.launcher.Launcher;
|
||||||
|
import ru.gravit.launcher.request.Request;
|
||||||
|
import ru.gravit.launcher.request.RequestType;
|
||||||
|
import ru.gravit.launcher.serialize.HInput;
|
||||||
|
import ru.gravit.launcher.serialize.HOutput;
|
||||||
|
import ru.gravit.utils.helper.IOHelper;
|
||||||
|
|
||||||
|
import java.net.InetSocketAddress;
|
||||||
|
|
||||||
|
public class ChangeServerRequest extends Request<ChangeServerRequest.Result> {
|
||||||
|
@Override
|
||||||
|
public Integer getType() {
|
||||||
|
return RequestType.CHANGESERVER.getNumber();
|
||||||
|
}
|
||||||
|
public boolean change(Result result)
|
||||||
|
{
|
||||||
|
if(!result.needChange) return false;
|
||||||
|
Launcher.getConfig().address = InetSocketAddress.createUnresolved( result.address, result.port);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
protected Result requestDo(HInput input, HOutput output) throws Exception {
|
||||||
|
readError(input);
|
||||||
|
Result result = new Result();
|
||||||
|
result.needChange = input.readBoolean();
|
||||||
|
if(result.needChange)
|
||||||
|
{
|
||||||
|
result.address = input.readString(255);
|
||||||
|
result.port = input.readInt();
|
||||||
|
}
|
||||||
|
if(result.needChange) change(result);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public class Result
|
||||||
|
{
|
||||||
|
public boolean needChange;
|
||||||
|
public String address;
|
||||||
|
public int port;
|
||||||
|
}
|
||||||
|
}
|
|
@ -31,7 +31,7 @@ public static AutogenConfig getAutogenConfig() {
|
||||||
|
|
||||||
// Instance
|
// Instance
|
||||||
@LauncherAPI
|
@LauncherAPI
|
||||||
public final InetSocketAddress address;
|
public InetSocketAddress address;
|
||||||
@LauncherAPI
|
@LauncherAPI
|
||||||
public final String projectname;
|
public final String projectname;
|
||||||
public final int clientPort;
|
public final int clientPort;
|
||||||
|
|
|
@ -11,7 +11,7 @@ public enum RequestType implements EnumSerializer.Itf {
|
||||||
LEGACYLAUNCHER(1), UPDATE(2), UPDATE_LIST(3), // Update requests
|
LEGACYLAUNCHER(1), UPDATE(2), UPDATE_LIST(3), // Update requests
|
||||||
AUTH(4), JOIN_SERVER(5), CHECK_SERVER(6), // Auth requests
|
AUTH(4), JOIN_SERVER(5), CHECK_SERVER(6), // Auth requests
|
||||||
PROFILE_BY_USERNAME(7), PROFILE_BY_UUID(8), BATCH_PROFILE_BY_USERNAME(9), // Profile requests
|
PROFILE_BY_USERNAME(7), PROFILE_BY_UUID(8), BATCH_PROFILE_BY_USERNAME(9), // Profile requests
|
||||||
PROFILES(10),SERVERAUTH(11), SETPROFILE(12),LAUNCHER(13),
|
PROFILES(10),SERVERAUTH(11), SETPROFILE(12),LAUNCHER(13),CHANGESERVER(14),
|
||||||
CUSTOM(255); // Custom requests
|
CUSTOM(255); // Custom requests
|
||||||
private static final EnumSerializer<RequestType> SERIALIZER = new EnumSerializer<>(RequestType.class);
|
private static final EnumSerializer<RequestType> SERIALIZER = new EnumSerializer<>(RequestType.class);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue