Improved item handling
This commit is contained in:
@@ -135,21 +135,22 @@ public class Metrics {
|
|||||||
logSentData = config.getBoolean("logSentData", false);
|
logSentData = config.getBoolean("logSentData", false);
|
||||||
logResponseStatusText = config.getBoolean("logResponseStatusText", false);
|
logResponseStatusText = config.getBoolean("logResponseStatusText", false);
|
||||||
|
|
||||||
boolean found = false;
|
if (enabled) {
|
||||||
// Search for all other bStats Metrics classes to see if we are the first one
|
boolean found = false;
|
||||||
for (Class<?> service : Bukkit.getServicesManager().getKnownServices()) {
|
// Search for all other bStats Metrics classes to see if we are the first one
|
||||||
try {
|
for (Class<?> service : Bukkit.getServicesManager().getKnownServices()) {
|
||||||
service.getField("B_STATS_VERSION"); // Our identifier :)
|
try {
|
||||||
found = true; // We aren't the first
|
service.getField("B_STATS_VERSION"); // Our identifier :)
|
||||||
break;
|
found = true; // We aren't the first
|
||||||
} catch (NoSuchFieldException ignored) {
|
break;
|
||||||
|
} catch (NoSuchFieldException ignored) { }
|
||||||
|
}
|
||||||
|
// Register our service
|
||||||
|
Bukkit.getServicesManager().register(Metrics.class, this, plugin, ServicePriority.Normal);
|
||||||
|
if (!found) {
|
||||||
|
// We are the first!
|
||||||
|
startSubmitting();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
// Register our service
|
|
||||||
Bukkit.getServicesManager().register(Metrics.class, this, plugin, ServicePriority.Normal);
|
|
||||||
if (!found) {
|
|
||||||
// We are the first!
|
|
||||||
startSubmitting();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -115,16 +115,29 @@ public class Listeners implements Listener {
|
|||||||
int num = info.getNumber();
|
int num = info.getNumber();
|
||||||
String inventoryTitle = event.getView().getTitle();
|
String inventoryTitle = event.getView().getTitle();
|
||||||
String title = Lang.VAULT_TITLE.toString().replace("%number", String.valueOf(num)).replace("%p", info.getVaultName());
|
String title = Lang.VAULT_TITLE.toString().replace("%number", String.valueOf(num)).replace("%p", info.getVaultName());
|
||||||
if (((inventoryTitle.equalsIgnoreCase(title)) && event.getCurrentItem() != null)) {
|
if (inventoryTitle.equalsIgnoreCase(title)) {
|
||||||
try {
|
ItemStack[] items = new ItemStack[2];
|
||||||
event.getCurrentItem().toString();
|
items[0] = event.getCurrentItem();
|
||||||
} catch (Exception e) {
|
if (event.getHotbarButton() > -1 && event.getWhoClicked().getInventory().getItem(event.getHotbarButton()) != null) {
|
||||||
player.sendMessage(Lang.TITLE.toString() + Lang.BLOCKED_BAD_ITEM);
|
items[1] = event.getWhoClicked().getInventory().getItem(event.getHotbarButton());
|
||||||
event.setCancelled(true);
|
|
||||||
}
|
}
|
||||||
if (!player.hasPermission("playervaults.bypassblockeditems") && PlayerVaults.getInstance().isBlockedMaterial(event.getCurrentItem().getType())) {
|
|
||||||
event.setCancelled(true);
|
for (ItemStack item : items) {
|
||||||
player.sendMessage(Lang.TITLE.toString() + Lang.BLOCKED_ITEM.toString().replace("%m", event.getCurrentItem().getType().name()));
|
if (item == null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
item.toString();
|
||||||
|
} catch (Exception e) {
|
||||||
|
player.sendMessage(Lang.TITLE.toString() + Lang.BLOCKED_BAD_ITEM);
|
||||||
|
event.setCancelled(true);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (!player.hasPermission("playervaults.bypassblockeditems") && PlayerVaults.getInstance().isBlockedMaterial(item.getType())) {
|
||||||
|
event.setCancelled(true);
|
||||||
|
player.sendMessage(Lang.TITLE.toString() + Lang.BLOCKED_ITEM.toString().replace("%m", item.getType().name()));
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user