mirror of
https://github.com/GravitLauncher/Launcher
synced 2025-01-09 00:59:44 +03:00
[FEATURE] WhitelistComponent
This commit is contained in:
parent
b4718a8062
commit
3f0c972b08
4 changed files with 103 additions and 1 deletions
|
@ -63,6 +63,7 @@ public void invoke(String... args) throws Exception {
|
||||||
if (component instanceof AutoCloseable) {
|
if (component instanceof AutoCloseable) {
|
||||||
((AutoCloseable) component).close();
|
((AutoCloseable) component).close();
|
||||||
}
|
}
|
||||||
|
server.unregisterObject("component." + componentName, component);
|
||||||
server.config.components.remove(componentName);
|
server.config.components.remove(componentName);
|
||||||
logger.info("Component %s unloaded. Use 'config launchserver save' to save changes");
|
logger.info("Component %s unloaded. Use 'config launchserver save' to save changes");
|
||||||
}
|
}
|
||||||
|
@ -94,6 +95,7 @@ public void invoke(String... args) throws Exception {
|
||||||
component.setComponentName(componentName);
|
component.setComponentName(componentName);
|
||||||
server.config.components.put(componentName, component);
|
server.config.components.put(componentName, component);
|
||||||
component.init(server);
|
component.init(server);
|
||||||
|
server.registerObject("component." + componentName, component);
|
||||||
logger.info("Component %s ready. Use 'config launchserver save' to save changes");
|
logger.info("Component %s ready. Use 'config launchserver save' to save changes");
|
||||||
} catch (Throwable throwable) {
|
} catch (Throwable throwable) {
|
||||||
logger.error(throwable);
|
logger.error(throwable);
|
||||||
|
|
|
@ -14,6 +14,7 @@ public static void registerComponents() {
|
||||||
providers.register("regLimiter", RegLimiterComponent.class);
|
providers.register("regLimiter", RegLimiterComponent.class);
|
||||||
providers.register("commandRemover", CommandRemoverComponent.class);
|
providers.register("commandRemover", CommandRemoverComponent.class);
|
||||||
providers.register("proguard", ProGuardComponent.class);
|
providers.register("proguard", ProGuardComponent.class);
|
||||||
|
providers.register("whitelist", WhitelistComponent.class);
|
||||||
registredComp = true;
|
registredComp = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,99 @@
|
||||||
|
package pro.gravit.launchserver.components;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
import pro.gravit.launchserver.LaunchServer;
|
||||||
|
import pro.gravit.launchserver.Reconfigurable;
|
||||||
|
import pro.gravit.launchserver.socket.Client;
|
||||||
|
import pro.gravit.launchserver.socket.response.auth.AuthResponse;
|
||||||
|
import pro.gravit.launchserver.socket.response.auth.JoinServerResponse;
|
||||||
|
import pro.gravit.utils.HookException;
|
||||||
|
import pro.gravit.utils.command.Command;
|
||||||
|
import pro.gravit.utils.command.SubCommand;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class WhitelistComponent extends Component implements AutoCloseable, Reconfigurable {
|
||||||
|
private transient LaunchServer server;
|
||||||
|
private transient final Logger logger = LogManager.getLogger();
|
||||||
|
public String message = "auth.message.techwork";
|
||||||
|
public boolean enabled = true;
|
||||||
|
public List<String> whitelist = new ArrayList<>();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void init(LaunchServer launchServer) {
|
||||||
|
this.server = launchServer;
|
||||||
|
this.server.authHookManager.preHook.registerHook(this::hookAuth);
|
||||||
|
this.server.authHookManager.joinServerHook.registerHook(this::hookJoin);
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean hookAuth(AuthResponse.AuthContext context, Client client) throws HookException {
|
||||||
|
if (enabled) {
|
||||||
|
if (!whitelist.contains(context.login)) {
|
||||||
|
throw new HookException(message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean hookJoin(JoinServerResponse response, Client client) throws HookException {
|
||||||
|
if (enabled) {
|
||||||
|
if (!whitelist.contains(response.username)) {
|
||||||
|
throw new HookException(message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void close() throws Exception {
|
||||||
|
this.server.authHookManager.preHook.unregisterHook(this::hookAuth);
|
||||||
|
this.server.authHookManager.joinServerHook.unregisterHook(this::hookJoin);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Map<String, Command> getCommands() {
|
||||||
|
var commands = defaultCommandsMap();
|
||||||
|
commands.put("setmessage", new SubCommand("[new message]", "set message") {
|
||||||
|
@Override
|
||||||
|
public void invoke(String... args) throws Exception {
|
||||||
|
verifyArgs(args, 1);
|
||||||
|
message = args[0];
|
||||||
|
logger.info("Message: {}", args[0]);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
commands.put("whitelist.add", new SubCommand("[login]", "add login to whitelist") {
|
||||||
|
@Override
|
||||||
|
public void invoke(String... args) throws Exception {
|
||||||
|
verifyArgs(args, 1);
|
||||||
|
whitelist.add(args[0]);
|
||||||
|
logger.info("{} added to whitelist", args[0]);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
commands.put("whitelist.remove", new SubCommand("[login]", "remove login from whitelist") {
|
||||||
|
@Override
|
||||||
|
public void invoke(String... args) throws Exception {
|
||||||
|
verifyArgs(args, 1);
|
||||||
|
whitelist.remove(args[0]);
|
||||||
|
logger.info("{} removed from whitelist", args[0]);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
commands.put("disable", new SubCommand() {
|
||||||
|
@Override
|
||||||
|
public void invoke(String... args) throws Exception {
|
||||||
|
enabled = false;
|
||||||
|
logger.info("Whitelist disabled");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
commands.put("enable", new SubCommand() {
|
||||||
|
@Override
|
||||||
|
public void invoke(String... args) throws Exception {
|
||||||
|
enabled = true;
|
||||||
|
logger.info("Whitelist enabled");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return commands;
|
||||||
|
}
|
||||||
|
}
|
|
@ -208,7 +208,7 @@ public void init(LaunchServer.ReloadType type) {
|
||||||
server.registerObject("auth.".concat(pair.name).concat(".provider"), pair.provider);
|
server.registerObject("auth.".concat(pair.name).concat(".provider"), pair.provider);
|
||||||
server.registerObject("auth.".concat(pair.name).concat(".handler"), pair.handler);
|
server.registerObject("auth.".concat(pair.name).concat(".handler"), pair.handler);
|
||||||
server.registerObject("auth.".concat(pair.name).concat(".core"), pair.core);
|
server.registerObject("auth.".concat(pair.name).concat(".core"), pair.core);
|
||||||
server.registerObject("auth.".concat(pair.name).concat(".social"), pair.core);
|
server.registerObject("auth.".concat(pair.name).concat(".social"), pair.social);
|
||||||
server.registerObject("auth.".concat(pair.name).concat(".texture"), pair.textureProvider);
|
server.registerObject("auth.".concat(pair.name).concat(".texture"), pair.textureProvider);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue