mirror of
https://github.com/kaboomserver/extras.git
synced 2025-08-06 04:23:21 +00:00
Better command handling in console
This commit is contained in:
parent
d3902cbc8b
commit
6b22761698
14 changed files with 203 additions and 299 deletions
|
@ -11,10 +11,8 @@ import org.bukkit.entity.Player;
|
||||||
|
|
||||||
class CommandConsole implements CommandExecutor {
|
class CommandConsole implements CommandExecutor {
|
||||||
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
final Player player = (Player) sender;
|
|
||||||
|
|
||||||
if (args.length == 0) {
|
if (args.length == 0) {
|
||||||
player.sendMessage(ChatColor.RED + "Usage: /" + label + " <message ..>");
|
sender.sendMessage(ChatColor.RED + "Usage: /" + label + " <message ..>");
|
||||||
} else {
|
} else {
|
||||||
Bukkit.dispatchCommand(
|
Bukkit.dispatchCommand(
|
||||||
Bukkit.getConsoleSender(),
|
Bukkit.getConsoleSender(),
|
||||||
|
|
|
@ -13,7 +13,6 @@ import org.bukkit.entity.Player;
|
||||||
|
|
||||||
class CommandDestroyEntities implements CommandExecutor {
|
class CommandDestroyEntities implements CommandExecutor {
|
||||||
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
final Player player = (Player) sender;
|
|
||||||
int entityCount = 0;
|
int entityCount = 0;
|
||||||
int worldCount = 0;
|
int worldCount = 0;
|
||||||
|
|
||||||
|
@ -26,7 +25,7 @@ class CommandDestroyEntities implements CommandExecutor {
|
||||||
}
|
}
|
||||||
worldCount++;
|
worldCount++;
|
||||||
}
|
}
|
||||||
player.sendMessage("Successfully destroyed " + entityCount + " entities in " + worldCount + " worlds");
|
sender.sendMessage("Successfully destroyed " + entityCount + " entities in " + worldCount + " worlds");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,6 +5,7 @@ import org.bukkit.Material;
|
||||||
import org.bukkit.command.Command;
|
import org.bukkit.command.Command;
|
||||||
import org.bukkit.command.CommandExecutor;
|
import org.bukkit.command.CommandExecutor;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
|
|
||||||
import org.bukkit.enchantments.Enchantment;
|
import org.bukkit.enchantments.Enchantment;
|
||||||
|
|
||||||
|
@ -14,43 +15,47 @@ import org.bukkit.inventory.ItemStack;
|
||||||
|
|
||||||
class CommandEnchantAll implements CommandExecutor {
|
class CommandEnchantAll implements CommandExecutor {
|
||||||
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
final Player player = (Player) sender;
|
if (sender instanceof ConsoleCommandSender) {
|
||||||
final ItemStack item = player.getInventory().getItemInMainHand();
|
sender.sendMessage("Command has to be run by a player");
|
||||||
|
|
||||||
if (item.getType() == Material.AIR) {
|
|
||||||
player.sendMessage("Please hold an item in your hand to enchant it");
|
|
||||||
} else {
|
} else {
|
||||||
item.addUnsafeEnchantment(Enchantment.ARROW_DAMAGE, 32767);
|
final Player player = (Player) sender;
|
||||||
item.addUnsafeEnchantment(Enchantment.ARROW_FIRE, 32767);
|
final ItemStack item = player.getInventory().getItemInMainHand();
|
||||||
item.addUnsafeEnchantment(Enchantment.ARROW_INFINITE, 32767);
|
|
||||||
item.addUnsafeEnchantment(Enchantment.ARROW_KNOCKBACK, 32767);
|
if (item.getType() == Material.AIR) {
|
||||||
item.addUnsafeEnchantment(Enchantment.BINDING_CURSE, 32767);
|
player.sendMessage("Please hold an item in your hand to enchant it");
|
||||||
item.addUnsafeEnchantment(Enchantment.DAMAGE_ALL, 32767);
|
} else {
|
||||||
item.addUnsafeEnchantment(Enchantment.DAMAGE_ARTHROPODS, 32767);
|
item.addUnsafeEnchantment(Enchantment.ARROW_DAMAGE, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.DAMAGE_UNDEAD, 32767);
|
item.addUnsafeEnchantment(Enchantment.ARROW_FIRE, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.DEPTH_STRIDER, 32767);
|
item.addUnsafeEnchantment(Enchantment.ARROW_INFINITE, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.DIG_SPEED, 32767);
|
item.addUnsafeEnchantment(Enchantment.ARROW_KNOCKBACK, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.DURABILITY, 32767);
|
item.addUnsafeEnchantment(Enchantment.BINDING_CURSE, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.FIRE_ASPECT, 32767);
|
item.addUnsafeEnchantment(Enchantment.DAMAGE_ALL, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.FROST_WALKER, 32767);
|
item.addUnsafeEnchantment(Enchantment.DAMAGE_ARTHROPODS, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.KNOCKBACK, 32767);
|
item.addUnsafeEnchantment(Enchantment.DAMAGE_UNDEAD, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.LOOT_BONUS_BLOCKS, 32767);
|
item.addUnsafeEnchantment(Enchantment.DEPTH_STRIDER, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.LOOT_BONUS_MOBS, 32767);
|
item.addUnsafeEnchantment(Enchantment.DIG_SPEED, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.LUCK, 32767);
|
item.addUnsafeEnchantment(Enchantment.DURABILITY, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.LURE, 32767);
|
item.addUnsafeEnchantment(Enchantment.FIRE_ASPECT, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.MENDING, 32767);
|
item.addUnsafeEnchantment(Enchantment.FROST_WALKER, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.OXYGEN, 32767);
|
item.addUnsafeEnchantment(Enchantment.KNOCKBACK, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.PROTECTION_ENVIRONMENTAL, 32767);
|
item.addUnsafeEnchantment(Enchantment.LOOT_BONUS_BLOCKS, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.PROTECTION_EXPLOSIONS, 32767);
|
item.addUnsafeEnchantment(Enchantment.LOOT_BONUS_MOBS, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.PROTECTION_FALL, 32767);
|
item.addUnsafeEnchantment(Enchantment.LUCK, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.PROTECTION_FIRE, 32767);
|
item.addUnsafeEnchantment(Enchantment.LURE, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.PROTECTION_PROJECTILE, 32767);
|
item.addUnsafeEnchantment(Enchantment.MENDING, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.SILK_TOUCH, 32767);
|
item.addUnsafeEnchantment(Enchantment.OXYGEN, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.SWEEPING_EDGE, 32767);
|
item.addUnsafeEnchantment(Enchantment.PROTECTION_ENVIRONMENTAL, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.THORNS, 32767);
|
item.addUnsafeEnchantment(Enchantment.PROTECTION_EXPLOSIONS, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.VANISHING_CURSE, 32767);
|
item.addUnsafeEnchantment(Enchantment.PROTECTION_FALL, 32767);
|
||||||
item.addUnsafeEnchantment(Enchantment.WATER_WORKER, 32767);
|
item.addUnsafeEnchantment(Enchantment.PROTECTION_FIRE, 32767);
|
||||||
player.sendMessage("I killed Tim.");
|
item.addUnsafeEnchantment(Enchantment.PROTECTION_PROJECTILE, 32767);
|
||||||
|
item.addUnsafeEnchantment(Enchantment.SILK_TOUCH, 32767);
|
||||||
|
item.addUnsafeEnchantment(Enchantment.SWEEPING_EDGE, 32767);
|
||||||
|
item.addUnsafeEnchantment(Enchantment.THORNS, 32767);
|
||||||
|
item.addUnsafeEnchantment(Enchantment.VANISHING_CURSE, 32767);
|
||||||
|
item.addUnsafeEnchantment(Enchantment.WATER_WORKER, 32767);
|
||||||
|
player.sendMessage("I killed Tim.");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,23 +20,21 @@ class CommandJumpscare implements CommandExecutor {
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
final Player player = (Player) sender;
|
|
||||||
|
|
||||||
if (args.length == 0) {
|
if (args.length == 0) {
|
||||||
player.sendMessage(ChatColor.RED + "Usage: /" + label + " <player>");
|
sender.sendMessage(ChatColor.RED + "Usage: /" + label + " <player>");
|
||||||
} else {
|
} else {
|
||||||
if (args[0].equals("*") || args[0].equals("**")) {
|
if (args[0].equals("*") || args[0].equals("**")) {
|
||||||
for (Player onlinePlayer : Bukkit.getOnlinePlayers()) {
|
for (Player onlinePlayer : Bukkit.getOnlinePlayers()) {
|
||||||
createJumpscare(onlinePlayer);
|
createJumpscare(onlinePlayer);
|
||||||
}
|
}
|
||||||
player.sendMessage("Successfully created jumpscare for every player");
|
sender.sendMessage("Successfully created jumpscare for every player");
|
||||||
} else {
|
} else {
|
||||||
final Player target = Bukkit.getPlayer(args[0]);
|
final Player target = Bukkit.getPlayer(args[0]);
|
||||||
if (target != null) {
|
if (target != null) {
|
||||||
createJumpscare(target);
|
createJumpscare(target);
|
||||||
player.sendMessage("Successfully created jumpscare for player \"" + target.getName() + "\"");
|
sender.sendMessage("Successfully created jumpscare for player \"" + target.getName() + "\"");
|
||||||
} else {
|
} else {
|
||||||
player.sendMessage("Player \"" + target.getName() + "\" not found");
|
sender.sendMessage("Player \"" + target.getName() + "\" not found");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,6 +5,7 @@ import org.bukkit.ChatColor;
|
||||||
import org.bukkit.command.Command;
|
import org.bukkit.command.Command;
|
||||||
import org.bukkit.command.CommandExecutor;
|
import org.bukkit.command.CommandExecutor;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
|
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
@ -15,18 +16,22 @@ class CommandPrefix implements CommandExecutor {
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
final Player player = (Player) sender;
|
if (sender instanceof ConsoleCommandSender) {
|
||||||
|
sender.sendMessage("Command has to be run by a player");
|
||||||
if (args.length == 0) {
|
|
||||||
player.sendMessage(ChatColor.RED + "Usage: /" + label + " <prefix|off>");
|
|
||||||
} else if (args[0].equalsIgnoreCase("off")) {
|
|
||||||
main.getConfig().set(player.getUniqueId().toString(), null);
|
|
||||||
main.saveConfig();
|
|
||||||
player.sendMessage("You no longer have a tag");
|
|
||||||
} else {
|
} else {
|
||||||
main.getConfig().set(player.getUniqueId().toString(), String.join(" ", args));
|
final Player player = (Player) sender;
|
||||||
main.saveConfig();
|
|
||||||
player.sendMessage("You now have the tag: " + ChatColor.translateAlternateColorCodes('&', String.join(" ", args)));
|
if (args.length == 0) {
|
||||||
|
player.sendMessage(ChatColor.RED + "Usage: /" + label + " <prefix|off>");
|
||||||
|
} else if (args[0].equalsIgnoreCase("off")) {
|
||||||
|
main.getConfig().set(player.getUniqueId().toString(), null);
|
||||||
|
main.saveConfig();
|
||||||
|
player.sendMessage("You no longer have a tag");
|
||||||
|
} else {
|
||||||
|
main.getConfig().set(player.getUniqueId().toString(), String.join(" ", args));
|
||||||
|
main.saveConfig();
|
||||||
|
player.sendMessage("You now have the tag: " + ChatColor.translateAlternateColorCodes('&', String.join(" ", args)));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,23 +18,21 @@ class CommandPumpkin implements CommandExecutor {
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
final Player player = (Player) sender;
|
|
||||||
|
|
||||||
if (args.length == 0) {
|
if (args.length == 0) {
|
||||||
player.sendMessage(ChatColor.RED + "Usage: /" + label + " <player>");
|
sender.sendMessage(ChatColor.RED + "Usage: /" + label + " <player>");
|
||||||
} else {
|
} else {
|
||||||
if (args[0].equals("*") || args[0].equals("**")) {
|
if (args[0].equals("*") || args[0].equals("**")) {
|
||||||
for (Player onlinePlayer : Bukkit.getOnlinePlayers()) {
|
for (Player onlinePlayer : Bukkit.getOnlinePlayers()) {
|
||||||
placePumpkin(onlinePlayer);
|
placePumpkin(onlinePlayer);
|
||||||
}
|
}
|
||||||
player.sendMessage("Everyone is now a pumpkin");
|
sender.sendMessage("Everyone is now a pumpkin");
|
||||||
} else {
|
} else {
|
||||||
final Player target = Bukkit.getPlayer(args[0]);
|
final Player target = Bukkit.getPlayer(args[0]);
|
||||||
if (target != null) {
|
if (target != null) {
|
||||||
placePumpkin(target);
|
placePumpkin(target);
|
||||||
player.sendMessage("Player \"" + target.getName() + "\" is now a pumpkin");
|
sender.sendMessage("Player \"" + target.getName() + "\" is now a pumpkin");
|
||||||
} else {
|
} else {
|
||||||
player.sendMessage("Player \"" + target.getName() + "\" not found");
|
sender.sendMessage("Player \"" + target.getName() + "\" not found");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,6 +10,7 @@ import org.bukkit.ChatColor;
|
||||||
import org.bukkit.command.Command;
|
import org.bukkit.command.Command;
|
||||||
import org.bukkit.command.CommandExecutor;
|
import org.bukkit.command.CommandExecutor;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
|
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
@ -28,47 +29,51 @@ class CommandSkin implements CommandExecutor {
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean onCommand(CommandSender sender, Command command, String label, final String[] args) {
|
public boolean onCommand(CommandSender sender, Command command, String label, final String[] args) {
|
||||||
final Player player = (Player) sender;
|
if (sender instanceof ConsoleCommandSender) {
|
||||||
|
sender.sendMessage("Command has to be run by a player");
|
||||||
if (args.length == 0) {
|
|
||||||
player.sendMessage(ChatColor.RED + "Usage: /" + label + " <username>");
|
|
||||||
} else {
|
} else {
|
||||||
final String name = args[0];
|
final Player player = (Player) sender;
|
||||||
new BukkitRunnable() {
|
|
||||||
public void run() {
|
if (args.length == 0) {
|
||||||
try {
|
player.sendMessage(ChatColor.RED + "Usage: /" + label + " <username>");
|
||||||
final URL skinUrl = new URL("https://api.ashcon.app/mojang/v2/user/" + name);
|
} else {
|
||||||
final HttpsURLConnection skinConnection = (HttpsURLConnection) skinUrl.openConnection();
|
final String name = args[0];
|
||||||
skinConnection.setConnectTimeout(0);
|
new BukkitRunnable() {
|
||||||
skinConnection.setDefaultUseCaches(false);
|
public void run() {
|
||||||
skinConnection.setUseCaches(false);
|
try {
|
||||||
|
final URL skinUrl = new URL("https://api.ashcon.app/mojang/v2/user/" + name);
|
||||||
if (skinConnection.getResponseCode() == HttpsURLConnection.HTTP_OK) {
|
final HttpsURLConnection skinConnection = (HttpsURLConnection) skinUrl.openConnection();
|
||||||
final InputStreamReader skinStream = new InputStreamReader(skinConnection.getInputStream());
|
skinConnection.setConnectTimeout(0);
|
||||||
final JsonObject response = new JsonParser().parse(skinStream).getAsJsonObject();
|
skinConnection.setDefaultUseCaches(false);
|
||||||
final JsonObject rawSkin = response.getAsJsonObject("textures").getAsJsonObject("raw");
|
skinConnection.setUseCaches(false);
|
||||||
final String texture = rawSkin.get("value").getAsString();
|
|
||||||
final String signature = rawSkin.get("signature").getAsString();
|
if (skinConnection.getResponseCode() == HttpsURLConnection.HTTP_OK) {
|
||||||
skinStream.close();
|
final InputStreamReader skinStream = new InputStreamReader(skinConnection.getInputStream());
|
||||||
|
final JsonObject response = new JsonParser().parse(skinStream).getAsJsonObject();
|
||||||
final PlayerProfile textureProfile = player.getPlayerProfile();
|
final JsonObject rawSkin = response.getAsJsonObject("textures").getAsJsonObject("raw");
|
||||||
textureProfile.setProperty(new ProfileProperty("textures", texture, signature));
|
final String texture = rawSkin.get("value").getAsString();
|
||||||
|
final String signature = rawSkin.get("signature").getAsString();
|
||||||
player.sendMessage("Successfully set your skin to " + name + "'s");
|
skinStream.close();
|
||||||
new BukkitRunnable() {
|
|
||||||
public void run() {
|
final PlayerProfile textureProfile = player.getPlayerProfile();
|
||||||
player.setPlayerProfile(textureProfile);
|
textureProfile.setProperty(new ProfileProperty("textures", texture, signature));
|
||||||
}
|
|
||||||
}.runTask(main);
|
player.sendMessage("Successfully set your skin to " + name + "'s");
|
||||||
} else {
|
new BukkitRunnable() {
|
||||||
player.sendMessage("A player with that username doesn't exist");
|
public void run() {
|
||||||
|
player.setPlayerProfile(textureProfile);
|
||||||
|
}
|
||||||
|
}.runTask(main);
|
||||||
|
} else {
|
||||||
|
player.sendMessage("A player with that username doesn't exist");
|
||||||
|
}
|
||||||
|
|
||||||
|
skinConnection.disconnect();
|
||||||
|
} catch (Exception exception) {
|
||||||
}
|
}
|
||||||
|
|
||||||
skinConnection.disconnect();
|
|
||||||
} catch (Exception exception) {
|
|
||||||
}
|
}
|
||||||
}
|
}.runTaskAsynchronously(main);
|
||||||
}.runTaskAsynchronously(main);
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,27 +10,32 @@ import org.bukkit.block.BlockFace;
|
||||||
import org.bukkit.command.Command;
|
import org.bukkit.command.Command;
|
||||||
import org.bukkit.command.CommandExecutor;
|
import org.bukkit.command.CommandExecutor;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
|
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
class CommandSpawn implements CommandExecutor {
|
class CommandSpawn implements CommandExecutor {
|
||||||
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
final Player player = (Player) sender;
|
if (sender instanceof ConsoleCommandSender) {
|
||||||
final World world = Bukkit.getWorld("world");
|
sender.sendMessage("Command has to be run by a player");
|
||||||
final Location spawnLocation = world.getSpawnLocation();
|
} else {
|
||||||
|
final Player player = (Player) sender;
|
||||||
for (double y = spawnLocation.getY(); y <= 256; y++) {
|
final World world = Bukkit.getWorld("world");
|
||||||
final Location yLocation = new Location(world, spawnLocation.getX(), y, spawnLocation.getZ());
|
final Location spawnLocation = world.getSpawnLocation();
|
||||||
final Block coordBlock = world.getBlockAt(yLocation);
|
|
||||||
|
for (double y = spawnLocation.getY(); y <= 256; y++) {
|
||||||
if (!coordBlock.getType().isSolid() &&
|
final Location yLocation = new Location(world, spawnLocation.getX(), y, spawnLocation.getZ());
|
||||||
!coordBlock.getRelative(BlockFace.UP).getType().isSolid()) {
|
final Block coordBlock = world.getBlockAt(yLocation);
|
||||||
player.teleportAsync(yLocation);
|
|
||||||
break;
|
if (!coordBlock.getType().isSolid() &&
|
||||||
|
!coordBlock.getRelative(BlockFace.UP).getType().isSolid()) {
|
||||||
|
player.teleportAsync(yLocation);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
player.sendMessage("Successfully moved to spawn");
|
||||||
}
|
}
|
||||||
|
|
||||||
player.sendMessage("Successfully moved to spawn");
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,6 +6,7 @@ import org.bukkit.Material;
|
||||||
import org.bukkit.command.Command;
|
import org.bukkit.command.Command;
|
||||||
import org.bukkit.command.CommandExecutor;
|
import org.bukkit.command.CommandExecutor;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
|
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
@ -14,18 +15,22 @@ import org.bukkit.util.Vector;
|
||||||
|
|
||||||
class CommandSpidey implements CommandExecutor {
|
class CommandSpidey implements CommandExecutor {
|
||||||
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
final Player player = (Player) sender;
|
if (sender instanceof ConsoleCommandSender) {
|
||||||
final Location eyePos = player.getEyeLocation();
|
sender.sendMessage("Command has to be run by a player");
|
||||||
final Vector playerPos = new Vector(eyePos.getX(), eyePos.getY(), eyePos.getZ());
|
} else {
|
||||||
final Vector direction = eyePos.getDirection();
|
final Player player = (Player) sender;
|
||||||
final int distance = 50;
|
final Location eyePos = player.getEyeLocation();
|
||||||
|
final Vector playerPos = new Vector(eyePos.getX(), eyePos.getY(), eyePos.getZ());
|
||||||
final BlockIterator blockIterator = new BlockIterator(player.getWorld(), playerPos, direction, 0, distance);
|
final Vector direction = eyePos.getDirection();
|
||||||
|
final int distance = 50;
|
||||||
while (blockIterator.hasNext() &&
|
|
||||||
(blockIterator.next().getType() == Material.AIR ||
|
final BlockIterator blockIterator = new BlockIterator(player.getWorld(), playerPos, direction, 0, distance);
|
||||||
blockIterator.next().getType() == Material.CAVE_AIR)) {
|
|
||||||
blockIterator.next().setType(Material.COBWEB);
|
while (blockIterator.hasNext() &&
|
||||||
|
(blockIterator.next().getType() == Material.AIR ||
|
||||||
|
blockIterator.next().getType() == Material.CAVE_AIR)) {
|
||||||
|
blockIterator.next().setType(Material.COBWEB);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,10 +11,8 @@ import org.bukkit.entity.Player;
|
||||||
|
|
||||||
class CommandTellraw implements CommandExecutor {
|
class CommandTellraw implements CommandExecutor {
|
||||||
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
final Player player = (Player) sender;
|
|
||||||
|
|
||||||
if (args.length == 0) {
|
if (args.length == 0) {
|
||||||
player.sendMessage(ChatColor.RED + "Usage: /" + label + " <message ..>");
|
sender.sendMessage(ChatColor.RED + "Usage: /" + label + " <message ..>");
|
||||||
} else {
|
} else {
|
||||||
for (Player onlinePlayer : Bukkit.getOnlinePlayers()) {
|
for (Player onlinePlayer : Bukkit.getOnlinePlayers()) {
|
||||||
onlinePlayer.sendMessage(ChatColor.translateAlternateColorCodes('&', String.join(" ", args)));
|
onlinePlayer.sendMessage(ChatColor.translateAlternateColorCodes('&', String.join(" ", args)));
|
||||||
|
|
|
@ -12,7 +12,6 @@ import org.bukkit.entity.Player;
|
||||||
|
|
||||||
class CommandUnloadChunks implements CommandExecutor {
|
class CommandUnloadChunks implements CommandExecutor {
|
||||||
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
final Player player = (Player) sender;
|
|
||||||
int chunkCount = 0;
|
int chunkCount = 0;
|
||||||
|
|
||||||
for (World world : Bukkit.getServer().getWorlds()) {
|
for (World world : Bukkit.getServer().getWorlds()) {
|
||||||
|
@ -23,7 +22,7 @@ class CommandUnloadChunks implements CommandExecutor {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
player.sendMessage("Unloaded " + chunkCount + " unused chunks");
|
sender.sendMessage("Unloaded " + chunkCount + " unused chunks");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,6 +10,7 @@ import org.bukkit.ChatColor;
|
||||||
import org.bukkit.command.Command;
|
import org.bukkit.command.Command;
|
||||||
import org.bukkit.command.CommandExecutor;
|
import org.bukkit.command.CommandExecutor;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
|
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
@ -28,57 +29,61 @@ class CommandUsername implements CommandExecutor {
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean onCommand(CommandSender sender, Command command, String label, final String[] args) {
|
public boolean onCommand(CommandSender sender, Command command, String label, final String[] args) {
|
||||||
final Player player = (Player) sender;
|
if (sender instanceof ConsoleCommandSender) {
|
||||||
|
sender.sendMessage("Command has to be run by a player");
|
||||||
if (args.length == 0) {
|
|
||||||
player.sendMessage(ChatColor.RED + "Usage: /" + label + " <username>");
|
|
||||||
} else {
|
} else {
|
||||||
final String[] name = args;
|
final Player player = (Player) sender;
|
||||||
|
|
||||||
new BukkitRunnable() {
|
if (args.length == 0) {
|
||||||
public void run() {
|
player.sendMessage(ChatColor.RED + "Usage: /" + label + " <username>");
|
||||||
try {
|
} else {
|
||||||
String texture = "";
|
final String[] name = args;
|
||||||
String signature = "";
|
|
||||||
|
new BukkitRunnable() {
|
||||||
final String nameColor = ChatColor.translateAlternateColorCodes('&', String.join(" ", name));
|
public void run() {
|
||||||
final String nameShort = nameColor.substring(0, Math.min(16, nameColor.length()));
|
try {
|
||||||
|
String texture = "";
|
||||||
final URL skinUrl = new URL("https://api.ashcon.app/mojang/v2/user/" + nameShort);
|
String signature = "";
|
||||||
final HttpsURLConnection skinConnection = (HttpsURLConnection) skinUrl.openConnection();
|
|
||||||
skinConnection.setConnectTimeout(0);
|
final String nameColor = ChatColor.translateAlternateColorCodes('&', String.join(" ", name));
|
||||||
skinConnection.setDefaultUseCaches(false);
|
final String nameShort = nameColor.substring(0, Math.min(16, nameColor.length()));
|
||||||
skinConnection.setUseCaches(false);
|
|
||||||
|
final URL skinUrl = new URL("https://api.ashcon.app/mojang/v2/user/" + nameShort);
|
||||||
if (skinConnection.getResponseCode() == HttpsURLConnection.HTTP_OK) {
|
final HttpsURLConnection skinConnection = (HttpsURLConnection) skinUrl.openConnection();
|
||||||
final InputStreamReader skinStream = new InputStreamReader(skinConnection.getInputStream());
|
skinConnection.setConnectTimeout(0);
|
||||||
final JsonObject response = new JsonParser().parse(skinStream).getAsJsonObject();
|
skinConnection.setDefaultUseCaches(false);
|
||||||
final JsonObject rawSkin = response.getAsJsonObject("textures").getAsJsonObject("raw");
|
skinConnection.setUseCaches(false);
|
||||||
texture = rawSkin.get("value").getAsString();
|
|
||||||
signature = rawSkin.get("signature").getAsString();
|
if (skinConnection.getResponseCode() == HttpsURLConnection.HTTP_OK) {
|
||||||
skinStream.close();
|
final InputStreamReader skinStream = new InputStreamReader(skinConnection.getInputStream());
|
||||||
}
|
final JsonObject response = new JsonParser().parse(skinStream).getAsJsonObject();
|
||||||
|
final JsonObject rawSkin = response.getAsJsonObject("textures").getAsJsonObject("raw");
|
||||||
skinConnection.disconnect();
|
texture = rawSkin.get("value").getAsString();
|
||||||
|
signature = rawSkin.get("signature").getAsString();
|
||||||
final PlayerProfile profile = player.getPlayerProfile();
|
skinStream.close();
|
||||||
profile.setName(nameShort);
|
|
||||||
|
|
||||||
if (!("".equals(texture)) &&
|
|
||||||
!("".equals(signature))) {
|
|
||||||
profile.setProperty(new ProfileProperty("textures", texture, signature));
|
|
||||||
}
|
|
||||||
|
|
||||||
player.sendMessage("Successfully set your username to \"" + nameShort + "\"");
|
|
||||||
new BukkitRunnable() {
|
|
||||||
public void run() {
|
|
||||||
player.setPlayerProfile(profile);
|
|
||||||
}
|
}
|
||||||
}.runTask(main);
|
|
||||||
} catch (Exception exception) {
|
skinConnection.disconnect();
|
||||||
|
|
||||||
|
final PlayerProfile profile = player.getPlayerProfile();
|
||||||
|
profile.setName(nameShort);
|
||||||
|
|
||||||
|
if (!("".equals(texture)) &&
|
||||||
|
!("".equals(signature))) {
|
||||||
|
profile.setProperty(new ProfileProperty("textures", texture, signature));
|
||||||
|
}
|
||||||
|
|
||||||
|
player.sendMessage("Successfully set your username to \"" + nameShort + "\"");
|
||||||
|
new BukkitRunnable() {
|
||||||
|
public void run() {
|
||||||
|
player.setPlayerProfile(profile);
|
||||||
|
}
|
||||||
|
}.runTask(main);
|
||||||
|
} catch (Exception exception) {
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}.runTaskAsynchronously(main);
|
||||||
}.runTaskAsynchronously(main);
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,7 +25,7 @@ class PlayerChat implements Listener {
|
||||||
if (main.commandMillisList.get(playerUuid) != null) {
|
if (main.commandMillisList.get(playerUuid) != null) {
|
||||||
final long millisDifference = System.currentTimeMillis() - main.commandMillisList.get(playerUuid);
|
final long millisDifference = System.currentTimeMillis() - main.commandMillisList.get(playerUuid);
|
||||||
|
|
||||||
if (millisDifference < 20) {
|
if (millisDifference < 5) {
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,116 +14,6 @@ import org.bukkit.event.player.PlayerCommandPreprocessEvent;
|
||||||
|
|
||||||
import org.bukkit.scheduler.BukkitRunnable;
|
import org.bukkit.scheduler.BukkitRunnable;
|
||||||
|
|
||||||
|
|
||||||
import org.bukkit.command.CommandSender;
|
|
||||||
import org.bukkit.permissions.Permission;
|
|
||||||
|
|
||||||
import org.bukkit.permissions.PermissionAttachment;
|
|
||||||
|
|
||||||
import org.bukkit.permissions.PermissionAttachmentInfo;
|
|
||||||
import org.bukkit.Server;
|
|
||||||
import org.bukkit.plugin.Plugin;
|
|
||||||
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
class WrappedSender implements CommandSender {
|
|
||||||
private final CommandSender sender;
|
|
||||||
|
|
||||||
public WrappedSender(CommandSender sender) {
|
|
||||||
this.sender = sender;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void sendMessage(String message) {
|
|
||||||
sender.sendMessage(message);/*.substring(0, Math.min(256, message.length())));*/
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void sendMessage(String[] messages) {
|
|
||||||
sender.sendMessage(messages);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Server getServer() {
|
|
||||||
return sender.getServer();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getName() {
|
|
||||||
return sender.getName();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isPermissionSet(String name) {
|
|
||||||
return sender.isPermissionSet(name);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isPermissionSet(Permission perm) {
|
|
||||||
return sender.isPermissionSet(perm);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean hasPermission(String name) {
|
|
||||||
return sender.hasPermission(name);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean hasPermission(Permission perm) {
|
|
||||||
return sender.hasPermission(perm);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public PermissionAttachment addAttachment(Plugin plugin, String name, boolean value) {
|
|
||||||
return sender.addAttachment(plugin, name, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public PermissionAttachment addAttachment(Plugin plugin) {
|
|
||||||
return sender.addAttachment(plugin);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public PermissionAttachment addAttachment(Plugin plugin, String name, boolean value, int ticks) {
|
|
||||||
return sender.addAttachment(plugin, name, value, ticks);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public PermissionAttachment addAttachment(Plugin plugin, int ticks) {
|
|
||||||
return sender.addAttachment(plugin, ticks);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void removeAttachment(PermissionAttachment attachment) {
|
|
||||||
sender.removeAttachment(attachment);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void recalculatePermissions() {
|
|
||||||
sender.recalculatePermissions();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Set<PermissionAttachmentInfo> getEffectivePermissions() {
|
|
||||||
return sender.getEffectivePermissions();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isOp() {
|
|
||||||
return sender.isOp();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void setOp(boolean value) {
|
|
||||||
sender.setOp(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Spigot spigot() {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class PlayerCommand implements Listener {
|
class PlayerCommand implements Listener {
|
||||||
private Main main;
|
private Main main;
|
||||||
public PlayerCommand(Main main) {
|
public PlayerCommand(Main main) {
|
||||||
|
@ -139,7 +29,7 @@ class PlayerCommand implements Listener {
|
||||||
if (main.commandMillisList.get(playerUuid) != null) {
|
if (main.commandMillisList.get(playerUuid) != null) {
|
||||||
final long millisDifference = System.currentTimeMillis() - main.commandMillisList.get(playerUuid);
|
final long millisDifference = System.currentTimeMillis() - main.commandMillisList.get(playerUuid);
|
||||||
|
|
||||||
if (millisDifference < 200) {
|
if (millisDifference < 75) {
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -233,11 +123,5 @@ class PlayerCommand implements Listener {
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
Command.broadcastCommandMessage(event.getPlayer(), "Stopping the server");
|
Command.broadcastCommandMessage(event.getPlayer(), "Stopping the server");
|
||||||
}
|
}
|
||||||
|
|
||||||
/*if (!event.isCancelled()) {
|
|
||||||
WrappedSender wrapped = new WrappedSender(event.getPlayer());
|
|
||||||
Bukkit.getServer().dispatchCommand(wrapped, event.getMessage().substring(1));
|
|
||||||
event.setCancelled(true);
|
|
||||||
}*/
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue