parent
3e53aadd21
commit
9965e8d804
|
@ -16,5 +16,6 @@ Requires Fabric API.
|
||||||
Libraries that the project is using:
|
Libraries that the project is using:
|
||||||
- `Argon2 (LGPLv3)` https://github.com/phxql/argon2-jvm
|
- `Argon2 (LGPLv3)` https://github.com/phxql/argon2-jvm
|
||||||
- `JDBC (Apache 2)` https://github.com/xerial/sqlite-jdbc
|
- `JDBC (Apache 2)` https://github.com/xerial/sqlite-jdbc
|
||||||
|
- `JNA (Apache 2 || LGPLv3)` https://github.com/java-native-access/jna
|
||||||
|
|
||||||
This project is licensed under the `MIT` license.
|
This project is licensed under the `MIT` license.
|
||||||
|
|
|
@ -27,6 +27,7 @@ dependencies {
|
||||||
include 'de.mkammerer:argon2-jvm:2.6'
|
include 'de.mkammerer:argon2-jvm:2.6'
|
||||||
|
|
||||||
// JDBC SQLite Driver
|
// JDBC SQLite Driver
|
||||||
|
implementation group:'org.xerial', name:'sqlite-jdbc', version:'3.8.11.2'
|
||||||
include group:'org.xerial', name:'sqlite-jdbc', version:'3.8.11.2'
|
include group:'org.xerial', name:'sqlite-jdbc', version:'3.8.11.2'
|
||||||
|
|
||||||
// JNA lib
|
// JNA lib
|
||||||
|
|
|
@ -2,14 +2,14 @@
|
||||||
org.gradle.jvmargs=-Xmx1G
|
org.gradle.jvmargs=-Xmx1G
|
||||||
|
|
||||||
# Fabric properties
|
# Fabric properties
|
||||||
minecraft_version=1.15-pre3
|
minecraft_version=1.15.1
|
||||||
yarn_mappings=1.15-pre3+build.2
|
yarn_mappings=1.15.1+build.18
|
||||||
loader_version=0.7.2+build.174
|
loader_version=0.7.3+build.176
|
||||||
|
|
||||||
#Fabric api
|
#Fabric api
|
||||||
fabric_version=0.4.18+build.271-1.15
|
fabric_version=0.4.26+build.283-1.15
|
||||||
|
|
||||||
# Mod Properties
|
# Mod Properties
|
||||||
mod_version = 1.0.0
|
mod_version = 1.1.0
|
||||||
maven_group = org.samo_lego
|
maven_group = org.samo_lego
|
||||||
archives_base_name = simpleauth
|
archives_base_name = simpleauth
|
|
@ -5,7 +5,6 @@ pluginManagement {
|
||||||
name = 'Fabric'
|
name = 'Fabric'
|
||||||
url = 'https://maven.fabricmc.net/'
|
url = 'https://maven.fabricmc.net/'
|
||||||
}
|
}
|
||||||
|
|
||||||
gradlePluginPortal()
|
gradlePluginPortal()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,11 +11,12 @@ import org.apache.logging.log4j.Logger;
|
||||||
import org.samo_lego.simpleauth.commands.*;
|
import org.samo_lego.simpleauth.commands.*;
|
||||||
import org.samo_lego.simpleauth.database.SimpleAuthDatabase;
|
import org.samo_lego.simpleauth.database.SimpleAuthDatabase;
|
||||||
import org.samo_lego.simpleauth.event.AuthEventHandler;
|
import org.samo_lego.simpleauth.event.AuthEventHandler;
|
||||||
import org.samo_lego.simpleauth.event.entity.player.OnChatCallback;
|
import org.samo_lego.simpleauth.event.entity.player.ChatCallback;
|
||||||
import org.samo_lego.simpleauth.event.entity.player.OnPlayerMoveCallback;
|
import org.samo_lego.simpleauth.event.entity.player.PlayerMoveCallback;
|
||||||
import org.samo_lego.simpleauth.event.entity.player.PlayerJoinServerCallback;
|
import org.samo_lego.simpleauth.event.entity.player.PlayerJoinServerCallback;
|
||||||
import org.samo_lego.simpleauth.event.entity.player.PlayerLeaveServerCallback;
|
import org.samo_lego.simpleauth.event.entity.player.PlayerLeaveServerCallback;
|
||||||
import org.samo_lego.simpleauth.event.item.DropItemCallback;
|
import org.samo_lego.simpleauth.event.item.DropItemCallback;
|
||||||
|
import org.samo_lego.simpleauth.utils.AuthConfig;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
@ -25,6 +26,8 @@ public class SimpleAuth implements DedicatedServerModInitializer {
|
||||||
public static SimpleAuthDatabase db = new SimpleAuthDatabase();
|
public static SimpleAuthDatabase db = new SimpleAuthDatabase();
|
||||||
public static HashSet<PlayerEntity> authenticatedUsers = new HashSet<>();
|
public static HashSet<PlayerEntity> authenticatedUsers = new HashSet<>();
|
||||||
public static boolean isAuthenticated(ServerPlayerEntity player) { return authenticatedUsers.contains(player); }
|
public static boolean isAuthenticated(ServerPlayerEntity player) { return authenticatedUsers.contains(player); }
|
||||||
|
public static AuthConfig config;
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onInitializeServer() {
|
public void onInitializeServer() {
|
||||||
|
@ -32,14 +35,17 @@ public class SimpleAuth implements DedicatedServerModInitializer {
|
||||||
LOGGER.info("[SimpleAuth] SimpleAuth mod by samo_lego.");
|
LOGGER.info("[SimpleAuth] SimpleAuth mod by samo_lego.");
|
||||||
// The support on discord was great! I really appreciate your help.
|
// The support on discord was great! I really appreciate your help.
|
||||||
LOGGER.info("[SimpleAuth] This mod wouldn't exist without the awesome Fabric Community. TYSM guys!");
|
LOGGER.info("[SimpleAuth] This mod wouldn't exist without the awesome Fabric Community. TYSM guys!");
|
||||||
// Connecting to db
|
|
||||||
db.openConnection();
|
|
||||||
|
|
||||||
// Creating data directory (database is stored there)
|
// Creating data directory (database and config files are stored there)
|
||||||
File file = new File("./mods/SimpleAuth");
|
File file = new File("./mods/SimpleAuth");
|
||||||
if (!file.exists() && !file.mkdir())
|
if (!file.exists() && !file.mkdir())
|
||||||
LOGGER.error("[SimpleAuth] Error creating directory!");
|
LOGGER.error("[SimpleAuth] Error creating directory!");
|
||||||
|
// Loading config
|
||||||
|
config = AuthConfig.load(new File("./mods/SimpleAuth/config.json"));
|
||||||
|
// Connecting to db
|
||||||
|
db.openConnection();
|
||||||
|
// Making a table in the database
|
||||||
|
db.makeTable();
|
||||||
|
|
||||||
// Registering the commands
|
// Registering the commands
|
||||||
CommandRegistry.INSTANCE.register(false, dispatcher -> {
|
CommandRegistry.INSTANCE.register(false, dispatcher -> {
|
||||||
|
@ -54,8 +60,8 @@ public class SimpleAuth implements DedicatedServerModInitializer {
|
||||||
PlayerJoinServerCallback.EVENT.register(AuthEventHandler::onPlayerJoin);
|
PlayerJoinServerCallback.EVENT.register(AuthEventHandler::onPlayerJoin);
|
||||||
PlayerLeaveServerCallback.EVENT.register(AuthEventHandler::onPlayerLeave);
|
PlayerLeaveServerCallback.EVENT.register(AuthEventHandler::onPlayerLeave);
|
||||||
DropItemCallback.EVENT.register(AuthEventHandler::onDropItem);
|
DropItemCallback.EVENT.register(AuthEventHandler::onDropItem);
|
||||||
OnChatCallback.EVENT.register(AuthEventHandler::onPlayerChat);
|
ChatCallback.EVENT.register(AuthEventHandler::onPlayerChat);
|
||||||
OnPlayerMoveCallback.EVENT.register(AuthEventHandler::onPlayerMove);
|
PlayerMoveCallback.EVENT.register(AuthEventHandler::onPlayerMove);
|
||||||
// From Fabric API
|
// From Fabric API
|
||||||
AttackBlockCallback.EVENT.register((playerEntity, world, hand, blockPos, direction) -> AuthEventHandler.onAttackBlock(playerEntity));
|
AttackBlockCallback.EVENT.register((playerEntity, world, hand, blockPos, direction) -> AuthEventHandler.onAttackBlock(playerEntity));
|
||||||
UseBlockCallback.EVENT.register((player, world, hand, blockHitResult) -> AuthEventHandler.onUseBlock(player));
|
UseBlockCallback.EVENT.register((player, world, hand, blockHitResult) -> AuthEventHandler.onUseBlock(player));
|
||||||
|
@ -63,10 +69,7 @@ public class SimpleAuth implements DedicatedServerModInitializer {
|
||||||
AttackEntityCallback.EVENT.register((player, world, hand, entity, entityHitResult) -> AuthEventHandler.onAttackEntity(player));
|
AttackEntityCallback.EVENT.register((player, world, hand, entity, entityHitResult) -> AuthEventHandler.onAttackEntity(player));
|
||||||
UseEntityCallback.EVENT.register((player, world, hand, entity, entityHitResult) -> AuthEventHandler.onUseEntity(player));
|
UseEntityCallback.EVENT.register((player, world, hand, entity, entityHitResult) -> AuthEventHandler.onUseEntity(player));
|
||||||
ServerStopCallback.EVENT.register(minecraftServer -> SimpleAuth.onStopServer());
|
ServerStopCallback.EVENT.register(minecraftServer -> SimpleAuth.onStopServer());
|
||||||
// Making a table in the database
|
|
||||||
db.makeTable();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void onStopServer() {
|
private static void onStopServer() {
|
||||||
LOGGER.info("[SimpleAuth] Shutting down SimpleAuth.");
|
LOGGER.info("[SimpleAuth] Shutting down SimpleAuth.");
|
||||||
db.close();
|
db.close();
|
||||||
|
|
|
@ -3,12 +3,16 @@ package org.samo_lego.simpleauth.commands;
|
||||||
import com.mojang.brigadier.CommandDispatcher;
|
import com.mojang.brigadier.CommandDispatcher;
|
||||||
import net.minecraft.entity.Entity;
|
import net.minecraft.entity.Entity;
|
||||||
import net.minecraft.server.command.ServerCommandSource;
|
import net.minecraft.server.command.ServerCommandSource;
|
||||||
import net.minecraft.text.TranslatableText;
|
import net.minecraft.text.LiteralText;
|
||||||
|
import net.minecraft.text.Text;
|
||||||
import org.apache.logging.log4j.LogManager;
|
import org.apache.logging.log4j.LogManager;
|
||||||
import org.apache.logging.log4j.Logger;
|
import org.apache.logging.log4j.Logger;
|
||||||
import org.samo_lego.simpleauth.SimpleAuth;
|
import org.samo_lego.simpleauth.SimpleAuth;
|
||||||
|
import org.samo_lego.simpleauth.utils.AuthConfig;
|
||||||
import org.samo_lego.simpleauth.utils.AuthHelper;
|
import org.samo_lego.simpleauth.utils.AuthHelper;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
|
||||||
import static com.mojang.brigadier.arguments.StringArgumentType.getString;
|
import static com.mojang.brigadier.arguments.StringArgumentType.getString;
|
||||||
import static com.mojang.brigadier.arguments.StringArgumentType.word;
|
import static com.mojang.brigadier.arguments.StringArgumentType.word;
|
||||||
import static net.minecraft.server.command.CommandManager.argument;
|
import static net.minecraft.server.command.CommandManager.argument;
|
||||||
|
@ -17,13 +21,17 @@ import static net.minecraft.server.command.CommandManager.literal;
|
||||||
public class AuthCommand {
|
public class AuthCommand {
|
||||||
private static final Logger LOGGER = LogManager.getLogger();
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
private static TranslatableText userdataDeleted = new TranslatableText("§aUserdata deleted.");
|
private static Text userdataDeleted = new LiteralText(SimpleAuth.config.lang.userdataDeleted);
|
||||||
private static TranslatableText userdataUpdated = new TranslatableText("§aUserdata updated.");
|
private static Text userdataUpdated = new LiteralText(SimpleAuth.config.lang.userdataUpdated);
|
||||||
|
private static Text configurationReloaded = new LiteralText(SimpleAuth.config.lang.configurationReloaded);
|
||||||
|
|
||||||
public static void registerCommand(CommandDispatcher<ServerCommandSource> dispatcher) {
|
public static void registerCommand(CommandDispatcher<ServerCommandSource> dispatcher) {
|
||||||
// Registering the "/auth" command
|
// Registering the "/auth" command
|
||||||
dispatcher.register(literal("auth")
|
dispatcher.register(literal("auth")
|
||||||
.requires(source -> source.hasPermissionLevel(4))
|
.requires(source -> source.hasPermissionLevel(4))
|
||||||
|
.then(literal("reload")
|
||||||
|
.executes( ctx -> reloadConfig(ctx.getSource()))
|
||||||
|
)
|
||||||
.then(literal("update")
|
.then(literal("update")
|
||||||
.then(literal("byUuid")
|
.then(literal("byUuid")
|
||||||
.then(argument("uuid", word())
|
.then(argument("uuid", word())
|
||||||
|
@ -102,4 +110,14 @@ public class AuthCommand {
|
||||||
LOGGER.info(userdataDeleted);
|
LOGGER.info(userdataDeleted);
|
||||||
return 1; // Success
|
return 1; // Success
|
||||||
}
|
}
|
||||||
|
private static int reloadConfig(ServerCommandSource source) {
|
||||||
|
Entity sender = source.getEntity();
|
||||||
|
SimpleAuth.config = AuthConfig.load(new File("./mods/SimpleAuth/config.json"));
|
||||||
|
|
||||||
|
if(sender != null)
|
||||||
|
sender.sendMessage(configurationReloaded);
|
||||||
|
else
|
||||||
|
LOGGER.info(configurationReloaded);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,11 +2,11 @@ package org.samo_lego.simpleauth.commands;
|
||||||
|
|
||||||
import com.mojang.brigadier.CommandDispatcher;
|
import com.mojang.brigadier.CommandDispatcher;
|
||||||
import com.mojang.brigadier.exceptions.CommandSyntaxException;
|
import com.mojang.brigadier.exceptions.CommandSyntaxException;
|
||||||
import de.mkammerer.argon2.Argon2;
|
|
||||||
import de.mkammerer.argon2.Argon2Factory;
|
|
||||||
import net.minecraft.server.command.ServerCommandSource;
|
import net.minecraft.server.command.ServerCommandSource;
|
||||||
import net.minecraft.server.network.ServerPlayerEntity;
|
import net.minecraft.server.network.ServerPlayerEntity;
|
||||||
import net.minecraft.text.TranslatableText;
|
import net.minecraft.text.LiteralText;
|
||||||
|
import net.minecraft.text.Text;
|
||||||
|
import net.minecraft.text.Text;
|
||||||
import org.samo_lego.simpleauth.SimpleAuth;
|
import org.samo_lego.simpleauth.SimpleAuth;
|
||||||
import org.samo_lego.simpleauth.utils.AuthHelper;
|
import org.samo_lego.simpleauth.utils.AuthHelper;
|
||||||
|
|
||||||
|
@ -16,10 +16,10 @@ import static net.minecraft.server.command.CommandManager.argument;
|
||||||
import static net.minecraft.server.command.CommandManager.literal;
|
import static net.minecraft.server.command.CommandManager.literal;
|
||||||
|
|
||||||
public class ChangepwCommand {
|
public class ChangepwCommand {
|
||||||
private static TranslatableText enterNewPassword = new TranslatableText("§4You need to enter new password!");
|
private static Text enterNewPassword = new LiteralText(SimpleAuth.config.lang.enterNewPassword);
|
||||||
private static TranslatableText enterPassword = new TranslatableText("§6You need to enter your password!");
|
private static Text enterPassword = new LiteralText(SimpleAuth.config.lang.enterPassword);
|
||||||
private static TranslatableText wrongPassword = new TranslatableText("§4Wrong password!");
|
private static Text wrongPassword = new LiteralText(SimpleAuth.config.lang.wrongPassword);
|
||||||
private static TranslatableText passwordUpdated = new TranslatableText("§4Your password was updated successfully!");
|
private static Text passwordUpdated = new LiteralText(SimpleAuth.config.lang.passwordUpdated);
|
||||||
|
|
||||||
public static void registerCommand(CommandDispatcher<ServerCommandSource> dispatcher) {
|
public static void registerCommand(CommandDispatcher<ServerCommandSource> dispatcher) {
|
||||||
// Registering the "/changepw" command
|
// Registering the "/changepw" command
|
||||||
|
|
|
@ -6,7 +6,7 @@ import net.minecraft.server.command.ServerCommandSource;
|
||||||
import net.minecraft.server.network.ServerPlayerEntity;
|
import net.minecraft.server.network.ServerPlayerEntity;
|
||||||
import net.minecraft.text.LiteralText;
|
import net.minecraft.text.LiteralText;
|
||||||
import net.minecraft.text.Text;
|
import net.minecraft.text.Text;
|
||||||
import net.minecraft.text.TranslatableText;
|
import net.minecraft.text.Text;
|
||||||
import org.samo_lego.simpleauth.SimpleAuth;
|
import org.samo_lego.simpleauth.SimpleAuth;
|
||||||
import org.samo_lego.simpleauth.utils.AuthHelper;
|
import org.samo_lego.simpleauth.utils.AuthHelper;
|
||||||
|
|
||||||
|
@ -16,10 +16,11 @@ import static net.minecraft.server.command.CommandManager.argument;
|
||||||
import static net.minecraft.server.command.CommandManager.literal;
|
import static net.minecraft.server.command.CommandManager.literal;
|
||||||
|
|
||||||
public class LoginCommand {
|
public class LoginCommand {
|
||||||
private static TranslatableText enterPassword = new TranslatableText("§6You need to enter your password!");
|
private static Text enterPassword = new LiteralText(SimpleAuth.config.lang.enterPassword);
|
||||||
private static TranslatableText wrongPassword = new TranslatableText("§4Wrong password!");
|
private static Text wrongPassword = new LiteralText(SimpleAuth.config.lang.wrongPassword);
|
||||||
private static TranslatableText alreadyAuthenticated = new TranslatableText("§4You are already authenticated.");
|
private static Text alreadyAuthenticated = new LiteralText(SimpleAuth.config.lang.alreadyAuthenticated);
|
||||||
private static Text text = new LiteralText("§aYou are now authenticated.");
|
private static Text loginTriesExceeded = new LiteralText("§4Too many login tries.");
|
||||||
|
private static Text successfullyAuthenticated = new LiteralText(SimpleAuth.config.lang.successfullyAuthenticated);
|
||||||
|
|
||||||
public static void registerCommand(CommandDispatcher<ServerCommandSource> dispatcher) {
|
public static void registerCommand(CommandDispatcher<ServerCommandSource> dispatcher) {
|
||||||
// Registering the "/login" command
|
// Registering the "/login" command
|
||||||
|
@ -37,7 +38,6 @@ public class LoginCommand {
|
||||||
private static int login(ServerCommandSource source, String pass) throws CommandSyntaxException {
|
private static int login(ServerCommandSource source, String pass) throws CommandSyntaxException {
|
||||||
// Getting the player who send the command
|
// Getting the player who send the command
|
||||||
ServerPlayerEntity player = source.getPlayer();
|
ServerPlayerEntity player = source.getPlayer();
|
||||||
|
|
||||||
if(SimpleAuth.isAuthenticated(player)) {
|
if(SimpleAuth.isAuthenticated(player)) {
|
||||||
player.sendMessage(alreadyAuthenticated);
|
player.sendMessage(alreadyAuthenticated);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -47,7 +47,9 @@ public class LoginCommand {
|
||||||
// Player no longer needs to be invisible and invulnerable
|
// Player no longer needs to be invisible and invulnerable
|
||||||
player.setInvulnerable(false);
|
player.setInvulnerable(false);
|
||||||
player.setInvisible(false);
|
player.setInvisible(false);
|
||||||
player.sendMessage(text);
|
//player.setAir(AuthEventHandler.playerAir);
|
||||||
|
//player.getDataTracker().startTracking();
|
||||||
|
player.sendMessage(successfullyAuthenticated);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
player.sendMessage(wrongPassword);
|
player.sendMessage(wrongPassword);
|
||||||
|
|
|
@ -5,7 +5,7 @@ import com.mojang.brigadier.exceptions.CommandSyntaxException;
|
||||||
import net.minecraft.server.command.ServerCommandSource;
|
import net.minecraft.server.command.ServerCommandSource;
|
||||||
import net.minecraft.server.network.ServerPlayerEntity;
|
import net.minecraft.server.network.ServerPlayerEntity;
|
||||||
import net.minecraft.text.LiteralText;
|
import net.minecraft.text.LiteralText;
|
||||||
import net.minecraft.text.TranslatableText;
|
import net.minecraft.text.Text;
|
||||||
import org.samo_lego.simpleauth.SimpleAuth;
|
import org.samo_lego.simpleauth.SimpleAuth;
|
||||||
import org.samo_lego.simpleauth.utils.AuthHelper;
|
import org.samo_lego.simpleauth.utils.AuthHelper;
|
||||||
|
|
||||||
|
@ -16,11 +16,11 @@ import static net.minecraft.server.command.CommandManager.literal;
|
||||||
|
|
||||||
|
|
||||||
public class RegisterCommand {
|
public class RegisterCommand {
|
||||||
private static TranslatableText enterPassword = new TranslatableText("§6You need to enter your password!");
|
private static Text enterPassword = new LiteralText(SimpleAuth.config.lang.enterPassword);
|
||||||
private static TranslatableText alreadyAuthenticated = new TranslatableText("§4You are already authenticated.");
|
private static Text alreadyAuthenticated = new LiteralText(SimpleAuth.config.lang.alreadyAuthenticated);
|
||||||
private static TranslatableText alreadyRegistered = new TranslatableText("§6This account name is already registered!");
|
private static Text alreadyRegistered = new LiteralText(SimpleAuth.config.lang.alreadyRegistered);
|
||||||
private static TranslatableText registerSuccess = new TranslatableText("§aYou are now authenticated.");
|
private static Text registerSuccess = new LiteralText(SimpleAuth.config.lang.registerSuccess);
|
||||||
private static TranslatableText matchPass = new TranslatableText( "§6Passwords must match!");
|
private static Text matchPass = new LiteralText( SimpleAuth.config.lang.matchPassword);
|
||||||
|
|
||||||
public static void registerCommand(CommandDispatcher<ServerCommandSource> dispatcher) {
|
public static void registerCommand(CommandDispatcher<ServerCommandSource> dispatcher) {
|
||||||
|
|
||||||
|
@ -41,6 +41,7 @@ public class RegisterCommand {
|
||||||
ServerPlayerEntity player = source.getPlayer();
|
ServerPlayerEntity player = source.getPlayer();
|
||||||
if(SimpleAuth.isAuthenticated(player)) {
|
if(SimpleAuth.isAuthenticated(player)) {
|
||||||
player.sendMessage(alreadyAuthenticated);
|
player.sendMessage(alreadyAuthenticated);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
else if(pass1.equals(pass2)) {
|
else if(pass1.equals(pass2)) {
|
||||||
String hash = AuthHelper.hashPass(pass1.toCharArray());
|
String hash = AuthHelper.hashPass(pass1.toCharArray());
|
||||||
|
@ -49,6 +50,8 @@ public class RegisterCommand {
|
||||||
// Player no longer needs to be invisible and invulnerable
|
// Player no longer needs to be invisible and invulnerable
|
||||||
player.setInvulnerable(false);
|
player.setInvulnerable(false);
|
||||||
player.setInvisible(false);
|
player.setInvisible(false);
|
||||||
|
if(player.isInWater())
|
||||||
|
player.setAir(10);
|
||||||
player.sendMessage(registerSuccess);
|
player.sendMessage(registerSuccess);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,8 +2,6 @@ package org.samo_lego.simpleauth.commands;
|
||||||
|
|
||||||
import com.mojang.brigadier.CommandDispatcher;
|
import com.mojang.brigadier.CommandDispatcher;
|
||||||
import com.mojang.brigadier.exceptions.CommandSyntaxException;
|
import com.mojang.brigadier.exceptions.CommandSyntaxException;
|
||||||
import de.mkammerer.argon2.Argon2;
|
|
||||||
import de.mkammerer.argon2.Argon2Factory;
|
|
||||||
import net.minecraft.server.command.ServerCommandSource;
|
import net.minecraft.server.command.ServerCommandSource;
|
||||||
import net.minecraft.server.network.ServerPlayerEntity;
|
import net.minecraft.server.network.ServerPlayerEntity;
|
||||||
import net.minecraft.text.TranslatableText;
|
import net.minecraft.text.TranslatableText;
|
||||||
|
|
|
@ -22,17 +22,17 @@ public class SimpleAuthDatabase {
|
||||||
try {
|
try {
|
||||||
conn = DriverManager.getConnection(url);
|
conn = DriverManager.getConnection(url);
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
LOGGER.error(e.getMessage());
|
LOGGER.error("[SimpleAuth] " + e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Cllosing connection
|
// Closing connection
|
||||||
public void close() {
|
public void close() {
|
||||||
if (conn != null) {
|
if (conn != null) {
|
||||||
try {
|
try {
|
||||||
conn.close();
|
conn.close();
|
||||||
LOGGER.info("[SimpleAuth] Database connection closed successfully.");
|
LOGGER.info("[SimpleAuth] Database connection closed successfully.");
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
LOGGER.info("[SimpleAuth] Error: " + e);
|
LOGGER.info("[SimpleAuth] Error: " + e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -52,7 +52,7 @@ public class SimpleAuthDatabase {
|
||||||
Statement stmt = conn.createStatement();
|
Statement stmt = conn.createStatement();
|
||||||
stmt.execute(sql);
|
stmt.execute(sql);
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
LOGGER.error(e.getMessage());
|
LOGGER.error("[SimpleAuth] Error: " + e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -74,15 +74,17 @@ public class SimpleAuthDatabase {
|
||||||
rs.getString("UUID");
|
rs.getString("UUID");
|
||||||
return false;
|
return false;
|
||||||
} catch(SQLException ignored) {
|
} catch(SQLException ignored) {
|
||||||
|
// User is not registered
|
||||||
|
} finally {
|
||||||
pstmt.setString(1, uuid);
|
pstmt.setString(1, uuid);
|
||||||
pstmt.setString(2, username);
|
pstmt.setString(2, username);
|
||||||
pstmt.setString(3, password);
|
pstmt.setString(3, password);
|
||||||
|
|
||||||
pstmt.executeUpdate();
|
pstmt.executeUpdate();
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
return true;
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
LOGGER.error("Register error: " + e.getMessage());
|
LOGGER.error("[SimpleAuth] Register error: " + e.getMessage());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -100,7 +102,7 @@ public class SimpleAuthDatabase {
|
||||||
pstmt.executeUpdate();
|
pstmt.executeUpdate();
|
||||||
|
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
LOGGER.error(e.getMessage());
|
LOGGER.error("[SimpleAuth] " + e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -119,7 +121,7 @@ public class SimpleAuthDatabase {
|
||||||
// update
|
// update
|
||||||
pstmt.executeUpdate();
|
pstmt.executeUpdate();
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
LOGGER.error(e.getMessage());
|
LOGGER.error("[SimpleAuth] " + e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -137,7 +139,7 @@ public class SimpleAuthDatabase {
|
||||||
// Getting the password
|
// Getting the password
|
||||||
pass = rs.getString("Password");
|
pass = rs.getString("Password");
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
LOGGER.error(e.getMessage());
|
LOGGER.error("[SimpleAuth] Error getting password: " + e.getMessage());
|
||||||
}
|
}
|
||||||
return pass;
|
return pass;
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,7 @@ import org.samo_lego.simpleauth.SimpleAuth;
|
||||||
* and cancels them if they aren't authenticated
|
* and cancels them if they aren't authenticated
|
||||||
*/
|
*/
|
||||||
public class AuthEventHandler {
|
public class AuthEventHandler {
|
||||||
private static TranslatableText notAuthenticated = new TranslatableText("§4You are not authenticated!\nTry with /login or /register.");
|
private static TranslatableText notAuthenticated = new TranslatableText(SimpleAuth.config.lang.notAuthenticated);
|
||||||
|
|
||||||
// Player joining the server
|
// Player joining the server
|
||||||
public static void onPlayerJoin(ServerPlayerEntity player) {
|
public static void onPlayerJoin(ServerPlayerEntity player) {
|
||||||
|
@ -22,11 +22,10 @@ public class AuthEventHandler {
|
||||||
if (!SimpleAuth.isAuthenticated(player)) {
|
if (!SimpleAuth.isAuthenticated(player)) {
|
||||||
player.sendMessage(notAuthenticated);
|
player.sendMessage(notAuthenticated);
|
||||||
// Setting the player to be invisible to mobs and also invulnerable
|
// Setting the player to be invisible to mobs and also invulnerable
|
||||||
player.setInvulnerable(true);
|
player.setInvulnerable(SimpleAuth.config.main.playerInvulnerable);
|
||||||
player.setInvisible(true);
|
player.setInvisible(SimpleAuth.config.main.playerInvisible);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Player leaving the server
|
// Player leaving the server
|
||||||
public static void onPlayerLeave(ServerPlayerEntity player) {
|
public static void onPlayerLeave(ServerPlayerEntity player) {
|
||||||
SimpleAuth.authenticatedUsers.remove(player);
|
SimpleAuth.authenticatedUsers.remove(player);
|
||||||
|
@ -34,7 +33,12 @@ public class AuthEventHandler {
|
||||||
|
|
||||||
public static ActionResult onPlayerChat(PlayerEntity player, ChatMessageC2SPacket chatMessageC2SPacket) {
|
public static ActionResult onPlayerChat(PlayerEntity player, ChatMessageC2SPacket chatMessageC2SPacket) {
|
||||||
String msg = chatMessageC2SPacket.getChatMessage();
|
String msg = chatMessageC2SPacket.getChatMessage();
|
||||||
if(!SimpleAuth.authenticatedUsers.contains(player) && !msg.startsWith("/login") && !msg.startsWith("/register")) {
|
if(
|
||||||
|
!SimpleAuth.authenticatedUsers.contains(player) &&
|
||||||
|
!msg.startsWith("/login") &&
|
||||||
|
!msg.startsWith("/register") &&
|
||||||
|
(!SimpleAuth.config.main.allowChat || msg.startsWith("/"))
|
||||||
|
) {
|
||||||
player.sendMessage(notAuthenticated);
|
player.sendMessage(notAuthenticated);
|
||||||
return ActionResult.FAIL;
|
return ActionResult.FAIL;
|
||||||
}
|
}
|
||||||
|
@ -42,7 +46,7 @@ public class AuthEventHandler {
|
||||||
}
|
}
|
||||||
// Player movement
|
// Player movement
|
||||||
public static ActionResult onPlayerMove(PlayerEntity player) {
|
public static ActionResult onPlayerMove(PlayerEntity player) {
|
||||||
if(!SimpleAuth.authenticatedUsers.contains(player)) {
|
if(!SimpleAuth.authenticatedUsers.contains(player) && !SimpleAuth.config.main.allowMovement) {
|
||||||
return ActionResult.FAIL;
|
return ActionResult.FAIL;
|
||||||
}
|
}
|
||||||
return ActionResult.PASS;
|
return ActionResult.PASS;
|
||||||
|
@ -50,7 +54,7 @@ public class AuthEventHandler {
|
||||||
|
|
||||||
// Using a block (right-click function)
|
// Using a block (right-click function)
|
||||||
public static ActionResult onUseBlock(PlayerEntity player) {
|
public static ActionResult onUseBlock(PlayerEntity player) {
|
||||||
if(!SimpleAuth.authenticatedUsers.contains(player)) {
|
if(!SimpleAuth.authenticatedUsers.contains(player) && !SimpleAuth.config.main.allowBlockUse) {
|
||||||
player.sendMessage(notAuthenticated);
|
player.sendMessage(notAuthenticated);
|
||||||
return ActionResult.FAIL;
|
return ActionResult.FAIL;
|
||||||
}
|
}
|
||||||
|
@ -59,7 +63,7 @@ public class AuthEventHandler {
|
||||||
|
|
||||||
// Punching a block
|
// Punching a block
|
||||||
public static ActionResult onAttackBlock(PlayerEntity player) {
|
public static ActionResult onAttackBlock(PlayerEntity player) {
|
||||||
if(!SimpleAuth.authenticatedUsers.contains(player)) {
|
if(!SimpleAuth.authenticatedUsers.contains(player) && !SimpleAuth.config.main.allowBlockPunch) {
|
||||||
player.sendMessage(notAuthenticated);
|
player.sendMessage(notAuthenticated);
|
||||||
return ActionResult.FAIL;
|
return ActionResult.FAIL;
|
||||||
}
|
}
|
||||||
|
@ -68,16 +72,24 @@ public class AuthEventHandler {
|
||||||
|
|
||||||
// Using an item
|
// Using an item
|
||||||
public static TypedActionResult<ItemStack> onUseItem(PlayerEntity player) {
|
public static TypedActionResult<ItemStack> onUseItem(PlayerEntity player) {
|
||||||
if(!SimpleAuth.authenticatedUsers.contains(player)) {
|
if(!SimpleAuth.authenticatedUsers.contains(player) && !SimpleAuth.config.main.allowItemUse) {
|
||||||
player.sendMessage(notAuthenticated);
|
player.sendMessage(notAuthenticated);
|
||||||
return TypedActionResult.fail(ItemStack.EMPTY);
|
return TypedActionResult.fail(ItemStack.EMPTY);
|
||||||
}
|
}
|
||||||
|
|
||||||
return TypedActionResult.pass(ItemStack.EMPTY);
|
return TypedActionResult.pass(ItemStack.EMPTY);
|
||||||
}
|
}
|
||||||
|
// Dropping an item
|
||||||
|
public static ActionResult onDropItem(PlayerEntity player) {
|
||||||
|
if(!SimpleAuth.authenticatedUsers.contains(player) && !SimpleAuth.config.main.allowItemDrop) {
|
||||||
|
player.sendMessage(notAuthenticated);
|
||||||
|
return ActionResult.FAIL;
|
||||||
|
}
|
||||||
|
return ActionResult.PASS;
|
||||||
|
}
|
||||||
// Attacking an entity
|
// Attacking an entity
|
||||||
public static ActionResult onAttackEntity(PlayerEntity player) {
|
public static ActionResult onAttackEntity(PlayerEntity player) {
|
||||||
if(!SimpleAuth.authenticatedUsers.contains(player)) {
|
if(!SimpleAuth.authenticatedUsers.contains(player) && !SimpleAuth.config.main.allowEntityPunch) {
|
||||||
player.sendMessage(notAuthenticated);
|
player.sendMessage(notAuthenticated);
|
||||||
return ActionResult.FAIL;
|
return ActionResult.FAIL;
|
||||||
}
|
}
|
||||||
|
@ -86,19 +98,11 @@ public class AuthEventHandler {
|
||||||
}
|
}
|
||||||
// Interacting with entity
|
// Interacting with entity
|
||||||
public static ActionResult onUseEntity(PlayerEntity player) {
|
public static ActionResult onUseEntity(PlayerEntity player) {
|
||||||
if(!SimpleAuth.authenticatedUsers.contains(player)) {
|
if(!SimpleAuth.authenticatedUsers.contains(player) && !SimpleAuth.config.main.allowEntityInteract) {
|
||||||
player.sendMessage(notAuthenticated);
|
player.sendMessage(notAuthenticated);
|
||||||
return ActionResult.FAIL;
|
return ActionResult.FAIL;
|
||||||
}
|
}
|
||||||
|
|
||||||
return ActionResult.PASS;
|
return ActionResult.PASS;
|
||||||
}
|
}
|
||||||
// Dropping an item
|
|
||||||
public static ActionResult onDropItem(PlayerEntity player) {
|
|
||||||
if(!SimpleAuth.authenticatedUsers.contains(player)) {
|
|
||||||
player.sendMessage(notAuthenticated);
|
|
||||||
return ActionResult.FAIL;
|
|
||||||
}
|
|
||||||
return ActionResult.PASS;
|
|
||||||
}
|
|
||||||
}
|
}
|
|
@ -6,9 +6,9 @@ import net.minecraft.entity.player.PlayerEntity;
|
||||||
import net.minecraft.server.network.packet.ChatMessageC2SPacket;
|
import net.minecraft.server.network.packet.ChatMessageC2SPacket;
|
||||||
import net.minecraft.util.ActionResult;
|
import net.minecraft.util.ActionResult;
|
||||||
|
|
||||||
public interface OnChatCallback {
|
public interface ChatCallback {
|
||||||
Event<OnChatCallback> EVENT = EventFactory.createArrayBacked(OnChatCallback.class, listeners -> (player, chatMessageC2SPacket) -> {
|
Event<ChatCallback> EVENT = EventFactory.createArrayBacked(ChatCallback.class, listeners -> (player, chatMessageC2SPacket) -> {
|
||||||
for (OnChatCallback event : listeners) {
|
for (ChatCallback event : listeners) {
|
||||||
ActionResult result = event.onPlayerChat(player, chatMessageC2SPacket);
|
ActionResult result = event.onPlayerChat(player, chatMessageC2SPacket);
|
||||||
|
|
||||||
if (result != ActionResult.PASS) {
|
if (result != ActionResult.PASS) {
|
|
@ -3,12 +3,11 @@ package org.samo_lego.simpleauth.event.entity.player;
|
||||||
import net.fabricmc.fabric.api.event.Event;
|
import net.fabricmc.fabric.api.event.Event;
|
||||||
import net.fabricmc.fabric.api.event.EventFactory;
|
import net.fabricmc.fabric.api.event.EventFactory;
|
||||||
import net.minecraft.entity.player.PlayerEntity;
|
import net.minecraft.entity.player.PlayerEntity;
|
||||||
import net.minecraft.server.network.packet.ChatMessageC2SPacket;
|
|
||||||
import net.minecraft.util.ActionResult;
|
import net.minecraft.util.ActionResult;
|
||||||
|
|
||||||
public interface OnPlayerMoveCallback {
|
public interface PlayerMoveCallback {
|
||||||
Event<OnPlayerMoveCallback> EVENT = EventFactory.createArrayBacked(OnPlayerMoveCallback.class, listeners -> (player) -> {
|
Event<PlayerMoveCallback> EVENT = EventFactory.createArrayBacked(PlayerMoveCallback.class, listeners -> (player) -> {
|
||||||
for (OnPlayerMoveCallback event : listeners) {
|
for (PlayerMoveCallback event : listeners) {
|
||||||
ActionResult result = event.onPlayerMove(player);
|
ActionResult result = event.onPlayerMove(player);
|
||||||
|
|
||||||
if (result != ActionResult.PASS) {
|
if (result != ActionResult.PASS) {
|
|
@ -1,12 +1,10 @@
|
||||||
package org.samo_lego.simpleauth.mixin;
|
package org.samo_lego.simpleauth.mixin;
|
||||||
|
|
||||||
import net.minecraft.client.network.packet.InventoryS2CPacket;
|
|
||||||
import net.minecraft.container.PlayerContainer;
|
import net.minecraft.container.PlayerContainer;
|
||||||
import net.minecraft.entity.ItemEntity;
|
import net.minecraft.entity.ItemEntity;
|
||||||
import net.minecraft.entity.player.PlayerEntity;
|
import net.minecraft.entity.player.PlayerEntity;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.server.network.ServerPlayerEntity;
|
import net.minecraft.server.network.ServerPlayerEntity;
|
||||||
import net.minecraft.server.network.packet.UpdateSelectedSlotC2SPacket;
|
|
||||||
import net.minecraft.util.ActionResult;
|
import net.minecraft.util.ActionResult;
|
||||||
import org.samo_lego.simpleauth.event.item.DropItemCallback;
|
import org.samo_lego.simpleauth.event.item.DropItemCallback;
|
||||||
import org.spongepowered.asm.mixin.Final;
|
import org.spongepowered.asm.mixin.Final;
|
||||||
|
|
|
@ -1,16 +1,14 @@
|
||||||
package org.samo_lego.simpleauth.mixin;
|
package org.samo_lego.simpleauth.mixin;
|
||||||
|
|
||||||
import net.minecraft.client.network.packet.InventoryS2CPacket;
|
import net.minecraft.client.network.packet.EntityS2CPacket;
|
||||||
import net.minecraft.client.network.packet.PlayerSpawnPositionS2CPacket;
|
import net.minecraft.network.NetworkThreadUtils;
|
||||||
import net.minecraft.entity.player.PlayerEntity;
|
|
||||||
import net.minecraft.network.Packet;
|
|
||||||
import net.minecraft.server.network.ServerPlayNetworkHandler;
|
import net.minecraft.server.network.ServerPlayNetworkHandler;
|
||||||
import net.minecraft.server.network.ServerPlayerEntity;
|
import net.minecraft.server.network.ServerPlayerEntity;
|
||||||
import net.minecraft.server.network.packet.ChatMessageC2SPacket;
|
import net.minecraft.server.network.packet.ChatMessageC2SPacket;
|
||||||
import net.minecraft.server.network.packet.PlayerMoveC2SPacket;
|
import net.minecraft.server.network.packet.PlayerMoveC2SPacket;
|
||||||
import net.minecraft.util.ActionResult;
|
import net.minecraft.util.ActionResult;
|
||||||
import org.samo_lego.simpleauth.event.entity.player.OnChatCallback;
|
import org.samo_lego.simpleauth.event.entity.player.ChatCallback;
|
||||||
import org.samo_lego.simpleauth.event.entity.player.OnPlayerMoveCallback;
|
import org.samo_lego.simpleauth.event.entity.player.PlayerMoveCallback;
|
||||||
import org.spongepowered.asm.mixin.Mixin;
|
import org.spongepowered.asm.mixin.Mixin;
|
||||||
import org.spongepowered.asm.mixin.Shadow;
|
import org.spongepowered.asm.mixin.Shadow;
|
||||||
import org.spongepowered.asm.mixin.injection.At;
|
import org.spongepowered.asm.mixin.injection.At;
|
||||||
|
@ -22,8 +20,6 @@ public abstract class MixinServerPlayNetworkHandler {
|
||||||
@Shadow
|
@Shadow
|
||||||
public ServerPlayerEntity player;
|
public ServerPlayerEntity player;
|
||||||
|
|
||||||
@Shadow public abstract void sendPacket(Packet<?> packet_1);
|
|
||||||
|
|
||||||
@Inject(
|
@Inject(
|
||||||
method = "onChatMessage(Lnet/minecraft/server/network/packet/ChatMessageC2SPacket;)V",
|
method = "onChatMessage(Lnet/minecraft/server/network/packet/ChatMessageC2SPacket;)V",
|
||||||
at = @At(
|
at = @At(
|
||||||
|
@ -34,14 +30,14 @@ public abstract class MixinServerPlayNetworkHandler {
|
||||||
),
|
),
|
||||||
cancellable = true
|
cancellable = true
|
||||||
)
|
)
|
||||||
|
// todo: redirect packets to off-thread packet manager?
|
||||||
private void onChatMessage(ChatMessageC2SPacket chatMessageC2SPacket_1, CallbackInfo ci) {
|
private void onChatMessage(ChatMessageC2SPacket chatMessageC2SPacket_1, CallbackInfo ci) {
|
||||||
ActionResult result = OnChatCallback.EVENT.invoker().onPlayerChat(player, chatMessageC2SPacket_1);
|
ActionResult result = ChatCallback.EVENT.invoker().onPlayerChat(player, chatMessageC2SPacket_1);
|
||||||
if (result == ActionResult.FAIL) {
|
if (result == ActionResult.FAIL) {
|
||||||
ci.cancel();
|
ci.cancel();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO
|
|
||||||
@Inject(
|
@Inject(
|
||||||
method="onPlayerMove(Lnet/minecraft/server/network/packet/PlayerMoveC2SPacket;)V",
|
method="onPlayerMove(Lnet/minecraft/server/network/packet/PlayerMoveC2SPacket;)V",
|
||||||
at = @At(
|
at = @At(
|
||||||
|
@ -53,7 +49,7 @@ public abstract class MixinServerPlayNetworkHandler {
|
||||||
cancellable = true
|
cancellable = true
|
||||||
)
|
)
|
||||||
private void onPlayerMove(PlayerMoveC2SPacket playerMoveC2SPacket_1, CallbackInfo ci) {
|
private void onPlayerMove(PlayerMoveC2SPacket playerMoveC2SPacket_1, CallbackInfo ci) {
|
||||||
ActionResult result = OnPlayerMoveCallback.EVENT.invoker().onPlayerMove(player);
|
ActionResult result = PlayerMoveCallback.EVENT.invoker().onPlayerMove(player);
|
||||||
if (result == ActionResult.FAIL) {
|
if (result == ActionResult.FAIL) {
|
||||||
// A bit ugly, I know. (we need to update player position)
|
// A bit ugly, I know. (we need to update player position)
|
||||||
player.teleport(player.getX(), player.getY(), player.getZ());
|
player.teleport(player.getX(), player.getY(), player.getZ());
|
||||||
|
|
|
@ -0,0 +1,90 @@
|
||||||
|
/*
|
||||||
|
Original author:
|
||||||
|
https://github.com/jellysquid3/Lithium/blob/1.15.x/fabric/src/main/java/me/jellysquid/mods/lithium/common/config/LithiumConfig.java
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
package org.samo_lego.simpleauth.utils;
|
||||||
|
|
||||||
|
import com.google.gson.Gson;
|
||||||
|
import com.google.gson.GsonBuilder;
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
public class AuthConfig {
|
||||||
|
public static class MainConfig {
|
||||||
|
public boolean allowChat = false;
|
||||||
|
public boolean allowMovement = false;
|
||||||
|
public boolean allowBlockUse = false;
|
||||||
|
public boolean allowBlockPunch = false;
|
||||||
|
public boolean allowItemDrop = false;
|
||||||
|
public boolean allowItemUse = false;
|
||||||
|
public boolean allowEntityPunch = false;
|
||||||
|
public boolean allowEntityInteract = false;
|
||||||
|
public boolean playerInvulnerable = true;
|
||||||
|
public boolean playerInvisible = true;
|
||||||
|
}
|
||||||
|
public static class LangConfig {
|
||||||
|
public String enterPassword = "§6You need to enter your password!";
|
||||||
|
public String enterNewPassword = "§4You need to enter new password!";
|
||||||
|
public String wrongPassword = "§4Wrong password!";
|
||||||
|
public String matchPassword = "§6Passwords must match!";
|
||||||
|
public String passwordUpdated = "§4Your password was updated successfully!";
|
||||||
|
public String notAuthenticated = "§cYou are not authenticated!\n§6Try with /login or /register.";
|
||||||
|
public String alreadyAuthenticated = "§4You are already authenticated.";
|
||||||
|
public String successfullyAuthenticated = "§aYou are now authenticated.";
|
||||||
|
public String alreadyRegistered = "§6This account name is already registered!";
|
||||||
|
public String registerSuccess = "§aYou are now authenticated.";
|
||||||
|
public String userdataDeleted = "§aUserdata deleted.";
|
||||||
|
public String userdataUpdated = "§aUserdata updated.";
|
||||||
|
public String configurationReloaded = "§aConfiguration file was reloaded successfully.";
|
||||||
|
|
||||||
|
}
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
private static final Gson gson = new GsonBuilder()
|
||||||
|
.setPrettyPrinting()
|
||||||
|
.create();
|
||||||
|
|
||||||
|
public MainConfig main = new MainConfig();
|
||||||
|
public LangConfig lang = new LangConfig();
|
||||||
|
|
||||||
|
public static AuthConfig load(File file) {
|
||||||
|
AuthConfig config;
|
||||||
|
if (file.exists()) {
|
||||||
|
try (FileReader fileReader = new FileReader(file)) {
|
||||||
|
config = gson.fromJson(fileReader, AuthConfig.class);
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new RuntimeException("[SimpleAuth] Problem occurred when trying to load config: ", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
config = new AuthConfig();
|
||||||
|
}
|
||||||
|
config.save(file);
|
||||||
|
|
||||||
|
return config;
|
||||||
|
}
|
||||||
|
private void save(File file) {
|
||||||
|
try (FileWriter writer = new FileWriter(file)) {
|
||||||
|
gson.toJson(this, writer);
|
||||||
|
} catch (IOException e) {
|
||||||
|
LOGGER.error("[SimpleAuth] Problem occurred when saving config: ", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -20,18 +20,18 @@ public class AuthHelper {
|
||||||
return argon2.verify(hashed, pass);
|
return argon2.verify(hashed, pass);
|
||||||
} catch(Error e) {
|
} catch(Error e) {
|
||||||
LOGGER.error("[SimpleAuth] error: " + e);
|
LOGGER.error("[SimpleAuth] error: " + e);
|
||||||
|
return false;
|
||||||
} finally {
|
} finally {
|
||||||
// Wipe confidential data
|
// Wipe confidential data
|
||||||
argon2.wipeArray(pass);
|
argon2.wipeArray(pass);
|
||||||
}
|
}
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
// Hashing the password with the Argon2 power
|
// Hashing the password with the Argon2 power
|
||||||
public static String hashPass(char[] pass) {
|
public static String hashPass(char[] pass) {
|
||||||
try {
|
try {
|
||||||
return argon2.hash(10, 65536, 1, pass);
|
return argon2.hash(10, 65536, 1, pass);
|
||||||
} catch (Error e) {
|
} catch (Error e) {
|
||||||
LOGGER.error(e);
|
LOGGER.error("[SimpleAuth] " + e);
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +0,0 @@
|
||||||
{
|
|
||||||
"command.simpleauth.password": "§6You need to enter your password!",
|
|
||||||
"command.simpleauth.passwordTwice": "§6You need to enter your password twice!",
|
|
||||||
"command.simpleauth.passwordMatch": "§6Passwords must match!",
|
|
||||||
"command.simpleauth.passwordWrong": "§4Wrong password!",
|
|
||||||
"command.simpleauth.alreadyRegistered": "§6This account name is already registered!",
|
|
||||||
"command.simpleauth.notAuthenticated": "§4You are not authenticated!",
|
|
||||||
"command.simpleauth.authenticated": "§aYou are now authenticated."
|
|
||||||
}
|
|
Loading…
Reference in New Issue