mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-22 06:03:45 +02:00 
			
		
		
		
	Compare commits
	
		
			46 Commits
		
	
	
		
			fix/ci/pub
			...
			feat/v7/be
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 0c8773c2cc | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | db188150d7 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | cfd8401515 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | c887cbe28c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 59183c1412 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 439fb3a8ea | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 78d6ca1deb | ||
|   | 03aa1be5a3 | ||
|   | 2e3832f1bd | ||
|   | 05af41f832 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | b613318a29 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | c2f8356042 | ||
|   | 109e6059f8 | ||
|   | f01c287f89 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | fd8cf3c475 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 8c9957edeb | ||
|   | aaba2b5b1a | ||
|   | 02a65c8855 | ||
|   | 8a5fa26796 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 13cbb7e083 | ||
|   | bb11a7aec9 | ||
|   | 4d8d5b3a9f | ||
| ![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 | ||
|   | 025b08e716 | ||
|   | 921435689e | ||
|   | aae154b23a | ||
|   | 0f33465d76 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 438f1d9656 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | cb38aeef93 | ||
|   | 7be0655b86 | ||
|   | 774298bef5 | ||
|   | 6fc25bc034 | ||
|   | 1054018e1e | ||
|   | 0508a7f6b6 | ||
|   | da0a57a48c | ||
|   | 87859b002b | 
| @@ -11,7 +11,7 @@ jobs: | |||||||
|           DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }} |           DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }} | ||||||
|           DISCORD_USERNAME: PlotSquared Release |           DISCORD_USERNAME: PlotSquared Release | ||||||
|           DISCORD_AVATAR: https://raw.githubusercontent.com/IntellectualSites/Assets/main/plugins/PlotSquared/PlotSquared.png |           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: |         with: | ||||||
|           args: | |           args: | | ||||||
|             "<@&525015541815967744> <@&679322738552471574> <@&699293353862496266>" |             "<@&525015541815967744> <@&679322738552471574> <@&699293353862496266>" | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							| @@ -9,11 +9,11 @@ jobs: | |||||||
|         os: [ ubuntu-latest, windows-latest, macos-latest ] |         os: [ ubuntu-latest, windows-latest, macos-latest ] | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout Repository |       - name: Checkout Repository | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - name: Validate Gradle Wrapper |       - name: Validate Gradle Wrapper | ||||||
|         uses: gradle/actions/wrapper-validation@v4 |         uses: gradle/actions/wrapper-validation@v4 | ||||||
|       - name: Setup Java |       - name: Setup Java | ||||||
|         uses: actions/setup-java@v4 |         uses: actions/setup-java@v5 | ||||||
|         with: |         with: | ||||||
|           distribution: temurin |           distribution: temurin | ||||||
|           java-version: 21 |           java-version: 21 | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -9,11 +9,11 @@ jobs: | |||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout Repository |       - name: Checkout Repository | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - name: Validate Gradle Wrapper |       - name: Validate Gradle Wrapper | ||||||
|         uses: gradle/actions/wrapper-validation@v4 |         uses: gradle/actions/wrapper-validation@v4 | ||||||
|       - name: Setup Java |       - name: Setup Java | ||||||
|         uses: actions/setup-java@v4 |         uses: actions/setup-java@v5 | ||||||
|         with: |         with: | ||||||
|           distribution: temurin |           distribution: temurin | ||||||
|           java-version: 21 |           java-version: 21 | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							| @@ -20,9 +20,9 @@ jobs: | |||||||
|         language: [ 'java' ] |         language: [ 'java' ] | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout repository |       - name: Checkout repository | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - name: Setup Java |       - name: Setup Java | ||||||
|         uses: actions/setup-java@v4 |         uses: actions/setup-java@v5 | ||||||
|         with: |         with: | ||||||
|           distribution: temurin |           distribution: temurin | ||||||
|           java-version: 21 |           java-version: 21 | ||||||
|   | |||||||
| @@ -17,6 +17,19 @@ repositories { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // Make sure we control the exact version of paper being included, while dropping spigot + bukkit | ||||||
|  | configurations.all { | ||||||
|  |     exclude("org.bukkit") | ||||||
|  |     exclude("org.spigotmc") | ||||||
|  |  | ||||||
|  |     resolutionStrategy.eachDependency { | ||||||
|  |         if (requested.group == "io.papermc.paper" && requested.name == "paper-api") { | ||||||
|  |             useVersion(checkNotNull(libs.paper.orNull?.version)) | ||||||
|  |             because("specific paper version is required to prevent binary incompatibilities on older versions") | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| dependencies { | dependencies { | ||||||
|     api(projects.plotsquaredCore) |     api(projects.plotsquaredCore) | ||||||
|  |  | ||||||
| @@ -28,20 +41,13 @@ dependencies { | |||||||
|     implementation(libs.paperlib) |     implementation(libs.paperlib) | ||||||
|  |  | ||||||
|     // Plugins |     // Plugins | ||||||
|     compileOnly(libs.worldeditBukkit) { |     compileOnly(libs.worldeditBukkit) | ||||||
|         exclude(group = "org.bukkit") |  | ||||||
|         exclude(group = "org.spigotmc") |  | ||||||
|     } |  | ||||||
|     compileOnly(libs.faweBukkit) { isTransitive = false } |     compileOnly(libs.faweBukkit) { isTransitive = false } | ||||||
|     testImplementation(libs.faweBukkit) { isTransitive = false } |     testImplementation(libs.faweBukkit) { isTransitive = false } | ||||||
|     compileOnly(libs.vault) { |     compileOnly(libs.vault) | ||||||
|         exclude(group = "org.bukkit") |  | ||||||
|     } |  | ||||||
|     compileOnly(libs.placeholderapi) |     compileOnly(libs.placeholderapi) | ||||||
|     compileOnly(libs.luckperms) |     compileOnly(libs.luckperms) | ||||||
|     compileOnly(libs.essentialsx) { |     compileOnly(libs.essentialsx) | ||||||
|         exclude(group = "org.spigotmc") |  | ||||||
|     } |  | ||||||
|     compileOnly(libs.mvdwapi) { isTransitive = false } |     compileOnly(libs.mvdwapi) { isTransitive = false } | ||||||
|  |  | ||||||
|     // Other libraries |     // Other libraries | ||||||
|   | |||||||
| @@ -837,7 +837,8 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                         case "HOPPER_MINECART": |                         case "HOPPER_MINECART": | ||||||
|                         case "MINECART_MOB_SPAWNER": |                         case "MINECART_MOB_SPAWNER": | ||||||
|                         case "SPAWNER_MINECART": |                         case "SPAWNER_MINECART": | ||||||
|                         case "ENDER_CRYSTAL": |                         case "END_CRYSTAL": | ||||||
|  |                         case "ENDER_CRYSTAL": // Backwards compatibility for 1.20.4 | ||||||
|                         case "MINECART_TNT": |                         case "MINECART_TNT": | ||||||
|                         case "TNT_MINECART": |                         case "TNT_MINECART": | ||||||
|                         case "CHEST_BOAT": |                         case "CHEST_BOAT": | ||||||
| @@ -955,6 +956,8 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                         case "ENDERMITE": |                         case "ENDERMITE": | ||||||
|                         case "ENDER_DRAGON": |                         case "ENDER_DRAGON": | ||||||
|                         case "GHAST": |                         case "GHAST": | ||||||
|  |                         case "HAPPY_GHAST": // 1.21.6+ | ||||||
|  |                         case "GHASTLING": // 1.21.6+ | ||||||
|                         case "GIANT": |                         case "GIANT": | ||||||
|                         case "GUARDIAN": |                         case "GUARDIAN": | ||||||
|                         case "HORSE": |                         case "HORSE": | ||||||
|   | |||||||
| @@ -115,7 +115,7 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 this.dataByte = getOrdinal(Boat.Type.values(), boat.getBoatType()); |                 this.dataByte = getOrdinal(Boat.Type.values(), boat.getBoatType()); | ||||||
|                 storeInventory(boat); |                 storeInventory(boat); | ||||||
|             } |             } | ||||||
|             case "ARROW", "EGG", "ENDER_CRYSTAL", "ENDER_PEARL", "ENDER_SIGNAL", "EXPERIENCE_ORB", "FALLING_BLOCK", "FIREBALL", |             case "ARROW", "EGG", "END_CRYSTAL", "ENDER_CRYSTAL", "ENDER_PEARL", "ENDER_SIGNAL", "EXPERIENCE_ORB", "FALLING_BLOCK", "FIREBALL", | ||||||
|                     "FIREWORK", "FISHING_HOOK", "LEASH_HITCH", "LIGHTNING", "MINECART", "MINECART_COMMAND", "MINECART_MOB_SPAWNER", |                     "FIREWORK", "FISHING_HOOK", "LEASH_HITCH", "LIGHTNING", "MINECART", "MINECART_COMMAND", "MINECART_MOB_SPAWNER", | ||||||
|                     "MINECART_TNT", "PLAYER", "PRIMED_TNT", "SLIME", "SMALL_FIREBALL", "SNOWBALL", "MINECART_FURNACE", "SPLASH_POTION", |                     "MINECART_TNT", "PLAYER", "PRIMED_TNT", "SLIME", "SMALL_FIREBALL", "SNOWBALL", "MINECART_FURNACE", "SPLASH_POTION", | ||||||
|                     "THROWN_EXP_BOTTLE", "WITHER_SKULL", "UNKNOWN", "SPECTRAL_ARROW", "SHULKER_BULLET", "DRAGON_FIREBALL", "AREA_EFFECT_CLOUD", |                     "THROWN_EXP_BOTTLE", "WITHER_SKULL", "UNKNOWN", "SPECTRAL_ARROW", "SHULKER_BULLET", "DRAGON_FIREBALL", "AREA_EFFECT_CLOUD", | ||||||
| @@ -272,7 +272,7 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 this.dataByte = (byte) entity1.getPhase().ordinal(); |                 this.dataByte = (byte) entity1.getPhase().ordinal(); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             case "SKELETON", "WITHER_SKELETON", "GUARDIAN", "ELDER_GUARDIAN", "GHAST", "MAGMA_CUBE", "SQUID", "PIG_ZOMBIE", "HOGLIN", |             case "SKELETON", "WITHER_SKELETON", "GUARDIAN", "ELDER_GUARDIAN", "GHAST", "HAPPY_GHAST", "GHASTLING", "MAGMA_CUBE", "SQUID", "PIG_ZOMBIE", "HOGLIN", | ||||||
|                     "ZOMBIFIED_PIGLIN", "PIGLIN", "PIGLIN_BRUTE", "ZOMBIE", "WITHER", "WITCH", "SPIDER", "CAVE_SPIDER", "SILVERFISH", |                     "ZOMBIFIED_PIGLIN", "PIGLIN", "PIGLIN_BRUTE", "ZOMBIE", "WITHER", "WITCH", "SPIDER", "CAVE_SPIDER", "SILVERFISH", | ||||||
|                     "GIANT", "ENDERMAN", "CREEPER", "BLAZE", "SHULKER", "SNOWMAN", "SNOW_GOLEM" -> { |                     "GIANT", "ENDERMAN", "CREEPER", "BLAZE", "SHULKER", "SNOWMAN", "SNOW_GOLEM" -> { | ||||||
|                 storeLiving((LivingEntity) entity); |                 storeLiving((LivingEntity) entity); | ||||||
| @@ -511,7 +511,7 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 ((Slime) entity).setSize(this.dataByte); |                 ((Slime) entity).setSize(this.dataByte); | ||||||
|                 return entity; |                 return entity; | ||||||
|             } */ |             } */ | ||||||
|             case "ARROW", "EGG", "ENDER_CRYSTAL", "ENDER_PEARL", "ENDER_SIGNAL", "DROPPED_ITEM", "EXPERIENCE_ORB", "FALLING_BLOCK", |             case "ARROW", "EGG", "END_CRYSTAL", "ENDER_CRYSTAL", "ENDER_PEARL", "ENDER_SIGNAL", "DROPPED_ITEM", "EXPERIENCE_ORB", "FALLING_BLOCK", | ||||||
|                     "FIREBALL", "FIREWORK", "FISHING_HOOK", "LEASH_HITCH", "LIGHTNING", "MINECART", "MINECART_COMMAND", |                     "FIREBALL", "FIREWORK", "FISHING_HOOK", "LEASH_HITCH", "LIGHTNING", "MINECART", "MINECART_COMMAND", | ||||||
|                     "MINECART_MOB_SPAWNER", "MINECART_TNT", "PLAYER", "PRIMED_TNT", "SMALL_FIREBALL", "SNOWBALL", |                     "MINECART_MOB_SPAWNER", "MINECART_TNT", "PLAYER", "PRIMED_TNT", "SMALL_FIREBALL", "SNOWBALL", | ||||||
|                     "SPLASH_POTION", "THROWN_EXP_BOTTLE", "SPECTRAL_ARROW", "SHULKER_BULLET", "AREA_EFFECT_CLOUD", |                     "SPLASH_POTION", "THROWN_EXP_BOTTLE", "SPECTRAL_ARROW", "SHULKER_BULLET", "AREA_EFFECT_CLOUD", | ||||||
| @@ -676,7 +676,7 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             } |             } | ||||||
|             case "ENDERMITE", "GHAST", "MAGMA_CUBE", "SQUID", "PIG_ZOMBIE", "HOGLIN", "PIGLIN", "ZOMBIFIED_PIGLIN", "PIGLIN_BRUTE", "ZOMBIE", "WITHER", "WITCH", "SPIDER", "CAVE_SPIDER", "SILVERFISH", "GIANT", "ENDERMAN", "CREEPER", "BLAZE", "SNOWMAN", "SHULKER", "GUARDIAN", "ELDER_GUARDIAN", "SKELETON", "WITHER_SKELETON" -> { |             case "ENDERMITE", "GHAST", "HAPPY_GHAST", "GHASTLING", "MAGMA_CUBE", "SQUID", "PIG_ZOMBIE", "HOGLIN", "PIGLIN", "ZOMBIFIED_PIGLIN", "PIGLIN_BRUTE", "ZOMBIE", "WITHER", "WITCH", "SPIDER", "CAVE_SPIDER", "SILVERFISH", "GIANT", "ENDERMAN", "CREEPER", "BLAZE", "SNOWMAN", "SHULKER", "GUARDIAN", "ELDER_GUARDIAN", "SKELETON", "WITHER_SKELETON" -> { | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -79,6 +79,7 @@ import com.plotsquared.core.util.task.TaskManager; | |||||||
| import com.plotsquared.core.util.task.TaskTime; | import com.plotsquared.core.util.task.TaskTime; | ||||||
| import com.sk89q.worldedit.WorldEdit; | import com.sk89q.worldedit.WorldEdit; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
|  | import com.sk89q.worldedit.util.Enums; | ||||||
| import com.sk89q.worldedit.world.block.BlockType; | import com.sk89q.worldedit.world.block.BlockType; | ||||||
| import com.sk89q.worldedit.world.block.BlockTypes; | import com.sk89q.worldedit.world.block.BlockTypes; | ||||||
| import io.papermc.lib.PaperLib; | import io.papermc.lib.PaperLib; | ||||||
| @@ -159,6 +160,7 @@ import java.util.Collections; | |||||||
| import java.util.HashSet; | import java.util.HashSet; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Locale; | import java.util.Locale; | ||||||
|  | import java.util.Objects; | ||||||
| import java.util.Optional; | import java.util.Optional; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
| @@ -183,6 +185,15 @@ public class PlayerEventListener implements Listener { | |||||||
|             Material.WRITABLE_BOOK, |             Material.WRITABLE_BOOK, | ||||||
|             Material.WRITTEN_BOOK |             Material.WRITTEN_BOOK | ||||||
|     ); |     ); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * The correct EntityType for End Crystal, determined once at class loading time. | ||||||
|  |      * Tries END_CRYSTAL first (1.21+), falls back to ENDER_CRYSTAL (1.20.4 and older). | ||||||
|  |      */ | ||||||
|  |     private static final EntityType END_CRYSTAL_ENTITY_TYPE = Objects.requireNonNull( | ||||||
|  |             Enums.findByValue(EntityType.class, "END_CRYSTAL", "ENDER_CRYSTAL") | ||||||
|  |     ); | ||||||
|  |  | ||||||
|     private static final Set<String> DYES; |     private static final Set<String> DYES; | ||||||
|  |  | ||||||
|     static { |     static { | ||||||
| @@ -1317,8 +1328,8 @@ public class PlayerEventListener implements Listener { | |||||||
|                 // reset the player's hand item if spawning needs to be cancelled. |                 // reset the player's hand item if spawning needs to be cancelled. | ||||||
|                 if (type == Material.ARMOR_STAND || type == Material.END_CRYSTAL) { |                 if (type == Material.ARMOR_STAND || type == Material.END_CRYSTAL) { | ||||||
|                     Plot plot = location.getOwnedPlotAbs(); |                     Plot plot = location.getOwnedPlotAbs(); | ||||||
|                     if (BukkitEntityUtil.checkEntity(type == Material.ARMOR_STAND ? EntityType.ARMOR_STAND : EntityType.ENDER_CRYSTAL, |                     EntityType entityType = type == Material.ARMOR_STAND ? EntityType.ARMOR_STAND : END_CRYSTAL_ENTITY_TYPE; | ||||||
|                             plot)) { |                     if (BukkitEntityUtil.checkEntity(entityType, plot)) { | ||||||
|                         event.setCancelled(true); |                         event.setCancelled(true); | ||||||
|                         break; |                         break; | ||||||
|                     } |                     } | ||||||
|   | |||||||
| @@ -47,6 +47,7 @@ import org.bukkit.event.entity.LingeringPotionSplashEvent; | |||||||
| import org.bukkit.event.entity.PotionSplashEvent; | import org.bukkit.event.entity.PotionSplashEvent; | ||||||
| import org.bukkit.event.entity.ProjectileHitEvent; | import org.bukkit.event.entity.ProjectileHitEvent; | ||||||
| import org.bukkit.event.entity.ProjectileLaunchEvent; | import org.bukkit.event.entity.ProjectileLaunchEvent; | ||||||
|  | import org.bukkit.event.player.PlayerEggThrowEvent; | ||||||
| import org.bukkit.projectiles.BlockProjectileSource; | import org.bukkit.projectiles.BlockProjectileSource; | ||||||
| import org.bukkit.projectiles.ProjectileSource; | import org.bukkit.projectiles.ProjectileSource; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| @@ -157,14 +158,26 @@ public class ProjectileEventListener implements Listener { | |||||||
|  |  | ||||||
|     @EventHandler |     @EventHandler | ||||||
|     public void onProjectileHit(ProjectileHitEvent event) { |     public void onProjectileHit(ProjectileHitEvent event) { | ||||||
|         Projectile entity = event.getEntity(); |         if (cancelProjectileHit(event.getEntity())) { | ||||||
|  |             event.setCancelled(true); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @EventHandler | ||||||
|  |     public void onPlayerEggThrow(PlayerEggThrowEvent event) { | ||||||
|  |         if (cancelProjectileHit(event.getEgg())) { | ||||||
|  |             event.setHatching(false); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private boolean cancelProjectileHit(Projectile entity) { | ||||||
|         Location location = BukkitUtil.adapt(entity.getLocation()); |         Location location = BukkitUtil.adapt(entity.getLocation()); | ||||||
|         if (!this.plotAreaManager.hasPlotArea(location.getWorldName())) { |         if (!this.plotAreaManager.hasPlotArea(location.getWorldName())) { | ||||||
|             return; |             return false; | ||||||
|         } |         } | ||||||
|         PlotArea area = location.getPlotArea(); |         PlotArea area = location.getPlotArea(); | ||||||
|         if (area == null) { |         if (area == null) { | ||||||
|             return; |             return false; | ||||||
|         } |         } | ||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         ProjectileSource shooter = entity.getShooter(); |         ProjectileSource shooter = entity.getShooter(); | ||||||
| @@ -172,15 +185,14 @@ public class ProjectileEventListener implements Listener { | |||||||
|             if (!((Player) shooter).isOnline()) { |             if (!((Player) shooter).isOnline()) { | ||||||
|                 if (plot != null) { |                 if (plot != null) { | ||||||
|                     if (plot.isAdded(((Player) shooter).getUniqueId()) || plot.getFlag(ProjectilesFlag.class)) { |                     if (plot.isAdded(((Player) shooter).getUniqueId()) || plot.getFlag(ProjectilesFlag.class)) { | ||||||
|                         return; |                         return false; | ||||||
|                     } |                     } | ||||||
|                 } else if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true)) { |                 } else if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true)) { | ||||||
|                     return; |                     return false; | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 event.setCancelled(true); |                 return true; | ||||||
|                 return; |  | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); |             PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); | ||||||
| @@ -189,38 +201,36 @@ public class ProjectileEventListener implements Listener { | |||||||
|                         Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED |                         Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED | ||||||
|                 )) { |                 )) { | ||||||
|                     entity.remove(); |                     entity.remove(); | ||||||
|                     event.setCancelled(true); |                     return true; | ||||||
|                 } |                 } | ||||||
|                 return; |                 return false; | ||||||
|             } |             } | ||||||
|             if (plot.isAdded(pp.getUUID()) || pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER) || plot.getFlag( |             if (plot.isAdded(pp.getUUID()) || pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER) || plot.getFlag( | ||||||
|                     ProjectilesFlag.class) || (entity instanceof FishHook && plot.getFlag( |                     ProjectilesFlag.class) || (entity instanceof FishHook && plot.getFlag( | ||||||
|                     FishingFlag.class))) { |                     FishingFlag.class))) { | ||||||
|                 return; |                 return false; | ||||||
|             } |             } | ||||||
|             entity.remove(); |             entity.remove(); | ||||||
|             event.setCancelled(true); |             return true; | ||||||
|             return; |  | ||||||
|         } |         } | ||||||
|         if (!(shooter instanceof Entity) && shooter != null) { |         if (!(shooter instanceof Entity) && shooter != null) { | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 event.setCancelled(true); |                 return true; | ||||||
|                 return; |  | ||||||
|             } |             } | ||||||
|             Location sLoc = |             Location sLoc = | ||||||
|                     BukkitUtil.adapt(((BlockProjectileSource) shooter).getBlock().getLocation()); |                     BukkitUtil.adapt(((BlockProjectileSource) shooter).getBlock().getLocation()); | ||||||
|             if (!area.contains(sLoc.getX(), sLoc.getZ())) { |             if (!area.contains(sLoc.getX(), sLoc.getZ())) { | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 event.setCancelled(true); |                 return true; | ||||||
|                 return; |  | ||||||
|             } |             } | ||||||
|             Plot sPlot = area.getOwnedPlotAbs(sLoc); |             Plot sPlot = area.getOwnedPlotAbs(sLoc); | ||||||
|             if (sPlot == null || !PlotHandler.sameOwners(plot, sPlot)) { |             if (sPlot == null || !PlotHandler.sameOwners(plot, sPlot)) { | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 event.setCancelled(true); |                 return true; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |         return false; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -18,6 +18,8 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.core.backup; | package com.plotsquared.core.backup; | ||||||
|  |  | ||||||
|  | import org.apache.logging.log4j.LogManager; | ||||||
|  | import org.apache.logging.log4j.Logger; | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| @@ -30,12 +32,14 @@ import java.nio.file.Path; | |||||||
|  */ |  */ | ||||||
| public class Backup { | public class Backup { | ||||||
|  |  | ||||||
|  |     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + Backup.class.getSimpleName()); | ||||||
|  |  | ||||||
|     private final BackupProfile owner; |     private final BackupProfile owner; | ||||||
|     private final long creationTime; |     private final long creationTime; | ||||||
|     @Nullable |     @Nullable | ||||||
|     private final Path file; |     private final Path file; | ||||||
|  |  | ||||||
|     Backup(final BackupProfile owner, final long creationTime, final Path file) { |     Backup(final BackupProfile owner, final long creationTime, @Nullable final Path file) { | ||||||
|         this.owner = owner; |         this.owner = owner; | ||||||
|         this.creationTime = creationTime; |         this.creationTime = creationTime; | ||||||
|         this.file = file; |         this.file = file; | ||||||
| @@ -49,7 +53,7 @@ public class Backup { | |||||||
|             try { |             try { | ||||||
|                 Files.deleteIfExists(file); |                 Files.deleteIfExists(file); | ||||||
|             } catch (final IOException e) { |             } catch (final IOException e) { | ||||||
|                 e.printStackTrace(); |                 LOGGER.error("Error deleting backup at {}", file, e); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -21,14 +21,15 @@ package com.plotsquared.core.backup; | |||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.google.inject.assistedinject.Assisted; | import com.google.inject.assistedinject.Assisted; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.player.ConsolePlayer; | import com.plotsquared.core.exception.PlotSquaredException; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.schematic.Schematic; | import com.plotsquared.core.plot.schematic.Schematic; | ||||||
| import com.plotsquared.core.util.SchematicHandler; | import com.plotsquared.core.util.SchematicHandler; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import net.kyori.adventure.text.minimessage.MiniMessage; | import org.apache.logging.log4j.LogManager; | ||||||
|  | import org.apache.logging.log4j.Logger; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| @@ -51,7 +52,7 @@ import java.util.concurrent.CompletableFuture; | |||||||
|  */ |  */ | ||||||
| public class PlayerBackupProfile implements BackupProfile { | public class PlayerBackupProfile implements BackupProfile { | ||||||
|  |  | ||||||
|     static final MiniMessage MINI_MESSAGE = MiniMessage.builder().build(); |     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + PlayerBackupProfile.class.getSimpleName()); | ||||||
|  |  | ||||||
|     private final UUID owner; |     private final UUID owner; | ||||||
|     private final Plot plot; |     private final Plot plot; | ||||||
| @@ -87,7 +88,7 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|                 Files.createDirectory(path); |                 Files.createDirectory(path); | ||||||
|             } |             } | ||||||
|         } catch (final Exception e) { |         } catch (final Exception e) { | ||||||
|             e.printStackTrace(); |             LOGGER.error("Error resolving {} from {}", child, parent, e); | ||||||
|         } |         } | ||||||
|         return path; |         return path; | ||||||
|     } |     } | ||||||
| @@ -104,7 +105,7 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|                     try { |                     try { | ||||||
|                         Files.createDirectories(path); |                         Files.createDirectories(path); | ||||||
|                     } catch (IOException e) { |                     } catch (IOException e) { | ||||||
|                         e.printStackTrace(); |                         LOGGER.error("Error creating directory {}", path, e); | ||||||
|                         return Collections.emptyList(); |                         return Collections.emptyList(); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @@ -117,11 +118,11 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|                             backups.add( |                             backups.add( | ||||||
|                                     new Backup(this, basicFileAttributes.creationTime().toMillis(), file)); |                                     new Backup(this, basicFileAttributes.creationTime().toMillis(), file)); | ||||||
|                         } catch (IOException e) { |                         } catch (IOException e) { | ||||||
|                             e.printStackTrace(); |                             LOGGER.error("Error getting attributes for file {} to create backup", file, e); | ||||||
|                         } |                         } | ||||||
|                     }); |                     }); | ||||||
|                 } catch (IOException e) { |                 } catch (IOException e) { | ||||||
|                     e.printStackTrace(); |                     LOGGER.error("Error walking files from {}", path, e); | ||||||
|                 } |                 } | ||||||
|                 backups.sort(Comparator.comparingLong(Backup::getCreationTime).reversed()); |                 backups.sort(Comparator.comparingLong(Backup::getCreationTime).reversed()); | ||||||
|                 return (this.backupCache = backups); |                 return (this.backupCache = backups); | ||||||
| @@ -133,7 +134,7 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|     public void destroy() { |     public void destroy() { | ||||||
|         this.listBackups().whenCompleteAsync((backups, error) -> { |         this.listBackups().whenCompleteAsync((backups, error) -> { | ||||||
|             if (error != null) { |             if (error != null) { | ||||||
|                 error.printStackTrace(); |                 LOGGER.error("Error while listing backups", error); | ||||||
|             } |             } | ||||||
|             backups.forEach(Backup::delete); |             backups.forEach(Backup::delete); | ||||||
|             this.backupCache = null; |             this.backupCache = null; | ||||||
| @@ -141,10 +142,12 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     public @NonNull Path getBackupDirectory() { |     public @NonNull Path getBackupDirectory() { | ||||||
|         return resolve(resolve( |         return resolve( | ||||||
|                 resolve(backupManager.getBackupPath(), Objects.requireNonNull(plot.getArea().toString(), "plot area id")), |                 resolve( | ||||||
|                 Objects.requireNonNull(plot.getId().toDashSeparatedString(), "plot id") |                         resolve(backupManager.getBackupPath(), Objects.requireNonNull(plot.getArea().toString(), "plot area id")), | ||||||
|         ), Objects.requireNonNull(owner.toString(), "owner")); |                         Objects.requireNonNull(plot.getId().toDashSeparatedString(), "plot id") | ||||||
|  |                 ), Objects.requireNonNull(owner.toString(), "owner") | ||||||
|  |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -156,7 +159,8 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|                     backups.get(backups.size() - 1).delete(); |                     backups.get(backups.size() - 1).delete(); | ||||||
|                 } |                 } | ||||||
|                 final List<Plot> plots = Collections.singletonList(plot); |                 final List<Plot> plots = Collections.singletonList(plot); | ||||||
|                 final boolean result = this.schematicHandler.exportAll(plots, getBackupDirectory().toFile(), |                 final boolean result = this.schematicHandler.exportAll( | ||||||
|  |                         plots, getBackupDirectory().toFile(), | ||||||
|                         "%world%-%id%-" + System.currentTimeMillis(), () -> |                         "%world%-%id%-" + System.currentTimeMillis(), () -> | ||||||
|                                 future.complete(new Backup(this, System.currentTimeMillis(), null)) |                                 future.complete(new Backup(this, System.currentTimeMillis(), null)) | ||||||
|                 ); |                 ); | ||||||
| @@ -180,7 +184,7 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|                 try { |                 try { | ||||||
|                     schematic = this.schematicHandler.getSchematic(backup.getFile().toFile()); |                     schematic = this.schematicHandler.getSchematic(backup.getFile().toFile()); | ||||||
|                 } catch (SchematicHandler.UnsupportedFormatException e) { |                 } catch (SchematicHandler.UnsupportedFormatException e) { | ||||||
|                     e.printStackTrace(); |                     LOGGER.error("Unsupported format for backup {}", backup.getFile(), e); | ||||||
|                 } |                 } | ||||||
|                 if (schematic == null) { |                 if (schematic == null) { | ||||||
|                     future.completeExceptionally(new IllegalArgumentException( |                     future.completeExceptionally(new IllegalArgumentException( | ||||||
| @@ -200,10 +204,9 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|                                     if (value) { |                                     if (value) { | ||||||
|                                         future.complete(null); |                                         future.complete(null); | ||||||
|                                     } else { |                                     } else { | ||||||
|                                         future.completeExceptionally(new RuntimeException(MINI_MESSAGE.escapeTags( |                                         future.completeExceptionally(new PlotSquaredException( | ||||||
|                                                 TranslatableCaption |                                                 TranslatableCaption | ||||||
|                                                         .of("schematics.schematic_paste_failed") |                                                         .of("schematics.schematic_paste_failed"))); | ||||||
|                                                         .getComponent(ConsolePlayer.getConsole())))); |  | ||||||
|                                     } |                                     } | ||||||
|                                 } |                                 } | ||||||
|                             } |                             } | ||||||
|   | |||||||
| @@ -32,6 +32,8 @@ import com.plotsquared.core.util.task.TaskManager; | |||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
|  | import org.apache.logging.log4j.LogManager; | ||||||
|  | import org.apache.logging.log4j.Logger; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| @@ -47,6 +49,7 @@ import java.util.concurrent.TimeUnit; | |||||||
| @Singleton | @Singleton | ||||||
| public class SimpleBackupManager implements BackupManager { | public class SimpleBackupManager implements BackupManager { | ||||||
|  |  | ||||||
|  |     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + SimpleBackupManager.class.getSimpleName()); | ||||||
|     private final Path backupPath; |     private final Path backupPath; | ||||||
|     private final boolean automaticBackup; |     private final boolean automaticBackup; | ||||||
|     private final int backupLimit; |     private final int backupLimit; | ||||||
| @@ -112,7 +115,12 @@ public class SimpleBackupManager implements BackupManager { | |||||||
|                                 TagResolver.resolver("reason", Tag.inserting(Component.text(throwable.getMessage()))) |                                 TagResolver.resolver("reason", Tag.inserting(Component.text(throwable.getMessage()))) | ||||||
|                         ); |                         ); | ||||||
|                     } |                     } | ||||||
|                     throwable.printStackTrace(); |                     LOGGER.error( | ||||||
|  |                             "Error creating backup for plot {};{} and player {}", | ||||||
|  |                             plot.getArea(), | ||||||
|  |                             plot.getId(), | ||||||
|  |                             player == null ? "null" : player.getName(), throwable | ||||||
|  |                     ); | ||||||
|                 } else { |                 } else { | ||||||
|                     if (player != null) { |                     if (player != null) { | ||||||
|                         player.sendMessage(TranslatableCaption.of("backups.backup_automatic_finished")); |                         player.sendMessage(TranslatableCaption.of("backups.backup_automatic_finished")); | ||||||
| @@ -128,6 +136,7 @@ public class SimpleBackupManager implements BackupManager { | |||||||
|         return this.automaticBackup; |         return this.automaticBackup; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @NonNull | ||||||
|     public Path getBackupPath() { |     public Path getBackupPath() { | ||||||
|         return this.backupPath; |         return this.backupPath; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -23,6 +23,8 @@ import com.plotsquared.core.PlotSquared; | |||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.database.DBFunc; | import com.plotsquared.core.database.DBFunc; | ||||||
|  | import com.plotsquared.core.events.PlayerPlotAddRemoveEvent; | ||||||
|  | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| @@ -151,20 +153,41 @@ public class Add extends Command { | |||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                     // Success |                     // Success | ||||||
|                     confirm.run(this, () -> { |                     confirm.run( | ||||||
|                         for (UUID uuid : uuids) { |                             this, () -> { | ||||||
|                             if (uuid != DBFunc.EVERYONE) { |                                 for (UUID uuid : uuids) { | ||||||
|                                 if (!plot.removeTrusted(uuid)) { |                                     if (this.eventDispatcher.callPlayerAdd( | ||||||
|                                     if (plot.getDenied().contains(uuid)) { |                                             player, | ||||||
|                                         plot.removeDenied(uuid); |                                             plot, | ||||||
|  |                                             uuid, | ||||||
|  |                                             PlayerPlotAddRemoveEvent.Reason.COMMAND | ||||||
|  |                                     ).getEventResult() == Result.DENY) { | ||||||
|  |                                         player.sendMessage( | ||||||
|  |                                                 TranslatableCaption.of("events.event_denied"), | ||||||
|  |                                                 TagResolver.resolver("value", Tag.inserting(Component.text("Add"))) | ||||||
|  |                                         ); | ||||||
|  |                                         continue; | ||||||
|                                     } |                                     } | ||||||
|  |                                     if (uuid != DBFunc.EVERYONE) { | ||||||
|  |                                         if (!plot.removeTrusted(uuid)) { | ||||||
|  |                                             if (plot.getDenied().contains(uuid)) { | ||||||
|  |                                                 plot.removeDenied(uuid); | ||||||
|  |                                             } | ||||||
|  |                                         } | ||||||
|  |                                     } | ||||||
|  |                                     plot.addMember(uuid); | ||||||
|  |                                     this.eventDispatcher.callMember(player, plot, uuid, true); | ||||||
|  |                                     this.eventDispatcher.callPostAdded( | ||||||
|  |                                             player, | ||||||
|  |                                             plot, | ||||||
|  |                                             uuid, | ||||||
|  |                                             false, | ||||||
|  |                                             PlayerPlotAddRemoveEvent.Reason.COMMAND | ||||||
|  |                                     ); | ||||||
|  |                                     player.sendMessage(TranslatableCaption.of("member.member_added")); | ||||||
|                                 } |                                 } | ||||||
|                             } |                             }, null | ||||||
|                             plot.addMember(uuid); |                     ); | ||||||
|                             this.eventDispatcher.callMember(player, plot, uuid, true); |  | ||||||
|                             player.sendMessage(TranslatableCaption.of("member.member_added")); |  | ||||||
|                         } |  | ||||||
|                     }, null); |  | ||||||
|                 } catch (final Throwable exception) { |                 } catch (final Throwable exception) { | ||||||
|                     future.completeExceptionally(exception); |                     future.completeExceptionally(exception); | ||||||
|                     return; |                     return; | ||||||
|   | |||||||
| @@ -21,7 +21,6 @@ package com.plotsquared.core.command; | |||||||
| import com.plotsquared.core.PlotSquared; | import com.plotsquared.core.PlotSquared; | ||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| @@ -58,8 +57,7 @@ public class Alias extends SubCommand { | |||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         Location location = player.getLocation(); |         Plot plot = player.getCurrentPlot(); | ||||||
|         Plot plot = location.getPlotAbs(); |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -24,6 +24,7 @@ import com.plotsquared.core.backup.BackupProfile; | |||||||
| import com.plotsquared.core.backup.NullBackupProfile; | import com.plotsquared.core.backup.NullBackupProfile; | ||||||
| import com.plotsquared.core.backup.PlayerBackupProfile; | import com.plotsquared.core.backup.PlayerBackupProfile; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
|  | import com.plotsquared.core.exception.PlotSquaredException; | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| @@ -32,6 +33,8 @@ import com.plotsquared.core.util.task.RunnableVal3; | |||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
|  | import org.apache.logging.log4j.LogManager; | ||||||
|  | import org.apache.logging.log4j.Logger; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.nio.file.Files; | import java.nio.file.Files; | ||||||
| @@ -57,6 +60,8 @@ import java.util.stream.Stream; | |||||||
|         permission = "plots.backup") |         permission = "plots.backup") | ||||||
| public final class Backup extends Command { | public final class Backup extends Command { | ||||||
|  |  | ||||||
|  |     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + Backup.class.getSimpleName()); | ||||||
|  |  | ||||||
|     private final BackupManager backupManager; |     private final BackupManager backupManager; | ||||||
|  |  | ||||||
|     @Inject |     @Inject | ||||||
| @@ -326,20 +331,43 @@ public final class Backup extends Command { | |||||||
|             if (backupProfile instanceof NullBackupProfile) { |             if (backupProfile instanceof NullBackupProfile) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("backups.backup_impossible"), |                         TranslatableCaption.of("backups.backup_impossible"), | ||||||
|                         TagResolver.resolver("plot", Tag.inserting( |                         TagResolver.resolver( | ||||||
|                                 TranslatableCaption.of("generic.generic_other").toComponent(player) |                                 "plot", Tag.inserting( | ||||||
|                         )) |                                         TranslatableCaption.of("generic.generic_other").toComponent(player) | ||||||
|  |                                 ) | ||||||
|  |                         ) | ||||||
|                 ); |                 ); | ||||||
|             } else { |             } else { | ||||||
|                 backupProfile.listBackups().whenComplete((backups, throwable) -> { |                 backupProfile.listBackups().whenComplete((backups, throwable) -> { | ||||||
|                     if (throwable != null) { |                     if (throwable != null) { | ||||||
|  |                         Component reason; | ||||||
|  |                         if (throwable instanceof PlotSquaredException pe) { | ||||||
|  |                             reason = pe.getCaption().toComponent(player); | ||||||
|  |                         } else { | ||||||
|  |                             reason = Component.text(throwable.getMessage()); | ||||||
|  |                         } | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("backups.backup_load_failure"), |                                 TranslatableCaption.of("backups.backup_load_failure"), | ||||||
|                                 TagResolver.resolver("reason", Tag.inserting(Component.text(throwable.getMessage()))) |                                 TagResolver.resolver("reason", Tag.inserting(reason)) | ||||||
|  |                         ); | ||||||
|  |                         LOGGER.error("Error loading player ({}) backup", player.getName(), throwable); | ||||||
|  |                         return; | ||||||
|  |                     } | ||||||
|  |                     if (number < 1 || number > backups.size()) { | ||||||
|  |                         player.sendMessage( | ||||||
|  |                                 TranslatableCaption.of("backups.backup_impossible"), | ||||||
|  |                                 TagResolver.resolver( | ||||||
|  |                                         "plot", | ||||||
|  |                                         Tag.inserting(TranslatableCaption | ||||||
|  |                                                 .of("generic.generic_invalid_choice") | ||||||
|  |                                                 .toComponent(player)) | ||||||
|  |                                 ) | ||||||
|                         ); |                         ); | ||||||
|                         throwable.printStackTrace(); |  | ||||||
|                     } else { |                     } else { | ||||||
|                         if (number < 1 || number > backups.size()) { |                         final com.plotsquared.core.backup.Backup backup = | ||||||
|  |                                 backups.get(number - 1); | ||||||
|  |                         if (backup == null || backup.getFile() == null || !Files | ||||||
|  |                                 .exists(backup.getFile())) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("backups.backup_impossible"), |                                     TranslatableCaption.of("backups.backup_impossible"), | ||||||
|                                     TagResolver.resolver( |                                     TagResolver.resolver( | ||||||
| @@ -350,37 +378,23 @@ public final class Backup extends Command { | |||||||
|                                     ) |                                     ) | ||||||
|                             ); |                             ); | ||||||
|                         } else { |                         } else { | ||||||
|                             final com.plotsquared.core.backup.Backup backup = |                             CmdConfirm.addPending( | ||||||
|                                     backups.get(number - 1); |                                     player, "/plot backup load " + number, | ||||||
|                             if (backup == null || backup.getFile() == null || !Files |                                     () -> backupProfile.restoreBackup(backup, player) | ||||||
|                                     .exists(backup.getFile())) { |                                             .whenComplete((n, error) -> { | ||||||
|                                 player.sendMessage( |                                                 if (error != null) { | ||||||
|                                         TranslatableCaption.of("backups.backup_impossible"), |                                                     player.sendMessage( | ||||||
|                                         TagResolver.resolver( |                                                             TranslatableCaption.of("backups.backup_load_failure"), | ||||||
|                                                 "plot", |                                                             TagResolver.resolver( | ||||||
|                                                 Tag.inserting(TranslatableCaption |                                                                     "reason", | ||||||
|                                                         .of("generic.generic_invalid_choice") |                                                                     Tag.inserting(Component.text(error.getMessage())) | ||||||
|                                                         .toComponent(player)) |                                                             ) | ||||||
|                                         ) |                                                     ); | ||||||
|                                 ); |                                                 } else { | ||||||
|                             } else { |                                                     player.sendMessage(TranslatableCaption.of("backups.backup_load_success")); | ||||||
|                                 CmdConfirm.addPending(player, "/plot backup load " + number, |                                                 } | ||||||
|                                         () -> backupProfile.restoreBackup(backup, player) |                                             }) | ||||||
|                                                 .whenComplete((n, error) -> { |                             ); | ||||||
|                                                     if (error != null) { |  | ||||||
|                                                         player.sendMessage( |  | ||||||
|                                                                 TranslatableCaption.of("backups.backup_load_failure"), |  | ||||||
|                                                                 TagResolver.resolver( |  | ||||||
|                                                                         "reason", |  | ||||||
|                                                                         Tag.inserting(Component.text(error.getMessage())) |  | ||||||
|                                                                 ) |  | ||||||
|                                                         ); |  | ||||||
|                                                     } else { |  | ||||||
|                                                         player.sendMessage(TranslatableCaption.of("backups.backup_load_success")); |  | ||||||
|                                                     } |  | ||||||
|                                                 }) |  | ||||||
|                                 ); |  | ||||||
|                             } |  | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                 }); |                 }); | ||||||
|   | |||||||
| @@ -20,6 +20,7 @@ package com.plotsquared.core.command; | |||||||
|  |  | ||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.plotsquared.core.PlotSquared; | import com.plotsquared.core.PlotSquared; | ||||||
|  | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.events.PlayerBuyPlotEvent; | import com.plotsquared.core.events.PlayerBuyPlotEvent; | ||||||
| import com.plotsquared.core.events.Result; | import com.plotsquared.core.events.Result; | ||||||
| @@ -84,8 +85,9 @@ public class Buy extends Command { | |||||||
|         checkTrue(plot.hasOwner(), TranslatableCaption.of("info.plot_unowned")); |         checkTrue(plot.hasOwner(), TranslatableCaption.of("info.plot_unowned")); | ||||||
|         checkTrue(!plot.isOwner(player.getUUID()), TranslatableCaption.of("economy.cannot_buy_own")); |         checkTrue(!plot.isOwner(player.getUUID()), TranslatableCaption.of("economy.cannot_buy_own")); | ||||||
|         Set<Plot> plots = plot.getConnectedPlots(); |         Set<Plot> plots = plot.getConnectedPlots(); | ||||||
|  |         int plotCount = Settings.Limit.GLOBAL ? player.getPlotCount() : player.getPlotCount(plot.getWorldName()); | ||||||
|         checkTrue( |         checkTrue( | ||||||
|                 player.getPlotCount() + plots.size() <= player.getAllowedPlots(), |                 plotCount + plots.size() <= player.getAllowedPlots(), | ||||||
|                 TranslatableCaption.of("permission.cant_claim_more_plots"), |                 TranslatableCaption.of("permission.cant_claim_more_plots"), | ||||||
|                 TagResolver.resolver("amount", Tag.inserting(Component.text(player.getAllowedPlots()))) |                 TagResolver.resolver("amount", Tag.inserting(Component.text(player.getAllowedPlots()))) | ||||||
|         ); |         ); | ||||||
|   | |||||||
| @@ -26,7 +26,6 @@ import com.plotsquared.core.events.PlayerClaimPlotEvent; | |||||||
| import com.plotsquared.core.events.PlotMergeEvent; | import com.plotsquared.core.events.PlotMergeEvent; | ||||||
| import com.plotsquared.core.events.Result; | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.location.Direction; | import com.plotsquared.core.location.Direction; | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.MetaDataAccess; | import com.plotsquared.core.player.MetaDataAccess; | ||||||
| import com.plotsquared.core.player.PlayerMetaDataKeys; | import com.plotsquared.core.player.PlayerMetaDataKeys; | ||||||
| @@ -72,8 +71,7 @@ public class Claim extends SubCommand { | |||||||
|         if (args.length >= 1) { |         if (args.length >= 1) { | ||||||
|             schematic = args[0]; |             schematic = args[0]; | ||||||
|         } |         } | ||||||
|         Location location = player.getLocation(); |         Plot plot = player.getCurrentPlot(); | ||||||
|         Plot plot = location.getPlotAbs(); |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
| @@ -90,7 +88,7 @@ public class Claim extends SubCommand { | |||||||
|         boolean force = event.getEventResult() == Result.FORCE; |         boolean force = event.getEventResult() == Result.FORCE; | ||||||
|         int currentPlots = Settings.Limit.GLOBAL ? |         int currentPlots = Settings.Limit.GLOBAL ? | ||||||
|                 player.getPlotCount() : |                 player.getPlotCount() : | ||||||
|                 player.getPlotCount(location.getWorldName()); |                 player.getPlotCount(plot.getWorldName()); | ||||||
|  |  | ||||||
|         final PlotArea area = plot.getArea(); |         final PlotArea area = plot.getArea(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -68,8 +68,8 @@ public class Continue extends SubCommand { | |||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         int size = plot.getConnectedPlots().size(); |         int size = plot.getConnectedPlots().size(); | ||||||
|         if (!Settings.Done.COUNTS_TOWARDS_LIMIT && (player.getAllowedPlots() |         int plotCount = Settings.Limit.GLOBAL ? player.getPlotCount() : player.getPlotCount(plot.getWorldName()); | ||||||
|                 < player.getPlotCount() + size)) { |         if (!Settings.Done.COUNTS_TOWARDS_LIMIT && (player.getAllowedPlots() < plotCount + size)) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.cant_claim_more_plots"), |                     TranslatableCaption.of("permission.cant_claim_more_plots"), | ||||||
|                     TagResolver.resolver("amount", Tag.inserting(Component.text(player.getAllowedPlots()))) |                     TagResolver.resolver("amount", Tag.inserting(Component.text(player.getAllowedPlots()))) | ||||||
|   | |||||||
| @@ -19,7 +19,6 @@ | |||||||
| package com.plotsquared.core.command; | package com.plotsquared.core.command; | ||||||
|  |  | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| @@ -37,8 +36,7 @@ public class Copy extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(final PlotPlayer<?> player, String[] args) { |     public boolean onCommand(final PlotPlayer<?> player, String[] args) { | ||||||
|         Location location = player.getLocation(); |         Plot plot1 = player.getCurrentPlot(); | ||||||
|         Plot plot1 = location.getPlotAbs(); |  | ||||||
|         if (plot1 == null) { |         if (plot1 == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -22,7 +22,6 @@ import com.google.inject.Inject; | |||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.generator.HybridPlotWorld; | import com.plotsquared.core.generator.HybridPlotWorld; | ||||||
| import com.plotsquared.core.generator.HybridUtils; | import com.plotsquared.core.generator.HybridUtils; | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| @@ -47,8 +46,7 @@ public class CreateRoadSchematic extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { |     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||||
|         Location location = player.getLocation(); |         Plot plot = player.getCurrentPlot(); | ||||||
|         Plot plot = location.getPlotAbs(); |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
| @@ -57,7 +55,7 @@ public class CreateRoadSchematic extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); |             player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!(location.getPlotArea() instanceof HybridPlotWorld)) { |         if (!(plot.getArea() instanceof HybridPlotWorld)) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||||
|         } |         } | ||||||
|         this.hybridUtils.setupRoadSchematic(plot); |         this.hybridUtils.setupRoadSchematic(plot); | ||||||
|   | |||||||
| @@ -22,7 +22,6 @@ import com.google.inject.Inject; | |||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.generator.HybridPlotManager; | import com.plotsquared.core.generator.HybridPlotManager; | ||||||
| import com.plotsquared.core.generator.HybridUtils; | import com.plotsquared.core.generator.HybridUtils; | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| @@ -57,8 +56,7 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { |     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||||
|         Location location = player.getLocation(); |         Plot plot = player.getCurrentPlot(); | ||||||
|         Plot plot = location.getPlotAbs(); |  | ||||||
|         if (args.length < 1) { |         if (args.length < 1) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
| @@ -92,8 +90,7 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     public boolean regenPlot(PlotPlayer<?> player) { |     public boolean regenPlot(PlotPlayer<?> player) { | ||||||
|         Location location = player.getLocation(); |         PlotArea area = player.getCurrentPlot().getArea(); | ||||||
|         PlotArea area = location.getPlotArea(); |  | ||||||
|         if (area == null) { |         if (area == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||||
|             return false; |             return false; | ||||||
| @@ -148,8 +145,7 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         Location location = player.getLocation(); |         PlotArea area = player.getCurrentPlot().getArea(); | ||||||
|         PlotArea area = location.getPlotArea(); |  | ||||||
|         if (area == null) { |         if (area == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -23,7 +23,6 @@ import com.plotsquared.core.configuration.Settings; | |||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.events.Result; | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.events.TeleportCause; | import com.plotsquared.core.events.TeleportCause; | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| @@ -61,8 +60,7 @@ public class Delete extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(final PlotPlayer<?> player, String[] args) { |     public boolean onCommand(final PlotPlayer<?> player, String[] args) { | ||||||
|         Location location = player.getLocation(); |         final Plot plot = player.getCurrentPlot(); | ||||||
|         final Plot plot = location.getPlotAbs(); |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
| @@ -92,7 +90,7 @@ public class Delete extends SubCommand { | |||||||
|         final java.util.Set<Plot> plots = plot.getConnectedPlots(); |         final java.util.Set<Plot> plots = plot.getConnectedPlots(); | ||||||
|         final int currentPlots = Settings.Limit.GLOBAL ? |         final int currentPlots = Settings.Limit.GLOBAL ? | ||||||
|                 player.getPlotCount() : |                 player.getPlotCount() : | ||||||
|                 player.getPlotCount(location.getWorldName()); |                 player.getPlotCount(plot.getWorldName()); | ||||||
|         Runnable run = () -> { |         Runnable run = () -> { | ||||||
|             if (plot.getRunning() > 0) { |             if (plot.getRunning() > 0) { | ||||||
|                 player.sendMessage(TranslatableCaption.of("errors.wait_for_timer")); |                 player.sendMessage(TranslatableCaption.of("errors.wait_for_timer")); | ||||||
|   | |||||||
| @@ -23,6 +23,8 @@ import com.plotsquared.core.PlotSquared; | |||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.database.DBFunc; | import com.plotsquared.core.database.DBFunc; | ||||||
|  | import com.plotsquared.core.events.PlayerPlotAddRemoveEvent; | ||||||
|  | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.events.TeleportCause; | import com.plotsquared.core.events.TeleportCause; | ||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| @@ -70,8 +72,7 @@ public class Deny extends SubCommand { | |||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { |     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||||
|  |  | ||||||
|         Location location = player.getLocation(); |         final Plot plot = player.getCurrentPlot(); | ||||||
|         final Plot plot = location.getPlotAbs(); |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
| @@ -125,21 +126,29 @@ public class Deny extends SubCommand { | |||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } else { |                     } else { | ||||||
|  |                         if (this.eventDispatcher | ||||||
|  |                                 .callPlayerDeny(player, plot, uuid, PlayerPlotAddRemoveEvent.Reason.COMMAND) | ||||||
|  |                                 .getEventResult() == Result.DENY) { | ||||||
|  |                             player.sendMessage( | ||||||
|  |                                     TranslatableCaption.of("events.event_denied"), | ||||||
|  |                                     TagResolver.resolver("value", Tag.inserting(Component.text("Deny"))) | ||||||
|  |                             ); | ||||||
|  |                             continue; | ||||||
|  |                         } | ||||||
|                         if (uuid != DBFunc.EVERYONE) { |                         if (uuid != DBFunc.EVERYONE) { | ||||||
|                             plot.removeMember(uuid); |                             plot.removeMember(uuid); | ||||||
|                             plot.removeTrusted(uuid); |                             plot.removeTrusted(uuid); | ||||||
|                         } |                         } | ||||||
|                         plot.addDenied(uuid); |                         plot.addDenied(uuid); | ||||||
|                         this.eventDispatcher.callDenied(player, plot, uuid, true); |                         this.eventDispatcher.callDenied(player, plot, uuid, true); | ||||||
|  |                         this.eventDispatcher.callPostDenied(player, plot, uuid, true, PlayerPlotAddRemoveEvent.Reason.COMMAND); | ||||||
|                         if (!uuid.equals(DBFunc.EVERYONE)) { |                         if (!uuid.equals(DBFunc.EVERYONE)) { | ||||||
|                             handleKick(PlotSquared.platform().playerManager().getPlayerIfExists(uuid), plot); |                             handleKick(PlotSquared.platform().playerManager().getPlayerIfExists(uuid), plot); | ||||||
|                         } else { |                         } else { | ||||||
|                             for (PlotPlayer<?> plotPlayer : plot.getPlayersInPlot()) { |                             for (PlotPlayer<?> plotPlayer : plot.getPlayersInPlot()) { | ||||||
|                                 // Ignore plot-owners |                                 if (plot.isDenied(plotPlayer.getUUID())) { | ||||||
|                                 if (plot.isAdded(plotPlayer.getUUID())) { |                                     handleKick(plotPlayer, plot); | ||||||
|                                     continue; |  | ||||||
|                                 } |                                 } | ||||||
|                                 handleKick(plotPlayer, plot); |  | ||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|   | |||||||
| @@ -26,7 +26,6 @@ import com.plotsquared.core.events.PlotDoneEvent; | |||||||
| import com.plotsquared.core.events.PlotFlagAddEvent; | import com.plotsquared.core.events.PlotFlagAddEvent; | ||||||
| import com.plotsquared.core.events.Result; | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.generator.HybridUtils; | import com.plotsquared.core.generator.HybridUtils; | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| @@ -61,8 +60,7 @@ public class Done extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(final PlotPlayer<?> player, String[] args) { |     public boolean onCommand(final PlotPlayer<?> player, String[] args) { | ||||||
|         Location location = player.getLocation(); |         final Plot plot = player.getCurrentPlot(); | ||||||
|         final Plot plot = location.getPlotAbs(); |  | ||||||
|         if ((plot == null) || !plot.hasOwner()) { |         if ((plot == null) || !plot.hasOwner()) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -73,7 +73,7 @@ public class Download extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(final PlotPlayer<?> player, String[] args) { |     public boolean onCommand(final PlotPlayer<?> player, String[] args) { | ||||||
|         String world = player.getLocation().getWorldName(); |         String world = player.getCurrentPlot().getWorldName(); | ||||||
|         if (!this.plotAreaManager.hasPlotArea(world)) { |         if (!this.plotAreaManager.hasPlotArea(world)) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -27,7 +27,6 @@ import com.plotsquared.core.configuration.caption.TranslatableCaption; | |||||||
| import com.plotsquared.core.events.PlotFlagAddEvent; | import com.plotsquared.core.events.PlotFlagAddEvent; | ||||||
| import com.plotsquared.core.events.PlotFlagRemoveEvent; | import com.plotsquared.core.events.PlotFlagRemoveEvent; | ||||||
| import com.plotsquared.core.events.Result; | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| @@ -179,8 +178,7 @@ public final class FlagCommand extends Command { | |||||||
|      * @return {@code true} if the player is allowed to modify the flags at their current location |      * @return {@code true} if the player is allowed to modify the flags at their current location | ||||||
|      */ |      */ | ||||||
|     private static boolean checkRequirements(final @NonNull PlotPlayer<?> player) { |     private static boolean checkRequirements(final @NonNull PlotPlayer<?> player) { | ||||||
|         final Location location = player.getLocation(); |         final Plot plot = player.getCurrentPlot(); | ||||||
|         final Plot plot = location.getPlotAbs(); |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
| @@ -344,7 +342,7 @@ public final class FlagCommand extends Command { | |||||||
|         if (plotFlag == null) { |         if (plotFlag == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Plot plot = player.getLocation().getPlotAbs(); |         Plot plot = player.getCurrentPlot(); | ||||||
|         PlotFlagAddEvent event = eventDispatcher.callFlagAdd(plotFlag, plot); |         PlotFlagAddEvent event = eventDispatcher.callFlagAdd(plotFlag, plot); | ||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
| @@ -409,7 +407,7 @@ public final class FlagCommand extends Command { | |||||||
|         if (plotFlag == null) { |         if (plotFlag == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Plot plot = player.getLocation().getPlotAbs(); |         Plot plot = player.getCurrentPlot(); | ||||||
|         PlotFlagAddEvent event = eventDispatcher.callFlagAdd(plotFlag, plot); |         PlotFlagAddEvent event = eventDispatcher.callFlagAdd(plotFlag, plot); | ||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
| @@ -419,7 +417,7 @@ public final class FlagCommand extends Command { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         boolean force = event.getEventResult() == Result.FORCE; |         boolean force = event.getEventResult() == Result.FORCE; | ||||||
|         final PlotFlag localFlag = player.getLocation().getPlotAbs().getFlagContainer() |         final PlotFlag localFlag = player.getCurrentPlot().getFlagContainer() | ||||||
|                 .getFlag(event.getFlag().getClass()); |                 .getFlag(event.getFlag().getClass()); | ||||||
|         if (!force) { |         if (!force) { | ||||||
|             for (String entry : args[1].split(",")) { |             for (String entry : args[1].split(",")) { | ||||||
| @@ -444,7 +442,7 @@ public final class FlagCommand extends Command { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         boolean result = |         boolean result = | ||||||
|                 player.getLocation().getPlotAbs().setFlag(localFlag.merge(parsed.getValue())); |                 player.getCurrentPlot().setFlag(localFlag.merge(parsed.getValue())); | ||||||
|         if (!result) { |         if (!result) { | ||||||
|             player.sendMessage(TranslatableCaption.of("flag.flag_not_added")); |             player.sendMessage(TranslatableCaption.of("flag.flag_not_added")); | ||||||
|             return; |             return; | ||||||
| @@ -484,7 +482,7 @@ public final class FlagCommand extends Command { | |||||||
|         if (flag == null) { |         if (flag == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         final Plot plot = player.getLocation().getPlotAbs(); |         final Plot plot = player.getCurrentPlot(); | ||||||
|         final PlotFlag<?, ?> flagWithOldValue = plot.getFlagContainer().getFlag(flag.getClass()); |         final PlotFlag<?, ?> flagWithOldValue = plot.getFlagContainer().getFlag(flag.getClass()); | ||||||
|         PlotFlagRemoveEvent event = eventDispatcher.callFlagRemove(flag, plot); |         PlotFlagRemoveEvent event = eventDispatcher.callFlagRemove(flag, plot); | ||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
| @@ -687,7 +685,7 @@ public final class FlagCommand extends Command { | |||||||
|                             .build() |                             .build() | ||||||
|             ); |             ); | ||||||
|             // Default value |             // Default value | ||||||
|             final String defaultValue = player.getLocation().getPlotArea().getFlagContainer() |             final String defaultValue = player.getCurrentPlot().getArea().getFlagContainer() | ||||||
|                     .getFlagErased(plotFlag.getClass()).toString(); |                     .getFlagErased(plotFlag.getClass()).toString(); | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("flag.flag_info_default_value"), |                     TranslatableCaption.of("flag.flag_info_default_value"), | ||||||
|   | |||||||
| @@ -101,6 +101,10 @@ public class Grant extends Command { | |||||||
|                                     ); |                                     ); | ||||||
|                                 } else { |                                 } else { | ||||||
|                                     access.set(access.get().orElse(0) + 1); |                                     access.set(access.get().orElse(0) + 1); | ||||||
|  |                                     player.sendMessage( | ||||||
|  |                                             TranslatableCaption.of("grants.added"), | ||||||
|  |                                             TagResolver.resolver("grants", Tag.inserting(Component.text(access.get().orElse(0)))) | ||||||
|  |                                     ); | ||||||
|                                 } |                                 } | ||||||
|                             } |                             } | ||||||
|                         } else { |                         } else { | ||||||
| @@ -173,8 +177,14 @@ public class Grant extends Command { | |||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             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(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -65,8 +65,7 @@ public class Kick extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { |     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||||
|         Location location = player.getLocation(); |         Plot plot = player.getCurrentPlot(); | ||||||
|         Plot plot = location.getPlot(); |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
| @@ -124,7 +123,7 @@ public class Kick extends SubCommand { | |||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                     Location spawn = this.worldUtil.getSpawn(location.getWorldName()); |                     Location spawn = this.worldUtil.getSpawn(plot.getWorldName()); | ||||||
|                     player2.sendMessage(TranslatableCaption.of("kick.you_got_kicked")); |                     player2.sendMessage(TranslatableCaption.of("kick.you_got_kicked")); | ||||||
|                     if (plot.equals(spawn.getPlot())) { |                     if (plot.equals(spawn.getPlot())) { | ||||||
|                         Location newSpawn = this.worldUtil.getSpawn(this.plotAreaManager.getAllWorlds()[0]); |                         Location newSpawn = this.worldUtil.getSpawn(this.plotAreaManager.getAllWorlds()[0]); | ||||||
| @@ -148,8 +147,7 @@ public class Kick extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         Location location = player.getLocation(); |         Plot plot = player.getCurrentPlot(); | ||||||
|         Plot plot = location.getPlotAbs(); |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             return Collections.emptyList(); |             return Collections.emptyList(); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -20,6 +20,8 @@ package com.plotsquared.core.command; | |||||||
|  |  | ||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
|  | import com.plotsquared.core.events.PlayerPlotAddRemoveEvent; | ||||||
|  | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| @@ -61,11 +63,22 @@ public class Leave extends Command { | |||||||
|         } else { |         } else { | ||||||
|             UUID uuid = player.getUUID(); |             UUID uuid = player.getUUID(); | ||||||
|             if (plot.isAdded(uuid)) { |             if (plot.isAdded(uuid)) { | ||||||
|  |                 if (this.eventDispatcher | ||||||
|  |                         .callPlayerRemove(player, plot, uuid, PlayerPlotAddRemoveEvent.Reason.COMMAND) | ||||||
|  |                         .getEventResult() == Result.DENY) { | ||||||
|  |                     player.sendMessage( | ||||||
|  |                             TranslatableCaption.of("events.event_denied"), | ||||||
|  |                             TagResolver.resolver("value", Tag.inserting(Component.text("Leave"))) | ||||||
|  |                     ); | ||||||
|  |                     return  CompletableFuture.completedFuture(true); | ||||||
|  |                 } | ||||||
|                 if (plot.removeTrusted(uuid)) { |                 if (plot.removeTrusted(uuid)) { | ||||||
|                     this.eventDispatcher.callTrusted(player, plot, uuid, false); |                     this.eventDispatcher.callTrusted(player, plot, uuid, false); | ||||||
|  |                     this.eventDispatcher.callPostTrusted(player, plot, uuid, false, PlayerPlotAddRemoveEvent.Reason.COMMAND); | ||||||
|                 } |                 } | ||||||
|                 if (plot.removeMember(uuid)) { |                 if (plot.removeMember(uuid)) { | ||||||
|                     this.eventDispatcher.callMember(player, plot, uuid, false); |                     this.eventDispatcher.callMember(player, plot, uuid, false); | ||||||
|  |                     this.eventDispatcher.callPostAdded(player, plot, uuid, false, PlayerPlotAddRemoveEvent.Reason.COMMAND); | ||||||
|                 } |                 } | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("member.plot_left"), |                         TranslatableCaption.of("member.plot_left"), | ||||||
|   | |||||||
| @@ -150,8 +150,8 @@ public class ListCmd extends SubCommand { | |||||||
|             page = 0; |             page = 0; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         String world = player.getLocation().getWorldName(); |         String world = player.getCurrentPlot().getWorldName(); | ||||||
|         PlotArea area = player.getApplicablePlotArea(); |         PlotArea area = player.getCurrentPlot().getArea(); | ||||||
|         String arg = args[0].toLowerCase(); |         String arg = args[0].toLowerCase(); | ||||||
|         final boolean[] sort = new boolean[]{true}; |         final boolean[] sort = new boolean[]{true}; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -68,7 +68,7 @@ public class Load extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(final PlotPlayer<?> player, final String[] args) { |     public boolean onCommand(final PlotPlayer<?> player, final String[] args) { | ||||||
|         final String world = player.getLocation().getWorldName(); |         final String world = player.getCurrentPlot().getWorldName(); | ||||||
|         if (!this.plotAreaManager.hasPlotArea(world)) { |         if (!this.plotAreaManager.hasPlotArea(world)) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -275,7 +275,7 @@ public class MainCommand extends Command { | |||||||
|     private CompletableFuture<Optional<CommandExecutionData>> prepareArguments(CommandExecutionData data) { |     private CompletableFuture<Optional<CommandExecutionData>> prepareArguments(CommandExecutionData data) { | ||||||
|         if (data.args().length >= 2) { |         if (data.args().length >= 2) { | ||||||
|             PlotArea area = data.player().getApplicablePlotArea(); |             PlotArea area = data.player().getApplicablePlotArea(); | ||||||
|             Plot newPlot = Plot.fromString(area, data.args()[0]); |             Plot newPlot = Plot.fromString(area, data.args()[0], data.player()); | ||||||
|             return preparePlotArgument(newPlot, data, area) |             return preparePlotArgument(newPlot, data, area) | ||||||
|                     .thenApply(d -> d.flatMap(x -> prepareFlagArgument(x, area))); |                     .thenApply(d -> d.flatMap(x -> prepareFlagArgument(x, area))); | ||||||
|         } else { |         } else { | ||||||
| @@ -283,32 +283,41 @@ public class MainCommand extends Command { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private CompletableFuture<Optional<CommandExecutionData>> preparePlotArgument(@Nullable Plot newPlot, |     private CompletableFuture<Optional<CommandExecutionData>> preparePlotArgument( | ||||||
|                                                                         @Nonnull CommandExecutionData data, |             @Nullable Plot newPlot, | ||||||
|                                                                                   @Nullable PlotArea area) { |             @Nonnull CommandExecutionData data, | ||||||
|         if (newPlot != null && (data.player() instanceof ConsolePlayer |             @Nullable PlotArea area | ||||||
|                 || (area != null && area.equals(newPlot.getArea())) |     ) { | ||||||
|                 || data.player().hasPermission(Permission.PERMISSION_ADMIN) |         if (newPlot == null) { | ||||||
|                 || data.player().hasPermission(Permission.PERMISSION_ADMIN_AREA_SUDO)) |             return CompletableFuture.completedFuture(Optional.of(data)); | ||||||
|                 && !newPlot.isDenied(data.player().getUUID())) { |  | ||||||
|             return fetchPlotCenterLocation(newPlot) |  | ||||||
|                     .thenApply(newLoc -> { |  | ||||||
|                         if (!data.player().canTeleport(newLoc)) { |  | ||||||
|                             data.player().sendMessage(TranslatableCaption.of("border.denied")); |  | ||||||
|                             return Optional.empty(); |  | ||||||
|                         } |  | ||||||
|                         // Save meta |  | ||||||
|                         var originalCommandMeta = setCommandScope(data.player(), new TemporaryCommandMeta(newLoc, newPlot)); |  | ||||||
|                         return Optional.of(new CommandExecutionData( |  | ||||||
|                                 data.player(), |  | ||||||
|                                 Arrays.copyOfRange(data.args(), 1, data.args().length), // Trimmed command |  | ||||||
|                                 data.confirm(), |  | ||||||
|                                 data.whenDone(), |  | ||||||
|                                 originalCommandMeta |  | ||||||
|                         )); |  | ||||||
|                     }); |  | ||||||
|         } |         } | ||||||
|         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 (!player.canTeleport(newLoc)) { | ||||||
|  |                         player.sendMessage(TranslatableCaption.of("border.denied")); | ||||||
|  |                         return Optional.empty(); | ||||||
|  |                     } | ||||||
|  |                     // Save meta | ||||||
|  |                     var originalCommandMeta = setCommandScope(player, new TemporaryCommandMeta(newLoc, newPlot)); | ||||||
|  |                     return Optional.of(new CommandExecutionData( | ||||||
|  |                             player, | ||||||
|  |                             Arrays.copyOfRange(data.args(), 1, data.args().length), // Trimmed command | ||||||
|  |                             data.confirm(), | ||||||
|  |                             data.whenDone(), | ||||||
|  |                             originalCommandMeta | ||||||
|  |                     )); | ||||||
|  |                 }); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private Optional<CommandExecutionData> prepareFlagArgument(@Nonnull CommandExecutionData data, @Nonnull PlotArea area) { |     private Optional<CommandExecutionData> prepareFlagArgument(@Nonnull CommandExecutionData data, @Nonnull PlotArea area) { | ||||||
|   | |||||||
| @@ -20,7 +20,6 @@ package com.plotsquared.core.command; | |||||||
|  |  | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.events.TeleportCause; | import com.plotsquared.core.events.TeleportCause; | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
|  |  | ||||||
| @@ -36,8 +35,7 @@ public class Middle extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] arguments) { |     public boolean onCommand(PlotPlayer<?> player, String[] arguments) { | ||||||
|         Location location = player.getLocation(); |         Plot plot = player.getCurrentPlot(); | ||||||
|         Plot plot = location.getPlot(); |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -20,7 +20,6 @@ package com.plotsquared.core.command; | |||||||
|  |  | ||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| @@ -55,8 +54,7 @@ public class Move extends SubCommand { | |||||||
|             RunnableVal3<Command, Runnable, Runnable> confirm, |             RunnableVal3<Command, Runnable, Runnable> confirm, | ||||||
|             RunnableVal2<Command, CommandResult> whenDone |             RunnableVal2<Command, CommandResult> whenDone | ||||||
|     ) { |     ) { | ||||||
|         Location location = player.getLocation(); |         Plot plot1 = player.getCurrentPlot(); | ||||||
|         Plot plot1 = location.getPlotAbs(); |  | ||||||
|         if (plot1 == null) { |         if (plot1 == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return CompletableFuture.completedFuture(false); |             return CompletableFuture.completedFuture(false); | ||||||
|   | |||||||
| @@ -23,7 +23,6 @@ import com.plotsquared.core.configuration.caption.TranslatableCaption; | |||||||
| import com.plotsquared.core.events.PlotFlagAddEvent; | import com.plotsquared.core.events.PlotFlagAddEvent; | ||||||
| import com.plotsquared.core.events.PlotFlagRemoveEvent; | import com.plotsquared.core.events.PlotFlagRemoveEvent; | ||||||
| import com.plotsquared.core.events.Result; | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| @@ -74,8 +73,7 @@ public class Music extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { |     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||||
|         Location location = player.getLocation(); |         final Plot plot = player.getCurrentPlot(); | ||||||
|         final Plot plot = location.getPlotAbs(); |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -21,6 +21,8 @@ package com.plotsquared.core.command; | |||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.database.DBFunc; | import com.plotsquared.core.database.DBFunc; | ||||||
|  | import com.plotsquared.core.events.PlayerPlotAddRemoveEvent; | ||||||
|  | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| @@ -56,8 +58,7 @@ public class Remove extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { |     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||||
|         Location location = player.getLocation(); |         Plot plot = player.getCurrentPlot(); | ||||||
|         Plot plot = location.getPlotAbs(); |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
| @@ -84,33 +85,48 @@ public class Remove extends SubCommand { | |||||||
|                 return; |                 return; | ||||||
|             } else if (!uuids.isEmpty()) { |             } else if (!uuids.isEmpty()) { | ||||||
|                 for (UUID uuid : uuids) { |                 for (UUID uuid : uuids) { | ||||||
|  |                     if (this.eventDispatcher | ||||||
|  |                             .callPlayerRemove(player, plot, uuid, PlayerPlotAddRemoveEvent.Reason.COMMAND) | ||||||
|  |                             .getEventResult() == Result.DENY) { | ||||||
|  |                         player.sendMessage( | ||||||
|  |                                 TranslatableCaption.of("events.event_denied"), | ||||||
|  |                                 TagResolver.resolver("value", Tag.inserting(Component.text("Remove"))) | ||||||
|  |                         ); | ||||||
|  |                         continue; | ||||||
|  |                     } | ||||||
|                     if (plot.getTrusted().contains(uuid)) { |                     if (plot.getTrusted().contains(uuid)) { | ||||||
|                         if (plot.removeTrusted(uuid)) { |                         if (plot.removeTrusted(uuid)) { | ||||||
|                             this.eventDispatcher.callTrusted(player, plot, uuid, false); |                             this.eventDispatcher.callTrusted(player, plot, uuid, false); | ||||||
|  |                             this.eventDispatcher.callPostTrusted(player, plot, uuid, false, PlayerPlotAddRemoveEvent.Reason.COMMAND); | ||||||
|                             count++; |                             count++; | ||||||
|                         } |                         } | ||||||
|                     } else if (plot.getMembers().contains(uuid)) { |                     } else if (plot.getMembers().contains(uuid)) { | ||||||
|                         if (plot.removeMember(uuid)) { |                         if (plot.removeMember(uuid)) { | ||||||
|                             this.eventDispatcher.callMember(player, plot, uuid, false); |                             this.eventDispatcher.callMember(player, plot, uuid, false); | ||||||
|  |                             this.eventDispatcher.callPostAdded(player, plot, uuid, false, PlayerPlotAddRemoveEvent.Reason.COMMAND); | ||||||
|                             count++; |                             count++; | ||||||
|                         } |                         } | ||||||
|                     } else if (plot.getDenied().contains(uuid)) { |                     } else if (plot.getDenied().contains(uuid)) { | ||||||
|                         if (plot.removeDenied(uuid)) { |                         if (plot.removeDenied(uuid)) { | ||||||
|                             this.eventDispatcher.callDenied(player, plot, uuid, false); |                             this.eventDispatcher.callDenied(player, plot, uuid, false); | ||||||
|  |                             this.eventDispatcher.callPostDenied(player, plot, uuid, true, PlayerPlotAddRemoveEvent.Reason.COMMAND); | ||||||
|                             count++; |                             count++; | ||||||
|                         } |                         } | ||||||
|                     } else if (uuid == DBFunc.EVERYONE) { |                     } else if (uuid == DBFunc.EVERYONE) { | ||||||
|                         count += plot.getTrusted().size(); |                         count += plot.getTrusted().size(); | ||||||
|                         if (plot.removeTrusted(uuid)) { |                         if (plot.removeTrusted(uuid)) { | ||||||
|                             this.eventDispatcher.callTrusted(player, plot, uuid, false); |                             this.eventDispatcher.callTrusted(player, plot, uuid, false); | ||||||
|  |                             this.eventDispatcher.callPostTrusted(player, plot, uuid, false, PlayerPlotAddRemoveEvent.Reason.COMMAND); | ||||||
|                         } |                         } | ||||||
|                         count += plot.getMembers().size(); |                         count += plot.getMembers().size(); | ||||||
|                         if (plot.removeMember(uuid)) { |                         if (plot.removeMember(uuid)) { | ||||||
|                             this.eventDispatcher.callMember(player, plot, uuid, false); |                             this.eventDispatcher.callMember(player, plot, uuid, false); | ||||||
|  |                             this.eventDispatcher.callPostAdded(player, plot, uuid, false, PlayerPlotAddRemoveEvent.Reason.COMMAND); | ||||||
|                         } |                         } | ||||||
|                         count += plot.getDenied().size(); |                         count += plot.getDenied().size(); | ||||||
|                         if (plot.removeDenied(uuid)) { |                         if (plot.removeDenied(uuid)) { | ||||||
|                             this.eventDispatcher.callDenied(player, plot, uuid, false); |                             this.eventDispatcher.callDenied(player, plot, uuid, false); | ||||||
|  |                             this.eventDispatcher.callPostDenied(player, plot, uuid, true, PlayerPlotAddRemoveEvent.Reason.COMMAND); | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @@ -132,8 +148,7 @@ public class Remove extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         Location location = player.getLocation(); |         Plot plot = player.getCurrentPlot(); | ||||||
|         Plot plot = location.getPlotAbs(); |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             return Collections.emptyList(); |             return Collections.emptyList(); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -22,7 +22,6 @@ import com.google.common.collect.Lists; | |||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.ConsolePlayer; | import com.plotsquared.core.player.ConsolePlayer; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| @@ -102,8 +101,7 @@ public class SchematicCmd extends SubCommand { | |||||||
|                     ); |                     ); | ||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
|                 Location loc = player.getLocation(); |                 final Plot plot = player.getCurrentPlot(); | ||||||
|                 final Plot plot = loc.getPlotAbs(); |  | ||||||
|                 if (plot == null) { |                 if (plot == null) { | ||||||
|                     player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |                     player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|                     return false; |                     return false; | ||||||
| @@ -247,8 +245,7 @@ public class SchematicCmd extends SubCommand { | |||||||
|                     player.sendMessage(TranslatableCaption.of("error.task_in_process")); |                     player.sendMessage(TranslatableCaption.of("error.task_in_process")); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 Location location = player.getLocation(); |                 Plot plot = player.getCurrentPlot(); | ||||||
|                 Plot plot = location.getPlotAbs(); |  | ||||||
|                 if (plot == null) { |                 if (plot == null) { | ||||||
|                     player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |                     player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|                     return false; |                     return false; | ||||||
|   | |||||||
| @@ -78,7 +78,7 @@ public class Set extends SubCommand { | |||||||
|  |  | ||||||
|             @Override |             @Override | ||||||
|             public boolean set(PlotPlayer<?> player, final Plot plot, String value) { |             public boolean set(PlotPlayer<?> player, final Plot plot, String value) { | ||||||
|                 final PlotArea plotArea = player.getLocation().getPlotArea(); |                 final PlotArea plotArea = player.getCurrentPlot().getArea(); | ||||||
|                 if (plotArea == null) { |                 if (plotArea == null) { | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|   | |||||||
| @@ -19,7 +19,6 @@ | |||||||
| package com.plotsquared.core.command; | package com.plotsquared.core.command; | ||||||
|  |  | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| @@ -32,8 +31,7 @@ public abstract class SetCommand extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { |     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||||
|         Location location = player.getLocation(); |         Plot plot = player.getCurrentPlot(); | ||||||
|         Plot plot = location.getPlotAbs(); |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -19,7 +19,6 @@ | |||||||
| package com.plotsquared.core.command; | package com.plotsquared.core.command; | ||||||
|  |  | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| @@ -44,8 +43,7 @@ public class Swap extends SubCommand { | |||||||
|             RunnableVal3<Command, Runnable, Runnable> confirm, |             RunnableVal3<Command, Runnable, Runnable> confirm, | ||||||
|             RunnableVal2<Command, CommandResult> whenDone |             RunnableVal2<Command, CommandResult> whenDone | ||||||
|     ) { |     ) { | ||||||
|         Location location = player.getLocation(); |         Plot plot1 = player.getCurrentPlot(); | ||||||
|         Plot plot1 = location.getPlotAbs(); |  | ||||||
|         if (plot1 == null) { |         if (plot1 == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return CompletableFuture.completedFuture(false); |             return CompletableFuture.completedFuture(false); | ||||||
| @@ -79,8 +77,10 @@ public class Swap extends SubCommand { | |||||||
|         String p1 = plot1.toString(); |         String p1 = plot1.toString(); | ||||||
|         String p2 = plot2.toString(); |         String p2 = plot2.toString(); | ||||||
|  |  | ||||||
|         return plot1.getPlotModificationManager().move(plot2, player, () -> { |         return plot1.getPlotModificationManager().move( | ||||||
|         }, true).thenApply(result -> { |                 plot2, player, () -> { | ||||||
|  |                 }, true | ||||||
|  |         ).thenApply(result -> { | ||||||
|             if (result) { |             if (result) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("swap.swap_success"), |                         TranslatableCaption.of("swap.swap_success"), | ||||||
|   | |||||||
| @@ -23,6 +23,8 @@ import com.plotsquared.core.PlotSquared; | |||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.database.DBFunc; | import com.plotsquared.core.database.DBFunc; | ||||||
|  | import com.plotsquared.core.events.PlayerPlotAddRemoveEvent; | ||||||
|  | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| @@ -150,23 +152,43 @@ public class Trust extends Command { | |||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 // Success |                 // Success | ||||||
|                 confirm.run(this, () -> { |                 confirm.run( | ||||||
|                     for (UUID uuid : uuids) { |                         this, () -> { | ||||||
|                         if (uuid != DBFunc.EVERYONE) { |                             for (UUID uuid : uuids) { | ||||||
|                             if (!currentPlot.removeMember(uuid)) { |                                 if (this.eventDispatcher | ||||||
|                                 if (currentPlot.getDenied().contains(uuid)) { |                                         .callPlayerTrust(player, currentPlot, uuid, PlayerPlotAddRemoveEvent.Reason.COMMAND) | ||||||
|                                     currentPlot.removeDenied(uuid); |                                         .getEventResult() == Result.DENY) { | ||||||
|  |                                     player.sendMessage( | ||||||
|  |                                             TranslatableCaption.of("events.event_denied"), | ||||||
|  |                                             TagResolver.resolver("value", Tag.inserting(Component.text("Trust"))) | ||||||
|  |                                     ); | ||||||
|  |                                     return; | ||||||
|                                 } |                                 } | ||||||
|  |  | ||||||
|  |                                 if (uuid != DBFunc.EVERYONE) { | ||||||
|  |                                     if (!currentPlot.removeMember(uuid)) { | ||||||
|  |                                         if (currentPlot.getDenied().contains(uuid)) { | ||||||
|  |                                             currentPlot.removeDenied(uuid); | ||||||
|  |                                         } | ||||||
|  |                                     } | ||||||
|  |                                 } | ||||||
|  |                                 currentPlot.addTrusted(uuid); | ||||||
|  |                                 this.eventDispatcher.callTrusted(player, currentPlot, uuid, true); | ||||||
|  |                                 this.eventDispatcher.callPostTrusted( | ||||||
|  |                                         player, | ||||||
|  |                                         currentPlot, | ||||||
|  |                                         uuid, | ||||||
|  |                                         false, | ||||||
|  |                                         PlayerPlotAddRemoveEvent.Reason.COMMAND | ||||||
|  |                                 ); | ||||||
|  |                                 player.sendMessage(TranslatableCaption.of("trusted.trusted_added")); | ||||||
|                             } |                             } | ||||||
|                         } |                         }, null | ||||||
|                         currentPlot.addTrusted(uuid); |                 ); | ||||||
|                         this.eventDispatcher.callTrusted(player, currentPlot, uuid, true); |  | ||||||
|                         player.sendMessage(TranslatableCaption.of("trusted.trusted_added")); |  | ||||||
|                     } |  | ||||||
|                 }, null); |  | ||||||
|             } |             } | ||||||
|             future.complete(true); |                     future.complete(true); | ||||||
|         }); |                 } | ||||||
|  |         ); | ||||||
|         return CompletableFuture.completedFuture(true); |         return CompletableFuture.completedFuture(true); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -22,7 +22,6 @@ import com.google.inject.Inject; | |||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.events.PlotUnlinkEvent; | import com.plotsquared.core.events.PlotUnlinkEvent; | ||||||
| import com.plotsquared.core.events.Result; | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| @@ -51,8 +50,7 @@ public class Unlink extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(final PlotPlayer<?> player, String[] args) { |     public boolean onCommand(final PlotPlayer<?> player, String[] args) { | ||||||
|         Location location = player.getLocation(); |         final Plot plot = player.getCurrentPlot(); | ||||||
|         final Plot plot = location.getPlotAbs(); |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -0,0 +1,45 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * 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 <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.core.events; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.Plot; | ||||||
|  |  | ||||||
|  | import java.util.UUID; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Called when a player is going to be added to a plot | ||||||
|  |  * | ||||||
|  |  * @since TODO | ||||||
|  |  */ | ||||||
|  | public class PlayerPlotAddEvent extends PlayerPlotAddRemoveCancellableEvent { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Called when a player will be added to a plot | ||||||
|  |      * | ||||||
|  |      * @param initiator Player that initiated the event | ||||||
|  |      * @param plot      Plot in which the event occurred | ||||||
|  |      * @param player    Player that will be added | ||||||
|  |      * @param reason    The reason for the add | ||||||
|  |      */ | ||||||
|  |     public PlayerPlotAddEvent(PlotPlayer<?> initiator, Plot plot, UUID player, Reason reason) { | ||||||
|  |         super(initiator, plot, player, reason); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -0,0 +1,55 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * 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 <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.core.events; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.Plot; | ||||||
|  | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
|  | import java.util.UUID; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Parent class for the varies events regarding a player being added/removed/denied/trusted | ||||||
|  |  * | ||||||
|  |  * @since TODO | ||||||
|  |  */ | ||||||
|  | public class PlayerPlotAddRemoveCancellableEvent extends PlayerPlotAddRemoveEvent implements CancellablePlotEvent { | ||||||
|  |  | ||||||
|  |     private Result eventResult; | ||||||
|  |  | ||||||
|  |     protected PlayerPlotAddRemoveCancellableEvent( | ||||||
|  |             final PlotPlayer<?> initiator, | ||||||
|  |             Plot plot, | ||||||
|  |             final UUID player, | ||||||
|  |             final Reason reason | ||||||
|  |     ) { | ||||||
|  |         super(initiator, plot, player, reason); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public @Nullable Result getEventResult() { | ||||||
|  |         return eventResult; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void setEventResult(@Nullable final Result eventResult) { | ||||||
|  |         this.eventResult = eventResult; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -0,0 +1,88 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * 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 <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.core.events; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.Plot; | ||||||
|  | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
|  | import java.util.UUID; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Parent class for the varies events regarding a player being added/removed/denied/trusted | ||||||
|  |  * | ||||||
|  |  * @since TODO | ||||||
|  |  */ | ||||||
|  | public class PlayerPlotAddRemoveEvent extends PlotEvent { | ||||||
|  |  | ||||||
|  |     private final Reason reason; | ||||||
|  |     private final PlotPlayer<?> initiator; | ||||||
|  |     private final UUID player; | ||||||
|  |  | ||||||
|  |     protected PlayerPlotAddRemoveEvent(final PlotPlayer<?> initiator, Plot plot, final UUID player, final Reason reason) { | ||||||
|  |         super(plot); | ||||||
|  |         this.initiator = initiator; | ||||||
|  |         this.player = player; | ||||||
|  |         this.reason = reason; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * The player to be added/denied/removed/trusted. | ||||||
|  |      * | ||||||
|  |      * @return UUID | ||||||
|  |      */ | ||||||
|  |     public UUID getPlayer() { | ||||||
|  |         return this.player; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * The player initiating the action. May be null (if a player, or a {@link com.plotsquared.core.player.ConsolePlayer}. | ||||||
|  |      * | ||||||
|  |      * @return PlotPlayer | ||||||
|  |      */ | ||||||
|  |     @Nullable | ||||||
|  |     public PlotPlayer<?> getInitiator() { | ||||||
|  |         return this.initiator; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get the reason the player is being added/removed/denied/trusted | ||||||
|  |      * | ||||||
|  |      * @return Reason | ||||||
|  |      */ | ||||||
|  |     public Reason getReason() { | ||||||
|  |         return this.reason; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public enum Reason { | ||||||
|  |         /** | ||||||
|  |          * If a plot merge caused the player to be added/removed/denied/trusted | ||||||
|  |          */ | ||||||
|  |         MERGE, | ||||||
|  |         /** | ||||||
|  |          * If a command caused the player to be added/removed/denied/trusted | ||||||
|  |          */ | ||||||
|  |         COMMAND, | ||||||
|  |         /** | ||||||
|  |          * If something unknown caused the player to be added/removed/denied/trusted | ||||||
|  |          */ | ||||||
|  |         UNKNOWN | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -23,6 +23,10 @@ import com.plotsquared.core.plot.Plot; | |||||||
|  |  | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @deprecated Use {@link com.plotsquared.core.events.post.PostPlayerPlotDeniedEvent} | ||||||
|  |  */ | ||||||
|  | @Deprecated(forRemoval = true, since = "TODO") | ||||||
| public class PlayerPlotDeniedEvent extends PlotEvent { | public class PlayerPlotDeniedEvent extends PlotEvent { | ||||||
|  |  | ||||||
|     private final PlotPlayer<?> initiator; |     private final PlotPlayer<?> initiator; | ||||||
| @@ -36,7 +40,9 @@ public class PlayerPlotDeniedEvent extends PlotEvent { | |||||||
|      * @param plot      Plot in which the event occurred |      * @param plot      Plot in which the event occurred | ||||||
|      * @param player    Player that was denied/un-denied |      * @param player    Player that was denied/un-denied | ||||||
|      * @param added     {@code true} of add to deny list, {@code false} if removed |      * @param added     {@code true} of add to deny list, {@code false} if removed | ||||||
|  |      * @deprecated Use {@link com.plotsquared.core.events.post.PostPlayerPlotDeniedEvent} | ||||||
|      */ |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "TODO") | ||||||
|     public PlayerPlotDeniedEvent(PlotPlayer<?> initiator, Plot plot, UUID player, boolean added) { |     public PlayerPlotDeniedEvent(PlotPlayer<?> initiator, Plot plot, UUID player, boolean added) { | ||||||
|         super(plot); |         super(plot); | ||||||
|         this.initiator = initiator; |         this.initiator = initiator; | ||||||
| @@ -48,7 +54,9 @@ public class PlayerPlotDeniedEvent extends PlotEvent { | |||||||
|      * If a user was added. |      * If a user was added. | ||||||
|      * |      * | ||||||
|      * @return boolean |      * @return boolean | ||||||
|  |      * @deprecated Use {@link com.plotsquared.core.events.post.PostPlayerPlotDeniedEvent} | ||||||
|      */ |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "TODO") | ||||||
|     public boolean wasAdded() { |     public boolean wasAdded() { | ||||||
|         return this.added; |         return this.added; | ||||||
|     } |     } | ||||||
| @@ -57,7 +65,9 @@ public class PlayerPlotDeniedEvent extends PlotEvent { | |||||||
|      * The player added/removed. |      * The player added/removed. | ||||||
|      * |      * | ||||||
|      * @return UUID |      * @return UUID | ||||||
|  |      * @deprecated Use {@link com.plotsquared.core.events.post.PostPlayerPlotDeniedEvent} | ||||||
|      */ |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "TODO") | ||||||
|     public UUID getPlayer() { |     public UUID getPlayer() { | ||||||
|         return this.player; |         return this.player; | ||||||
|     } |     } | ||||||
| @@ -66,7 +76,9 @@ public class PlayerPlotDeniedEvent extends PlotEvent { | |||||||
|      * The player initiating the action. |      * The player initiating the action. | ||||||
|      * |      * | ||||||
|      * @return PlotPlayer |      * @return PlotPlayer | ||||||
|  |      * @deprecated Use {@link com.plotsquared.core.events.post.PostPlayerPlotDeniedEvent} | ||||||
|      */ |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "TODO") | ||||||
|     public PlotPlayer<?> getInitiator() { |     public PlotPlayer<?> getInitiator() { | ||||||
|         return this.initiator; |         return this.initiator; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -0,0 +1,45 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * 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 <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.core.events; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.Plot; | ||||||
|  |  | ||||||
|  | import java.util.UUID; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Called when a player is going to be denied from a plot | ||||||
|  |  * | ||||||
|  |  * @since TODO | ||||||
|  |  */ | ||||||
|  | public class PlayerPlotDenyEvent extends PlayerPlotAddRemoveCancellableEvent { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Called when a player will be denied from a plot | ||||||
|  |      * | ||||||
|  |      * @param initiator Player that initiated the event | ||||||
|  |      * @param plot      Plot in which the event occurred | ||||||
|  |      * @param player    Player that will be denied | ||||||
|  |      * @param reason    The reason for the deny | ||||||
|  |      */ | ||||||
|  |     public PlayerPlotDenyEvent(PlotPlayer<?> initiator, Plot plot, UUID player, Reason reason) { | ||||||
|  |         super(initiator, plot, player, reason); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -24,8 +24,9 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * |  * @deprecated Use {@link com.plotsquared.core.events.post.PostPlayerPlotAddedEvent} | ||||||
|  */ |  */ | ||||||
|  | @Deprecated(forRemoval = true, since = "TODO") | ||||||
| public class PlayerPlotHelperEvent extends PlotEvent { | public class PlayerPlotHelperEvent extends PlotEvent { | ||||||
|  |  | ||||||
|     private final PlotPlayer<?> initiator; |     private final PlotPlayer<?> initiator; | ||||||
| @@ -39,7 +40,9 @@ public class PlayerPlotHelperEvent extends PlotEvent { | |||||||
|      * @param plot      Plot in which the event occurred |      * @param plot      Plot in which the event occurred | ||||||
|      * @param player    Player that was added/removed from the helper list |      * @param player    Player that was added/removed from the helper list | ||||||
|      * @param added     {@code true} if the player was added, {@code false} if the player was removed |      * @param added     {@code true} if the player was added, {@code false} if the player was removed | ||||||
|  |      * @deprecated Use {@link com.plotsquared.core.events.post.PostPlayerPlotAddedEvent} | ||||||
|      */ |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "TODO") | ||||||
|     public PlayerPlotHelperEvent(PlotPlayer<?> initiator, Plot plot, UUID player, boolean added) { |     public PlayerPlotHelperEvent(PlotPlayer<?> initiator, Plot plot, UUID player, boolean added) { | ||||||
|         super(plot); |         super(plot); | ||||||
|         this.initiator = initiator; |         this.initiator = initiator; | ||||||
| @@ -51,7 +54,9 @@ public class PlayerPlotHelperEvent extends PlotEvent { | |||||||
|      * If a player was added |      * If a player was added | ||||||
|      * |      * | ||||||
|      * @return boolean |      * @return boolean | ||||||
|  |      * @deprecated Use {@link com.plotsquared.core.events.post.PostPlayerPlotAddedEvent} | ||||||
|      */ |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "TODO") | ||||||
|     public boolean wasAdded() { |     public boolean wasAdded() { | ||||||
|         return this.added; |         return this.added; | ||||||
|     } |     } | ||||||
| @@ -60,7 +65,9 @@ public class PlayerPlotHelperEvent extends PlotEvent { | |||||||
|      * The UUID added/removed |      * The UUID added/removed | ||||||
|      * |      * | ||||||
|      * @return UUID |      * @return UUID | ||||||
|  |      * @deprecated Use {@link com.plotsquared.core.events.post.PostPlayerPlotAddedEvent} | ||||||
|      */ |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "TODO") | ||||||
|     public UUID getPlayer() { |     public UUID getPlayer() { | ||||||
|         return this.player; |         return this.player; | ||||||
|     } |     } | ||||||
| @@ -69,7 +76,9 @@ public class PlayerPlotHelperEvent extends PlotEvent { | |||||||
|      * The player initiating the action |      * The player initiating the action | ||||||
|      * |      * | ||||||
|      * @return PlotPlayer |      * @return PlotPlayer | ||||||
|  |      * @deprecated Use {@link com.plotsquared.core.events.post.PostPlayerPlotAddedEvent} | ||||||
|      */ |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "TODO") | ||||||
|     public PlotPlayer<?> getInitiator() { |     public PlotPlayer<?> getInitiator() { | ||||||
|         return this.initiator; |         return this.initiator; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -0,0 +1,45 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * 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 <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.core.events; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.Plot; | ||||||
|  |  | ||||||
|  | import java.util.UUID; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Called when a player is going to be removed from a plot (could be removed from added, trusted, or denied) | ||||||
|  |  * | ||||||
|  |  * @since TODO | ||||||
|  |  */ | ||||||
|  | public class PlayerPlotRemoveEvent extends PlayerPlotAddRemoveCancellableEvent { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Called when a player is going to be removed from a plot (could be removed from added, trusted, or denied) | ||||||
|  |      * | ||||||
|  |      * @param initiator Player that initiated the event | ||||||
|  |      * @param plot      Plot in which the event occurred | ||||||
|  |      * @param player    Player that will be removed | ||||||
|  |      * @param reason    The reason for the remove | ||||||
|  |      */ | ||||||
|  |     public PlayerPlotRemoveEvent(PlotPlayer<?> initiator, Plot plot, UUID player, Reason reason) { | ||||||
|  |         super(initiator, plot, player, reason); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -0,0 +1,45 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * 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 <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.core.events; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.Plot; | ||||||
|  |  | ||||||
|  | import java.util.UUID; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Called when a player is going to be trusted to a plot | ||||||
|  |  * | ||||||
|  |  * @since TODO | ||||||
|  |  */ | ||||||
|  | public class PlayerPlotTrustEvent extends PlayerPlotAddRemoveCancellableEvent { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Called when a player will be trusted to a plot | ||||||
|  |      * | ||||||
|  |      * @param initiator Player that initiated the event | ||||||
|  |      * @param plot      Plot in which the event occurred | ||||||
|  |      * @param player    Player that will be trusted | ||||||
|  |      * @param reason    The reason for the trust | ||||||
|  |      */ | ||||||
|  |     public PlayerPlotTrustEvent(PlotPlayer<?> initiator, Plot plot, UUID player, Reason reason) { | ||||||
|  |         super(initiator, plot, player, reason); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -23,6 +23,10 @@ import com.plotsquared.core.plot.Plot; | |||||||
|  |  | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @deprecated Use {@link com.plotsquared.core.events.post.PostPlayerPlotTrustedEvent} | ||||||
|  |  */ | ||||||
|  | @Deprecated(forRemoval = true, since = "TODO") | ||||||
| public class PlayerPlotTrustedEvent extends PlotEvent { | public class PlayerPlotTrustedEvent extends PlotEvent { | ||||||
|  |  | ||||||
|     private final PlotPlayer<?> initiator; |     private final PlotPlayer<?> initiator; | ||||||
| @@ -36,7 +40,9 @@ public class PlayerPlotTrustedEvent extends PlotEvent { | |||||||
|      * @param plot      Plot in which the event occurred |      * @param plot      Plot in which the event occurred | ||||||
|      * @param player    Player that was added/removed from the trusted list |      * @param player    Player that was added/removed from the trusted list | ||||||
|      * @param added     {@code true} if the player was added, {@code false} if the player was removed |      * @param added     {@code true} if the player was added, {@code false} if the player was removed | ||||||
|  |      * @deprecated Use {@link com.plotsquared.core.events.post.PostPlayerPlotTrustedEvent} | ||||||
|      */ |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "TODO") | ||||||
|     public PlayerPlotTrustedEvent(PlotPlayer<?> initiator, Plot plot, UUID player, boolean added) { |     public PlayerPlotTrustedEvent(PlotPlayer<?> initiator, Plot plot, UUID player, boolean added) { | ||||||
|         super(plot); |         super(plot); | ||||||
|         this.initiator = initiator; |         this.initiator = initiator; | ||||||
| @@ -48,7 +54,9 @@ public class PlayerPlotTrustedEvent extends PlotEvent { | |||||||
|      * If a player was added |      * If a player was added | ||||||
|      * |      * | ||||||
|      * @return boolean |      * @return boolean | ||||||
|  |      * @deprecated Use {@link com.plotsquared.core.events.post.PostPlayerPlotTrustedEvent} | ||||||
|      */ |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "TODO") | ||||||
|     public boolean wasAdded() { |     public boolean wasAdded() { | ||||||
|         return this.added; |         return this.added; | ||||||
|     } |     } | ||||||
| @@ -57,7 +65,9 @@ public class PlayerPlotTrustedEvent extends PlotEvent { | |||||||
|      * The UUID added/removed |      * The UUID added/removed | ||||||
|      * |      * | ||||||
|      * @return UUID |      * @return UUID | ||||||
|  |      * @deprecated Use {@link com.plotsquared.core.events.post.PostPlayerPlotTrustedEvent} | ||||||
|      */ |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "TODO") | ||||||
|     public UUID getPlayer() { |     public UUID getPlayer() { | ||||||
|         return this.player; |         return this.player; | ||||||
|     } |     } | ||||||
| @@ -66,7 +76,9 @@ public class PlayerPlotTrustedEvent extends PlotEvent { | |||||||
|      * The player initiating the action |      * The player initiating the action | ||||||
|      * |      * | ||||||
|      * @return PlotPlayer |      * @return PlotPlayer | ||||||
|  |      * @deprecated Use {@link com.plotsquared.core.events.post.PostPlayerPlotTrustedEvent} | ||||||
|      */ |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "TODO") | ||||||
|     public PlotPlayer<?> getInitiator() { |     public PlotPlayer<?> getInitiator() { | ||||||
|         return this.initiator; |         return this.initiator; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -0,0 +1,56 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * 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 <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.core.events.post; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.events.PlayerPlotAddRemoveEvent; | ||||||
|  | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.Plot; | ||||||
|  |  | ||||||
|  | import java.util.UUID; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Parent class for events covering players being added/removed to added/trusted/denied lists. | ||||||
|  |  * | ||||||
|  |  * @since TODO | ||||||
|  |  */ | ||||||
|  | public sealed class PostPlayerPlotAddRemoveEvent extends PlayerPlotAddRemoveEvent permits PostPlayerPlotAddedEvent, | ||||||
|  |         PostPlayerPlotDeniedEvent, PostPlayerPlotTrustedEvent { | ||||||
|  |  | ||||||
|  |     private final boolean added; | ||||||
|  |  | ||||||
|  |     protected PostPlayerPlotAddRemoveEvent( | ||||||
|  |             final PlotPlayer<?> initiator, | ||||||
|  |             final Plot plot, | ||||||
|  |             final UUID player, | ||||||
|  |             final Reason reason, | ||||||
|  |             boolean added | ||||||
|  |     ) { | ||||||
|  |         super(initiator, plot, player, reason); | ||||||
|  |         this.added = added; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get if the player was added to a list, or removed. | ||||||
|  |      */ | ||||||
|  |     public boolean added() { | ||||||
|  |         return added; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -0,0 +1,46 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * 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 <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.core.events.post; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.Plot; | ||||||
|  |  | ||||||
|  | import java.util.UUID; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Called when a player is added to a plot | ||||||
|  |  * | ||||||
|  |  * @since TODO | ||||||
|  |  */ | ||||||
|  | public final class PostPlayerPlotAddedEvent extends PostPlayerPlotAddRemoveEvent { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * PlayerPlotHelperEvent: Called when a player is added to a plot | ||||||
|  |      * | ||||||
|  |      * @param initiator Player that initiated the event | ||||||
|  |      * @param plot      Plot in which the event occurred | ||||||
|  |      * @param player    Player that was added/removed from the helper list | ||||||
|  |      * @param added     {@code true} if the player was added, {@code false} if the player was removed | ||||||
|  |      * @param reason    The reason for the add/remove | ||||||
|  |      */ | ||||||
|  |     public PostPlayerPlotAddedEvent(PlotPlayer<?> initiator, Plot plot, UUID player, boolean added, Reason reason) { | ||||||
|  |         super(initiator, plot, player, reason, added); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -0,0 +1,46 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * 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 <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.core.events.post; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.Plot; | ||||||
|  |  | ||||||
|  | import java.util.UUID; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Called when a player is denied from a plot | ||||||
|  |  * | ||||||
|  |  * @since TODO | ||||||
|  |  */ | ||||||
|  | public final class PostPlayerPlotDeniedEvent extends PostPlayerPlotAddRemoveEvent { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * PlayerPlotDeniedEvent: Called when the denied UUID list is modified for a plot. | ||||||
|  |      * | ||||||
|  |      * @param initiator Player that initiated the event | ||||||
|  |      * @param plot      Plot in which the event occurred | ||||||
|  |      * @param player    Player that was denied/un-denied | ||||||
|  |      * @param added     {@code true} of add to deny list, {@code false} if removed | ||||||
|  |      * @param reason    The reason for the deny/remove | ||||||
|  |      */ | ||||||
|  |     public PostPlayerPlotDeniedEvent(PlotPlayer<?> initiator, Plot plot, UUID player, boolean added, Reason reason) { | ||||||
|  |         super(initiator, plot, player, reason, added); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -0,0 +1,46 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * 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 <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.core.events.post; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.Plot; | ||||||
|  |  | ||||||
|  | import java.util.UUID; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Called when a plot trusted user is added/removed | ||||||
|  |  * | ||||||
|  |  * @since TODO | ||||||
|  |  */ | ||||||
|  | public final class PostPlayerPlotTrustedEvent extends PostPlayerPlotAddRemoveEvent { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * PlayerPlotTrustedEvent: Called when a plot trusted user is added/removed | ||||||
|  |      * | ||||||
|  |      * @param initiator Player that initiated the event | ||||||
|  |      * @param plot      Plot in which the event occurred | ||||||
|  |      * @param player    Player that was added/removed from the trusted list | ||||||
|  |      * @param added     {@code true} if the player was added, {@code false} if the player was removed | ||||||
|  |      * @param reason    The reason for the trust/remove | ||||||
|  |      */ | ||||||
|  |     public PostPlayerPlotTrustedEvent(PlotPlayer<?> initiator, Plot plot, UUID player, boolean added, Reason reason) { | ||||||
|  |         super(initiator, plot, player, reason, added); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -0,0 +1,62 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * 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 <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.core.exception; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.configuration.caption.Caption; | ||||||
|  | import com.plotsquared.core.configuration.caption.LocaleHolder; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Internal use only. Used to allow adventure captions to be used in an exception | ||||||
|  |  * | ||||||
|  |  * @since 7.5.7 | ||||||
|  |  */ | ||||||
|  | public final class PlotSquaredException extends RuntimeException { | ||||||
|  |  | ||||||
|  |     private final Caption caption; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Create a new instance with the given caption | ||||||
|  |      * | ||||||
|  |      * @param caption caption | ||||||
|  |      */ | ||||||
|  |     public PlotSquaredException(Caption caption) { | ||||||
|  |         this.caption = caption; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Create a new instance with the given caption and cause | ||||||
|  |      * | ||||||
|  |      * @param caption caption | ||||||
|  |      * @param cause   cause | ||||||
|  |      */ | ||||||
|  |     public PlotSquaredException(Caption caption, Exception cause) { | ||||||
|  |         super(cause); | ||||||
|  |         this.caption = caption; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public String getMessage() { | ||||||
|  |         return caption.getComponent(LocaleHolder.console()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Caption getCaption() { | ||||||
|  |         return caption; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -290,6 +290,7 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|      * |      * | ||||||
|      * @return the plot the player is standing on or null if standing on a road or not in a {@link PlotArea} |      * @return the plot the player is standing on or null if standing on a road or not in a {@link PlotArea} | ||||||
|      */ |      */ | ||||||
|  |     @Nullable | ||||||
|     public Plot getCurrentPlot() { |     public Plot getCurrentPlot() { | ||||||
|         try (final MetaDataAccess<Plot> lastPlotAccess = |         try (final MetaDataAccess<Plot> lastPlotAccess = | ||||||
|                      this.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_LAST_PLOT)) { |                      this.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_LAST_PLOT)) { | ||||||
| @@ -319,7 +320,7 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|      */ |      */ | ||||||
|     public int getPlotCount() { |     public int getPlotCount() { | ||||||
|         if (!Settings.Limit.GLOBAL) { |         if (!Settings.Limit.GLOBAL) { | ||||||
|             return getPlotCount(getLocation().getWorldName()); |             return getPlotCount(getCurrentPlot().getWorldName()); | ||||||
|         } |         } | ||||||
|         final AtomicInteger count = new AtomicInteger(0); |         final AtomicInteger count = new AtomicInteger(0); | ||||||
|         final UUID uuid = getUUID(); |         final UUID uuid = getUUID(); | ||||||
| @@ -339,7 +340,7 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|  |  | ||||||
|     public int getClusterCount() { |     public int getClusterCount() { | ||||||
|         if (!Settings.Limit.GLOBAL) { |         if (!Settings.Limit.GLOBAL) { | ||||||
|             return getClusterCount(getLocation().getWorldName()); |             return getClusterCount(getCurrentPlot().getWorldName()); | ||||||
|         } |         } | ||||||
|         final AtomicInteger count = new AtomicInteger(0); |         final AtomicInteger count = new AtomicInteger(0); | ||||||
|         this.plotAreaManager.forEachPlotArea(value -> { |         this.plotAreaManager.forEachPlotArea(value -> { | ||||||
| @@ -408,7 +409,11 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     public PlotArea getApplicablePlotArea() { |     public PlotArea getApplicablePlotArea() { | ||||||
|         return this.plotAreaManager.getApplicablePlotArea(getLocation()); |         Plot plot = getCurrentPlot(); | ||||||
|  |         if (plot == null) { | ||||||
|  |             return this.plotAreaManager.getApplicablePlotArea(getLocation()); | ||||||
|  |         } | ||||||
|  |         return plot.getArea(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -614,16 +619,16 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|             PlotId id = plot.getId(); |             PlotId id = plot.getId(); | ||||||
|             int x = id.getX(); |             int x = id.getX(); | ||||||
|             int z = id.getY(); |             int z = id.getY(); | ||||||
|             ByteBuffer buffer = ByteBuffer.allocate(13); |             ByteBuffer buffer = ByteBuffer.allocate(14); | ||||||
|             buffer.putShort((short) x); |             buffer.putShort((short) x); | ||||||
|             buffer.putShort((short) z); |             buffer.putShort((short) z); | ||||||
|             Location location = getLocation(); |             Location location = getLocation(); | ||||||
|             buffer.putInt(location.getX()); |             buffer.putInt(location.getX()); | ||||||
|             buffer.put((byte) location.getY()); |             buffer.putShort((short) location.getY()); | ||||||
|             buffer.putInt(location.getZ()); |             buffer.putInt(location.getZ()); | ||||||
|             setPersistentMeta("quitLoc", buffer.array()); |             setPersistentMeta("quitLocV2", buffer.array()); | ||||||
|         } else if (hasPersistentMeta("quitLoc")) { |         } else if (hasPersistentMeta("quitLocV2")) { | ||||||
|             removePersistentMeta("quitLoc"); |             removePersistentMeta("quitLocV2"); | ||||||
|         } |         } | ||||||
|         if (plot != null) { |         if (plot != null) { | ||||||
|             this.eventDispatcher.callLeave(this, plot); |             this.eventDispatcher.callLeave(this, plot); | ||||||
| @@ -700,11 +705,18 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|                             return; |                             return; | ||||||
|                         } |                         } | ||||||
|                         PlotArea area = ((SinglePlotAreaManager) manager).getArea(); |                         PlotArea area = ((SinglePlotAreaManager) manager).getArea(); | ||||||
|  |                         boolean V2 = false; | ||||||
|                         byte[] arr = PlotPlayer.this.getPersistentMeta("quitLoc"); |                         byte[] arr = PlotPlayer.this.getPersistentMeta("quitLoc"); | ||||||
|                         if (arr == null) { |                         if (arr == null) { | ||||||
|                             return; |                             arr = PlotPlayer.this.getPersistentMeta("quitLocV2"); | ||||||
|  |                             if (arr == null) { | ||||||
|  |                                 return; | ||||||
|  |                             } | ||||||
|  |                             V2 = true; | ||||||
|  |                             removePersistentMeta("quitLocV2"); | ||||||
|  |                         } else { | ||||||
|  |                             removePersistentMeta("quitLoc"); | ||||||
|                         } |                         } | ||||||
|                         removePersistentMeta("quitLoc"); |  | ||||||
|  |  | ||||||
|                         if (!getMeta("teleportOnLogin", true)) { |                         if (!getMeta("teleportOnLogin", true)) { | ||||||
|                             return; |                             return; | ||||||
| @@ -714,7 +726,7 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|                         final int plotZ = quitWorld.getShort(); |                         final int plotZ = quitWorld.getShort(); | ||||||
|                         PlotId id = PlotId.of(plotX, plotZ); |                         PlotId id = PlotId.of(plotX, plotZ); | ||||||
|                         int x = quitWorld.getInt(); |                         int x = quitWorld.getInt(); | ||||||
|                         int y = quitWorld.get() & 0xFF; |                         int y = V2 ? quitWorld.getShort() : (quitWorld.get() & 0xFF); | ||||||
|                         int z = quitWorld.getInt(); |                         int z = quitWorld.getInt(); | ||||||
|                         Plot plot = area.getOwnedPlot(id); |                         Plot plot = area.getOwnedPlot(id); | ||||||
|  |  | ||||||
| @@ -748,10 +760,11 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
|                     } catch (Throwable e) { |                     } catch (Throwable e) { | ||||||
|                         e.printStackTrace(); |                         LOGGER.error("Error populating persistent meta for player {}", PlotPlayer.this.getName(), e); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             }); |                     } | ||||||
|  |             ); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -29,6 +29,7 @@ import com.plotsquared.core.configuration.caption.CaptionUtility; | |||||||
| import com.plotsquared.core.configuration.caption.StaticCaption; | import com.plotsquared.core.configuration.caption.StaticCaption; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.database.DBFunc; | import com.plotsquared.core.database.DBFunc; | ||||||
|  | import com.plotsquared.core.events.PlayerPlotAddRemoveEvent; | ||||||
| import com.plotsquared.core.events.PlayerTeleportToPlotEvent; | import com.plotsquared.core.events.PlayerTeleportToPlotEvent; | ||||||
| import com.plotsquared.core.events.Result; | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.events.TeleportCause; | import com.plotsquared.core.events.TeleportCause; | ||||||
| @@ -321,7 +322,8 @@ public class Plot { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Get the plot from a string. |      * Get the plot from a string. Performs a check to ensure Plot#getBottomAbs is not outside world bounds | ||||||
|  |      * (x/z +/- 30,000,000) to prevent crashes | ||||||
|      * |      * | ||||||
|      * @param player  Provides a context for what world to search in. Prefixing the term with 'world_name;' will override this context. |      * @param player  Provides a context for what world to search in. Prefixing the term with 'world_name;' will override this context. | ||||||
|      * @param arg     The search term |      * @param arg     The search term | ||||||
| @@ -332,6 +334,31 @@ public class Plot { | |||||||
|             final @Nullable PlotPlayer<?> player, |             final @Nullable PlotPlayer<?> player, | ||||||
|             final @Nullable String arg, |             final @Nullable String arg, | ||||||
|             final boolean message |             final boolean message | ||||||
|  |     ) { | ||||||
|  |         Plot plot = getPlotFromStringUnchecked(player, arg, message); | ||||||
|  |         if (plot != null && !WorldUtil.isValidLocation(plot.getBottomAbs())) { | ||||||
|  |             if (message) { | ||||||
|  |                 (player == null ? ConsolePlayer.getConsole() : player).sendMessage(TranslatableCaption.of( | ||||||
|  |                         "invalid.world_location_plot")); | ||||||
|  |             } | ||||||
|  |             return null; | ||||||
|  |         } | ||||||
|  |         return plot; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get the plot from a string. Does not perform a check on world bounds. | ||||||
|  |      * | ||||||
|  |      * @param player  Provides a context for what world to search in. Prefixing the term with 'world_name;' will override this context. | ||||||
|  |      * @param arg     The search term | ||||||
|  |      * @param message If a message should be sent to the player if a plot cannot be found | ||||||
|  |      * @return The plot if only 1 result is found, or null | ||||||
|  |      * @since 7.5.5 | ||||||
|  |      */ | ||||||
|  |     public static @Nullable Plot getPlotFromStringUnchecked( | ||||||
|  |             final @Nullable PlotPlayer<?> player, | ||||||
|  |             final @Nullable String arg, | ||||||
|  |             final boolean message | ||||||
|     ) { |     ) { | ||||||
|         if (arg == null) { |         if (arg == null) { | ||||||
|             if (player == null) { |             if (player == null) { | ||||||
| @@ -389,13 +416,51 @@ public class Plot { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Gets a plot from a string e.g. [area];[id] |      * Gets a plot from a string e.g. [area];[id]. Performs a check to ensure Plot#getBottomAbs is not outside world bounds | ||||||
|  |      * (x/z +/- 30,000,000) to prevent crashes | ||||||
|      * |      * | ||||||
|      * @param defaultArea if no area is specified |      * @param defaultArea if no area is specified | ||||||
|      * @param string      plot id/area + id |      * @param string      plot id/area + id | ||||||
|      * @return New or existing plot object |      * @return New or existing plot object | ||||||
|      */ |      */ | ||||||
|     public static @Nullable Plot fromString(final @Nullable PlotArea defaultArea, final @NonNull String string) { |     public static @Nullable Plot fromString(final @Nullable PlotArea defaultArea, final @NonNull String string) { | ||||||
|  |         return fromString(defaultArea, string, null); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Gets a plot from a string e.g. [area];[id]. Performs a check to ensure Plot#getBottomAbs is not outside world bounds | ||||||
|  |      * (x/z +/- 30,000,000) to prevent crashes | ||||||
|  |      * | ||||||
|  |      * @param defaultArea if no area is specified | ||||||
|  |      * @param string      plot id/area + id | ||||||
|  |      * @param player      {@link PlotPlayer} player to notify if plot is invalid (outside bounds) | ||||||
|  |      * @return New or existing plot object | ||||||
|  |      * @since 7.5.5 | ||||||
|  |      */ | ||||||
|  |     public static @Nullable Plot fromString( | ||||||
|  |             final @Nullable PlotArea defaultArea, | ||||||
|  |             final @NonNull String string, | ||||||
|  |             final @Nullable PlotPlayer<?> player | ||||||
|  |     ) { | ||||||
|  |         Plot plot = fromStringUnchecked(defaultArea, string); | ||||||
|  |         if (plot != null && !WorldUtil.isValidLocation(plot.getBottomAbs())) { | ||||||
|  |             if (player != null) { | ||||||
|  |                 player.sendMessage(TranslatableCaption.of("invalid.world_location_plot")); | ||||||
|  |             } | ||||||
|  |             return null; | ||||||
|  |         } | ||||||
|  |         return plot; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Gets a plot from a string e.g. [area];[id]. Does not perform a check on world bounds. | ||||||
|  |      * | ||||||
|  |      * @param defaultArea if no area is specified | ||||||
|  |      * @param string      plot id/area + id | ||||||
|  |      * @return New or existing plot object | ||||||
|  |      * @since 7.5.5 | ||||||
|  |      */ | ||||||
|  |     public static @Nullable Plot fromStringUnchecked(final @Nullable PlotArea defaultArea, final @NonNull String string) { | ||||||
|         final String[] split = string.split("[;,]"); |         final String[] split = string.split("[;,]"); | ||||||
|         if (split.length == 2) { |         if (split.length == 2) { | ||||||
|             if (defaultArea != null) { |             if (defaultArea != null) { | ||||||
| @@ -419,7 +484,8 @@ public class Plot { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Return a new/cached plot object at a given location. |      * Return a new/cached plot object at a given location. Does not check world bounds for potential crashes, these should be | ||||||
|  |      * performed before (or after) this method is used. | ||||||
|      * |      * | ||||||
|      * <p> |      * <p> | ||||||
|      * Use {@link PlotPlayer#getCurrentPlot()} if a player is expected here. |      * Use {@link PlotPlayer#getCurrentPlot()} if a player is expected here. | ||||||
| @@ -909,7 +975,10 @@ public class Plot { | |||||||
|      * Sets the denied users for this plot. |      * Sets the denied users for this plot. | ||||||
|      * |      * | ||||||
|      * @param uuids uuids to deny |      * @param uuids uuids to deny | ||||||
|  |      * @deprecated Use {@link Plot#addDenied(UUID)} (UUID)} calling | ||||||
|  |      *         {@link EventDispatcher#callPlayerDeny(PlotPlayer, Plot, UUID, PlayerPlotAddRemoveEvent.Reason)} for each. | ||||||
|      */ |      */ | ||||||
|  |     @Deprecated | ||||||
|     public void setDenied(final @NonNull Set<UUID> uuids) { |     public void setDenied(final @NonNull Set<UUID> uuids) { | ||||||
|         boolean larger = uuids.size() > getDenied().size(); |         boolean larger = uuids.size() > getDenied().size(); | ||||||
|         HashSet<UUID> intersection; |         HashSet<UUID> intersection; | ||||||
| @@ -950,7 +1019,10 @@ public class Plot { | |||||||
|      * Sets the trusted users for this plot. |      * Sets the trusted users for this plot. | ||||||
|      * |      * | ||||||
|      * @param uuids uuids to trust |      * @param uuids uuids to trust | ||||||
|  |      * @deprecated Use {@link Plot#addTrusted(UUID)} calling | ||||||
|  |      *         {@link EventDispatcher#callPlayerTrust(PlotPlayer, Plot, UUID, PlayerPlotAddRemoveEvent.Reason)} for each. | ||||||
|      */ |      */ | ||||||
|  |     @Deprecated | ||||||
|     public void setTrusted(final @NonNull Set<UUID> uuids) { |     public void setTrusted(final @NonNull Set<UUID> uuids) { | ||||||
|         boolean larger = uuids.size() > getTrusted().size(); |         boolean larger = uuids.size() > getTrusted().size(); | ||||||
|         HashSet<UUID> intersection = new HashSet<>(larger ? getTrusted() : uuids); |         HashSet<UUID> intersection = new HashSet<>(larger ? getTrusted() : uuids); | ||||||
| @@ -982,7 +1054,10 @@ public class Plot { | |||||||
|      * Sets the members for this plot. |      * Sets the members for this plot. | ||||||
|      * |      * | ||||||
|      * @param uuids uuids to set member status for |      * @param uuids uuids to set member status for | ||||||
|  |      * @deprecated Use {@link Plot#addMember(UUID)} (UUID)} (UUID)} calling | ||||||
|  |      *         {@link EventDispatcher#callPlayerAdd(PlotPlayer, Plot, UUID, PlayerPlotAddRemoveEvent.Reason)} for each. | ||||||
|      */ |      */ | ||||||
|  |     @Deprecated | ||||||
|     public void setMembers(final @NonNull Set<UUID> uuids) { |     public void setMembers(final @NonNull Set<UUID> uuids) { | ||||||
|         boolean larger = uuids.size() > getMembers().size(); |         boolean larger = uuids.size() > getMembers().size(); | ||||||
|         HashSet<UUID> intersection = new HashSet<>(larger ? getMembers() : uuids); |         HashSet<UUID> intersection = new HashSet<>(larger ? getMembers() : uuids); | ||||||
| @@ -2237,23 +2312,53 @@ public class Plot { | |||||||
|             this.setAlias(plot.getAlias()); |             this.setAlias(plot.getAlias()); | ||||||
|         } |         } | ||||||
|         for (UUID uuid : this.getTrusted()) { |         for (UUID uuid : this.getTrusted()) { | ||||||
|             plot.addTrusted(uuid); |             if (eventDispatcher | ||||||
|  |                     .callPlayerTrust(null, plot, uuid, PlayerPlotAddRemoveEvent.Reason.MERGE) | ||||||
|  |                     .getEventResult() != Result.DENY) { | ||||||
|  |                 plot.addTrusted(uuid); | ||||||
|  |                 eventDispatcher.callPostTrusted(null, plot, uuid, true, PlayerPlotAddRemoveEvent.Reason.MERGE); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|         for (UUID uuid : plot.getTrusted()) { |         for (UUID uuid : plot.getTrusted()) { | ||||||
|             this.addTrusted(uuid); |             if (eventDispatcher | ||||||
|  |                     .callPlayerTrust(null, this, uuid, PlayerPlotAddRemoveEvent.Reason.MERGE) | ||||||
|  |                     .getEventResult() != Result.DENY) { | ||||||
|  |                 this.addTrusted(uuid); | ||||||
|  |                 eventDispatcher.callPostTrusted(null, this, uuid, true, PlayerPlotAddRemoveEvent.Reason.MERGE); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|         for (UUID uuid : this.getMembers()) { |         for (UUID uuid : this.getMembers()) { | ||||||
|             plot.addMember(uuid); |             if (eventDispatcher | ||||||
|  |                     .callPlayerAdd(null, plot, uuid, PlayerPlotAddRemoveEvent.Reason.MERGE) | ||||||
|  |                     .getEventResult() != Result.DENY) { | ||||||
|  |                 plot.addMember(uuid); | ||||||
|  |                 eventDispatcher.callPostAdded(null, plot, uuid, true, PlayerPlotAddRemoveEvent.Reason.MERGE); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|         for (UUID uuid : plot.getMembers()) { |         for (UUID uuid : plot.getMembers()) { | ||||||
|             this.addMember(uuid); |             if (eventDispatcher | ||||||
|  |                     .callPlayerAdd(null, this, uuid, PlayerPlotAddRemoveEvent.Reason.MERGE) | ||||||
|  |                     .getEventResult() != Result.DENY) { | ||||||
|  |                 this.addMember(uuid); | ||||||
|  |                 eventDispatcher.callPostAdded(null, this, uuid, true, PlayerPlotAddRemoveEvent.Reason.MERGE); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         for (UUID uuid : this.getDenied()) { |         for (UUID uuid : this.getDenied()) { | ||||||
|             plot.addDenied(uuid); |             if (eventDispatcher | ||||||
|  |                     .callPlayerDeny(null, plot, uuid, PlayerPlotAddRemoveEvent.Reason.MERGE) | ||||||
|  |                     .getEventResult() != Result.DENY) { | ||||||
|  |                 plot.addDenied(uuid); | ||||||
|  |                 eventDispatcher.callPostDenied(null, plot, uuid, true, PlayerPlotAddRemoveEvent.Reason.MERGE); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|         for (UUID uuid : plot.getDenied()) { |         for (UUID uuid : plot.getDenied()) { | ||||||
|             this.addDenied(uuid); |             if (eventDispatcher | ||||||
|  |                     .callPlayerDeny(null, this, uuid, PlayerPlotAddRemoveEvent.Reason.MERGE) | ||||||
|  |                     .getEventResult() != Result.DENY) { | ||||||
|  |                 this.addDenied(uuid); | ||||||
|  |                 eventDispatcher.callPostDenied(null, this, uuid, true, PlayerPlotAddRemoveEvent.Reason.MERGE); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -21,6 +21,7 @@ package com.plotsquared.core.plot; | |||||||
| import com.google.common.collect.ImmutableMap; | import com.google.common.collect.ImmutableMap; | ||||||
| import com.google.common.collect.ImmutableSet; | import com.google.common.collect.ImmutableSet; | ||||||
| import com.google.common.collect.Lists; | import com.google.common.collect.Lists; | ||||||
|  | import com.google.inject.Inject; | ||||||
| import com.plotsquared.core.PlotSquared; | import com.plotsquared.core.PlotSquared; | ||||||
| import com.plotsquared.core.collection.QuadMap; | import com.plotsquared.core.collection.QuadMap; | ||||||
| import com.plotsquared.core.configuration.ConfigurationNode; | import com.plotsquared.core.configuration.ConfigurationNode; | ||||||
| @@ -29,6 +30,8 @@ import com.plotsquared.core.configuration.ConfigurationUtil; | |||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.configuration.file.YamlConfiguration; | import com.plotsquared.core.configuration.file.YamlConfiguration; | ||||||
|  | import com.plotsquared.core.events.PlayerPlotAddRemoveEvent; | ||||||
|  | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.generator.GridPlotWorld; | import com.plotsquared.core.generator.GridPlotWorld; | ||||||
| import com.plotsquared.core.generator.IndependentPlotGenerator; | import com.plotsquared.core.generator.IndependentPlotGenerator; | ||||||
| import com.plotsquared.core.inject.annotations.WorldConfig; | import com.plotsquared.core.inject.annotations.WorldConfig; | ||||||
| @@ -47,6 +50,7 @@ import com.plotsquared.core.plot.flag.PlotFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
| import com.plotsquared.core.queue.GlobalBlockQueue; | import com.plotsquared.core.queue.GlobalBlockQueue; | ||||||
| import com.plotsquared.core.queue.QueueCoordinator; | import com.plotsquared.core.queue.QueueCoordinator; | ||||||
|  | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
| import com.plotsquared.core.util.PlotExpression; | import com.plotsquared.core.util.PlotExpression; | ||||||
| import com.plotsquared.core.util.RegionUtil; | import com.plotsquared.core.util.RegionUtil; | ||||||
| @@ -155,6 +159,9 @@ public abstract class PlotArea implements ComponentLike { | |||||||
|     private QuadMap<PlotCluster> clusters; |     private QuadMap<PlotCluster> clusters; | ||||||
|     private String signMaterial = "OAK_WALL_SIGN"; |     private String signMaterial = "OAK_WALL_SIGN"; | ||||||
|     private String legacySignMaterial = "WALL_SIGN"; |     private String legacySignMaterial = "WALL_SIGN"; | ||||||
|  |     // These will be injected | ||||||
|  |     @Inject | ||||||
|  |     private EventDispatcher eventDispatcher; | ||||||
|  |  | ||||||
|     public PlotArea( |     public PlotArea( | ||||||
|             final @NonNull String worldName, final @Nullable String id, |             final @NonNull String worldName, final @Nullable String id, | ||||||
| @@ -1104,9 +1111,44 @@ public abstract class PlotArea implements ComponentLike { | |||||||
|                 final PlotId id = PlotId.of(x, y); |                 final PlotId id = PlotId.of(x, y); | ||||||
|                 final Plot plot = getPlotAbs(id); |                 final Plot plot = getPlotAbs(id); | ||||||
|  |  | ||||||
|                 plot.setTrusted(trusted); |                 Set<UUID> currentlyTrusted = plot.getTrusted(); | ||||||
|                 plot.setMembers(members); |                 trusted.forEach(uuid -> { | ||||||
|                 plot.setDenied(denied); |                     if (!currentlyTrusted.contains(uuid) && eventDispatcher.callPlayerTrust( | ||||||
|  |                             null, | ||||||
|  |                             plot, | ||||||
|  |                             uuid, | ||||||
|  |                             PlayerPlotAddRemoveEvent.Reason.MERGE | ||||||
|  |                     ).getEventResult() != Result.DENY) { | ||||||
|  |                         plot.addTrusted(uuid); | ||||||
|  |                         eventDispatcher.callPostTrusted(null, plot, uuid, true, PlayerPlotAddRemoveEvent.Reason.MERGE); | ||||||
|  |                     } | ||||||
|  |                 }); | ||||||
|  |  | ||||||
|  |                 Set<UUID> currentlyAdded = plot.getMembers(); | ||||||
|  |                 members.forEach(uuid -> { | ||||||
|  |                     if (!currentlyAdded.contains(uuid) && eventDispatcher.callPlayerAdd( | ||||||
|  |                             null, | ||||||
|  |                             plot, | ||||||
|  |                             uuid, | ||||||
|  |                             PlayerPlotAddRemoveEvent.Reason.MERGE | ||||||
|  |                     ).getEventResult() != Result.DENY) { | ||||||
|  |                         plot.addMember(uuid); | ||||||
|  |                         eventDispatcher.callPostAdded(null, plot, uuid, true, PlayerPlotAddRemoveEvent.Reason.MERGE); | ||||||
|  |                     } | ||||||
|  |                 }); | ||||||
|  |  | ||||||
|  |                 Set<UUID> currentlyDenied = plot.getDenied(); | ||||||
|  |                 denied.forEach(uuid -> { | ||||||
|  |                     if (!currentlyDenied.contains(uuid) && eventDispatcher.callPlayerDeny( | ||||||
|  |                             null, | ||||||
|  |                             plot, | ||||||
|  |                             uuid, | ||||||
|  |                             PlayerPlotAddRemoveEvent.Reason.MERGE | ||||||
|  |                     ).getEventResult() != Result.DENY) { | ||||||
|  |                         plot.addDenied(uuid); | ||||||
|  |                         eventDispatcher.callPostDenied(null, plot, uuid, true, PlayerPlotAddRemoveEvent.Reason.MERGE); | ||||||
|  |                     } | ||||||
|  |                 }); | ||||||
|  |  | ||||||
|                 Plot plot2; |                 Plot plot2; | ||||||
|                 if (lx) { |                 if (lx) { | ||||||
|   | |||||||
| @@ -371,8 +371,7 @@ public final class PlotModificationManager { | |||||||
|                             manager.createRoadSouthEast(current, queue); |                             manager.createRoadSouthEast(current, queue); | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                 } |                 } else if (current.isMerged(Direction.SOUTH)) { | ||||||
|                 if (current.isMerged(Direction.SOUTH)) { |  | ||||||
|                     manager.createRoadSouth(current, queue); |                     manager.createRoadSouth(current, queue); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -63,4 +63,18 @@ public class PlotTitle { | |||||||
|         return subtitle; |         return subtitle; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Provides a string representation of this plot title value (used in placeholders). | ||||||
|  |      * | ||||||
|  |      * @return the plot title representation in the format {@code "<title>" "<subtitle>"} | ||||||
|  |      * @since 7.5.5 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public String toString() { | ||||||
|  |         return "\"%s\" \"%s\"".formatted( | ||||||
|  |                 this.title != null ? this.title : "", | ||||||
|  |                 this.subtitle != null ? this.subtitle : "" | ||||||
|  |         ); | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -29,9 +29,14 @@ import com.plotsquared.core.events.PlayerBuyPlotEvent; | |||||||
| import com.plotsquared.core.events.PlayerClaimPlotEvent; | import com.plotsquared.core.events.PlayerClaimPlotEvent; | ||||||
| import com.plotsquared.core.events.PlayerEnterPlotEvent; | import com.plotsquared.core.events.PlayerEnterPlotEvent; | ||||||
| import com.plotsquared.core.events.PlayerLeavePlotEvent; | import com.plotsquared.core.events.PlayerLeavePlotEvent; | ||||||
|  | import com.plotsquared.core.events.PlayerPlotAddEvent; | ||||||
|  | import com.plotsquared.core.events.PlayerPlotAddRemoveEvent; | ||||||
| import com.plotsquared.core.events.PlayerPlotDeniedEvent; | import com.plotsquared.core.events.PlayerPlotDeniedEvent; | ||||||
|  | import com.plotsquared.core.events.PlayerPlotDenyEvent; | ||||||
| import com.plotsquared.core.events.PlayerPlotHelperEvent; | import com.plotsquared.core.events.PlayerPlotHelperEvent; | ||||||
| import com.plotsquared.core.events.PlayerPlotLimitEvent; | import com.plotsquared.core.events.PlayerPlotLimitEvent; | ||||||
|  | import com.plotsquared.core.events.PlayerPlotRemoveEvent; | ||||||
|  | import com.plotsquared.core.events.PlayerPlotTrustEvent; | ||||||
| import com.plotsquared.core.events.PlayerPlotTrustedEvent; | import com.plotsquared.core.events.PlayerPlotTrustedEvent; | ||||||
| import com.plotsquared.core.events.PlayerTeleportToPlotEvent; | import com.plotsquared.core.events.PlayerTeleportToPlotEvent; | ||||||
| import com.plotsquared.core.events.PlotAutoMergeEvent; | import com.plotsquared.core.events.PlotAutoMergeEvent; | ||||||
| @@ -51,6 +56,9 @@ import com.plotsquared.core.events.RemoveRoadEntityEvent; | |||||||
| import com.plotsquared.core.events.TeleportCause; | import com.plotsquared.core.events.TeleportCause; | ||||||
| import com.plotsquared.core.events.post.PostPlayerAutoPlotEvent; | import com.plotsquared.core.events.post.PostPlayerAutoPlotEvent; | ||||||
| import com.plotsquared.core.events.post.PostPlayerBuyPlotEvent; | import com.plotsquared.core.events.post.PostPlayerBuyPlotEvent; | ||||||
|  | import com.plotsquared.core.events.post.PostPlayerPlotAddedEvent; | ||||||
|  | import com.plotsquared.core.events.post.PostPlayerPlotDeniedEvent; | ||||||
|  | import com.plotsquared.core.events.post.PostPlayerPlotTrustedEvent; | ||||||
| import com.plotsquared.core.events.post.PostPlotChangeOwnerEvent; | import com.plotsquared.core.events.post.PostPlotChangeOwnerEvent; | ||||||
| import com.plotsquared.core.events.post.PostPlotClearEvent; | import com.plotsquared.core.events.post.PostPlotClearEvent; | ||||||
| import com.plotsquared.core.events.post.PostPlotDeleteEvent; | import com.plotsquared.core.events.post.PostPlotDeleteEvent; | ||||||
| @@ -258,6 +266,7 @@ public class EventDispatcher { | |||||||
|         return event; |         return event; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Deprecated(forRemoval = true, since = "TODO") | ||||||
|     public PlayerPlotDeniedEvent callDenied( |     public PlayerPlotDeniedEvent callDenied( | ||||||
|             PlotPlayer<?> initiator, Plot plot, UUID player, |             PlotPlayer<?> initiator, Plot plot, UUID player, | ||||||
|             boolean added |             boolean added | ||||||
| @@ -267,6 +276,7 @@ public class EventDispatcher { | |||||||
|         return event; |         return event; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Deprecated(forRemoval = true, since = "TODO") | ||||||
|     public PlayerPlotTrustedEvent callTrusted( |     public PlayerPlotTrustedEvent callTrusted( | ||||||
|             PlotPlayer<?> initiator, Plot plot, UUID player, |             PlotPlayer<?> initiator, Plot plot, UUID player, | ||||||
|             boolean added |             boolean added | ||||||
| @@ -276,6 +286,7 @@ public class EventDispatcher { | |||||||
|         return event; |         return event; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Deprecated(forRemoval = true, since = "TODO") | ||||||
|     public PlayerPlotHelperEvent callMember( |     public PlayerPlotHelperEvent callMember( | ||||||
|             PlotPlayer<?> initiator, Plot plot, UUID player, |             PlotPlayer<?> initiator, Plot plot, UUID player, | ||||||
|             boolean added |             boolean added | ||||||
| @@ -285,6 +296,62 @@ public class EventDispatcher { | |||||||
|         return event; |         return event; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public PostPlayerPlotDeniedEvent callPostDenied( | ||||||
|  |             PlotPlayer<?> initiator, Plot plot, UUID player, boolean added, PlayerPlotAddRemoveEvent.Reason reason | ||||||
|  |     ) { | ||||||
|  |         PostPlayerPlotDeniedEvent event = new PostPlayerPlotDeniedEvent(initiator, plot, player, added, reason); | ||||||
|  |         callEvent(event); | ||||||
|  |         return event; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public PostPlayerPlotTrustedEvent callPostTrusted( | ||||||
|  |             PlotPlayer<?> initiator, Plot plot, UUID player, boolean added, PlayerPlotAddRemoveEvent.Reason reason | ||||||
|  |     ) { | ||||||
|  |         PostPlayerPlotTrustedEvent event = new PostPlayerPlotTrustedEvent(initiator, plot, player, added, reason); | ||||||
|  |         callEvent(event); | ||||||
|  |         return event; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public PostPlayerPlotAddedEvent callPostAdded( | ||||||
|  |             PlotPlayer<?> initiator, Plot plot, UUID player, boolean added, PlayerPlotAddRemoveEvent.Reason reason | ||||||
|  |     ) { | ||||||
|  |         PostPlayerPlotAddedEvent event = new PostPlayerPlotAddedEvent(initiator, plot, player, added, reason); | ||||||
|  |         callEvent(event); | ||||||
|  |         return event; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public PlayerPlotDenyEvent callPlayerDeny( | ||||||
|  |             PlotPlayer<?> initiator, Plot plot, UUID player, PlayerPlotAddRemoveEvent.Reason reason | ||||||
|  |     ) { | ||||||
|  |         PlayerPlotDenyEvent event = new PlayerPlotDenyEvent(initiator, plot, player, reason); | ||||||
|  |         callEvent(event); | ||||||
|  |         return event; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public PlayerPlotTrustEvent callPlayerTrust( | ||||||
|  |             PlotPlayer<?> initiator, Plot plot, UUID player, PlayerPlotAddRemoveEvent.Reason reason | ||||||
|  |     ) { | ||||||
|  |         PlayerPlotTrustEvent event = new PlayerPlotTrustEvent(initiator, plot, player, reason); | ||||||
|  |         callEvent(event); | ||||||
|  |         return event; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public PlayerPlotAddEvent callPlayerAdd( | ||||||
|  |             PlotPlayer<?> initiator, Plot plot, UUID player, PlayerPlotAddRemoveEvent.Reason reason | ||||||
|  |     ) { | ||||||
|  |         PlayerPlotAddEvent event = new PlayerPlotAddEvent(initiator, plot, player, reason); | ||||||
|  |         callEvent(event); | ||||||
|  |         return event; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public PlayerPlotRemoveEvent callPlayerRemove( | ||||||
|  |             PlotPlayer<?> initiator, Plot plot, UUID player, PlayerPlotAddRemoveEvent.Reason reason | ||||||
|  |     ) { | ||||||
|  |         PlayerPlotRemoveEvent event = new PlayerPlotRemoveEvent(initiator, plot, player, reason); | ||||||
|  |         callEvent(event); | ||||||
|  |         return event; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public PlotChangeOwnerEvent callOwnerChange( |     public PlotChangeOwnerEvent callOwnerChange( | ||||||
|             PlotPlayer<?> initiator, Plot plot, UUID oldOwner, |             PlotPlayer<?> initiator, Plot plot, UUID oldOwner, | ||||||
|             UUID newOwner, boolean hasOldOwner |             UUID newOwner, boolean hasOldOwner | ||||||
|   | |||||||
| @@ -135,6 +135,7 @@ public abstract class SchematicHandler { | |||||||
|         } |         } | ||||||
|         final String filename; |         final String filename; | ||||||
|         final String website; |         final String website; | ||||||
|  |         final @Nullable UUID finalUuid = uuid; | ||||||
|         if (uuid == null) { |         if (uuid == null) { | ||||||
|             uuid = UUID.randomUUID(); |             uuid = UUID.randomUUID(); | ||||||
|             website = Settings.Web.URL + "upload.php?" + uuid; |             website = Settings.Web.URL + "upload.php?" + uuid; | ||||||
| @@ -144,10 +145,11 @@ public abstract class SchematicHandler { | |||||||
|             filename = file + '.' + extension; |             filename = file + '.' + extension; | ||||||
|         } |         } | ||||||
|         final URL url; |         final URL url; | ||||||
|  |         String uri = Settings.Web.URL + "?key=" + uuid + "&type=" + extension; | ||||||
|         try { |         try { | ||||||
|             url = URI.create(Settings.Web.URL + "?key=" + uuid + "&type=" + extension).toURL(); |             url = URI.create(uri).toURL(); | ||||||
|         } catch (MalformedURLException e) { |         } catch (MalformedURLException e) { | ||||||
|             e.printStackTrace(); |             LOGGER.error("Malformed URI `{}`", uri, e); | ||||||
|             whenDone.run(); |             whenDone.run(); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -193,7 +195,7 @@ public abstract class SchematicHandler { | |||||||
|                 } |                 } | ||||||
|                 TaskManager.runTask(whenDone); |                 TaskManager.runTask(whenDone); | ||||||
|             } catch (IOException e) { |             } catch (IOException e) { | ||||||
|                 e.printStackTrace(); |                 LOGGER.error("Error while uploading schematic for UUID {}", finalUuid, e); | ||||||
|                 TaskManager.runTask(whenDone); |                 TaskManager.runTask(whenDone); | ||||||
|             } |             } | ||||||
|         }); |         }); | ||||||
| @@ -388,8 +390,14 @@ public abstract class SchematicHandler { | |||||||
|             } |             } | ||||||
|             queue.enqueue(); |             queue.enqueue(); | ||||||
|         } catch (Exception e) { |         } catch (Exception e) { | ||||||
|             e.printStackTrace(); |  | ||||||
|             TaskManager.runTask(whenDone); |             TaskManager.runTask(whenDone); | ||||||
|  |             LOGGER.error( | ||||||
|  |                     "Error pasting schematic to plot {};{} for player {}", | ||||||
|  |                     plot.getArea(), | ||||||
|  |                     plot.getId(), | ||||||
|  |                     actor == null ? "null" : actor.getName(), | ||||||
|  |                     e | ||||||
|  |             ); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -456,7 +464,7 @@ public abstract class SchematicHandler { | |||||||
|                 Clipboard clip = reader.read(); |                 Clipboard clip = reader.read(); | ||||||
|                 return new Schematic(clip); |                 return new Schematic(clip); | ||||||
|             } catch (IOException e) { |             } catch (IOException e) { | ||||||
|                 e.printStackTrace(); |                 LOGGER.error("Error reading schematic from file {}", file.getAbsolutePath(), e); | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             throw new UnsupportedFormatException("This schematic format is not recognised or supported."); |             throw new UnsupportedFormatException("This schematic format is not recognised or supported."); | ||||||
| @@ -470,7 +478,7 @@ public abstract class SchematicHandler { | |||||||
|             InputStream inputStream = Channels.newInputStream(readableByteChannel); |             InputStream inputStream = Channels.newInputStream(readableByteChannel); | ||||||
|             return getSchematic(inputStream); |             return getSchematic(inputStream); | ||||||
|         } catch (IOException e) { |         } catch (IOException e) { | ||||||
|             e.printStackTrace(); |             LOGGER.error("Error reading schematic from {}", url, e); | ||||||
|         } |         } | ||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
| @@ -486,7 +494,7 @@ public abstract class SchematicHandler { | |||||||
|                 Clipboard clip = schematicReader.read(); |                 Clipboard clip = schematicReader.read(); | ||||||
|                 return new Schematic(clip); |                 return new Schematic(clip); | ||||||
|             } catch (IOException e) { |             } catch (IOException e) { | ||||||
|                 e.printStackTrace(); |                 LOGGER.error("Error reading schematic", e); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         return null; |         return null; | ||||||
| @@ -515,7 +523,7 @@ public abstract class SchematicHandler { | |||||||
|             } |             } | ||||||
|             return schematics; |             return schematics; | ||||||
|         } catch (JsonParseException | IOException e) { |         } catch (JsonParseException | IOException e) { | ||||||
|             e.printStackTrace(); |             LOGGER.error("Error retrieving saves for UUID {}", uuid, e); | ||||||
|         } |         } | ||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
| @@ -532,7 +540,7 @@ public abstract class SchematicHandler { | |||||||
|                 try (NBTOutputStream nos = new NBTOutputStream(new GZIPOutputStream(output, true))) { |                 try (NBTOutputStream nos = new NBTOutputStream(new GZIPOutputStream(output, true))) { | ||||||
|                     nos.writeNamedTag("Schematic", tag); |                     nos.writeNamedTag("Schematic", tag); | ||||||
|                 } catch (IOException e1) { |                 } catch (IOException e1) { | ||||||
|                     e1.printStackTrace(); |                     LOGGER.error("Error uploading schematic for UUID {}", uuid, e1); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }, whenDone); |         }, whenDone); | ||||||
| @@ -556,9 +564,9 @@ public abstract class SchematicHandler { | |||||||
|                 nbtStream.writeNamedTag("Schematic", tag); |                 nbtStream.writeNamedTag("Schematic", tag); | ||||||
|             } |             } | ||||||
|         } catch (FileNotFoundException e) { |         } catch (FileNotFoundException e) { | ||||||
|             e.printStackTrace(); |             LOGGER.error("Error saving schematic at {}", path, e); | ||||||
|         } catch (IOException e) { |         } catch (IOException e) { | ||||||
|             e.printStackTrace(); |             LOGGER.error("Error saving schematic at {}", path, e); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         return true; |         return true; | ||||||
| @@ -581,7 +589,7 @@ public abstract class SchematicHandler { | |||||||
|         schematic.put("BlockData", new ByteArrayTag(buffer.toByteArray())); |         schematic.put("BlockData", new ByteArrayTag(buffer.toByteArray())); | ||||||
|         schematic.put("BlockEntities", new ListTag(CompoundTag.class, tileEntities)); |         schematic.put("BlockEntities", new ListTag(CompoundTag.class, tileEntities)); | ||||||
|  |  | ||||||
|         if (biomeBuffer.size() == 0 || biomePalette.size() == 0) { |         if (biomeBuffer.size() == 0 || biomePalette.isEmpty()) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -733,10 +741,7 @@ public abstract class SchematicHandler { | |||||||
|                                     } |                                     } | ||||||
|                                     BaseBlock block = aabb.getWorld().getFullBlock(point); |                                     BaseBlock block = aabb.getWorld().getFullBlock(point); | ||||||
|                                     if (block.getNbtData() != null) { |                                     if (block.getNbtData() != null) { | ||||||
|                                         Map<String, Tag> values = new HashMap<>(); |                                         Map<String, Tag> values = new HashMap<>(block.getNbtData().getValue()); | ||||||
|                                         for (Map.Entry<String, Tag> entry : block.getNbtData().getValue().entrySet()) { |  | ||||||
|                                             values.put(entry.getKey(), entry.getValue()); |  | ||||||
|                                         } |  | ||||||
|  |  | ||||||
|                                         // Positions are kept in NBT, we don't want that. |                                         // Positions are kept in NBT, we don't want that. | ||||||
|                                         values.remove("x"); |                                         values.remove("x"); | ||||||
|   | |||||||
| @@ -49,10 +49,12 @@ import java.util.Collection; | |||||||
| import java.util.Collections; | import java.util.Collections; | ||||||
| import java.util.Locale; | import java.util.Locale; | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
|  | import java.util.Set; | ||||||
| import java.util.TimeZone; | import java.util.TimeZone; | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
| import java.util.concurrent.TimeUnit; | import java.util.concurrent.TimeUnit; | ||||||
| import java.util.function.BiFunction; | import java.util.function.BiFunction; | ||||||
|  | import java.util.stream.Collectors; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Registry that contains {@link Placeholder placeholders} |  * Registry that contains {@link Placeholder placeholders} | ||||||
| @@ -127,6 +129,22 @@ public final class PlaceholderRegistry { | |||||||
|             } |             } | ||||||
|             return legacyComponent(TranslatableCaption.of("info.unknown"), player); |             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) -> { |         this.createPlaceholder("currentplot_members", (player, plot) -> { | ||||||
|             if (plot.getMembers().isEmpty() && plot.getTrusted().isEmpty()) { |             if (plot.getMembers().isEmpty() && plot.getTrusted().isEmpty()) { | ||||||
|                 return legacyComponent(TranslatableCaption.of("info.none"), player); |                 return legacyComponent(TranslatableCaption.of("info.none"), player); | ||||||
|   | |||||||
| @@ -234,6 +234,7 @@ | |||||||
|   "invalid.not_valid_number": "<prefix><red>That's not a valid number within the range: </red><gray><value></gray>", |   "invalid.not_valid_number": "<prefix><red>That's not a valid number within the range: </red><gray><value></gray>", | ||||||
|   "invalid.not_valid_plot_id": "<prefix><red>That's not a valid plot ID.</red>", |   "invalid.not_valid_plot_id": "<prefix><red>That's not a valid plot ID.</red>", | ||||||
|   "invalid.origin_cant_be_target": "<prefix><red>The origin and target location cannot be the same.</red>", |   "invalid.origin_cant_be_target": "<prefix><red>The origin and target location cannot be the same.</red>", | ||||||
|  |   "invalid.world_location_plot": "<prefix><red>The target plot is invalid.</red>", | ||||||
|   "invalid.found_no_plots": "<prefix><red>Found no plots with your search query.</red>", |   "invalid.found_no_plots": "<prefix><red>Found no plots with your search query.</red>", | ||||||
|   "invalid.number_not_in_range": "<prefix><red>That's not a valid number within the range: <gray>(<min>, <max>)</gray></red>", |   "invalid.number_not_in_range": "<prefix><red>That's not a valid number within the range: <gray>(<min>, <max>)</gray></red>", | ||||||
|   "invalid.number_not_positive": "<red>That's not a positive number: <gray><value></gray></red>", |   "invalid.number_not_positive": "<red>That's not a positive number: <gray><value></gray></red>", | ||||||
| @@ -414,6 +415,7 @@ | |||||||
|   "deny.denied_added": "<prefix><dark_aqua>You successfully denied the player from this plot.</dark_aqua>", |   "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.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.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>", |   "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.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>", |   "kick.cannot_kick_player": "<prefix><red>You cannot kick the player <gray><player></gray>.</red>", | ||||||
| @@ -456,7 +458,7 @@ | |||||||
|   "category.command_category_debug": "<gray>Debug</gray>", |   "category.command_category_debug": "<gray>Debug</gray>", | ||||||
|   "category.command_category_administration": "<gray>Admin</gray>", |   "category.command_category_administration": "<gray>Admin</gray>", | ||||||
|   "grants.granted_plots": "<prefix><gold>Result: <gray><amount> </gray>grants left.</gold>", |   "grants.granted_plots": "<prefix><gold>Result: <gray><amount> </gray>grants left.</gold>", | ||||||
|   "grants.added": "<prefix><gold><grants></gold> <gray>grant(s) have been added.</gray>", |   "grants.added": "<prefix><gold>1</gold> <gray>grant has been added. (<grants> total grants)</gray>", | ||||||
|   "events.event_denied": "<prefix><gold><value> </gold><gray>Cancelled by external plugin.</gray>", |   "events.event_denied": "<prefix><gold><value> </gold><gray>Cancelled by external plugin.</gray>", | ||||||
|   "backups.backup_impossible": "<prefix><red>Backups are not enabled for this plot: <plot>.</red>", |   "backups.backup_impossible": "<prefix><red>Backups are not enabled for this plot: <plot>.</red>", | ||||||
|   "backups.backup_save_success": "<prefix><gold>The backup was created successfully.</gold>", |   "backups.backup_save_success": "<prefix><gold>The backup was created successfully.</gold>", | ||||||
|   | |||||||
| @@ -1,9 +1,7 @@ | |||||||
| import com.diffplug.gradle.spotless.SpotlessPlugin | import com.diffplug.gradle.spotless.SpotlessPlugin | ||||||
| import com.github.jengelman.gradle.plugins.shadow.ShadowPlugin | import com.github.jengelman.gradle.plugins.shadow.ShadowPlugin | ||||||
| import com.vanniktech.maven.publish.SonatypeHost |  | ||||||
| import groovy.json.JsonSlurper | import groovy.json.JsonSlurper | ||||||
| import xyz.jpenilla.runpaper.task.RunServer | import xyz.jpenilla.runpaper.task.RunServer | ||||||
| import java.net.URI |  | ||||||
|  |  | ||||||
| plugins { | plugins { | ||||||
|     java |     java | ||||||
| @@ -22,7 +20,7 @@ plugins { | |||||||
| } | } | ||||||
|  |  | ||||||
| group = "com.intellectualsites.plotsquared" | group = "com.intellectualsites.plotsquared" | ||||||
| version = "7.5.5-SNAPSHOT" | version = "7.5.9-SNAPSHOT" | ||||||
|  |  | ||||||
| if (!File("$rootDir/.git").exists()) { | if (!File("$rootDir/.git").exists()) { | ||||||
|     logger.lifecycle(""" |     logger.lifecycle(""" | ||||||
| @@ -69,8 +67,8 @@ subprojects { | |||||||
|  |  | ||||||
|     dependencies { |     dependencies { | ||||||
|         // Tests |         // Tests | ||||||
|         testImplementation("org.junit.jupiter:junit-jupiter:5.13.3") |         testImplementation("org.junit.jupiter:junit-jupiter:5.14.0") | ||||||
|         testRuntimeOnly("org.junit.platform:junit-platform-launcher:1.13.3") |         testRuntimeOnly("org.junit.platform:junit-platform-launcher:1.14.0") | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     plugins.withId("java") { |     plugins.withId("java") { | ||||||
| @@ -172,7 +170,7 @@ subprojects { | |||||||
|                 url.set("https://github.com/IntellectualSites/PlotSquared/issues") |                 url.set("https://github.com/IntellectualSites/PlotSquared/issues") | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             publishToMavenCentral(SonatypeHost.CENTRAL_PORTAL) |             publishToMavenCentral() | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -206,7 +204,7 @@ tasks.getByName<Jar>("jar") { | |||||||
|     enabled = false |     enabled = false | ||||||
| } | } | ||||||
|  |  | ||||||
| val supportedVersions = listOf("1.19.4", "1.20.6", "1.21.1", "1.21.3", "1.21.4", "1.21.5") | val supportedVersions = listOf("1.19.4", "1.20.6", "1.21.1", "1.21.3", "1.21.4", "1.21.5", "1.21.6", "1.21.7", "1.21.8") | ||||||
| tasks { | tasks { | ||||||
|     register("cacheLatestFaweArtifact") { |     register("cacheLatestFaweArtifact") { | ||||||
|         val lastSuccessfulBuildUrl = uri("https://ci.athion.net/job/FastAsyncWorldEdit/lastSuccessfulBuild/api/json").toURL() |         val lastSuccessfulBuildUrl = uri("https://ci.athion.net/job/FastAsyncWorldEdit/lastSuccessfulBuild/api/json").toURL() | ||||||
|   | |||||||
| @@ -2,21 +2,21 @@ | |||||||
| # Platform expectations | # Platform expectations | ||||||
| paper = "1.20.4-R0.1-SNAPSHOT" | paper = "1.20.4-R0.1-SNAPSHOT" | ||||||
| guice = "7.0.0" | guice = "7.0.0" | ||||||
| spotbugs = "4.9.3" | spotbugs = "4.9.6" | ||||||
| checkerqual = "3.49.5" | checkerqual = "3.51.1" | ||||||
| gson = "2.10" | gson = "2.10" | ||||||
| guava = "31.1-jre" | guava = "31.1-jre" | ||||||
| snakeyaml = "2.0" | snakeyaml = "2.0" | ||||||
| adventure = "4.23.0" | adventure = "4.24.0" | ||||||
| adventure-bukkit = "4.4.0" | adventure-bukkit = "4.4.1" | ||||||
| log4j = "2.19.0" | log4j = "2.19.0" | ||||||
|  |  | ||||||
| # Plugins | # Plugins | ||||||
| worldedit = "7.2.20" | worldedit = "7.2.20" | ||||||
| fawe = "2.13.0" | fawe = "2.13.2" | ||||||
| placeholderapi = "2.11.6" | placeholderapi = "2.11.6" | ||||||
| luckperms = "5.5" | luckperms = "5.5" | ||||||
| essentialsx = "2.21.1" | essentialsx = "2.21.2" | ||||||
| mvdwapi = "3.1.1" | mvdwapi = "3.1.1" | ||||||
|  |  | ||||||
| # Third party | # Third party | ||||||
| @@ -33,11 +33,11 @@ vault = "1.7.1" | |||||||
| serverlib = "2.3.7" | serverlib = "2.3.7" | ||||||
|  |  | ||||||
| # Gradle plugins | # Gradle plugins | ||||||
| shadow = "8.3.8" | shadow = "8.3.9" | ||||||
| grgit = "4.1.1" | grgit = "4.1.1" | ||||||
| spotless = "7.2.0" | spotless = "8.0.0" | ||||||
| publish = "0.33.0" | publish = "0.34.0" | ||||||
| runPaper = "2.3.1" | runPaper = "3.0.1" | ||||||
|  |  | ||||||
| [libraries] | [libraries] | ||||||
| # Platform expectations | # Platform expectations | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user