/
KickCommand.java
56 lines (50 loc) · 1.8 KB
/
KickCommand.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
package com.denizenscript.denizen.scripts.commands.player;
import com.denizenscript.denizen.utilities.PaperAPITools;
import com.denizenscript.denizencore.scripts.commands.generator.*;
import com.denizenscript.denizen.objects.PlayerTag;
import com.denizenscript.denizencore.scripts.commands.AbstractCommand;
import java.util.List;
public class KickCommand extends AbstractCommand {
public KickCommand() {
setName("kick");
setSyntax("kick [<player>|...] (reason:<text>)");
setRequiredArguments(1, 2);
isProcedural = false;
autoCompile();
}
// <--[command]
// @Name kick
// @Syntax kick [<player>|...] (reason:<text>)
// @Required 1
// @Maximum 2
// @Short Kicks a player from the server.
// @Group player
//
// @Description
// Kick a player or a list of players from the server and optionally specify a reason.
// If no reason is specified it defaults to "Kicked."
//
// @Tags
// None
//
// @Usage
// Use to kick the player with the default reason.
// - kick <player>
//
// @Usage
// Use to kick the player with a reason.
// - kick <player> "reason:Because I can."
//
// @Usage
// Use to kick another player with a reason.
// - kick <[player]> "reason:Because I can."
// -->
public static void autoExecute(@ArgName("targets") @ArgLinear @ArgSubType(PlayerTag.class) List<PlayerTag> targets,
@ArgName("reason") @ArgPrefixed @ArgDefaultText("Kicked.") String reason) {
for (PlayerTag player : targets) {
if (player.isValid() && player.isOnline()) {
PaperAPITools.instance.kickPlayer(player.getPlayerEntity(), reason);
}
}
}
}