Compare commits

..

10 Commits

Author SHA1 Message Date
mbax 845056484e Bump deps 2023-08-08 12:59:54 -04:00
mbax 3b91a09782 Custom model data allowing/denying 2023-08-07 21:17:23 -04:00
mbax 664dfd37a0 Remove outdated del check 2023-07-19 11:56:29 -04:00
mbax 8be902c3f5 Add EnderVaults converter 2023-06-30 19:17:12 -04:00
mbax 64a124c268 PlayerVaultsX 4.2.14 2022-12-28 15:31:04 -05:00
mbax 9c651db060 Fix delete inconsistencies 2022-12-28 15:29:43 -05:00
mbax ea6dea1ef7 PlayerVaultsX 4.2.13 2022-12-08 22:23:28 -05:00
mbax d2e048b742 Upgrade to support 1.19.3 2022-12-08 22:22:52 -05:00
mbax f4713884c9 PlayerVaultsX 4.2.12 2022-09-11 20:09:19 -04:00
mbax 940c8530d6 Fix update checker excitedness 2022-09-11 20:08:46 -04:00
8 changed files with 197 additions and 16 deletions
+11 -5
View File
@@ -4,7 +4,7 @@
<groupId>com.drtshock</groupId> <groupId>com.drtshock</groupId>
<artifactId>PlayerVaultsX</artifactId> <artifactId>PlayerVaultsX</artifactId>
<version>4.2.11</version> <version>4.2.14</version>
<name>PlayerVaultsX</name> <name>PlayerVaultsX</name>
<url>https://www.spigotmc.org/resources/51204/</url> <url>https://www.spigotmc.org/resources/51204/</url>
@@ -101,7 +101,7 @@
<dependency> <dependency>
<groupId>net.kyori</groupId> <groupId>net.kyori</groupId>
<artifactId>adventure-platform-bukkit</artifactId> <artifactId>adventure-platform-bukkit</artifactId>
<version>4.1.2</version> <version>4.3.0</version>
<scope>compile</scope> <scope>compile</scope>
<optional>true</optional> <optional>true</optional>
<exclusions> <exclusions>
@@ -118,7 +118,7 @@
<dependency> <dependency>
<groupId>net.kyori</groupId> <groupId>net.kyori</groupId>
<artifactId>adventure-text-minimessage</artifactId> <artifactId>adventure-text-minimessage</artifactId>
<version>4.11.0</version> <version>4.14.0</version>
<scope>compile</scope> <scope>compile</scope>
<optional>true</optional> <optional>true</optional>
<exclusions> <exclusions>
@@ -135,7 +135,7 @@
<dependency> <dependency>
<groupId>com.google.code.gson</groupId> <groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId> <artifactId>gson</artifactId>
<version>2.8.8</version> <version>2.10.1</version>
<scope>compile</scope> <scope>compile</scope>
</dependency> </dependency>
<dependency> <dependency>
@@ -153,7 +153,13 @@
<dependency> <dependency>
<groupId>org.spigotmc</groupId> <groupId>org.spigotmc</groupId>
<artifactId>spigot-api</artifactId> <artifactId>spigot-api</artifactId>
<version>1.13.1-R0.1-SNAPSHOT</version> <version>1.14.4-R0.1-SNAPSHOT</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>com.googlecode.json-simple</groupId>
<artifactId>json-simple</artifactId>
<version>1.1.1</version>
<scope>provided</scope> <scope>provided</scope>
</dependency> </dependency>
<dependency> <dependency>
@@ -50,6 +50,7 @@ import org.bukkit.configuration.InvalidConfigurationException;
import org.bukkit.configuration.file.YamlConfiguration; import org.bukkit.configuration.file.YamlConfiguration;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.bukkit.inventory.Inventory; import org.bukkit.inventory.Inventory;
import org.bukkit.inventory.meta.ItemMeta;
import org.bukkit.plugin.Plugin; import org.bukkit.plugin.Plugin;
import org.bukkit.plugin.java.JavaPlugin; import org.bukkit.plugin.java.JavaPlugin;
import org.bukkit.scheduler.BukkitRunnable; import org.bukkit.scheduler.BukkitRunnable;
@@ -94,6 +95,8 @@ public class PlayerVaults extends JavaPlugin {
// VaultViewInfo - Inventory // VaultViewInfo - Inventory
private final HashMap<String, Inventory> openInventories = new HashMap<>(); private final HashMap<String, Inventory> openInventories = new HashMap<>();
private final Set<Material> blockedMats = new HashSet<>(); private final Set<Material> blockedMats = new HashSet<>();
private boolean blockWithModelData = false;
private boolean blockWithoutModelData = false;
private boolean useVault; private boolean useVault;
private YamlConfiguration signs; private YamlConfiguration signs;
private File signsFile; private File signsFile;
@@ -292,8 +295,8 @@ public class PlayerVaults extends JavaPlugin {
String reply = new BufferedReader(new InputStreamReader(con.getInputStream(), StandardCharsets.UTF_8)).lines().collect(Collectors.joining("\n")); String reply = new BufferedReader(new InputStreamReader(con.getInputStream(), StandardCharsets.UTF_8)).lines().collect(Collectors.joining("\n"));
Response response = new Gson().fromJson(reply, Response.class); Response response = new Gson().fromJson(reply, Response.class);
if (response.isSuccess()) { if (response.isSuccess()) {
PlayerVaults.this.updateResponse = response;
if (response.isUpdateAvailable()) { if (response.isUpdateAvailable()) {
PlayerVaults.this.updateResponse = response;
if (response.isUrgent()) { if (response.isUrgent()) {
PlayerVaults.this.getServer().getOnlinePlayers().forEach(PlayerVaults.this::updateNotification); PlayerVaults.this.getServer().getOnlinePlayers().forEach(PlayerVaults.this::updateNotification);
} }
@@ -393,8 +396,16 @@ public class PlayerVaults extends JavaPlugin {
// Clear just in case this is a reload. // Clear just in case this is a reload.
blockedMats.clear(); blockedMats.clear();
this.blockWithModelData = false;
this.blockWithoutModelData = false;
if (getConf().getItemBlocking().isEnabled()) { if (getConf().getItemBlocking().isEnabled()) {
for (String s : getConf().getItemBlocking().getList()) { for (String s : getConf().getItemBlocking().getList()) {
if (s.equalsIgnoreCase("BLOCK_ALL_WITH_CUSTOM_MODEL_DATA")) {
this.blockWithModelData = true;
}
if (s.equalsIgnoreCase("BLOCK_ALL_WITHOUT_CUSTOM_MODEL_DATA")) {
this.blockWithoutModelData = true;
}
Material mat = Material.matchMaterial(s); Material mat = Material.matchMaterial(s);
if (mat != null) { if (mat != null) {
blockedMats.add(mat); blockedMats.add(mat);
@@ -402,6 +413,12 @@ public class PlayerVaults extends JavaPlugin {
} }
} }
} }
try {
ItemMeta.class.getMethod("hasCustomModelData");
} catch (NoSuchMethodException e) {
this.blockWithModelData = false;
this.blockWithoutModelData = false;
}
File lang = new File(this.getDataFolder(), "lang"); File lang = new File(this.getDataFolder(), "lang");
if (lang.exists()) { if (lang.exists()) {
@@ -560,6 +577,14 @@ public class PlayerVaults extends JavaPlugin {
return blockedMats.contains(mat); return blockedMats.contains(mat);
} }
public boolean isBlockWithModelData() {
return this.blockWithModelData;
}
public boolean isBlockWithoutModelData() {
return this.blockWithoutModelData;
}
/** /**
* Tries to grab the server version as a string. * Tries to grab the server version as a string.
* *
@@ -19,10 +19,7 @@
package com.drtshock.playervaults.commands; package com.drtshock.playervaults.commands;
import com.drtshock.playervaults.PlayerVaults; import com.drtshock.playervaults.PlayerVaults;
import com.drtshock.playervaults.converters.BackpackConverter; import com.drtshock.playervaults.converters.*;
import com.drtshock.playervaults.converters.Converter;
import com.drtshock.playervaults.converters.Cosmic2Converter;
import com.drtshock.playervaults.converters.Cosmic3Converter;
import com.drtshock.playervaults.vaultmanagement.VaultOperations; import com.drtshock.playervaults.vaultmanagement.VaultOperations;
import org.bukkit.command.Command; import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor; import org.bukkit.command.CommandExecutor;
@@ -40,6 +37,7 @@ public class ConvertCommand implements CommandExecutor {
converters.add(new BackpackConverter()); converters.add(new BackpackConverter());
converters.add(new Cosmic2Converter()); converters.add(new Cosmic2Converter());
converters.add(new Cosmic3Converter()); converters.add(new Cosmic3Converter());
converters.add(new EnderVaultsConverter());
this.plugin = plugin; this.plugin = plugin;
} }
@@ -56,7 +56,7 @@ public class DeleteCommand implements CommandExecutor {
} }
OfflinePlayer searchPlayer = Bukkit.getOfflinePlayer(args[0]); OfflinePlayer searchPlayer = Bukkit.getOfflinePlayer(args[0]);
String target = args[0]; String target = args[0];
if (searchPlayer != null && searchPlayer.hasPlayedBefore()) { if (searchPlayer != null) {
target = searchPlayer.getUniqueId().toString(); target = searchPlayer.getUniqueId().toString();
} }
@@ -30,7 +30,10 @@ public class Config {
public class Block { public class Block {
private boolean enabled = true; private boolean enabled = true;
@Comment("Material list for blocked items (does not support ID's), only effective if the feature is enabled.\n" + @Comment("Material list for blocked items (does not support ID's), only effective if the feature is enabled.\n" +
" If you don't know material names: https://hub.spigotmc.org/javadocs/bukkit/org/bukkit/Material.html") " If you don't know material names: https://hub.spigotmc.org/javadocs/bukkit/org/bukkit/Material.html\n" +
"\n" +
"Also, if you add \"BLOCK_ALL_WITH_CUSTOM_MODEL_DATA\" or \"BLOCK_ALL_WITHOUT_CUSTOM_MODEL_DATA\"\n" +
" then either all items with custom model data will be blocked, or all items without custom model data will be blocked.")
private List<String> list = new ArrayList<String>() { private List<String> list = new ArrayList<String>() {
{ {
this.add("PUMPKIN"); this.add("PUMPKIN");
@@ -174,6 +174,8 @@ public class Translation {
private TL locked = TL.of("<error>Vaults are currently locked while conversion occurs. Please try again in a moment!"); private TL locked = TL.of("<error>Vaults are currently locked while conversion occurs. Please try again in a moment!");
private TL help = TL.of("/pv <number>"); private TL help = TL.of("/pv <number>");
private TL blockedItem = TL.of("<gold><item></gold> <error>is blocked from vaults."); private TL blockedItem = TL.of("<gold><item></gold> <error>is blocked from vaults.");
private TL blockedItemWithModelData = TL.of("<error>This item is blocked from vaults.");
private TL blockedItemWithoutModelData = TL.of("<error>This item is blocked from vaults.");
private TL signsDisabled = TL.of("<error>Vault signs are currently disabled."); private TL signsDisabled = TL.of("<error>Vault signs are currently disabled.");
private TL blockedBadItem = TL.of("<error>This item is not allowed in a vault."); private TL blockedBadItem = TL.of("<error>This item is not allowed in a vault.");
} }
@@ -306,6 +308,14 @@ public class Translation {
return this.translations.blockedItem; return this.translations.blockedItem;
} }
public @NonNull TL blockedItemWithModelData() {
return this.translations.blockedItemWithModelData;
}
public @NonNull TL blockedItemWithoutModelData() {
return this.translations.blockedItemWithoutModelData;
}
public @NonNull TL signsDisabled() { public @NonNull TL signsDisabled() {
return this.translations.signsDisabled; return this.translations.signsDisabled;
} }
@@ -0,0 +1,127 @@
/*
* PlayerVaultsX
* Copyright (C) 2013 Trent Hensler, turt2live
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package com.drtshock.playervaults.converters;
import com.drtshock.playervaults.PlayerVaults;
import com.drtshock.playervaults.vaultmanagement.VaultManager;
import org.bukkit.command.CommandSender;
import org.bukkit.inventory.Inventory;
import org.bukkit.plugin.Plugin;
import java.io.IOException;
import java.lang.invoke.MethodHandle;
import java.lang.invoke.MethodHandles;
import java.lang.invoke.MethodType;
import java.nio.file.Files;
import java.nio.file.Path;
import java.util.List;
import java.util.Map;
import java.util.UUID;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.logging.Level;
import java.util.stream.Stream;
public class EnderVaultsConverter implements Converter {
@SuppressWarnings("unchecked")
@Override
public int run(CommandSender initiator) {
PlayerVaults plugin = PlayerVaults.getInstance();
VaultManager vaultManager = VaultManager.getInstance();
Path path = plugin.getDataFolder().toPath().getParent().resolve("EnderVaults").resolve("data");
if (!Files.isDirectory(path)) {
plugin.getLogger().warning("Could not find EnderVaults data folder");
return -1;
}
MethodHandle load;
MethodHandle getInventory;
MethodHandle getMetadata;
Plugin enderVaultsPlugin = plugin.getServer().getPluginManager().getPlugin("EnderVaults");
Object dataStorage;
if (enderVaultsPlugin == null) {
plugin.getLogger().warning("EnderVaults not running. Need it to convert.");
return -1;
}
try {
Class<?> pluginClass = Class.forName("com.github.dig.endervaults.api.EnderVaultsPlugin");
Class<?> dataStorageClass = Class.forName("com.github.dig.endervaults.api.storage.DataStorage");
Class<?> bukkitVaultClass = Class.forName("com.github.dig.endervaults.bukkit.vault.BukkitVault");
MethodHandles.Lookup lookup = MethodHandles.publicLookup();
MethodType typeGetDataStorage = MethodType.methodType(dataStorageClass);
MethodHandle getDataStorage = lookup.findVirtual(pluginClass, "getDataStorage", typeGetDataStorage);
dataStorage = getDataStorage.invoke(enderVaultsPlugin);
MethodType typeLoad = MethodType.methodType(List.class, UUID.class);
load = lookup.findVirtual(dataStorageClass, "load", typeLoad);
MethodType typeGetInventory = MethodType.methodType(Inventory.class);
getInventory = lookup.findVirtual(bukkitVaultClass, "getInventory", typeGetInventory);
MethodType typeGetMetadata = MethodType.methodType(Map.class);
getMetadata = lookup.findVirtual(bukkitVaultClass, "getMetadata", typeGetMetadata);
if (!pluginClass.isAssignableFrom(enderVaultsPlugin.getClass())) {
plugin.getLogger().warning("EnderVaults plugin not of expected type");
return -1;
}
} catch (Throwable e) {
e.printStackTrace();
return -1;
}
AtomicInteger playerCount = new AtomicInteger(0);
try (Stream<Path> dir = Files.list(path)) {
dir.forEach(f -> {
if (!Files.isDirectory(f)) {
return;
}
try {
List<Object> list = (List<Object>) load.invoke(dataStorage, UUID.fromString(f.getFileName().toString()));
for (Object vault : list) {
Inventory inventory = (Inventory) getInventory.invoke(vault);
Map<String, Object> meta = (Map<String, Object>) getMetadata.invoke(vault);
Integer order = (Integer) meta.get("order");
vaultManager.saveVault(inventory, f.getFileName().toString(), order);
}
} catch (Throwable e) {
e.printStackTrace();
return;
}
playerCount.incrementAndGet();
});
} catch (IOException e) {
plugin.getLogger().log(Level.SEVERE, "Failed. ", e);
}
return playerCount.get();
}
@Override
public boolean canConvert() {
return Files.isDirectory(PlayerVaults.getInstance().getDataFolder().toPath().getParent().resolve("EnderVaults").resolve("data"));
}
@Override
public String getName() {
return "EnderVaults";
}
}
@@ -135,10 +135,22 @@ public class Listeners implements Listener {
if (item == null) { if (item == null) {
continue; continue;
} }
if (!player.hasPermission("playervaults.bypassblockeditems") && PlayerVaults.getInstance().isBlockedMaterial(item.getType())) { if (!player.hasPermission("playervaults.bypassblockeditems")) {
event.setCancelled(true); if (PlayerVaults.getInstance().isBlockWithModelData() && item.hasItemMeta() && item.getItemMeta().hasCustomModelData()) {
this.plugin.getTL().blockedItem().title().with("item", item.getType().name()).send(player); event.setCancelled(true);
return; this.plugin.getTL().blockedItemWithModelData().title().send(player);
return;
}
if (PlayerVaults.getInstance().isBlockWithoutModelData() && (!item.hasItemMeta() || !item.getItemMeta().hasCustomModelData())) {
event.setCancelled(true);
this.plugin.getTL().blockedItemWithoutModelData().title().send(player);
return;
}
if (PlayerVaults.getInstance().isBlockedMaterial(item.getType())) {
event.setCancelled(true);
this.plugin.getTL().blockedItem().title().with("item", item.getType().name()).send(player);
return;
}
} }
} }
} }