Add account list command

This commit is contained in:
KingRainbow44 2023-05-10 20:53:20 -04:00
parent 7c065b33d6
commit 510e6bfa78
No known key found for this signature in database
GPG Key ID: FC2CB64B00D257BE

View File

@ -8,9 +8,11 @@ import emu.grasscutter.command.Command;
import emu.grasscutter.command.CommandHandler; import emu.grasscutter.command.CommandHandler;
import emu.grasscutter.config.Configuration; import emu.grasscutter.config.Configuration;
import emu.grasscutter.database.DatabaseHelper; import emu.grasscutter.database.DatabaseHelper;
import emu.grasscutter.database.DatabaseManager;
import emu.grasscutter.game.Account; import emu.grasscutter.game.Account;
import emu.grasscutter.game.player.Player; import emu.grasscutter.game.player.Player;
import java.util.List; import java.util.List;
import java.util.stream.Collectors;
@Command( @Command(
label = "account", label = "account",
@ -38,17 +40,14 @@ public final class AccountCommand implements CommandHandler {
String username = args.get(1); String username = args.get(1);
switch (action) { switch (action) {
default: default -> this.sendUsageMessage(sender);
sendUsageMessage(sender); case "create" -> {
return;
case "create":
int uid = 0; int uid = 0;
String password = ""; String password = "";
if (Configuration.ACCOUNT.EXPERIMENTAL_RealPassword) { if (Configuration.ACCOUNT.EXPERIMENTAL_RealPassword) {
if (args.size() < 3) { if (args.size() < 3) {
CommandHandler.sendMessage( CommandHandler.sendMessage(
sender, "EXPERIMENTAL_RealPassword requires a password argument"); sender, "EXPERIMENTAL_RealPassword requires a password argument");
CommandHandler.sendMessage(sender, "Usage: account create <username> <password> [uid]"); CommandHandler.sendMessage(sender, "Usage: account create <username> <password> [uid]");
return; return;
} }
@ -61,10 +60,10 @@ public final class AccountCommand implements CommandHandler {
CommandHandler.sendMessage(sender, translate(sender, "commands.account.invalid")); CommandHandler.sendMessage(sender, translate(sender, "commands.account.invalid"));
if (Configuration.ACCOUNT.EXPERIMENTAL_RealPassword) { if (Configuration.ACCOUNT.EXPERIMENTAL_RealPassword) {
CommandHandler.sendMessage( CommandHandler.sendMessage(
sender, sender,
"EXPERIMENTAL_RealPassword requires argument 2 to be a password, not a uid"); "EXPERIMENTAL_RealPassword requires argument 2 to be a password, not a uid");
CommandHandler.sendMessage( CommandHandler.sendMessage(
sender, "Usage: account create <username> <password> [uid]"); sender, "Usage: account create <username> <password> [uid]");
} }
return; return;
} }
@ -79,8 +78,7 @@ public final class AccountCommand implements CommandHandler {
} }
} }
} }
Account account = DatabaseHelper.createAccountWithUid(username, uid);
emu.grasscutter.game.Account account = DatabaseHelper.createAccountWithUid(username, uid);
if (account == null) { if (account == null) {
CommandHandler.sendMessage(sender, translate(sender, "commands.account.exists")); CommandHandler.sendMessage(sender, translate(sender, "commands.account.exists"));
return; return;
@ -92,36 +90,31 @@ public final class AccountCommand implements CommandHandler {
account.save(); // Save account to database. account.save(); // Save account to database.
CommandHandler.sendMessage( CommandHandler.sendMessage(
sender, translate(sender, "commands.account.create", account.getReservedPlayerUid())); sender, translate(sender, "commands.account.create", account.getReservedPlayerUid()));
} }
return; }
case "delete": case "delete" -> {
// Get the account we want to delete. // Get the account we want to delete.
Account toDelete = DatabaseHelper.getAccountByName(username); Account toDelete = DatabaseHelper.getAccountByName(username);
if (toDelete == null) { if (toDelete == null) {
CommandHandler.sendMessage(sender, translate(sender, "commands.account.no_account")); CommandHandler.sendMessage(sender, translate(sender, "commands.account.no_account"));
return; return;
} }
DatabaseHelper.deleteAccount(toDelete); DatabaseHelper.deleteAccount(toDelete);
CommandHandler.sendMessage(sender, translate(sender, "commands.account.delete")); CommandHandler.sendMessage(sender, translate(sender, "commands.account.delete"));
return; }
case "resetpass": case "resetpass" -> {
if (!Configuration.ACCOUNT.EXPERIMENTAL_RealPassword) { if (!Configuration.ACCOUNT.EXPERIMENTAL_RealPassword) {
CommandHandler.sendMessage( CommandHandler.sendMessage(
sender, "resetpass requires EXPERIMENTAL_RealPassword to be true."); sender, "resetpass requires EXPERIMENTAL_RealPassword to be true.");
return; return;
} }
if (args.size() != 3) { if (args.size() != 3) {
CommandHandler.sendMessage(sender, "Invalid Args"); CommandHandler.sendMessage(sender, "Invalid Args");
CommandHandler.sendMessage(sender, "Usage: account resetpass <username> <password>"); CommandHandler.sendMessage(sender, "Usage: account resetpass <username> <password>");
return; return;
} }
Account toUpdate = DatabaseHelper.getAccountByName(username); Account toUpdate = DatabaseHelper.getAccountByName(username);
if (toUpdate == null) { if (toUpdate == null) {
CommandHandler.sendMessage(sender, translate(sender, "commands.account.no_account")); CommandHandler.sendMessage(sender, translate(sender, "commands.account.no_account"));
return; return;
@ -129,13 +122,38 @@ public final class AccountCommand implements CommandHandler {
// Make sure player can't stay logged in with old password. // Make sure player can't stay logged in with old password.
kickAccount(toUpdate); kickAccount(toUpdate);
toUpdate.setPassword(BCrypt.withDefaults().hashToString(12, args.get(2).toCharArray())); toUpdate.setPassword(BCrypt.withDefaults().hashToString(12, args.get(2).toCharArray()));
toUpdate.save(); toUpdate.save();
CommandHandler.sendMessage(sender, "Password Updated."); CommandHandler.sendMessage(sender, "Password Updated.");
}
case "list" -> {
CommandHandler.sendMessage(sender, "Note: This command might take a while to complete.");
CommandHandler.sendMessage(sender,
"Accounts: \n" + DatabaseManager.getAccountDatastore()
.find(Account.class).stream()
.map(acc -> "%s: %s (%s)".formatted(
acc.getId(), acc.getUsername(),
acc.getReservedPlayerUid() == 0 ?
this.getPlayerUid(acc) :
acc.getReservedPlayerUid()))
.collect(Collectors.joining("\n"))
);
}
} }
} }
/**
* Returns the UID of the player associated with the given account.
* If the player is not found, returns "no UID".
*
* @param account The account to get the UID of.
* @return The UID of the player associated with the given account.
*/
private String getPlayerUid(Account account) {
var player = DatabaseHelper.getPlayerByAccount(account, Player.class);
return player == null ? "no UID" : String.valueOf(player.getUid());
}
private void kickAccount(Account account) { private void kickAccount(Account account) {
Player player = Grasscutter.getGameServer().getPlayerByAccountId(account.getId()); Player player = Grasscutter.getGameServer().getPlayerByAccountId(account.getId());
if (player != null) { if (player != null) {