From 318ed3bcf1d01dc086186366fe19e09cc9ef4dfe Mon Sep 17 00:00:00 2001 From: Euphyllia Bierque Date: Mon, 8 Jul 2024 12:18:35 +0200 Subject: [PATCH] Add Permission for use biome --- jitpack.yml | 2 +- plugin/src/main/java/fr/euphyllia/skyllia/Main.java | 2 -- .../commands/common/subcommands/SetBiomeSubCommand.java | 8 +++++++- .../fr/euphyllia/skyllia/configuration/LanguageToml.java | 2 ++ 4 files changed, 10 insertions(+), 4 deletions(-) diff --git a/jitpack.yml b/jitpack.yml index 82d42cb7..f28800bd 100644 --- a/jitpack.yml +++ b/jitpack.yml @@ -1,4 +1,4 @@ jdk: - - openjdk17 + - openjdk21 projectDir: api diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/Main.java b/plugin/src/main/java/fr/euphyllia/skyllia/Main.java index a0af84b8..94db8c82 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/Main.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/Main.java @@ -42,7 +42,6 @@ public class Main extends JavaPlugin { @Override public void onEnable() { - logger.log(Level.INFO, "Plugin Start"); try { this.interneAPI = new InterneAPI(this); } catch (UnsupportedMinecraftVersionException e) { @@ -87,7 +86,6 @@ public void onEnable() { @Override public void onDisable() { - this.logger.log(Level.INFO, "Plugin Off"); Bukkit.getAsyncScheduler().cancelTasks(this); Bukkit.getGlobalRegionScheduler().cancelTasks(this); if (this.interneAPI.getDatabaseLoader() != null) { diff --git a/plugin/src/main/java/fr/euphyllia/skyllia/commands/common/subcommands/SetBiomeSubCommand.java b/plugin/src/main/java/fr/euphyllia/skyllia/commands/common/subcommands/SetBiomeSubCommand.java index 488a4e0d..fa8df7c4 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/commands/common/subcommands/SetBiomeSubCommand.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/commands/common/subcommands/SetBiomeSubCommand.java @@ -64,6 +64,10 @@ public boolean onCommand(@NotNull Main plugin, @NotNull CommandSender sender, @N return true; } + if (!player.hasPermission("skyllia.island.command.biome.%s".formatted(biome.name()))) { + LanguageToml.sendMessage(plugin, player, LanguageToml.messageBiomePermissionDenied.formatted(selectBiome)); + } + if (Boolean.FALSE.equals(WorldUtils.isWorldSkyblock(playerLocation.getWorld().getName()))) { LanguageToml.sendMessage(plugin, player, LanguageToml.messageBiomeOnlyIsland); return true; @@ -125,7 +129,9 @@ public boolean onCommand(@NotNull Main plugin, @NotNull CommandSender sender, @N List biomesList = new ArrayList<>(); if (args.length == 1) { for (Biome biome : Biome.values()) { - biomesList.add(biome.name()); + if (sender.hasPermission("skyllia.island.command.biome.%s".formatted(biome.name()))) { + biomesList.add(biome.name()); + } } } return biomesList; 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 458c9acc..42303190 100644 --- a/plugin/src/main/java/fr/euphyllia/skyllia/configuration/LanguageToml.java +++ b/plugin/src/main/java/fr/euphyllia/skyllia/configuration/LanguageToml.java @@ -47,6 +47,7 @@ public class LanguageToml { public static String messageBiomeCommandNotEnoughArgs = "La commande n'est pas complète : /skyllia biome "; public static String messageBiomeOnlyIsland = "La commande ne peut être exécuté seulement sur une île"; public static String messageBiomeNotExist = "Le biome %s n'existe pas."; + public static String messageBiomePermissionDenied = "Vous n'avez pas la permission d'utiliser ce biome."; public static String messageBiomeChangeInProgress = "Changement de biome en cours. Veuillez notez que ça prends du temps... Un message vous avertira quand le processus sera achevé."; public static String messageBiomeChangeSuccess = "Le changement de biome dans le chunk où vous étiez est terminé ! Vous devez quitter et revenir sur votre île pour voir le changement."; public static String messageInviteAlreadyIsland = "Vous êtes déjà sur une île !"; @@ -235,6 +236,7 @@ private static void islandBiomeLanguage() { messageBiomeCommandNotEnoughArgs = getString("island.biome.not-enough-args", messageBiomeCommandNotEnoughArgs); messageBiomeOnlyIsland = getString("island.biome.only-island", messageBiomeOnlyIsland); messageBiomeNotExist = getString("island.biome.biome-not-exist", messageBiomeNotExist); + messageBiomePermissionDenied = getString("island.biome.permission-denied", messageBiomePermissionDenied); messageBiomeChangeInProgress = getString("island.biome.change-in-progress", messageBiomeChangeInProgress); messageBiomeChangeSuccess = getString("island.biome.success", messageBiomeChangeSuccess); }