mirror of
https://github.com/Grasscutters/Grasscutter.git
synced 2025-12-15 08:25:21 +01:00
Add permission to BanCommand, rework its targeting
This commit is contained in:
@@ -2,36 +2,26 @@ package emu.grasscutter.command.commands;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import emu.grasscutter.Grasscutter;
|
||||
import emu.grasscutter.command.Command;
|
||||
import emu.grasscutter.command.CommandHandler;
|
||||
import emu.grasscutter.database.DatabaseHelper;
|
||||
import emu.grasscutter.game.Account;
|
||||
import emu.grasscutter.game.player.Player;
|
||||
|
||||
import static emu.grasscutter.utils.Language.translate;
|
||||
import emu.grasscutter.server.game.GameSession;
|
||||
|
||||
@Command(
|
||||
label = "ban",
|
||||
usage = "ban <player> [time] [reason]",
|
||||
usage = "ban <@player> [time] [reason]",
|
||||
description = "commands.ban.description",
|
||||
targetRequirement = Command.TargetRequirement.NONE
|
||||
permission = "server.ban",
|
||||
targetRequirement = Command.TargetRequirement.PLAYER
|
||||
)
|
||||
public final class BanCommand implements CommandHandler {
|
||||
|
||||
private boolean banAccount(int uid, int time, String reason) {
|
||||
Player player = Grasscutter.getGameServer().getPlayerByUid(uid, true);
|
||||
private boolean banAccount(Player targetPlayer, int time, String reason) {
|
||||
Account account = targetPlayer.getAccount();
|
||||
|
||||
if (player == null) {
|
||||
return false;
|
||||
}
|
||||
|
||||
Account account = player.getAccount();
|
||||
if (account == null) {
|
||||
account = DatabaseHelper.getAccountByPlayerId(uid);
|
||||
if (account == null) {
|
||||
return false;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
account.setBanReason(reason);
|
||||
@@ -40,51 +30,36 @@ public final class BanCommand implements CommandHandler {
|
||||
account.setBanned(true);
|
||||
account.save();
|
||||
|
||||
Player banUser = Grasscutter.getGameServer().getPlayerByUid(uid);
|
||||
|
||||
if (banUser != null) {
|
||||
banUser.getSession().close();
|
||||
GameSession session = targetPlayer.getSession();
|
||||
if (session != null) {
|
||||
session.close();
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void execute(Player sender, Player targetPlayer, List<String> args) {
|
||||
if (args.size() < 1) {
|
||||
CommandHandler.sendMessage(sender, translate(sender, "commands.ban.command_usage"));
|
||||
return;
|
||||
}
|
||||
|
||||
int uid = 0;
|
||||
int time = 2051190000;
|
||||
String reason = "Reason not specified.";
|
||||
|
||||
if (args.size() >= 1) {
|
||||
try {
|
||||
uid = Integer.parseInt(args.get(0));
|
||||
} catch (NumberFormatException ignored) {
|
||||
CommandHandler.sendMessage(sender, translate(sender, "commands.ban.invalid_player_id"));
|
||||
return;
|
||||
}
|
||||
switch (args.size()) {
|
||||
case 2:
|
||||
reason = args.get(1); // Fall-through
|
||||
case 1:
|
||||
try {
|
||||
time = Integer.parseInt(args.get(0));
|
||||
} catch (NumberFormatException ignored) {
|
||||
CommandHandler.sendTranslatedMessage(sender, "commands.ban.invalid_time");
|
||||
return;
|
||||
} // Fall-through, unimportant
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
if (args.size() >= 2) {
|
||||
try {
|
||||
time = Integer.parseInt(args.get(1));
|
||||
} catch (NumberFormatException ignored) {
|
||||
CommandHandler.sendMessage(sender, translate(sender, "commands.ban.invalid_time"));
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if (args.size() >= 3) {
|
||||
reason = args.get(2);
|
||||
}
|
||||
|
||||
if (banAccount(uid, time, reason)) {
|
||||
CommandHandler.sendMessage(sender, translate(sender, "commands.ban.success"));
|
||||
if (banAccount(targetPlayer, time, reason)) {
|
||||
CommandHandler.sendTranslatedMessage(sender, "commands.ban.success");
|
||||
} else {
|
||||
CommandHandler.sendMessage(sender, translate(sender, "commands.ban.failure"));
|
||||
CommandHandler.sendTranslatedMessage(sender, "commands.ban.failure");
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -2,37 +2,25 @@ package emu.grasscutter.command.commands;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import emu.grasscutter.Grasscutter;
|
||||
import emu.grasscutter.command.Command;
|
||||
import emu.grasscutter.command.CommandHandler;
|
||||
import emu.grasscutter.database.DatabaseHelper;
|
||||
import emu.grasscutter.game.Account;
|
||||
import emu.grasscutter.game.player.Player;
|
||||
|
||||
import static emu.grasscutter.utils.Language.translate;
|
||||
|
||||
@Command(
|
||||
label = "unban",
|
||||
usage = "unban <player>",
|
||||
usage = "unban <@player>",
|
||||
description = "commands.unban.description",
|
||||
targetRequirement = Command.TargetRequirement.NONE
|
||||
permission = "server.ban",
|
||||
targetRequirement = Command.TargetRequirement.PLAYER
|
||||
)
|
||||
public final class UnBanCommand implements CommandHandler {
|
||||
|
||||
private boolean unBanAccount(int uid) {
|
||||
Player player = Grasscutter.getGameServer().getPlayerByUid(uid, true);
|
||||
|
||||
if (player == null) {
|
||||
return false;
|
||||
}
|
||||
|
||||
Account account = player.getAccount();
|
||||
private boolean unBanAccount(Player targetPlayer) {
|
||||
Account account = targetPlayer.getAccount();
|
||||
|
||||
if (account == null) {
|
||||
account = DatabaseHelper.getAccountByPlayerId(uid);
|
||||
if (account == null) {
|
||||
return false;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
account.setBanReason(null);
|
||||
@@ -46,24 +34,10 @@ public final class UnBanCommand implements CommandHandler {
|
||||
|
||||
@Override
|
||||
public void execute(Player sender, Player targetPlayer, List<String> args) {
|
||||
if (args.size() < 1) {
|
||||
CommandHandler.sendMessage(sender, translate(sender, "commands.unban.command_usage"));
|
||||
return;
|
||||
}
|
||||
|
||||
int uid = 0;
|
||||
|
||||
try {
|
||||
uid = Integer.parseInt(args.get(0));
|
||||
} catch (NumberFormatException ignored) {
|
||||
CommandHandler.sendMessage(sender, translate(sender, "commands.unban.invalid_player_id"));
|
||||
return;
|
||||
}
|
||||
|
||||
if (unBanAccount(uid)) {
|
||||
CommandHandler.sendMessage(sender, translate(sender, "commands.unban.success"));
|
||||
if (unBanAccount(targetPlayer)) {
|
||||
CommandHandler.sendTranslatedMessage(sender, "commands.unban.success");
|
||||
} else {
|
||||
CommandHandler.sendMessage(sender, translate(sender, "commands.unban.failure"));
|
||||
CommandHandler.sendTranslatedMessage(sender, "commands.unban.failure");
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user