diff --git a/src/main/java/com/craftaro/skyblock/island/Island.java b/src/main/java/com/craftaro/skyblock/island/Island.java index 5b47886b..6b7a6145 100644 --- a/src/main/java/com/craftaro/skyblock/island/Island.java +++ b/src/main/java/com/craftaro/skyblock/island/Island.java @@ -61,6 +61,7 @@ public class Island { private final List islandLocations = new ArrayList<>(); private final Map coopPlayers = new HashMap<>(); private final Set whitelistedPlayers = new HashSet<>(); + private final Map> roleCache = new HashMap<>(); private UUID islandUUID; private UUID ownerUUID; @@ -599,6 +600,11 @@ public boolean isAlwaysLoaded() { } public Set getRole(IslandRole role) { + + if (roleCache.containsKey(role)) { + return new HashSet<>(roleCache.get(role)); // Return a copy to avoid external modification + } + Set islandRoles = new HashSet<>(); if (role == IslandRole.OWNER) { @@ -615,6 +621,8 @@ public Set getRole(IslandRole role) { } } + roleCache.put(role, islandRoles); + return islandRoles; } @@ -673,6 +681,9 @@ public boolean setRole(IslandRole role, UUID uuid) { getVisit().setMembers(getRole(IslandRole.MEMBER).size() + getRole(IslandRole.OPERATOR).size() + 1); + //Update role cache + roleCache.remove(role); + return true; } } @@ -699,6 +710,9 @@ public boolean removeRole(IslandRole role, UUID uuid) { getVisit().setMembers(getRole(IslandRole.MEMBER).size() + getRole(IslandRole.OPERATOR).size() + 1); + //Update role cache + roleCache.remove(role); + return true; } } diff --git a/src/main/java/com/craftaro/skyblock/listeners/InteractListeners.java b/src/main/java/com/craftaro/skyblock/listeners/InteractListeners.java index 3b4185e4..1bc84464 100644 --- a/src/main/java/com/craftaro/skyblock/listeners/InteractListeners.java +++ b/src/main/java/com/craftaro/skyblock/listeners/InteractListeners.java @@ -170,13 +170,13 @@ public void onPlayerInteract(PlayerInteractEvent event) { return; } - Optional material = block == null ? Optional.empty() : CompatibleMaterial.getMaterial(block.getType()); - // Check permissions. if (!this.plugin.getPermissionManager().processPermission(event, player, island)) { return; } + Optional material = block == null ? Optional.empty() : CompatibleMaterial.getMaterial(block.getType()); + if (event.getAction() == Action.RIGHT_CLICK_BLOCK) { final Optional blockType = CompatibleMaterial.getMaterial(event.getClickedBlock().getType()); final XMaterial heldType;