mirror of
https://github.com/GravitLauncher/Launcher
synced 2025-01-09 00:59:44 +03:00
[FEATURE] Runtime может задавать свои параметры конфигурации
This commit is contained in:
parent
b0baf1e1f6
commit
4d6a456b8f
6 changed files with 21 additions and 201 deletions
|
@ -1,12 +1,11 @@
|
||||||
package ru.gravit.launcher;
|
package ru.gravit.launcher;
|
||||||
|
|
||||||
|
import ru.gravit.launcher.client.UserSettings;
|
||||||
import ru.gravit.launcher.hasher.HashedDir;
|
import ru.gravit.launcher.hasher.HashedDir;
|
||||||
import ru.gravit.launcher.profiles.ClientProfile;
|
import ru.gravit.launcher.profiles.ClientProfile;
|
||||||
|
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.util.ArrayList;
|
import java.util.*;
|
||||||
import java.util.LinkedList;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
public class NewLauncherSettings {
|
public class NewLauncherSettings {
|
||||||
@LauncherAPI
|
@LauncherAPI
|
||||||
|
@ -32,6 +31,8 @@ public class NewLauncherSettings {
|
||||||
public byte[] lastDigest;
|
public byte[] lastDigest;
|
||||||
@LauncherAPI
|
@LauncherAPI
|
||||||
public List<ClientProfile> lastProfiles = new LinkedList<>();
|
public List<ClientProfile> lastProfiles = new LinkedList<>();
|
||||||
|
@LauncherAPI
|
||||||
|
public Map<String, UserSettings> userSettings = new HashMap<>();
|
||||||
public static class HashedStoreEntry
|
public static class HashedStoreEntry
|
||||||
{
|
{
|
||||||
@LauncherAPI
|
@LauncherAPI
|
||||||
|
|
|
@ -79,6 +79,11 @@ public static long getJVMTotalMemory() {
|
||||||
public static HasherStore getDefaultHasherStore() {
|
public static HasherStore getDefaultHasherStore() {
|
||||||
return HasherManager.getDefaultStore();
|
return HasherManager.getDefaultStore();
|
||||||
}
|
}
|
||||||
|
@LauncherAPI
|
||||||
|
public static void registerUserSettings(String typename, Class<? extends UserSettings> clazz)
|
||||||
|
{
|
||||||
|
UserSettings.providers.registerProvider(typename, clazz);
|
||||||
|
}
|
||||||
|
|
||||||
@LauncherAPI
|
@LauncherAPI
|
||||||
public static void setAuthParams(AuthRequestEvent event) {
|
public static void setAuthParams(AuthRequestEvent event) {
|
||||||
|
|
|
@ -1,193 +0,0 @@
|
||||||
package ru.gravit.launcher.client;
|
|
||||||
|
|
||||||
import ru.gravit.launcher.Launcher;
|
|
||||||
import ru.gravit.launcher.LauncherAPI;
|
|
||||||
import ru.gravit.launcher.hasher.HashedDir;
|
|
||||||
import ru.gravit.launcher.profiles.ClientProfile;
|
|
||||||
import ru.gravit.launcher.serialize.HInput;
|
|
||||||
import ru.gravit.launcher.serialize.HOutput;
|
|
||||||
import ru.gravit.utils.helper.IOHelper;
|
|
||||||
import ru.gravit.utils.helper.JVMHelper;
|
|
||||||
import ru.gravit.utils.helper.LogHelper;
|
|
||||||
import ru.gravit.utils.helper.SecurityHelper;
|
|
||||||
|
|
||||||
import javax.crypto.BadPaddingException;
|
|
||||||
import javax.crypto.IllegalBlockSizeException;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.nio.file.Path;
|
|
||||||
import java.security.SignatureException;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.LinkedList;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
public class LauncherSettings {
|
|
||||||
public static int settingsMagic = 0xc0dea;
|
|
||||||
@LauncherAPI
|
|
||||||
public Path file = DirBridge.dir.resolve("settings.bin");
|
|
||||||
@LauncherAPI
|
|
||||||
public String login;
|
|
||||||
@LauncherAPI
|
|
||||||
public byte[] rsaPassword;
|
|
||||||
@LauncherAPI
|
|
||||||
public int profile;
|
|
||||||
@LauncherAPI
|
|
||||||
public Path updatesDir;
|
|
||||||
@LauncherAPI
|
|
||||||
public boolean autoEnter;
|
|
||||||
@LauncherAPI
|
|
||||||
public boolean fullScreen;
|
|
||||||
@LauncherAPI
|
|
||||||
public boolean offline;
|
|
||||||
@LauncherAPI
|
|
||||||
public int ram;
|
|
||||||
|
|
||||||
@LauncherAPI
|
|
||||||
public byte[] lastDigest;
|
|
||||||
@LauncherAPI
|
|
||||||
public List<ClientProfile> lastProfiles = new LinkedList<>();
|
|
||||||
@LauncherAPI
|
|
||||||
public Map<String, HashedDir> lastHDirs = new HashMap<>(16);
|
|
||||||
|
|
||||||
@LauncherAPI
|
|
||||||
public void load() throws SignatureException {
|
|
||||||
LogHelper.debug("Loading settings file");
|
|
||||||
try {
|
|
||||||
try (HInput input = new HInput(IOHelper.newInput(file))) {
|
|
||||||
read(input);
|
|
||||||
}
|
|
||||||
} catch (IOException e) {
|
|
||||||
LogHelper.error(e);
|
|
||||||
setDefault();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@LauncherAPI
|
|
||||||
public void save() {
|
|
||||||
LogHelper.debug("Save settings file");
|
|
||||||
try {
|
|
||||||
try (HOutput output = new HOutput(IOHelper.newOutput(file))) {
|
|
||||||
write(output);
|
|
||||||
}
|
|
||||||
} catch (IOException e) {
|
|
||||||
LogHelper.error(e);
|
|
||||||
setDefault();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@LauncherAPI
|
|
||||||
public void read(HInput input) throws IOException, SignatureException {
|
|
||||||
int magic = input.readInt();
|
|
||||||
if (magic != settingsMagic) {
|
|
||||||
setDefault();
|
|
||||||
LogHelper.warning("Settings magic mismatch: " + java.lang.Integer.toString(magic, 16));
|
|
||||||
return;
|
|
||||||
//throw new java.io.IOException();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Launcher settings
|
|
||||||
boolean debug = input.readBoolean();
|
|
||||||
if (!LogHelper.isDebugEnabled() && debug) {
|
|
||||||
LogHelper.setDebugEnabled(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Auth settings
|
|
||||||
login = input.readBoolean() ? input.readString(255) : null;
|
|
||||||
rsaPassword = input.readBoolean() ? input.readByteArray(IOHelper.BUFFER_SIZE) : null;
|
|
||||||
profile = input.readLength(0);
|
|
||||||
|
|
||||||
// Client settings
|
|
||||||
updatesDir = IOHelper.toPath(input.readString(0));
|
|
||||||
DirBridge.dirUpdates = updatesDir;
|
|
||||||
autoEnter = input.readBoolean();
|
|
||||||
fullScreen = input.readBoolean();
|
|
||||||
setRAM(input.readLength(JVMHelper.RAM));
|
|
||||||
|
|
||||||
// Offline cache
|
|
||||||
lastDigest = input.readBoolean() ? input.readByteArray(0) : null;
|
|
||||||
lastProfiles.clear();
|
|
||||||
int lastProfilesCount = input.readLength(0);
|
|
||||||
for (int i = 0; i < lastProfilesCount; i++) {
|
|
||||||
lastProfiles.add(Launcher.gsonManager.gson.fromJson(input.readString(0), ClientProfile.class));
|
|
||||||
}
|
|
||||||
lastHDirs.clear();
|
|
||||||
int lastHDirsCount = input.readLength(0);
|
|
||||||
for (int i = 0; i < lastHDirsCount; i++) {
|
|
||||||
String name = IOHelper.verifyFileName(input.readString(255));
|
|
||||||
HashedDir hdir = new HashedDir(input);
|
|
||||||
lastHDirs.put(name, hdir);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@LauncherAPI
|
|
||||||
public void write(HOutput output) throws IOException {
|
|
||||||
output.writeInt(settingsMagic);
|
|
||||||
|
|
||||||
// Launcher settings
|
|
||||||
output.writeBoolean(LogHelper.isDebugEnabled());
|
|
||||||
|
|
||||||
// Auth settings
|
|
||||||
output.writeBoolean(login != null);
|
|
||||||
if (login != null) {
|
|
||||||
output.writeString(login, 255);
|
|
||||||
}
|
|
||||||
output.writeBoolean(rsaPassword != null);
|
|
||||||
if (rsaPassword != null) {
|
|
||||||
output.writeByteArray(rsaPassword, IOHelper.BUFFER_SIZE);
|
|
||||||
}
|
|
||||||
output.writeLength(profile, 0);
|
|
||||||
|
|
||||||
// Client settings
|
|
||||||
output.writeString(IOHelper.toString(updatesDir), 0);
|
|
||||||
output.writeBoolean(autoEnter);
|
|
||||||
output.writeBoolean(fullScreen);
|
|
||||||
output.writeLength(ram, JVMHelper.RAM);
|
|
||||||
|
|
||||||
// Offline cache
|
|
||||||
output.writeBoolean(lastDigest != null);
|
|
||||||
if (lastDigest != null) {
|
|
||||||
output.writeByteArray(lastDigest, 0);
|
|
||||||
}
|
|
||||||
output.writeLength(lastProfiles.size(), 0);
|
|
||||||
for (ClientProfile profile : lastProfiles) {
|
|
||||||
output.writeString(Launcher.gsonManager.gson.toJson(profile), 0);
|
|
||||||
}
|
|
||||||
output.writeLength(lastHDirs.size(), 0);
|
|
||||||
for (Map.Entry<String, HashedDir> entry : lastHDirs.entrySet()) {
|
|
||||||
output.writeString(entry.getKey(), 0);
|
|
||||||
entry.getValue().write(output);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@LauncherAPI
|
|
||||||
public void setRAM(int ram) {
|
|
||||||
this.ram = java.lang.Math.min(((ram / 256)) * 256, JVMHelper.RAM);
|
|
||||||
}
|
|
||||||
|
|
||||||
@LauncherAPI
|
|
||||||
public void setDefault() {
|
|
||||||
// Auth settings
|
|
||||||
login = null;
|
|
||||||
rsaPassword = null;
|
|
||||||
profile = 0;
|
|
||||||
|
|
||||||
// Client settings
|
|
||||||
//==DEFAULT==
|
|
||||||
updatesDir = DirBridge.defaultUpdatesDir;
|
|
||||||
autoEnter = false;
|
|
||||||
fullScreen = false;
|
|
||||||
setRAM(1024);
|
|
||||||
//==========
|
|
||||||
|
|
||||||
// Offline cache
|
|
||||||
lastDigest = null;
|
|
||||||
lastProfiles.clear();
|
|
||||||
lastHDirs.clear();
|
|
||||||
}
|
|
||||||
|
|
||||||
@LauncherAPI
|
|
||||||
public byte[] setPassword(String password) throws BadPaddingException, IllegalBlockSizeException {
|
|
||||||
byte[] encrypted = SecurityHelper.newRSAEncryptCipher(Launcher.getConfig().publicKey).doFinal(IOHelper.encode(password));
|
|
||||||
return encrypted;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
package ru.gravit.launcher.client;
|
||||||
|
|
||||||
|
import ru.gravit.utils.ProviderMap;
|
||||||
|
|
||||||
|
public class UserSettings {
|
||||||
|
public static ProviderMap<UserSettings> providers = new ProviderMap<>();
|
||||||
|
}
|
|
@ -1,10 +1,7 @@
|
||||||
package ru.gravit.launcher.gui;
|
package ru.gravit.launcher.gui;
|
||||||
|
|
||||||
import ru.gravit.launcher.*;
|
import ru.gravit.launcher.*;
|
||||||
import ru.gravit.launcher.client.ClientLauncher;
|
import ru.gravit.launcher.client.*;
|
||||||
import ru.gravit.launcher.client.DirBridge;
|
|
||||||
import ru.gravit.launcher.client.FunctionalBridge;
|
|
||||||
import ru.gravit.launcher.client.ServerPinger;
|
|
||||||
import ru.gravit.launcher.hasher.FileNameMatcher;
|
import ru.gravit.launcher.hasher.FileNameMatcher;
|
||||||
import ru.gravit.launcher.hasher.HashedDir;
|
import ru.gravit.launcher.hasher.HashedDir;
|
||||||
import ru.gravit.launcher.hasher.HashedEntry;
|
import ru.gravit.launcher.hasher.HashedEntry;
|
||||||
|
@ -94,6 +91,7 @@ public static void addLauncherClassBindings(Map<String, Object> bindings) {
|
||||||
bindings.put("SignedObjectHolderClass", SignedObjectHolder.class);
|
bindings.put("SignedObjectHolderClass", SignedObjectHolder.class);
|
||||||
bindings.put("EnumSerializerClass", EnumSerializer.class);
|
bindings.put("EnumSerializerClass", EnumSerializer.class);
|
||||||
bindings.put("OptionalFileClass", OptionalFile.class);
|
bindings.put("OptionalFileClass", OptionalFile.class);
|
||||||
|
bindings.put("UserSettingsClass", UserSettings.class);
|
||||||
|
|
||||||
// Set helper class bindings
|
// Set helper class bindings
|
||||||
bindings.put("CommonHelperClass", CommonHelper.class);
|
bindings.put("CommonHelperClass", CommonHelper.class);
|
||||||
|
|
|
@ -1,11 +1,13 @@
|
||||||
package ru.gravit.launcher.managers;
|
package ru.gravit.launcher.managers;
|
||||||
|
|
||||||
import com.google.gson.GsonBuilder;
|
import com.google.gson.GsonBuilder;
|
||||||
|
import ru.gravit.launcher.client.UserSettings;
|
||||||
|
import ru.gravit.utils.UniversalJsonAdapter;
|
||||||
|
|
||||||
public class ClientGsonManager extends GsonManager {
|
public class ClientGsonManager extends GsonManager {
|
||||||
@Override
|
@Override
|
||||||
public void registerAdapters(GsonBuilder builder) {
|
public void registerAdapters(GsonBuilder builder) {
|
||||||
super.registerAdapters(builder);
|
super.registerAdapters(builder);
|
||||||
|
builder.registerTypeAdapter(UserSettings.class, new UniversalJsonAdapter<>(UserSettings.providers));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue