diff --git a/.idea/sonarlint/issuestore/index.pb b/.idea/sonarlint/issuestore/index.pb index d2025d0b..3a0458de 100644 --- a/.idea/sonarlint/issuestore/index.pb +++ b/.idea/sonarlint/issuestore/index.pb @@ -254,8 +254,6 @@ Qplugin/src/main/java/fr/euphyllia/skyllia/commands/admin/SkylliaAdminCommand.ja `plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/ForceDeleteSubCommands.java,7\2\727e6d67f400abf86622d6106203b3ccd1d4bc6d ‰ Yplugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/InfoSubCommands.java,c\1\c1e1ca091770cc424010513927dc179fe31e08d0 -’ -bplugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/SetIslandTypeSubCommands.java,c\d\cd75695c3fc5a7cc5a765babc6bd76ad7fc4feba Ś \plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/SetSizeSubCommands.java,2\9\2954e867fe2081323790b93dc6a674cfc6ac0038 ~ @@ -273,4 +271,8 @@ Zplugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/player/Interac Š Zplugin/src/main/java/fr/euphyllia/skyllia/commands/common/subcommands/TrustSubCommand.java,e\4\e484294215b6b1915a99474a764bdd9bfcbeb28f Ś -\plugin/src/main/java/fr/euphyllia/skyllia/commands/common/subcommands/UntrustSubCommand.java,c\f\cf34801432bb459b2127111f7623b8d59c138a73 \ No newline at end of file +\plugin/src/main/java/fr/euphyllia/skyllia/commands/common/subcommands/UntrustSubCommand.java,c\f\cf34801432bb459b2127111f7623b8d59c138a73 +’ +bplugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/SetMaxMembersSubCommands.java,e\6\e6f3fa7cab6d0c1142b07d696d4b3461d44ee011 +} +Mapi/src/main/java/fr/euphyllia/skyllia/api/event/SkyblockChangeSizeEvent.java,e\3\e3286fee0eae04df37bf16f88040ef2a0511d02a \ No newline at end of file diff --git a/.idea/sonarlint/securityhotspotstore/index.pb b/.idea/sonarlint/securityhotspotstore/index.pb index d2025d0b..3a0458de 100644 --- a/.idea/sonarlint/securityhotspotstore/index.pb +++ b/.idea/sonarlint/securityhotspotstore/index.pb @@ -254,8 +254,6 @@ Qplugin/src/main/java/fr/euphyllia/skyllia/commands/admin/SkylliaAdminCommand.ja `plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/ForceDeleteSubCommands.java,7\2\727e6d67f400abf86622d6106203b3ccd1d4bc6d ‰ Yplugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/InfoSubCommands.java,c\1\c1e1ca091770cc424010513927dc179fe31e08d0 -’ -bplugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/SetIslandTypeSubCommands.java,c\d\cd75695c3fc5a7cc5a765babc6bd76ad7fc4feba Ś \plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/SetSizeSubCommands.java,2\9\2954e867fe2081323790b93dc6a674cfc6ac0038 ~ @@ -273,4 +271,8 @@ Zplugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/player/Interac Š Zplugin/src/main/java/fr/euphyllia/skyllia/commands/common/subcommands/TrustSubCommand.java,e\4\e484294215b6b1915a99474a764bdd9bfcbeb28f Ś -\plugin/src/main/java/fr/euphyllia/skyllia/commands/common/subcommands/UntrustSubCommand.java,c\f\cf34801432bb459b2127111f7623b8d59c138a73 \ No newline at end of file +\plugin/src/main/java/fr/euphyllia/skyllia/commands/common/subcommands/UntrustSubCommand.java,c\f\cf34801432bb459b2127111f7623b8d59c138a73 +’ +bplugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/SetMaxMembersSubCommands.java,e\6\e6f3fa7cab6d0c1142b07d696d4b3461d44ee011 +} +Mapi/src/main/java/fr/euphyllia/skyllia/api/event/SkyblockChangeSizeEvent.java,e\3\e3286fee0eae04df37bf16f88040ef2a0511d02a \ No newline at end of file diff --git a/api/build.gradle.kts b/api/build.gradle.kts index f4b5c271..07a9ba53 100644 --- a/api/build.gradle.kts +++ b/api/build.gradle.kts @@ -7,7 +7,7 @@ dependencies { } group = "fr.euphyllia.skyllia"; -version = "1.0-RC1"; +version = "1.0-RC2"; publishing { repositories { diff --git a/api/src/main/java/fr/euphyllia/skyllia/api/event/SkyblockChangeSizeEvent.java b/api/src/main/java/fr/euphyllia/skyllia/api/event/SkyblockChangeSizeEvent.java new file mode 100644 index 00000000..ed9b42bd --- /dev/null +++ b/api/src/main/java/fr/euphyllia/skyllia/api/event/SkyblockChangeSizeEvent.java @@ -0,0 +1,39 @@ +package fr.euphyllia.skyllia.api.event; + +import fr.euphyllia.skyllia.api.skyblock.Island; +import org.bukkit.event.Event; +import org.bukkit.event.HandlerList; +import org.jetbrains.annotations.NotNull; + +public class SkyblockChangeSizeEvent extends Event { + + + private static final HandlerList handlerList = new HandlerList(); + private final Island island; + private final double sizeIsland; + + public SkyblockChangeSizeEvent(Island island, double rayon) { + super(true); + this.island = island; + this.sizeIsland = rayon; + } + + + public static HandlerList getHandlerList() { + return handlerList; + } + + @Override + public @NotNull HandlerList getHandlers() { + return getHandlerList(); + } + + public Island getIsland() { + return this.island; + } + + public double getSizeIsland() { + return this.sizeIsland; + } +} + diff --git a/api/src/main/java/fr/euphyllia/skyllia/api/skyblock/Island.java b/api/src/main/java/fr/euphyllia/skyllia/api/skyblock/Island.java index ac9b6406..04616120 100644 --- a/api/src/main/java/fr/euphyllia/skyllia/api/skyblock/Island.java +++ b/api/src/main/java/fr/euphyllia/skyllia/api/skyblock/Island.java @@ -20,7 +20,7 @@ public abstract class Island { public abstract double getSize(); - public abstract void setSize(double rayon) throws MaxIslandSizeExceedException; + public abstract boolean setSize(double rayon) throws MaxIslandSizeExceedException; public abstract @Nullable CopyOnWriteArrayList getWarps(); diff --git a/build.gradle.kts b/build.gradle.kts index 8ad416fa..1b02ee81 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -6,7 +6,7 @@ plugins { } group = "fr.euphyllia"; -version = "1.0-RC1"; +version = "1.0-RC2"; description = "Plugin Skyblock pour Folia / PaperMC"; val paperRepo = "https://repo.papermc.io/repository/maven-public/"; diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/Main.java b/plugin/src/main/java/fr/euphyllia/skyllia/Main.java index 8487381e..429f8a02 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/Main.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/Main.java @@ -66,6 +66,7 @@ public void onEnable() { this.interneAPI.setManagers(new Managers(interneAPI)); this.interneAPI.getManagers().init(); this.setupCommands(); + this.setupAdminCommands(); this.loadListener(); this.runCache(); this.disabledConfig(); diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/cache/CacheManager.java b/plugin/src/main/java/fr/euphyllia/skyllia/cache/CacheManager.java index 2209f0ae..2779d514 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/cache/CacheManager.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/cache/CacheManager.java @@ -5,13 +5,16 @@ import fr.euphyllia.skyllia.api.skyblock.Island; import fr.euphyllia.skyllia.api.skyblock.Players; import fr.euphyllia.skyllia.api.skyblock.model.PermissionRoleIsland; +import fr.euphyllia.skyllia.api.skyblock.model.Position; import fr.euphyllia.skyllia.api.skyblock.model.RoleType; import fr.euphyllia.skyllia.api.skyblock.model.permissions.PermissionsType; import fr.euphyllia.skyllia.managers.skyblock.SkyblockManager; +import fr.euphyllia.skyllia.utils.RegionUtils; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.bukkit.entity.Player; +import java.util.List; import java.util.UUID; import java.util.concurrent.Executors; @@ -45,7 +48,10 @@ public void deleteCacheIsland(Island island) { PlayersInIslandCache.delete(island.getId()); // ============= position island cache - PositionIslandCache.delete(island.getPosition()); + List islandPositionWithRadius = RegionUtils.getRegionsInRadius(island.getPosition(), (int) Math.round(island.getSize())); + for (Position possiblePosition : islandPositionWithRadius) { + PositionIslandCache.delete(possiblePosition); + } // ============= permission role cache for (RoleType roleType : RoleType.values()) { for (PermissionsType permissionsType : PermissionsType.values()) { @@ -61,7 +67,10 @@ public void updateCacheIsland(Island island, UUID playerId) { PlayersInIslandCache.getIslandIdByPlayerId().put(playerId, island.getId()); PlayersInIslandCache.add(island.getId(), island.getMembers()); // ============= position island cache - PositionIslandCache.add(island.getPosition(), island); + List islandPositionWithRadius = RegionUtils.getRegionsInRadius(island.getPosition(), (int) Math.round(island.getSize())); + for (Position possiblePosition : islandPositionWithRadius) { + PositionIslandCache.add(possiblePosition, island); + } // ============= permission role cache this.updatePermissionCacheIsland(island); }); diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/SubAdminCommands.java b/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/SubAdminCommands.java index 49f26ff2..4c3264d6 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/SubAdminCommands.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/SubAdminCommands.java @@ -2,13 +2,13 @@ import fr.euphyllia.skyllia.commands.SubCommandInterface; import fr.euphyllia.skyllia.commands.admin.subcommands.ForceDeleteSubCommands; -import fr.euphyllia.skyllia.commands.admin.subcommands.InfoSubCommands; +import fr.euphyllia.skyllia.commands.admin.subcommands.SetMaxMembersSubCommands; import fr.euphyllia.skyllia.commands.admin.subcommands.SetSizeSubCommands; import org.jetbrains.annotations.NotNull; public enum SubAdminCommands { FORCEDELETE(new ForceDeleteSubCommands()), - INFO(new InfoSubCommands()), + SETMAXMEMBERS(new SetMaxMembersSubCommands()), SETSIZE(new SetSizeSubCommands()), ; diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/ForceDeleteSubCommands.java b/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/ForceDeleteSubCommands.java index 5b812189..2d6231fe 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/ForceDeleteSubCommands.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/ForceDeleteSubCommands.java @@ -47,7 +47,7 @@ public boolean onCommand(@NotNull Main plugin, @NotNull CommandSender sender, @N } String playerName = args[0]; String confirm = args[1]; - if (confirm.equalsIgnoreCase("confirm")) { + if (!confirm.equalsIgnoreCase("confirm")) { LanguageToml.sendMessage(plugin, player, LanguageToml.messageADeleteNotConfirmedArgs); return true; } diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/InfoSubCommands.java b/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/InfoSubCommands.java deleted file mode 100644 index 830b9092..00000000 --- a/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/InfoSubCommands.java +++ /dev/null @@ -1,22 +0,0 @@ -package fr.euphyllia.skyllia.commands.admin.subcommands; - -import fr.euphyllia.skyllia.Main; -import fr.euphyllia.skyllia.commands.SubCommandInterface; -import org.bukkit.command.Command; -import org.bukkit.command.CommandSender; -import org.jetbrains.annotations.NotNull; -import org.jetbrains.annotations.Nullable; - -import java.util.List; - -public class InfoSubCommands implements SubCommandInterface { - @Override - public boolean onCommand(@NotNull Main plugin, @NotNull CommandSender sender, @NotNull Command command, @NotNull String label, @NotNull String[] args) { - return false; - } - - @Override - public @Nullable List onTabComplete(@NotNull Main plugin, @NotNull CommandSender sender, @NotNull Command command, @NotNull String label, @NotNull String[] args) { - return null; - } -} diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/SetMaxMembersSubCommands.java b/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/SetMaxMembersSubCommands.java new file mode 100644 index 00000000..13400ff5 --- /dev/null +++ b/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/SetMaxMembersSubCommands.java @@ -0,0 +1,92 @@ +package fr.euphyllia.skyllia.commands.admin.subcommands; + +import fr.euphyllia.skyllia.Main; +import fr.euphyllia.skyllia.api.skyblock.Island; +import fr.euphyllia.skyllia.commands.SubCommandInterface; +import fr.euphyllia.skyllia.configuration.LanguageToml; +import fr.euphyllia.skyllia.managers.skyblock.SkyblockManager; +import org.apache.logging.log4j.Level; +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; +import org.bukkit.Bukkit; +import org.bukkit.command.Command; +import org.bukkit.command.CommandSender; +import org.bukkit.entity.Player; +import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.Nullable; + +import java.util.List; +import java.util.UUID; +import java.util.concurrent.Executors; +import java.util.concurrent.ScheduledExecutorService; + +public class SetMaxMembersSubCommands implements SubCommandInterface { + + private final Logger logger = LogManager.getLogger(SetMaxMembersSubCommands.class); + + @Override + public boolean onCommand(@NotNull Main plugin, @NotNull CommandSender sender, @NotNull Command command, @NotNull String label, @NotNull String[] args) { + if (!(sender instanceof Player player)) { + return true; + } + if (!player.hasPermission("skyllia.admins.commands.island.setmaxmembers")) { + LanguageToml.sendMessage(plugin, player, LanguageToml.messagePlayerPermissionDenied); + return true; + } + + if (args.length < 3) { + LanguageToml.sendMessage(plugin, player, LanguageToml.messageASetMaxMembersCommandNotEnoughArgs); + return true; + } + String playerName = args[0]; + String changeValue = args[1]; + String confirm = args[2]; + if (!confirm.equalsIgnoreCase("confirm")) { + LanguageToml.sendMessage(plugin, player, LanguageToml.messageASetMaxMembersNotConfirmedArgs); + return true; + } + ScheduledExecutorService executor = Executors.newSingleThreadScheduledExecutor(); + try { + executor.execute(() -> { + try { + UUID playerId; + try { + playerId = UUID.fromString(playerName); + } catch (IllegalArgumentException ignored) { + playerId = Bukkit.getPlayerUniqueId(playerName); + } + SkyblockManager skyblockManager = plugin.getInterneAPI().getSkyblockManager(); + Island island = skyblockManager.getIslandByOwner(playerId).join(); + if (island == null) { + LanguageToml.sendMessage(plugin, player, LanguageToml.messagePlayerHasNotIsland); + return; + } + + int members = Integer.parseInt(changeValue); + boolean updated = island.setMaxMembers(members); + if (updated) { + LanguageToml.sendMessage(plugin, player, LanguageToml.messageASetSizeSuccess); + } else { + LanguageToml.sendMessage(plugin, player, LanguageToml.messageASetSizeFailed); + } + + } catch (Exception e) { + if (e instanceof NumberFormatException ignored) { + LanguageToml.sendMessage(plugin, player, LanguageToml.messageASetMaxMembersNAN); + } else { + logger.log(Level.FATAL, e.getMessage(), e); + LanguageToml.sendMessage(plugin, player, LanguageToml.messageError); + } + } + }); + } finally { + executor.shutdown(); + } + return true; + } + + @Override + public @Nullable List onTabComplete(@NotNull Main plugin, @NotNull CommandSender sender, @NotNull Command command, @NotNull String label, @NotNull String[] args) { + return null; + } +} diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/SetSizeSubCommands.java b/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/SetSizeSubCommands.java index bede924a..e668785c 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/SetSizeSubCommands.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/commands/admin/subcommands/SetSizeSubCommands.java @@ -15,6 +15,7 @@ import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; +import java.util.Arrays; import java.util.List; import java.util.UUID; import java.util.concurrent.Executors; @@ -41,7 +42,8 @@ public boolean onCommand(@NotNull Main plugin, @NotNull CommandSender sender, @N String playerName = args[0]; String changeValue = args[1]; String confirm = args[2]; - if (confirm.equalsIgnoreCase("confirm")) { + System.out.println(Arrays.toString(args)); + if (!confirm.equalsIgnoreCase("confirm")) { LanguageToml.sendMessage(plugin, player, LanguageToml.messageASetSizeNotConfirmedArgs); return true; } @@ -62,8 +64,8 @@ public boolean onCommand(@NotNull Main plugin, @NotNull CommandSender sender, @N return; } - int members = Integer.parseInt(changeValue); - boolean updated = island.setMaxMembers(members); + double newSize = Double.parseDouble(changeValue); + boolean updated = island.setSize(newSize); if (updated) { LanguageToml.sendMessage(plugin, player, LanguageToml.messageASetSizeSuccess); } else { diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/commands/common/subcommands/VisitSubCommand.java b/plugin/src/main/java/fr/euphyllia/skyllia/commands/common/subcommands/VisitSubCommand.java index f5eb39e1..51e875e5 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/commands/common/subcommands/VisitSubCommand.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/commands/common/subcommands/VisitSubCommand.java @@ -50,7 +50,12 @@ public boolean onCommand(@NotNull Main plugin, @NotNull CommandSender sender, @N executor.execute(() -> { try { String visitPlayer = args[0]; - UUID visitPlayerId = Bukkit.getPlayerUniqueId(visitPlayer); + UUID visitPlayerId; + try { + visitPlayerId = UUID.fromString(visitPlayer); + } catch (IllegalArgumentException ignored) { + visitPlayerId = Bukkit.getPlayerUniqueId(visitPlayer); + } if (visitPlayerId == null) { LanguageToml.sendMessage(plugin, player, LanguageToml.messagePlayerNotFound); return; diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/configuration/LanguageToml.java b/plugin/src/main/java/fr/euphyllia/skyllia/configuration/LanguageToml.java index 97fd12a9..156a66d6 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/configuration/LanguageToml.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/configuration/LanguageToml.java @@ -113,6 +113,9 @@ public class LanguageToml { public static String messageUntrustFailed = "Une erreur s'est produite lors de la suppression de la personne dans votre liste de confiance. Etait-il bien en confiance sur votre Ă®le ?"; public static String messageUntrustSuccess = "Le membre ne fait dorĂ©navant plus partie de vos confiances"; public static String messageUntrustCommandNotEnoughArgs = "La commande est incomplète : /skyllia untrust "; + public static String messageASetMaxMembersCommandNotEnoughArgs = "La commande est incomplète : /skyllia setmaxmembres value confirm"; + public static String messageASetMaxMembersNotConfirmedArgs = "Vous n'avez pas ajouter le \"confirm\" Ă  la fin"; + public static String messageASetMaxMembersNAN = "Le nombre indiquĂ© est incorrect."; private static boolean verbose; public static void init(File configFile) { @@ -189,6 +192,10 @@ private static void adminLanguage() { messageASetSizeFailed = getString("admin.commands.island.setsize.failed", messageASetSizeFailed); messageASetSizeNAN = getString("admin.commands.island.setsize.nan", messageASetSizeNAN); messageASetSizeNotConfirmedArgs = getString("admin.commands.island.setsize.no-confirm", messageASetSizeNotConfirmedArgs); + // setSize + messageASetMaxMembersCommandNotEnoughArgs = getString("admin.commands.island.setmaxmembers.not-enough-args", messageASetMaxMembersCommandNotEnoughArgs); + messageASetMaxMembersNotConfirmedArgs = getString("admin.commands.island.setmaxmembers.no-confirm", messageASetMaxMembersNotConfirmedArgs); + messageASetMaxMembersNAN = getString("admin.commands.island.setmaxmembers.nan", messageASetMaxMembersNAN); } diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/database/query/exec/IslandUpdateQuery.java b/plugin/src/main/java/fr/euphyllia/skyllia/database/query/exec/IslandUpdateQuery.java index 7241ce4c..cac17e05 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/database/query/exec/IslandUpdateQuery.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/database/query/exec/IslandUpdateQuery.java @@ -22,12 +22,18 @@ public class IslandUpdateQuery { WHERE `island_id` = ?; """; - private static final String UPDATE_SIZE_ISLAND = """ + private static final String UPDATE_MEMBERS_ISLAND = """ UPDATE `%s`.islands SET `max_members` = ? WHERE `island_id` = ?; """; + private static final String UPDATE_SIZE_ISLAND = """ + UPDATE `%s`.islands + SET `size` = ? + WHERE `island_id` = ?; + """; + private static final String SELECT_PRIVATE_ISLAND = """ SELECT `private` FROM `%s`.islands @@ -102,10 +108,22 @@ public CompletableFuture isPrivateIsland(Island island) { } public CompletableFuture setMaxMemberInIsland(Island island, int newValue) { + CompletableFuture completableFuture = new CompletableFuture<>(); + try { + MariaDBExecute.executeQueryDML(this.api.getDatabaseLoader(), UPDATE_MEMBERS_ISLAND.formatted(this.databaseName), List.of( + newValue, island.getId() + ), i -> completableFuture.complete(i != 0), null); + } catch (Exception e) { + completableFuture.complete(false); + } + return completableFuture; + } + + public CompletableFuture setSizeIsland(Island island, double newValue) { CompletableFuture completableFuture = new CompletableFuture<>(); try { MariaDBExecute.executeQueryDML(this.api.getDatabaseLoader(), UPDATE_SIZE_ISLAND.formatted(this.databaseName), List.of( - island.getId(), newValue + newValue, island.getId() ), i -> completableFuture.complete(i != 0), null); } catch (Exception e) { completableFuture.complete(false); diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/listeners/ListenersUtils.java b/plugin/src/main/java/fr/euphyllia/skyllia/listeners/ListenersUtils.java index 347eec45..51ee1ed8 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/listeners/ListenersUtils.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/listeners/ListenersUtils.java @@ -13,13 +13,16 @@ import fr.euphyllia.skyllia.utils.RegionUtils; import fr.euphyllia.skyllia.utils.WorldUtils; import org.bukkit.Chunk; +import org.bukkit.Location; import org.bukkit.entity.Player; import org.bukkit.event.Cancellable; import org.jetbrains.annotations.Nullable; public class ListenersUtils { - public static @Nullable Island checkPermission(Chunk chunk, Player player, Permissions permissionsIsland, Cancellable cancellable) { + + public static @Nullable Island checkPermission(Location location, Player player, Permissions permissionsIsland, Cancellable cancellable) { + Chunk chunk = location.getChunk(); if (Boolean.FALSE.equals(WorldUtils.isWorldSkyblock(chunk.getWorld().getName()))) { return null; } @@ -29,6 +32,11 @@ public class ListenersUtils { cancellable.setCancelled(true); // SĂ©curitĂ© ! return null; } + Position islandOriginPosition = island.getPosition(); + if (!RegionUtils.isBlockWithinRadius(RegionUtils.getCenterRegion(chunk.getWorld(), islandOriginPosition.x(), islandOriginPosition.z()), location.getBlockX(), location.getBlockZ(), (int) island.getSize())) { + cancellable.setCancelled(true); // ce n'est pas une ile. + return island; + } Players players = PlayersInIslandCache.getPlayers(island.getId(), player.getUniqueId()); if (players.getRoleType().equals(RoleType.OWNER)) return island; if (players.getRoleType().equals(RoleType.BAN)) { diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/BlockEvent.java b/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/BlockEvent.java index 9f85aa38..98961325 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/BlockEvent.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/BlockEvent.java @@ -23,12 +23,12 @@ public BlockEvent(InterneAPI interneAPI) { @EventHandler(priority = EventPriority.HIGHEST) public void onBlockBreakOnIsland(final BlockBreakEvent event) { if (event.isCancelled()) return; - ListenersUtils.checkPermission(event.getBlock().getChunk(), event.getPlayer(), PermissionsIsland.BLOCK_BREAK, event); + ListenersUtils.checkPermission(event.getBlock().getLocation(), event.getPlayer(), PermissionsIsland.BLOCK_BREAK, event); } @EventHandler(priority = EventPriority.HIGHEST) public void onBlockPlaceOnIsland(final BlockPlaceEvent event) { if (event.isCancelled()) return; - ListenersUtils.checkPermission(event.getBlock().getChunk(), event.getPlayer(), PermissionsIsland.BLOCK_PLACE, event); + ListenersUtils.checkPermission(event.getBlock().getLocation(), event.getPlayer(), PermissionsIsland.BLOCK_PLACE, event); } } diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/entity/DamageEvent.java b/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/entity/DamageEvent.java index 3394b670..0e03fa2d 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/entity/DamageEvent.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/entity/DamageEvent.java @@ -34,16 +34,16 @@ public void onPlayerDamageEntity(final EntityDamageByEntityEvent event) { return; } if (event.getEntity() instanceof Player) { - ListenersUtils.checkPermission(event.getEntity().getChunk(), damager, PermissionsIsland.PVP, event); + ListenersUtils.checkPermission(event.getEntity().getLocation(), damager, PermissionsIsland.PVP, event); } else { if (event.getEntity() instanceof Monster) { - ListenersUtils.checkPermission(event.getEntity().getChunk(), damager, PermissionsIsland.KILL_MONSTER, event); + ListenersUtils.checkPermission(event.getEntity().getLocation(), damager, PermissionsIsland.KILL_MONSTER, event); } else if (event.getEntity() instanceof Animals) { - ListenersUtils.checkPermission(event.getEntity().getChunk(), damager, PermissionsIsland.KILL_ANIMAL, event); + ListenersUtils.checkPermission(event.getEntity().getLocation(), damager, PermissionsIsland.KILL_ANIMAL, event); } else if (event.getEntity() instanceof NPC) { - ListenersUtils.checkPermission(event.getEntity().getChunk(), damager, PermissionsIsland.KILL_NPC, event); + ListenersUtils.checkPermission(event.getEntity().getLocation(), damager, PermissionsIsland.KILL_NPC, event); } else { - ListenersUtils.checkPermission(event.getEntity().getChunk(), damager, PermissionsIsland.KILL_UNKNOWN_ENTITY, event); + ListenersUtils.checkPermission(event.getEntity().getLocation(), damager, PermissionsIsland.KILL_UNKNOWN_ENTITY, event); } } } diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/player/InteractEvent.java b/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/player/InteractEvent.java index 72f3ca99..de543af8 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/player/InteractEvent.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/player/InteractEvent.java @@ -31,7 +31,7 @@ public void onPlayerInteractEvent(final PlayerInteractEvent event) { if (player.hasPermission("skyllia.interact.bypass")) { return; } - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsIsland.INTERACT, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsIsland.INTERACT, event); } @EventHandler(priority = EventPriority.HIGHEST) @@ -42,7 +42,7 @@ public void onPlayerInteractEntitiesEvent(final PlayerInteractEntityEvent event) if (player.hasPermission("skyllia.interact_entity.bypass")) { return; } - ListenersUtils.checkPermission(event.getRightClicked().getChunk(), player, PermissionsIsland.INTERACT_ENTITIES, event); + ListenersUtils.checkPermission(event.getRightClicked().getLocation(), player, PermissionsIsland.INTERACT_ENTITIES, event); } @EventHandler(priority = EventPriority.HIGHEST) @@ -53,7 +53,7 @@ public void onPlayerInteractEntitiesEvent(final PlayerInteractAtEntityEvent even if (player.hasPermission("skyllia.interact_entity.bypass")) { return; } - ListenersUtils.checkPermission(event.getRightClicked().getChunk(), player, PermissionsIsland.INTERACT_ENTITIES, event); + ListenersUtils.checkPermission(event.getRightClicked().getLocation(), player, PermissionsIsland.INTERACT_ENTITIES, event); } } diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/player/InventoryEvent.java b/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/player/InventoryEvent.java index 347fe3e1..7d3cbda4 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/player/InventoryEvent.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/player/InventoryEvent.java @@ -27,75 +27,75 @@ public void onInventoryOpen(final InventoryOpenEvent event) { InventoryType inventoryType = event.getInventory().getType(); switch (inventoryType) { case CHEST -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_CHEST, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_CHEST, event); } case DISPENSER -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_DISPENSER, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_DISPENSER, event); } case DROPPER -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_DROPPER, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_DROPPER, event); } case FURNACE -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_FURNACE, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_FURNACE, event); } case WORKBENCH -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_WORKBENCH, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_WORKBENCH, event); } case ENCHANTING -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_ENCHANTING, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_ENCHANTING, event); } case BREWING -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_BREWING, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_BREWING, event); } case MERCHANT -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_MERCHANT, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_MERCHANT, event); } case ANVIL -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_ANVIL, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_ANVIL, event); } case SMITHING -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_SMITHING, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_SMITHING, event); } case BEACON -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_BEACON, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_BEACON, event); } case HOPPER -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_HOPPER, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_HOPPER, event); } case SHULKER_BOX -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_SHULKER_BOX, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_SHULKER_BOX, event); } case BARREL -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_BARREL, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_BARREL, event); } case BLAST_FURNACE -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_BLAST_FURNACE, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_BLAST_FURNACE, event); } case LECTERN -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_LECTERN, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_LECTERN, event); } case SMOKER -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_SMOKER, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_SMOKER, event); } case LOOM -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_LOOM, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_LOOM, event); } case CARTOGRAPHY -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_CARTOGRAPHY, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_CARTOGRAPHY, event); } case GRINDSTONE -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_GRINDSTONE, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_GRINDSTONE, event); } case STONECUTTER -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_STONECUTTER, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_STONECUTTER, event); } case SMITHING_NEW -> { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_SMITHING_NEW, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_SMITHING_NEW, event); } default -> { // TODO sera remplace plus tard if (inventoryType.name().equalsIgnoreCase("CRAFTER")) { - ListenersUtils.checkPermission(player.getChunk(), player, PermissionsInventory.OPEN_CRAFTER, event); + ListenersUtils.checkPermission(player.getLocation(), player, PermissionsInventory.OPEN_CRAFTER, event); } } } diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/player/PlayerEvent.java b/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/player/PlayerEvent.java index 80425c9b..ba580239 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/player/PlayerEvent.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/listeners/bukkitevents/player/PlayerEvent.java @@ -33,20 +33,20 @@ public void onBucketFillEvent(PlayerBucketFillEvent event) { public void onPlayerUseBucket(final PlayerBucketEvent event) { if (event.isCancelled()) return; - ListenersUtils.checkPermission(event.getBlock().getChunk(), event.getPlayer(), PermissionsIsland.BUCKETS, event); + ListenersUtils.checkPermission(event.getBlock().getLocation(), event.getPlayer(), PermissionsIsland.BUCKETS, event); } @EventHandler(priority = EventPriority.HIGHEST) public void onPlayerDropItem(final PlayerDropItemEvent event) { if (event.isCancelled()) return; - ListenersUtils.checkPermission(event.getItemDrop().getChunk(), event.getPlayer(), PermissionsIsland.DROP_ITEMS, event); + ListenersUtils.checkPermission(event.getItemDrop().getLocation(), event.getPlayer(), PermissionsIsland.DROP_ITEMS, event); } @EventHandler(priority = EventPriority.HIGHEST) public void onPickUpItemDropped(final EntityPickupItemEvent event) { if (event.isCancelled()) return; if (event.getEntity() instanceof Player player) { - ListenersUtils.checkPermission(event.getItem().getChunk(), player, PermissionsIsland.PICKUP_ITEMS, event); + ListenersUtils.checkPermission(event.getItem().getLocation(), player, PermissionsIsland.PICKUP_ITEMS, event); } } @@ -54,6 +54,6 @@ public void onPickUpItemDropped(final EntityPickupItemEvent event) { public void onPlayerUsePortal(final PlayerPortalEvent event) { if (event.isCancelled()) return; event.setCanCreatePortal(false); - ListenersUtils.checkPermission(event.getPlayer().getChunk(), event.getPlayer(), PermissionsIsland.USE_NETHER_PORTAL, event); + ListenersUtils.checkPermission(event.getPlayer().getLocation(), event.getPlayer(), PermissionsIsland.USE_NETHER_PORTAL, event); } } diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/listeners/skyblockevents/SkyblockEvent.java b/plugin/src/main/java/fr/euphyllia/skyllia/listeners/skyblockevents/SkyblockEvent.java index ab5b1bcc..aa2cc87e 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/listeners/skyblockevents/SkyblockEvent.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/listeners/skyblockevents/SkyblockEvent.java @@ -8,6 +8,7 @@ import fr.euphyllia.skyllia.api.skyblock.model.permissions.PermissionsIsland; import fr.euphyllia.skyllia.configuration.LanguageToml; import fr.euphyllia.skyllia.listeners.ListenersUtils; +import fr.euphyllia.skyllia.utils.RegionUtils; import fr.euphyllia.skyllia.utils.WorldUtils; import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; @@ -20,6 +21,8 @@ import org.bukkit.event.EventPriority; import org.bukkit.event.Listener; +import java.util.List; + public class SkyblockEvent implements Listener { private final InterneAPI api; @@ -63,8 +66,22 @@ public void onSkyblockLoad(final SkyblockLoadEvent event) { this.api.getCacheManager().updateCacheIsland(event.getIsland(), players.getMojangId()); } + @EventHandler + public void onSkyblockSize(final SkyblockChangeSizeEvent event) { + List players = event.getIsland().getMembers(); + for (Players player : players) { + Player bPlayer = Bukkit.getPlayer(player.getMojangId()); + if (bPlayer != null && bPlayer.isOnline() && (Boolean.TRUE.equals(WorldUtils.isWorldSkyblock(bPlayer.getWorld().getName())))) { + Location centerIsland = RegionUtils.getCenterRegion(bPlayer.getWorld(), event.getIsland().getPosition().x(), event.getIsland().getPosition().z()); + this.api.getPlayerNMS().setOwnWorldBorder(this.api.getPlugin(), bPlayer, centerIsland, event.getSizeIsland(), 0, 0); + + + } + } + } + private void teleportOtherWorld(Player player, PlayerPrepareChangeWorldSkyblockEvent event, PermissionsIsland permissionsIsland) { - Island island = ListenersUtils.checkPermission(player.getChunk(), player, permissionsIsland, event); + Island island = ListenersUtils.checkPermission(player.getLocation(), player, permissionsIsland, event); if (island == null) { return; } diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/managers/skyblock/IslandHook.java b/plugin/src/main/java/fr/euphyllia/skyllia/managers/skyblock/IslandHook.java index 5001c03e..3640ffdc 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/managers/skyblock/IslandHook.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/managers/skyblock/IslandHook.java @@ -1,10 +1,7 @@ package fr.euphyllia.skyllia.managers.skyblock; import fr.euphyllia.skyllia.Main; -import fr.euphyllia.skyllia.api.event.SkyblockChangeAccessEvent; -import fr.euphyllia.skyllia.api.event.SkyblockCreateWarpEvent; -import fr.euphyllia.skyllia.api.event.SkyblockDeleteEvent; -import fr.euphyllia.skyllia.api.event.SkyblockDeleteWarpEvent; +import fr.euphyllia.skyllia.api.event.*; import fr.euphyllia.skyllia.api.exceptions.MaxIslandSizeExceedException; import fr.euphyllia.skyllia.api.skyblock.Island; import fr.euphyllia.skyllia.api.skyblock.Players; @@ -19,6 +16,7 @@ import java.sql.Timestamp; import java.util.UUID; +import java.util.concurrent.CompletableFuture; import java.util.concurrent.CopyOnWriteArrayList; public class IslandHook extends Island { @@ -66,11 +64,17 @@ public double getSize() { } @Override - public void setSize(double rayon) throws MaxIslandSizeExceedException { - if (this.size >= (511 * ConfigToml.regionDistance) || this.size <= 1) { + public boolean setSize(double rayon) throws MaxIslandSizeExceedException { + if (rayon >= (511 * ConfigToml.regionDistance) || rayon <= 1) { throw new MaxIslandSizeExceedException("The size of the island exceeds the permitted limit! Must be between 2 and %s.".formatted(511 * ConfigToml.regionDistance)); // Fix https://github.com/Euphillya/skyllia/issues/9 } this.size = rayon; + if (Boolean.TRUE.equals(this.plugin.getInterneAPI().getSkyblockManager().setSizeIsland(this, rayon).join())) { + CompletableFuture.runAsync(() -> Bukkit.getPluginManager().callEvent(new SkyblockChangeSizeEvent(this, rayon))); + return true; + } else { + return false; + } } @Override @@ -117,9 +121,7 @@ public boolean setDisable(boolean disable) { if (skyblockRemoveEvent.isCancelled()) { return false; } - this.plugin.getInterneAPI().getSkyblockManager().disableIsland(this, disable).join(); - - return disable; + return this.plugin.getInterneAPI().getSkyblockManager().disableIsland(this, disable).join(); } @Override diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/managers/skyblock/SkyblockManager.java b/plugin/src/main/java/fr/euphyllia/skyllia/managers/skyblock/SkyblockManager.java index 62f85afa..5884dae4 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/managers/skyblock/SkyblockManager.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/managers/skyblock/SkyblockManager.java @@ -142,4 +142,8 @@ public CompletableFuture getMaxMemberInIsland(Island island) { public CompletableFuture setMaxMemberInIsland(Island island, int newValue) { return this.plugin.getInterneAPI().getIslandQuery().getIslandUpdateQuery().setMaxMemberInIsland(island, newValue); } + + public CompletableFuture setSizeIsland(Island island, double newValue) { + return this.plugin.getInterneAPI().getIslandQuery().getIslandUpdateQuery().setSizeIsland(island, newValue); + } } diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/utils/RegionUtils.java b/plugin/src/main/java/fr/euphyllia/skyllia/utils/RegionUtils.java index 63d85f2f..86b63cab 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/utils/RegionUtils.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/utils/RegionUtils.java @@ -2,9 +2,9 @@ import fr.euphyllia.skyllia.Main; import fr.euphyllia.skyllia.api.skyblock.model.Position; +import fr.euphyllia.skyllia.configuration.ConfigToml; import fr.euphyllia.skyllia.utils.models.CallBackPosition; import fr.euphyllia.skyllia.utils.models.CallbackEntity; -import fr.euphyllia.skyllia.utils.models.CallbackLocation; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.bukkit.Bukkit; @@ -15,7 +15,8 @@ import org.bukkit.entity.EntityType; import org.bukkit.util.Vector; -import java.util.concurrent.TimeUnit; +import java.util.ArrayList; +import java.util.List; public class RegionUtils { @@ -64,44 +65,6 @@ public static Position getPositionNewIsland(int start) { return new Position(regionX, regionZ); } - public static void editBlockRegion(World world, int regionX, int regionZ, Main plugin, CallbackLocation callback, int nbrPerSecond) { - Bukkit.getAsyncScheduler().runNow(plugin, t1 -> { - int minChunkX = regionX << 5; - int minChunkZ = regionZ << 5; - - int minY = world.getMinHeight(); - int maxY = world.getMaxHeight(); - - - int maxChunkX = 32; - int maxChunkZ = 32; - - for (int cx = 0; cx < maxChunkX; cx++) { - for (int cz = 0; cz < maxChunkZ; cz++) { - int minX = (minChunkX + cx) << 4; - int maxX = minX + 15; - - int minZ = (minChunkZ + cz) << 4; - int maxZ = minZ + 15; - int numberChunk = (cx * maxChunkX) + cz; - int delayAfter = (numberChunk * 20) / nbrPerSecond; - for (int x = minX; x <= maxX; x++) { - for (int z = minZ; z <= maxZ; z++) { - for (int y = minY; y <= maxY; y++) { - Location loc = new Location(world, x, y, z); - Bukkit.getAsyncScheduler().runDelayed(plugin, t2 -> { - if (callback != null) { - callback.run(loc); - } - }, delayAfter, TimeUnit.MILLISECONDS); - } - } - } - } - } - }); - } - public static Vector getMinXRegion(World world, int regionX, int regionZ) { int minX = regionX << 9; int minZ = regionZ << 9; @@ -162,19 +125,23 @@ public static void getEntitiesInRegion(Main plugin, EntityType entityType, World } } - public static void spiralStartCenter(Position islandRegion, int size, CallBackPosition callbackChunkPosition) { + public static void spiralStartCenter(Position islandRegion, double size, CallBackPosition callbackChunkPosition) { Position chunk = RegionUtils.getChunkCenterRegion(islandRegion.x(), islandRegion.z()); int cx = chunk.x(); int cz = chunk.z(); int x = 0, z = 0; int dx = 0, dz = -1; - int maxI = size * size; - + int maxI = (33 * ConfigToml.regionDistance) * (33 * ConfigToml.regionDistance); + List islandPositionWithRadius = RegionUtils.getRegionsInRadius(islandRegion, (int) Math.round(size)); + List regionCleaned = new ArrayList<>(); for (int i = 0; i < maxI; i++) { if ((-size / 2 <= x) && (x <= size / 2) && (-size / 2 <= z) && (z <= size / 2)) { Position chunkPos = new Position(cx + x, cz + z); Position region = RegionUtils.getRegionInChunk(chunkPos.x(), chunkPos.z()); - if (islandRegion.x() == region.x() && (islandRegion.z() == region.z())) { + if (islandPositionWithRadius.contains(region)) { + if (!regionCleaned.contains(region)) { + regionCleaned.add(region); + } callbackChunkPosition.run(chunkPos); } } @@ -188,4 +155,35 @@ public static void spiralStartCenter(Position islandRegion, int size, CallBackPo z += dz; } } + + public static boolean isBlockWithinRadius(Location center, int blockX, int blockZ, int radius) { + double dx = (double) center.getBlockX() - blockX; + double dz = (double) center.getBlockZ() - blockZ; + double distance = Math.sqrt(dx * dx + dz * dz); + + return distance <= radius; + } + + public static List getRegionsInRadius(Position position, int blockRadius) { + return getRegionsInRadius(position.x(), position.z(), blockRadius); + } + + public static List getRegionsInRadius(int regionX, int regionZ, int blockRadius) { + int centerBlockX = (regionX << 9) + (int) OFFSET; + int centerBlockZ = (regionZ << 9) + (int) OFFSET; + + List regions = new ArrayList<>(); + int regionRadius = (blockRadius + (int) OFFSET) >> 9; + + for (int x = -regionRadius; x <= regionRadius; x++) { + for (int z = -regionRadius; z <= regionRadius; z++) { + int regionXCoord = (centerBlockX >> 9) + x; + int regionZCoord = (centerBlockZ >> 9) + z; + regions.add(new Position(regionXCoord, regionZCoord)); + } + } + + return regions; + } + } diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/utils/WorldEditUtils.java b/plugin/src/main/java/fr/euphyllia/skyllia/utils/WorldEditUtils.java index 25558bfb..e4805b0c 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/utils/WorldEditUtils.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/utils/WorldEditUtils.java @@ -19,20 +19,16 @@ import fr.euphyllia.skyllia.api.skyblock.Island; import fr.euphyllia.skyllia.api.skyblock.model.Position; import fr.euphyllia.skyllia.api.skyblock.model.SchematicWorld; -import fr.euphyllia.skyllia.configuration.ConfigToml; import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.bukkit.Bukkit; import org.bukkit.Location; import org.bukkit.block.Biome; -import org.bukkit.util.Vector; import java.io.File; import java.io.FileInputStream; -import java.util.ArrayList; import java.util.LinkedHashMap; -import java.util.List; import java.util.concurrent.CompletableFuture; import java.util.concurrent.atomic.AtomicInteger; import java.util.concurrent.atomic.AtomicLong; @@ -83,8 +79,7 @@ public static void deleteIsland(Main plugin, Island island, org.bukkit.World w) Position position = island.getPosition(); AtomicInteger delay = new AtomicInteger(1); - int regionSize = (32 * ConfigToml.regionDistance) + 1; // une region Ă  une taille de 32, mais un chunk n'est jamais au centre ! Donc je rajoute une marge d'erreur qui sera vĂ©rifier dans la spirale - RegionUtils.spiralStartCenter(position, regionSize, chunKPosition -> { + RegionUtils.spiralStartCenter(position, island.getSize(), chunKPosition -> { Bukkit.getRegionScheduler().runDelayed(plugin, w, chunKPosition.x(), chunKPosition.z(), task -> plugin.getInterneAPI().getWorldNMS().resetChunk(w, chunKPosition), delay.getAndIncrement()); }); @@ -112,63 +107,6 @@ public static CompletableFuture changeBiomeChunk(Main plugin, org.bukki return completableFuture; } - private static List getMiniCuboidRegions(World world, org.bukkit.World w, Island island, int regionSize) { - if (world == null) { - world = BukkitAdapter.adapt(w); - } - - Vector vmin = RegionUtils.getMinXRegion(w, island.getPosition().x(), island.getPosition().z()); - Vector vmax = RegionUtils.getMaxXRegion(w, island.getPosition().x(), island.getPosition().z()); - - int minX = (int) vmin.getX(); - int minY = (int) vmin.getY(); - int minZ = (int) vmin.getZ(); - int maxX = (int) vmax.getX(); - int maxY = (int) vmax.getY(); - int maxZ = (int) vmax.getZ(); - - List miniRegions = new ArrayList<>(); - - for (int x = minX; x < maxX; x += regionSize) { - for (int z = minZ; z < maxZ; z += regionSize) { - int endX = Math.min(x + (regionSize - 1), maxX); - int endZ = Math.min(z + (regionSize - 1), maxZ); - - BlockVector3 minRegion = BlockVector3.at(x, minY, z); - BlockVector3 maxRegion = BlockVector3.at(endX, maxY, endZ); - - miniRegions.add(new CuboidRegion(world, minRegion, maxRegion)); - } - } - - return miniRegions; - } - - private static CuboidRegion getCuboidRegion(World world, org.bukkit.World w, Island island) { - if (world == null) { - world = BukkitAdapter.adapt(w); - } - - Vector vmin = RegionUtils.getMinXRegion(w, island.getPosition().x(), island.getPosition().z()); - Vector vmax = RegionUtils.getMaxXRegion(w, island.getPosition().x(), island.getPosition().z()); - - BlockVector3 minRegion = BlockVector3.at(vmin.getX(), vmin.getY(), vmin.getZ()); - BlockVector3 maxRegion = BlockVector3.at(vmax.getX(), vmax.getY(), vmax.getZ()); - - return new CuboidRegion(world, minRegion, maxRegion); - } - - private static CuboidRegion getCuboidRegionWithRayon(World world, org.bukkit.World w, Island island, double rayon) { - if (world == null) { - world = BukkitAdapter.adapt(w); - } - Location center = RegionUtils.getCenterRegion(w, island.getPosition().x(), island.getPosition().z()); - BlockVector3 minRegion = BlockVector3.at(center.getBlockX() - rayon, world.getMinY(), center.getBlockZ() + rayon); - BlockVector3 maxRegion = BlockVector3.at(center.getBlockX() + rayon, world.getMaxY(), center.getBlockZ() - rayon); - - return new CuboidRegion(world, minRegion, maxRegion); - } - public enum Type { WORLD_EDIT, FAST_ASYNC_WORLD_EDIT, UNDEFINED }