mirror of
https://github.com/Grasscutters/Grasscutter.git
synced 2025-01-10 12:42:52 +08:00
Add account list command
This commit is contained in:
parent
7c065b33d6
commit
510e6bfa78
@ -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) {
|
||||||
|
Loading…
Reference in New Issue
Block a user