mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-25 07:33:44 +02:00 
			
		
		
		
	Compare commits
	
		
			12 Commits
		
	
	
		
			7.5.6
			...
			fix/v7/spe
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 49767b568a | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | cd6a32cf44 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 273c0ad989 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 774da7183b | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | e083015ab2 | ||
|   | 3f577d039b | ||
|   | 4d2e4a3d1a | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | e5d36579b1 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | f0cde251bd | ||
|   | 58016bb1c8 | ||
|   | e5943ba627 | ||
|   | 07dfdeef2c | 
| @@ -11,7 +11,7 @@ jobs: | ||||
|           DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }} | ||||
|           DISCORD_USERNAME: PlotSquared Release | ||||
|           DISCORD_AVATAR: https://raw.githubusercontent.com/IntellectualSites/Assets/main/plugins/PlotSquared/PlotSquared.png | ||||
|         uses: Ilshidur/action-discord@0.3.2 | ||||
|         uses: Ilshidur/action-discord@0.4.0 | ||||
|         with: | ||||
|           args: | | ||||
|             "<@&525015541815967744> <@&679322738552471574> <@&699293353862496266>" | ||||
|   | ||||
| @@ -15,12 +15,6 @@ repositories { | ||||
|         name = "EssentialsX" | ||||
|         url = uri("https://repo.essentialsx.net/releases/") | ||||
|     } | ||||
|     // To be removed when "adventure-platform-bukkit" cuts a new release of 4.4.1 or higher | ||||
|     maven("https://central.sonatype.com/repository/maven-snapshots/") { | ||||
|         content { | ||||
|             includeGroup("net.kyori") | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| dependencies { | ||||
|   | ||||
| @@ -177,8 +177,14 @@ public class Grant extends Command { | ||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||
|             } | ||||
|             return commands; | ||||
|         } else if (args.length == 2) { | ||||
|             final String subcommand = args[0].toLowerCase(); | ||||
|             if ((subcommand.equals("add") && player.hasPermission(Permission.PERMISSION_GRANT_ADD)) || | ||||
|                 (subcommand.equals("check") && player.hasPermission(Permission.PERMISSION_GRANT_CHECK))) { | ||||
|                 return TabCompletions.completePlayers(player, args[1], Collections.emptyList()); | ||||
|             } | ||||
|         return TabCompletions.completePlayers(player, String.join(",", args).trim(), Collections.emptyList()); | ||||
|         } | ||||
|         return Collections.emptyList(); | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -283,24 +283,35 @@ public class MainCommand extends Command { | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private CompletableFuture<Optional<CommandExecutionData>> preparePlotArgument(@Nullable Plot newPlot, | ||||
|     private CompletableFuture<Optional<CommandExecutionData>> preparePlotArgument( | ||||
|             @Nullable Plot newPlot, | ||||
|             @Nonnull CommandExecutionData data, | ||||
|                                                                                   @Nullable PlotArea area) { | ||||
|         if (newPlot != null && (data.player() instanceof ConsolePlayer | ||||
|                 || (area != null && area.equals(newPlot.getArea())) | ||||
|                 || data.player().hasPermission(Permission.PERMISSION_ADMIN) | ||||
|                 || data.player().hasPermission(Permission.PERMISSION_ADMIN_AREA_SUDO)) | ||||
|                 && !newPlot.isDenied(data.player().getUUID())) { | ||||
|             @Nullable PlotArea area | ||||
|     ) { | ||||
|         if (newPlot == null) { | ||||
|             return CompletableFuture.completedFuture(Optional.of(data)); | ||||
|         } | ||||
|         final PlotPlayer<?> player = data.player(); | ||||
|         final boolean isAdmin = player instanceof ConsolePlayer || player.hasPermission(Permission.PERMISSION_ADMIN); | ||||
|         final boolean isDenied = newPlot.isDenied(player.getUUID()); | ||||
|         if (!isAdmin) { | ||||
|             if (isDenied) { | ||||
|                 throw new CommandException(TranslatableCaption.of("deny.cannot_interact")); | ||||
|             } | ||||
|             if (area != null && area.equals(newPlot.getArea()) && !player.hasPermission(Permission.PERMISSION_ADMIN_AREA_SUDO)) { | ||||
|                 return CompletableFuture.completedFuture(Optional.of(data)); | ||||
|             } | ||||
|         } | ||||
|         return fetchPlotCenterLocation(newPlot) | ||||
|                 .thenApply(newLoc -> { | ||||
|                         if (!data.player().canTeleport(newLoc)) { | ||||
|                             data.player().sendMessage(TranslatableCaption.of("border.denied")); | ||||
|                     if (!player.canTeleport(newLoc)) { | ||||
|                         player.sendMessage(TranslatableCaption.of("border.denied")); | ||||
|                         return Optional.empty(); | ||||
|                     } | ||||
|                     // Save meta | ||||
|                         var originalCommandMeta = setCommandScope(data.player(), new TemporaryCommandMeta(newLoc, newPlot)); | ||||
|                     var originalCommandMeta = setCommandScope(player, new TemporaryCommandMeta(newLoc, newPlot)); | ||||
|                     return Optional.of(new CommandExecutionData( | ||||
|                                 data.player(), | ||||
|                             player, | ||||
|                             Arrays.copyOfRange(data.args(), 1, data.args().length), // Trimmed command | ||||
|                             data.confirm(), | ||||
|                             data.whenDone(), | ||||
| @@ -308,8 +319,6 @@ public class MainCommand extends Command { | ||||
|                     )); | ||||
|                 }); | ||||
|     } | ||||
|         return CompletableFuture.completedFuture(Optional.of(data)); | ||||
|     } | ||||
|  | ||||
|     private Optional<CommandExecutionData> prepareFlagArgument(@Nonnull CommandExecutionData data, @Nonnull PlotArea area) { | ||||
|         if (data.args().length >= 2 && !data.args()[0].isEmpty() && data.args()[0].charAt(0) == '-') { | ||||
|   | ||||
| @@ -40,6 +40,7 @@ import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||
| import org.checkerframework.checker.nullness.qual.NonNull; | ||||
|  | ||||
| import java.util.UUID; | ||||
| import java.util.function.Supplier; | ||||
|  | ||||
| @CommandDeclaration(command = "merge", | ||||
|         aliases = "m", | ||||
| @@ -116,9 +117,11 @@ public class Merge extends SubCommand { | ||||
|         if (direction == null) { | ||||
|             player.sendMessage( | ||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text( | ||||
|                     TagResolver.resolver( | ||||
|                             "value", Tag.inserting(Component.text( | ||||
|                                     "/plot merge <" + StringMan.join(values, " | ") + "> [removeroads]" | ||||
|                     ))) | ||||
|                             )) | ||||
|                     ) | ||||
|             ); | ||||
|             player.sendMessage( | ||||
|                     TranslatableCaption.of("help.direction"), | ||||
| @@ -244,28 +247,32 @@ public class Merge extends SubCommand { | ||||
|         } | ||||
|         java.util.Set<UUID> uuids = adjacent.getOwners(); | ||||
|         boolean isOnline = false; | ||||
|         if (!force) { | ||||
|             for (final UUID owner : uuids) { | ||||
|                 final PlotPlayer<?> accepter = PlotSquared.platform().playerManager().getPlayerIfExists(owner); | ||||
|             if (!force && accepter == null) { | ||||
|                 if (accepter == null) { | ||||
|                     continue; | ||||
|                 } | ||||
|                 isOnline = true; | ||||
|                 final Direction dir = direction; | ||||
|             Runnable run = () -> { | ||||
|                 Supplier<Boolean> run = () -> { | ||||
|                     accepter.sendMessage(TranslatableCaption.of("merge.merge_accepted")); | ||||
|                 plot.getPlotModificationManager().autoMerge(dir, maxSize - size, owner, player, terrain); | ||||
|                     if (plot.getPlotModificationManager().autoMerge(dir, maxSize - size, owner, player, terrain)) { | ||||
|                         PlotPlayer<?> plotPlayer = PlotSquared.platform().playerManager().getPlayerIfExists(player.getUUID()); | ||||
|                         if (plotPlayer == null) { | ||||
|                             accepter.sendMessage(TranslatableCaption.of("merge.merge_not_valid")); | ||||
|                     return; | ||||
|                             return false; | ||||
|                         } | ||||
|                         if (this.econHandler.isEnabled(plotArea) && !player.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_ECON) && price > 0d) { | ||||
|                     if (!force && this.econHandler.getMoney(player) < price) { | ||||
|                             if (this.econHandler.getMoney(player) < price) { | ||||
|                                 player.sendMessage( | ||||
|                                         TranslatableCaption.of("economy.cannot_afford_merge"), | ||||
|                                 TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(price)))) | ||||
|                                         TagResolver.resolver( | ||||
|                                                 "money", | ||||
|                                                 Tag.inserting(Component.text(this.econHandler.format(price))) | ||||
|                                         ) | ||||
|                                 ); | ||||
|                         return; | ||||
|                                 return false; | ||||
|                             } | ||||
|                             this.econHandler.withdrawMoney(player, price); | ||||
|                             player.sendMessage( | ||||
| @@ -275,9 +282,14 @@ public class Merge extends SubCommand { | ||||
|                         } | ||||
|                         player.sendMessage(TranslatableCaption.of("merge.success_merge")); | ||||
|                         eventDispatcher.callPostMerge(player, plot); | ||||
|                         return true; | ||||
|                     } | ||||
|                     player.sendMessage(TranslatableCaption.of("merge.no_available_automerge")); | ||||
|                     return false; | ||||
|                 }; | ||||
|             if (!force && hasConfirmation(player)) { | ||||
|                 CmdConfirm.addPending(accepter, MINI_MESSAGE.serialize(MINI_MESSAGE | ||||
|                 if (hasConfirmation(player)) { | ||||
|                     CmdConfirm.addPending( | ||||
|                             accepter, MINI_MESSAGE.serialize(MINI_MESSAGE | ||||
|                                     .deserialize( | ||||
|                                             TranslatableCaption.of("merge.merge_request_confirm").getComponent(player), | ||||
|                                             TagResolver.builder() | ||||
| @@ -288,10 +300,13 @@ public class Merge extends SubCommand { | ||||
|                                                     ) | ||||
|                                                     .build() | ||||
|                                     )), | ||||
|                         run | ||||
|                             run::get | ||||
|                     ); | ||||
|                 } else { | ||||
|                 run.run(); | ||||
|                     return run.get(); | ||||
|                 } | ||||
|                 // find first | ||||
|                 break; | ||||
|             } | ||||
|         } | ||||
|         if (force || !isOnline) { | ||||
|   | ||||
| @@ -49,10 +49,12 @@ import java.util.Collection; | ||||
| import java.util.Collections; | ||||
| import java.util.Locale; | ||||
| import java.util.Map; | ||||
| import java.util.Set; | ||||
| import java.util.TimeZone; | ||||
| import java.util.UUID; | ||||
| import java.util.concurrent.TimeUnit; | ||||
| import java.util.function.BiFunction; | ||||
| import java.util.stream.Collectors; | ||||
|  | ||||
| /** | ||||
|  * Registry that contains {@link Placeholder placeholders} | ||||
| @@ -127,6 +129,22 @@ public final class PlaceholderRegistry { | ||||
|             } | ||||
|             return legacyComponent(TranslatableCaption.of("info.unknown"), player); | ||||
|         }); | ||||
|         this.createPlaceholder("currentplot_owners", (player, plot) -> { | ||||
|             if (plot.getFlag(ServerPlotFlag.class)) { | ||||
|                 return legacyComponent(TranslatableCaption.of("info.server"), player); | ||||
|             } | ||||
|             final Set<UUID> plotOwners = plot.getOwners(); | ||||
|             if (plotOwners.isEmpty()) { | ||||
|                 return legacyComponent(TranslatableCaption.of("generic.generic_unowned"), player); | ||||
|             } | ||||
|             return plotOwners.stream().map(PlotSquared.platform().playerManager()::getUsernameCaption).map(f -> { | ||||
|                 try { | ||||
|                     return f.get(Settings.UUID.BLOCKING_TIMEOUT, TimeUnit.MILLISECONDS).getComponent(player); | ||||
|                 } catch (final Exception ignored) { | ||||
|                     return legacyComponent(TranslatableCaption.of("info.unknown"), player); | ||||
|                 } | ||||
|             }).collect(Collectors.joining(", ")); | ||||
|         }); | ||||
|         this.createPlaceholder("currentplot_members", (player, plot) -> { | ||||
|             if (plot.getMembers().isEmpty() && plot.getTrusted().isEmpty()) { | ||||
|                 return legacyComponent(TranslatableCaption.of("info.none"), player); | ||||
|   | ||||
| @@ -415,6 +415,7 @@ | ||||
|   "deny.denied_added": "<prefix><dark_aqua>You successfully denied the player from this plot.</dark_aqua>", | ||||
|   "deny.no_enter": "<prefix><red>You are denied from the plot <red><gold><plot></gold><red> and therefore not allowed to enter.</red>", | ||||
|   "deny.you_got_denied": "<prefix><red>You are denied from the plot you were previously on, and got teleported to spawn.</red>", | ||||
|   "deny.cannot_interact": "<prefix><red>You are denied from the plot <red><gold><plot></gold><red> and therefore cannot interact with it.</red>", | ||||
|   "deny.cant_remove_owner": "<prefix><red>You can't remove the plot owner.</red>", | ||||
|   "kick.player_not_in_plot": "<prefix><red>The player <gray><player></gray> is not on this plot.</red>", | ||||
|   "kick.cannot_kick_player": "<prefix><red>You cannot kick the player <gray><player></gray>.</red>", | ||||
|   | ||||
| @@ -20,7 +20,7 @@ plugins { | ||||
| } | ||||
|  | ||||
| group = "com.intellectualsites.plotsquared" | ||||
| version = "7.5.6" | ||||
| version = "7.5.7-SNAPSHOT" | ||||
|  | ||||
| if (!File("$rootDir/.git").exists()) { | ||||
|     logger.lifecycle(""" | ||||
|   | ||||
| @@ -2,21 +2,21 @@ | ||||
| # Platform expectations | ||||
| paper = "1.20.4-R0.1-SNAPSHOT" | ||||
| guice = "7.0.0" | ||||
| spotbugs = "4.9.3" | ||||
| spotbugs = "4.9.4" | ||||
| checkerqual = "3.49.5" | ||||
| gson = "2.10" | ||||
| guava = "31.1-jre" | ||||
| snakeyaml = "2.0" | ||||
| adventure = "4.23.0" | ||||
| adventure-bukkit = "4.4.1-SNAPSHOT" | ||||
| adventure = "4.24.0" | ||||
| adventure-bukkit = "4.4.1" | ||||
| log4j = "2.19.0" | ||||
|  | ||||
| # Plugins | ||||
| worldedit = "7.2.20" | ||||
| fawe = "2.13.0" | ||||
| fawe = "2.13.1" | ||||
| placeholderapi = "2.11.6" | ||||
| luckperms = "5.5" | ||||
| essentialsx = "2.21.1" | ||||
| essentialsx = "2.21.2" | ||||
| mvdwapi = "3.1.1" | ||||
|  | ||||
| # Third party | ||||
| @@ -33,7 +33,7 @@ vault = "1.7.1" | ||||
| serverlib = "2.3.7" | ||||
|  | ||||
| # Gradle plugins | ||||
| shadow = "8.3.8" | ||||
| shadow = "8.3.9" | ||||
| grgit = "4.1.1" | ||||
| spotless = "7.2.1" | ||||
| publish = "0.34.0" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user