Better command handling in console

This commit is contained in:
mathiascode 2019-09-22 05:37:43 +03:00
parent d3902cbc8b
commit 6b22761698
14 changed files with 203 additions and 299 deletions

View file

@ -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(),

View file

@ -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;
} }
} }

View file

@ -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;
} }

View file

@ -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");
} }
} }
} }

View file

@ -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;
} }

View file

@ -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");
} }
} }
} }

View file

@ -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;
} }

View file

@ -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;
} }
} }

View file

@ -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;
} }

View file

@ -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)));

View file

@ -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;
} }
} }

View file

@ -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;
} }

View file

@ -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);
} }
} }

View file

@ -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);
}*/
} }
} }