aboutsummaryrefslogtreecommitdiff
path: root/src/main
diff options
context:
space:
mode:
authorPetr Ilin <hevav@hevav.dev>2023-01-23 01:31:47 +0300
committerPetr Ilin <hevav@hevav.dev>2023-01-23 01:31:47 +0300
commit0fc01edf83f47ba9e19b9ea44ab2232cab4fe4a1 (patch)
treee37732f7c53ca73eca62d88e3f783f6623e32168 /src/main
parent6e20aed94c7ce313dd280546e2dd537d35cfb002 (diff)
downloadLimboAuth-0fc01edf83f47ba9e19b9ea44ab2232cab4fe4a1.tar.gz
LimboAuth-0fc01edf83f47ba9e19b9ea44ab2232cab4fe4a1.tar.bz2
LimboAuth-0fc01edf83f47ba9e19b9ea44ab2232cab4fe4a1.zip
Removing players from the session/premium cache when changing passwords
Diffstat (limited to 'src/main')
-rw-r--r--src/main/java/net/elytrium/limboauth/LimboAuth.java4
-rw-r--r--src/main/java/net/elytrium/limboauth/command/ChangePasswordCommand.java6
-rw-r--r--src/main/java/net/elytrium/limboauth/command/ForceChangePasswordCommand.java5
3 files changed, 11 insertions, 4 deletions
diff --git a/src/main/java/net/elytrium/limboauth/LimboAuth.java b/src/main/java/net/elytrium/limboauth/LimboAuth.java
index 6851d4f..1dcd22b 100644
--- a/src/main/java/net/elytrium/limboauth/LimboAuth.java
+++ b/src/main/java/net/elytrium/limboauth/LimboAuth.java
@@ -333,8 +333,8 @@ public class LimboAuth {
manager.register("unregister", new UnregisterCommand(this, this.playerDao), "unreg");
manager.register("premium", new PremiumCommand(this, this.playerDao), "license");
manager.register("forceunregister", new ForceUnregisterCommand(this, this.server, this.playerDao), "forceunreg");
- manager.register("changepassword", new ChangePasswordCommand(this.playerDao), "changepass", "cp");
- manager.register("forcechangepassword", new ForceChangePasswordCommand(this.server, this.playerDao), "forcechangepass", "fcp");
+ manager.register("changepassword", new ChangePasswordCommand(this, this.playerDao), "changepass", "cp");
+ manager.register("forcechangepassword", new ForceChangePasswordCommand(this, this.server, this.playerDao), "forcechangepass", "fcp");
manager.register("destroysession", new DestroySessionCommand(this), "logout");
if (Settings.IMP.MAIN.ENABLE_TOTP) {
manager.register("2fa", new TotpCommand(this.playerDao), "totp");
diff --git a/src/main/java/net/elytrium/limboauth/command/ChangePasswordCommand.java b/src/main/java/net/elytrium/limboauth/command/ChangePasswordCommand.java
index 2fea6f5..ebe9032 100644
--- a/src/main/java/net/elytrium/limboauth/command/ChangePasswordCommand.java
+++ b/src/main/java/net/elytrium/limboauth/command/ChangePasswordCommand.java
@@ -34,6 +34,7 @@ import net.kyori.adventure.text.Component;
public class ChangePasswordCommand implements SimpleCommand {
+ private final LimboAuth plugin;
private final Dao<RegisteredPlayer, String> playerDao;
private final boolean needOldPass;
@@ -44,7 +45,8 @@ public class ChangePasswordCommand implements SimpleCommand {
private final Component usage;
private final Component notPlayer;
- public ChangePasswordCommand(Dao<RegisteredPlayer, String> playerDao) {
+ public ChangePasswordCommand(LimboAuth plugin, Dao<RegisteredPlayer, String> playerDao) {
+ this.plugin = plugin;
this.playerDao = playerDao;
Serializer serializer = LimboAuth.getSerializer();
@@ -94,6 +96,8 @@ public class ChangePasswordCommand implements SimpleCommand {
updateBuilder.updateColumnValue(RegisteredPlayer.HASH_FIELD, RegisteredPlayer.genHash(needOldPass ? args[1] : args[0]));
updateBuilder.update();
+ this.plugin.removePlayerFromCache(username);
+
source.sendMessage(this.successful);
} catch (SQLException e) {
source.sendMessage(this.errorOccurred);
diff --git a/src/main/java/net/elytrium/limboauth/command/ForceChangePasswordCommand.java b/src/main/java/net/elytrium/limboauth/command/ForceChangePasswordCommand.java
index 67d9c67..9e769e8 100644
--- a/src/main/java/net/elytrium/limboauth/command/ForceChangePasswordCommand.java
+++ b/src/main/java/net/elytrium/limboauth/command/ForceChangePasswordCommand.java
@@ -36,6 +36,7 @@ import net.kyori.adventure.text.Component;
public class ForceChangePasswordCommand implements SimpleCommand {
+ private final LimboAuth plugin;
private final ProxyServer server;
private final Dao<RegisteredPlayer, String> playerDao;
@@ -44,7 +45,8 @@ public class ForceChangePasswordCommand implements SimpleCommand {
private final String notSuccessful;
private final Component usage;
- public ForceChangePasswordCommand(ProxyServer server, Dao<RegisteredPlayer, String> playerDao) {
+ public ForceChangePasswordCommand(LimboAuth plugin, ProxyServer server, Dao<RegisteredPlayer, String> playerDao) {
+ this.plugin = plugin;
this.server = server;
this.playerDao = playerDao;
@@ -75,6 +77,7 @@ public class ForceChangePasswordCommand implements SimpleCommand {
updateBuilder.updateColumnValue(RegisteredPlayer.HASH_FIELD, RegisteredPlayer.genHash(newPassword));
updateBuilder.update();
+ this.plugin.removePlayerFromCache(nickname);
this.server.getPlayer(nickname)
.ifPresent(player -> player.sendMessage(serializer.deserialize(MessageFormat.format(this.message, newPassword))));