From 7cbaf7f8123cf45c4c965b1d2569e1983b37d6a6 Mon Sep 17 00:00:00 2001 From: Luna Date: Sat, 1 Jul 2023 17:33:02 -0300 Subject: [PATCH 1/8] Bump dependencies --- pom.xml | 4 ++-- src/main/resources/plugin.yml | 10 +++++----- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/pom.xml b/pom.xml index e98f3b39..6ce8e3ea 100644 --- a/pom.xml +++ b/pom.xml @@ -15,7 +15,7 @@ io.papermc.paper paper-api - 1.19.4-R0.1-SNAPSHOT + 1.20.1-R0.1-SNAPSHOT provided @@ -33,7 +33,7 @@ org.apache.maven.plugins maven-checkstyle-plugin - 3.2.0 + 3.3.0 checkstyle diff --git a/src/main/resources/plugin.yml b/src/main/resources/plugin.yml index 4032abf5..ac4755ea 100644 --- a/src/main/resources/plugin.yml +++ b/src/main/resources/plugin.yml @@ -1,7 +1,7 @@ name: Extras main: pw.kaboom.extras.Main description: Plugin that adds extra functionality to the server. -api-version: 1.13 +api-version: '1.20' version: master commands: @@ -18,14 +18,14 @@ commands: description: Broadcasts text in vanilla style permission: extras.broadcastvanilla clearchat: - aliases: cc + aliases: [ cc ] description: Clears messages from the chat permission: extras.clearchat console: description: Broadcasts a message as the console permission: extras.console destroyentities: - aliases: de + aliases: [ de ] description: Destroys all entities in every world permission: extras.destroyentities enchantall: @@ -40,7 +40,7 @@ commands: description: Gets the JSON of a deserialized MiniMessage component permission: extras.getjsonmm jumpscare: - aliases: scare + aliases: [ scare ] description: Scares a player permission: extras.jumpscare kaboom: @@ -58,7 +58,7 @@ commands: description: Places a pumpkin on a player's head permission: extras.pumpkin serverinfo: - aliases: specs + aliases: [ specs ] description: Shows detailed server information permission: extras.serverinfo skin: From 7b51a42080916ae286295395370ff3f80e0bae8d Mon Sep 17 00:00:00 2001 From: Luna Date: Sat, 1 Jul 2023 17:51:46 -0300 Subject: [PATCH 2/8] Remove some unnecessary checks --- src/main/java/pw/kaboom/extras/Main.java | 14 --- .../extras/modules/block/BlockCheck.java | 26 ----- .../extras/modules/block/BlockPhysics.java | 102 ------------------ .../extras/modules/entity/EntitySpawn.java | 44 +------- .../extras/modules/entity/EntityTeleport.java | 43 -------- .../extras/modules/player/PlayerInteract.java | 9 -- .../extras/modules/player/PlayerTeleport.java | 7 -- .../extras/modules/server/ServerTick.java | 19 ---- 8 files changed, 3 insertions(+), 261 deletions(-) delete mode 100644 src/main/java/pw/kaboom/extras/modules/entity/EntityTeleport.java delete mode 100644 src/main/java/pw/kaboom/extras/modules/server/ServerTick.java diff --git a/src/main/java/pw/kaboom/extras/Main.java b/src/main/java/pw/kaboom/extras/Main.java index f855b7f5..37d6c0ee 100644 --- a/src/main/java/pw/kaboom/extras/Main.java +++ b/src/main/java/pw/kaboom/extras/Main.java @@ -12,12 +12,10 @@ import pw.kaboom.extras.modules.entity.EntityExplosion; import pw.kaboom.extras.modules.entity.EntityKnockback; import pw.kaboom.extras.modules.entity.EntitySpawn; -import pw.kaboom.extras.modules.entity.EntityTeleport; import pw.kaboom.extras.modules.player.*; import pw.kaboom.extras.modules.server.ServerCommand; import pw.kaboom.extras.modules.server.ServerGameRule; import pw.kaboom.extras.modules.server.ServerTabComplete; -import pw.kaboom.extras.modules.server.ServerTick; import java.io.File; import java.util.Collections; @@ -28,16 +26,6 @@ public final class Main extends JavaPlugin { @Override public void onLoad() { - /* Fill lists */ - Collections.addAll( - BlockPhysics.getBlockFaces(), - BlockFace.NORTH, - BlockFace.SOUTH, - BlockFace.WEST, - BlockFace.EAST, - BlockFace.UP - ); - /* Load missing config.yml defaults */ getConfig().options().copyDefaults(true); saveConfig(); @@ -80,7 +68,6 @@ public void onEnable() { this.getServer().getPluginManager().registerEvents(new EntityExplosion(), this); this.getServer().getPluginManager().registerEvents(new EntityKnockback(), this); this.getServer().getPluginManager().registerEvents(new EntitySpawn(), this); - this.getServer().getPluginManager().registerEvents(new EntityTeleport(), this); /* Player-related modules */ this.getServer().getPluginManager().registerEvents(new PlayerChat(), this); @@ -96,7 +83,6 @@ public void onEnable() { this.getServer().getPluginManager().registerEvents(new ServerCommand(), this); this.getServer().getPluginManager().registerEvents(new ServerGameRule(), this); this.getServer().getPluginManager().registerEvents(new ServerTabComplete(), this); - this.getServer().getPluginManager().registerEvents(new ServerTick(), this); /* Custom worlds */ this.getServer().createWorld( diff --git a/src/main/java/pw/kaboom/extras/modules/block/BlockCheck.java b/src/main/java/pw/kaboom/extras/modules/block/BlockCheck.java index 78f92043..ff3def40 100644 --- a/src/main/java/pw/kaboom/extras/modules/block/BlockCheck.java +++ b/src/main/java/pw/kaboom/extras/modules/block/BlockCheck.java @@ -3,39 +3,13 @@ import org.bukkit.Chunk; import org.bukkit.event.EventHandler; import org.bukkit.event.Listener; -import org.bukkit.event.block.BlockPlaceEvent; -import org.bukkit.event.block.SignChangeEvent; import org.bukkit.event.world.ChunkUnloadEvent; public final class BlockCheck implements Listener { - @EventHandler - void onBlockPlace(final BlockPlaceEvent event) { - try { - final int maxItemStringLength = 3019; - - if (event.getItemInHand().toString().length() > maxItemStringLength) { - event.setCancelled(true); - } - - event.getBlockPlaced().getState(); - } catch (Exception exception) { - event.setCancelled(true); - } - } - @EventHandler void onChunkUnload(final ChunkUnloadEvent event) { for (Chunk chunk : event.getChunk().getWorld().getForceLoadedChunks()) { chunk.setForceLoaded(false); } } - - @EventHandler - void onSignChange(final SignChangeEvent event) { - try { - event.getLines(); - } catch (Exception exception) { - event.setCancelled(true); - } - } } diff --git a/src/main/java/pw/kaboom/extras/modules/block/BlockPhysics.java b/src/main/java/pw/kaboom/extras/modules/block/BlockPhysics.java index bb9adb9b..4f1bbad1 100644 --- a/src/main/java/pw/kaboom/extras/modules/block/BlockPhysics.java +++ b/src/main/java/pw/kaboom/extras/modules/block/BlockPhysics.java @@ -24,109 +24,11 @@ public final class BlockPhysics implements Listener { // This class contains code to prevent large areas of non-solid blocks // from crashing the server private static double tps = 20; - private static HashSet blockFaces = new HashSet(); - - @EventHandler - void onBlockDestroy(final BlockDestroyEvent event) { - try { - if (!event.getBlock().getType().isSolid()) { - for (BlockFace face : getBlockFaces()) { - if (event.getBlock().getRelative(face).getType() - != event.getBlock().getType()) { - return; - } - if (!event.getBlock().getType().equals(Material.AIR)) { - event.getBlock().setType(Material.AIR, false); - } - if (!event.isCancelled()) { - event.setCancelled(true); - } - } - } - } catch (Exception | StackOverflowError e) { - event.setCancelled(true); - } - } - - @EventHandler - void onBlockFade(final BlockFadeEvent event) { - try { - if (event.getBlock().getType() == Material.FIRE) { - event.getBlock().setType(Material.AIR, false); - event.setCancelled(true); - } - } catch (Exception | StackOverflowError e) { - event.setCancelled(true); - } - } - - @EventHandler - void onBlockForm(final BlockFormEvent event) { - try { - if (event.getBlock().getType() == Material.LAVA - || event.getBlock().getType() == Material.WATER) { - for (BlockFace face : getBlockFaces()) { - if (event.getBlock().getRelative(face).getType() != Material.LAVA - && event.getBlock().getRelative(face).getType() != Material.WATER) { - return; - } - event.setCancelled(true); - } - } - } catch (Exception | StackOverflowError e) { - event.setCancelled(true); - } - } - - @EventHandler - void onBlockFromTo(final BlockFromToEvent event) { - try { - if (event.getBlock().getType() == Material.LAVA - || event.getBlock().getType() == Material.WATER) { - boolean lavaFound = false; - boolean waterFound = false; - - for (BlockFace face : getBlockFaces()) { - if (event.getBlock().getRelative(face).getType() == Material.LAVA - && !lavaFound) { - lavaFound = true; - } else if (event.getBlock().getRelative(face).getType() == Material.WATER - && !waterFound) { - waterFound = true; - } - - if (lavaFound && waterFound) { - event.setCancelled(true); - return; - } - } - } - } catch (Exception | StackOverflowError e) { - event.setCancelled(true); - } - } @EventHandler void onBlockPhysics(final BlockPhysicsEvent event) { try { switch (event.getChangedType()) { - case ACTIVATOR_RAIL: - case DETECTOR_RAIL: - case POWERED_RAIL: - case RAIL: - case COMPARATOR: - case REDSTONE_TORCH: - case REDSTONE_WIRE: - case REPEATER: - case TRIPWIRE: - if (!event.getBlock().getRelative(BlockFace.DOWN).getType().isSolid() - && !Material.AIR.equals(event.getBlock().getRelative(BlockFace.DOWN) - .getType()) - && !Material.CAVE_AIR.equals(event.getBlock() - .getRelative(BlockFace.DOWN).getType())) { - event.setCancelled(true); - } - return; case COMMAND_BLOCK: case CHAIN_COMMAND_BLOCK: case REPEATING_COMMAND_BLOCK: @@ -167,10 +69,6 @@ void onEntityChangeBlock(final EntityChangeBlockEvent event) { } } - public static HashSet getBlockFaces() { - return blockFaces; - } - private static void updateTPS() { final double[] tpsValues = Bukkit.getTPS(); diff --git a/src/main/java/pw/kaboom/extras/modules/entity/EntitySpawn.java b/src/main/java/pw/kaboom/extras/modules/entity/EntitySpawn.java index 6e85fe09..1eefdf8e 100644 --- a/src/main/java/pw/kaboom/extras/modules/entity/EntitySpawn.java +++ b/src/main/java/pw/kaboom/extras/modules/entity/EntitySpawn.java @@ -19,6 +19,7 @@ import org.bukkit.entity.minecart.ExplosiveMinecart; import org.bukkit.event.EventHandler; import org.bukkit.event.Listener; +import org.bukkit.event.block.TNTPrimeEvent; import org.bukkit.event.entity.AreaEffectCloudApplyEvent; import org.bukkit.event.entity.EntitySpawnEvent; import org.bukkit.event.entity.ExplosionPrimeEvent; @@ -27,7 +28,6 @@ import org.bukkit.event.vehicle.VehicleCreateEvent; import org.bukkit.event.weather.LightningStrikeEvent; -import com.destroystokyo.paper.event.block.TNTPrimeEvent; import com.destroystokyo.paper.event.entity.PreCreatureSpawnEvent; import com.destroystokyo.paper.event.entity.PreSpawnerSpawnEvent; import org.bukkit.plugin.java.JavaPlugin; @@ -107,21 +107,6 @@ private boolean isEntityLimitReached(final EntityType entityType, final Chunk ch return false; } - private boolean isOutsideBoundaries(final double x, final double y, final double z) { - final int maxValue = 30000000; - final int minValue = -30000000; - - if (x > maxValue - || x < minValue - || y > maxValue - || y < minValue - || z > maxValue - || z < minValue) { - return true; - } - return false; - } - private void limitAreaEffectCloudRadius(final AreaEffectCloud cloud) { if (cloud.getRadius() > 40) { cloud.setRadius(40); @@ -187,11 +172,6 @@ void onEntitySpawn(final EntitySpawnEvent event) { final double y = event.getLocation().getY(); final double z = event.getLocation().getZ(); - if (isOutsideBoundaries(x, y, z)) { - event.setCancelled(true); - return; - } - final EntityType entityType = event.getEntityType(); final Chunk chunk = event.getLocation().getChunk(); final World world = event.getLocation().getWorld(); @@ -225,11 +205,6 @@ void onLightningStrike(final LightningStrikeEvent event) { final double y = lightning.getLocation().getY(); final double z = lightning.getLocation().getZ(); - if (isOutsideBoundaries(x, y, z)) { - event.setCancelled(true); - return; - } - final EntityType entityType = EntityType.LIGHTNING; final Chunk chunk = lightning.getChunk(); final World world = event.getWorld(); @@ -273,16 +248,8 @@ void onSpawnerSpawn(final SpawnerSpawnEvent event) { @EventHandler void onTNTPrime(final TNTPrimeEvent event) { - switch (event.getReason()) { - case EXPLOSION: - case FIRE: - case REDSTONE: - if (ThreadLocalRandom.current().nextBoolean()) { - event.setCancelled(true); - } - return; - default: - break; + if (ThreadLocalRandom.current().nextBoolean()) { + event.setCancelled(true); } } @@ -293,11 +260,6 @@ void onVehicleCreate(final VehicleCreateEvent event) { final double y = vehicle.getLocation().getY(); final double z = vehicle.getLocation().getZ(); - if (isOutsideBoundaries(x, y, z)) { - event.setCancelled(true); - return; - } - final EntityType entityType = vehicle.getType(); final Chunk chunk = vehicle.getChunk(); final World world = vehicle.getWorld(); diff --git a/src/main/java/pw/kaboom/extras/modules/entity/EntityTeleport.java b/src/main/java/pw/kaboom/extras/modules/entity/EntityTeleport.java deleted file mode 100644 index 8858c543..00000000 --- a/src/main/java/pw/kaboom/extras/modules/entity/EntityTeleport.java +++ /dev/null @@ -1,43 +0,0 @@ -package pw.kaboom.extras.modules.entity; - -import org.bukkit.Location; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.entity.EntityTeleportEvent; - -public final class EntityTeleport implements Listener { - public static Location limitLocation(final Location location) { - double x = location.getX(); - double y = location.getY(); - double z = location.getZ(); - - final int maxValue = 30000000; - final int minValue = -30000000; - - if (x > maxValue) { - location.setX(maxValue); - } - if (x < minValue) { - location.setX(minValue); - } - if (y > maxValue) { - location.setY(maxValue); - } - if (y < minValue) { - location.setY(minValue); - } - if (z > maxValue) { - location.setZ(maxValue); - } - if (z < minValue) { - location.setZ(minValue); - } - - return location; - } - - @EventHandler - void onEntityTeleport(final EntityTeleportEvent event) { - event.setTo(limitLocation(event.getTo())); - } -} diff --git a/src/main/java/pw/kaboom/extras/modules/player/PlayerInteract.java b/src/main/java/pw/kaboom/extras/modules/player/PlayerInteract.java index 34d5c542..f48c7be0 100644 --- a/src/main/java/pw/kaboom/extras/modules/player/PlayerInteract.java +++ b/src/main/java/pw/kaboom/extras/modules/player/PlayerInteract.java @@ -14,15 +14,6 @@ public final class PlayerInteract implements Listener { //static HashMap interactMillisList = new HashMap(); - @EventHandler - void onInventoryClick(final InventoryClickEvent event) { - try { - event.getSlot(); - } catch (Exception exception) { - event.setCancelled(true); - } - } - @EventHandler void onPlayerInteract(final PlayerInteractEvent event) { /*final UUID playerUuid = event.getPlayer().getUniqueId(); diff --git a/src/main/java/pw/kaboom/extras/modules/player/PlayerTeleport.java b/src/main/java/pw/kaboom/extras/modules/player/PlayerTeleport.java index c481801c..cf72dad4 100644 --- a/src/main/java/pw/kaboom/extras/modules/player/PlayerTeleport.java +++ b/src/main/java/pw/kaboom/extras/modules/player/PlayerTeleport.java @@ -6,8 +6,6 @@ import org.bukkit.event.player.PlayerChangedWorldEvent; import org.bukkit.event.player.PlayerTeleportEvent; -import pw.kaboom.extras.modules.entity.EntityTeleport; - public final class PlayerTeleport implements Listener { @EventHandler void onPlayerChangedWorld(final PlayerChangedWorldEvent event) { @@ -19,9 +17,4 @@ void onPlayerChangedWorld(final PlayerChangedWorldEvent event) { player.setMaxHealth(20); } } - - @EventHandler - void onPlayerTeleport(final PlayerTeleportEvent event) { - event.setTo(EntityTeleport.limitLocation(event.getTo())); - } } diff --git a/src/main/java/pw/kaboom/extras/modules/server/ServerTick.java b/src/main/java/pw/kaboom/extras/modules/server/ServerTick.java deleted file mode 100644 index f5b38b6f..00000000 --- a/src/main/java/pw/kaboom/extras/modules/server/ServerTick.java +++ /dev/null @@ -1,19 +0,0 @@ -package pw.kaboom.extras.modules.server; - -import org.bukkit.World; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.player.PlayerStatisticIncrementEvent; - -public final class ServerTick implements Listener { - @EventHandler - void onPlayerStatisticIncrement(final PlayerStatisticIncrementEvent event) { - final World world = event.getPlayer().getWorld(); - - if (!world.isAutoSave()) { - world.setAutoSave(true); - } - - event.setCancelled(true); - } -} From 9639dde2dfaad9409f35596d3ad58adc9494b786 Mon Sep 17 00:00:00 2001 From: Luna Date: Sat, 1 Jul 2023 20:44:59 -0300 Subject: [PATCH 3/8] Remove usage of deprecated APIs --- .../extras/commands/CommandConsole.java | 5 ++-- .../extras/commands/CommandUsername.java | 12 ++++----- .../extras/modules/block/BlockPhysics.java | 8 ------ .../modules/player/PlayerConnection.java | 26 +++++++++---------- .../extras/modules/player/PlayerDamage.java | 25 +++++++++++------- .../extras/modules/player/PlayerInteract.java | 4 --- .../extras/modules/player/PlayerTeleport.java | 11 +++++--- .../java/pw/kaboom/extras/util/Utility.java | 23 ++++++++++++++++ 8 files changed, 67 insertions(+), 47 deletions(-) diff --git a/src/main/java/pw/kaboom/extras/commands/CommandConsole.java b/src/main/java/pw/kaboom/extras/commands/CommandConsole.java index b487d733..aaeaead1 100644 --- a/src/main/java/pw/kaboom/extras/commands/CommandConsole.java +++ b/src/main/java/pw/kaboom/extras/commands/CommandConsole.java @@ -3,10 +3,10 @@ import net.kyori.adventure.text.Component; import net.kyori.adventure.text.format.NamedTextColor; import org.bukkit.Bukkit; -import org.bukkit.ChatColor; import org.bukkit.command.Command; import org.bukkit.command.CommandExecutor; import org.bukkit.command.CommandSender; +import pw.kaboom.extras.util.Utility; import javax.annotation.Nonnull; @@ -24,8 +24,7 @@ public boolean onCommand(final @Nonnull CommandSender sender, Bukkit.dispatchCommand( Bukkit.getConsoleSender(), - "minecraft:say " + ChatColor.translateAlternateColorCodes( - '&', String.join(" ", args)) + "minecraft:say " + Utility.translateLegacyColors(String.join(" ", args)) ); return true; } diff --git a/src/main/java/pw/kaboom/extras/commands/CommandUsername.java b/src/main/java/pw/kaboom/extras/commands/CommandUsername.java index f42804a2..f0274b5d 100644 --- a/src/main/java/pw/kaboom/extras/commands/CommandUsername.java +++ b/src/main/java/pw/kaboom/extras/commands/CommandUsername.java @@ -4,11 +4,11 @@ import net.kyori.adventure.text.Component; import net.kyori.adventure.text.format.NamedTextColor; import org.bukkit.Bukkit; -import org.bukkit.ChatColor; import org.bukkit.command.Command; import org.bukkit.command.CommandExecutor; import org.bukkit.command.CommandSender; import org.bukkit.entity.Player; +import pw.kaboom.extras.util.Utility; import javax.annotation.Nonnull; import java.util.HashMap; @@ -28,8 +28,7 @@ public boolean onCommand(final @Nonnull CommandSender sender, return true; } - final String nameColor = ChatColor.translateAlternateColorCodes( - '&', String.join(" ", args)); + final String nameColor = Utility.translateLegacyColors(String.join(" ", args)); final String name = nameColor.substring(0, Math.min(16, nameColor.length())); final long millis = lastUsedMillis.getOrDefault(player, 0L); final long millisDifference = System.currentTimeMillis() - millis; @@ -61,10 +60,11 @@ public boolean onCommand(final @Nonnull CommandSender sender, return true; } - final PlayerProfile profile = player.getPlayerProfile(); + // Preserve UUIDs, as changing them breaks clients + final PlayerProfile newProfile = Bukkit.createProfileExact(player.getUniqueId(), name); + newProfile.setProperties(player.getPlayerProfile().getProperties()); - profile.setName(name); // FIXME: Marked for removal - player.setPlayerProfile(profile); + player.setPlayerProfile(newProfile); lastUsedMillis.put(player, System.currentTimeMillis()); player.sendMessage( diff --git a/src/main/java/pw/kaboom/extras/modules/block/BlockPhysics.java b/src/main/java/pw/kaboom/extras/modules/block/BlockPhysics.java index 4f1bbad1..c7dc0059 100644 --- a/src/main/java/pw/kaboom/extras/modules/block/BlockPhysics.java +++ b/src/main/java/pw/kaboom/extras/modules/block/BlockPhysics.java @@ -1,21 +1,13 @@ package pw.kaboom.extras.modules.block; -import java.util.HashSet; - import org.bukkit.Bukkit; import org.bukkit.Material; -import org.bukkit.block.BlockFace; import org.bukkit.entity.EntityType; import org.bukkit.event.EventHandler; import org.bukkit.event.Listener; -import org.bukkit.event.block.BlockFadeEvent; -import org.bukkit.event.block.BlockFormEvent; -import org.bukkit.event.block.BlockFromToEvent; import org.bukkit.event.block.BlockPhysicsEvent; import org.bukkit.event.block.BlockRedstoneEvent; import org.bukkit.event.entity.EntityChangeBlockEvent; - -import com.destroystokyo.paper.event.block.BlockDestroyEvent; import org.bukkit.scheduler.BukkitScheduler; import pw.kaboom.extras.Main; diff --git a/src/main/java/pw/kaboom/extras/modules/player/PlayerConnection.java b/src/main/java/pw/kaboom/extras/modules/player/PlayerConnection.java index be42ea91..6f1ee1d4 100644 --- a/src/main/java/pw/kaboom/extras/modules/player/PlayerConnection.java +++ b/src/main/java/pw/kaboom/extras/modules/player/PlayerConnection.java @@ -3,6 +3,8 @@ import com.destroystokyo.paper.event.profile.PreLookupProfileEvent; import com.destroystokyo.paper.profile.ProfileProperty; import com.google.common.base.Charsets; +import net.kyori.adventure.text.Component; +import net.kyori.adventure.title.Title; import org.bukkit.Bukkit; import org.bukkit.Location; import org.bukkit.Server; @@ -20,6 +22,7 @@ import pw.kaboom.extras.modules.player.skin.SkinManager; import pw.kaboom.extras.util.Utility; +import java.time.Duration; import java.util.HashSet; import java.util.UUID; import java.util.concurrent.ThreadLocalRandom; @@ -28,9 +31,9 @@ public final class PlayerConnection implements Listener { private static final FileConfiguration CONFIG = JavaPlugin.getPlugin(Main.class).getConfig(); private static final String TITLE = CONFIG.getString("playerJoinTitle"); private static final String SUBTITLE = CONFIG.getString("playerJoinSubtitle"); - private static final int FADE_IN = 10; - private static final int STAY = 160; - private static final int FADE_OUT = 5; + private static final Duration FADE_IN = Duration.ofMillis(50); + private static final Duration STAY = Duration.ofMillis(8000); + private static final Duration FADE_OUT = Duration.ofMillis(250); private static final boolean ENABLE_KICK = CONFIG.getBoolean("enableKick"); private static final boolean ENABLE_JOIN_RESTRICTIONS = CONFIG.getBoolean( @@ -46,7 +49,7 @@ void onAsyncPlayerPreLogin(final AsyncPlayerPreLoginEvent event) { if (player != null) { event.disallow(AsyncPlayerPreLoginEvent.Result.KICK_OTHER, - "A player with that username is already logged in"); + Component.text("A player with that username is already logged in")); } /*try { @@ -67,15 +70,12 @@ void onAsyncPlayerPreLogin(final AsyncPlayerPreLoginEvent event) { void onPlayerJoin(final PlayerJoinEvent event) { final Player player = event.getPlayer(); - if (TITLE != null - || SUBTITLE != null) { - player.sendTitle( - TITLE, - SUBTITLE, - FADE_IN, - STAY, - FADE_OUT - ); + if (TITLE != null || SUBTITLE != null) { + player.showTitle(Title.title( + Component.text(TITLE), + Component.text(SUBTITLE), + Title.Times.times(FADE_IN, STAY, FADE_OUT) + )); } ServerTabComplete.getLoginNameList().put(player.getUniqueId(), player.getName()); diff --git a/src/main/java/pw/kaboom/extras/modules/player/PlayerDamage.java b/src/main/java/pw/kaboom/extras/modules/player/PlayerDamage.java index 6257d42e..cf95d3f2 100644 --- a/src/main/java/pw/kaboom/extras/modules/player/PlayerDamage.java +++ b/src/main/java/pw/kaboom/extras/modules/player/PlayerDamage.java @@ -2,6 +2,8 @@ import org.bukkit.Bukkit; import org.bukkit.World; +import org.bukkit.attribute.Attribute; +import org.bukkit.attribute.AttributeInstance; import org.bukkit.entity.EntityType; import org.bukkit.entity.ExperienceOrb; import org.bukkit.entity.HumanEntity; @@ -15,6 +17,7 @@ import org.bukkit.event.entity.PlayerDeathEvent; import org.bukkit.inventory.ItemStack; import org.bukkit.potion.PotionEffect; +import pw.kaboom.extras.util.Utility; public final class PlayerDamage implements Listener { @EventHandler @@ -34,19 +37,17 @@ void onEntityRegainHealth(final EntityRegainHealthEvent event) { } } - @SuppressWarnings("deprecation") @EventHandler void onFoodLevelChange(final FoodLevelChangeEvent event) { final HumanEntity player = event.getEntity(); - - if (player.getMaxHealth() <= 0) { - player.setMaxHealth(Double.POSITIVE_INFINITY); + final AttributeInstance attribute = player.getAttribute(Attribute.GENERIC_MAX_HEALTH); + if (attribute == null) return; + if (attribute.getValue() <= 0) { + Utility.resetAttribute(attribute); player.setHealth(20); - player.setMaxHealth(20); } } - @SuppressWarnings("deprecation") @EventHandler void onPlayerDeath(final PlayerDeathEvent event) { final Player player = event.getEntity(); @@ -70,7 +71,11 @@ void onPlayerDeath(final PlayerDeathEvent event) { xp.setExperience(event.getDroppedExp()); } - player.setMaxHealth(20); + final AttributeInstance attribute = player.getAttribute(Attribute.GENERIC_MAX_HEALTH); + if (attribute != null) { + Utility.resetAttribute(attribute); + } + player.setHealth(20); if (player.getBedSpawnLocation() != null) { @@ -80,9 +85,11 @@ void onPlayerDeath(final PlayerDeathEvent event) { player.teleportAsync(world.getSpawnLocation()); } } catch (Exception exception) { - player.setMaxHealth(Double.POSITIVE_INFINITY); + final AttributeInstance attribute = player.getAttribute(Attribute.GENERIC_MAX_HEALTH); + if (attribute != null) { + Utility.resetAttribute(attribute); + } player.setHealth(20); - player.setMaxHealth(20); } player.setExp(event.getNewExp()); diff --git a/src/main/java/pw/kaboom/extras/modules/player/PlayerInteract.java b/src/main/java/pw/kaboom/extras/modules/player/PlayerInteract.java index f48c7be0..b5786040 100644 --- a/src/main/java/pw/kaboom/extras/modules/player/PlayerInteract.java +++ b/src/main/java/pw/kaboom/extras/modules/player/PlayerInteract.java @@ -1,13 +1,9 @@ package pw.kaboom.extras.modules.player; import org.bukkit.Material; -import org.bukkit.block.BlockState; -import org.bukkit.block.Sign; import org.bukkit.enchantments.Enchantment; import org.bukkit.event.EventHandler; import org.bukkit.event.Listener; -import org.bukkit.event.block.Action; -import org.bukkit.event.inventory.InventoryClickEvent; import org.bukkit.event.player.PlayerInteractEvent; import org.bukkit.inventory.ItemStack; diff --git a/src/main/java/pw/kaboom/extras/modules/player/PlayerTeleport.java b/src/main/java/pw/kaboom/extras/modules/player/PlayerTeleport.java index cf72dad4..bc58b079 100644 --- a/src/main/java/pw/kaboom/extras/modules/player/PlayerTeleport.java +++ b/src/main/java/pw/kaboom/extras/modules/player/PlayerTeleport.java @@ -1,20 +1,23 @@ package pw.kaboom.extras.modules.player; +import org.bukkit.attribute.Attribute; +import org.bukkit.attribute.AttributeInstance; import org.bukkit.entity.Player; import org.bukkit.event.EventHandler; import org.bukkit.event.Listener; import org.bukkit.event.player.PlayerChangedWorldEvent; -import org.bukkit.event.player.PlayerTeleportEvent; +import pw.kaboom.extras.util.Utility; public final class PlayerTeleport implements Listener { @EventHandler void onPlayerChangedWorld(final PlayerChangedWorldEvent event) { final Player player = event.getPlayer(); - if (player.getMaxHealth() <= 0) { - player.setMaxHealth(Double.POSITIVE_INFINITY); + final AttributeInstance attribute = player.getAttribute(Attribute.GENERIC_MAX_HEALTH); + if (attribute == null) return; + if (attribute.getValue() <= 0) { + Utility.resetAttribute(attribute); player.setHealth(20); - player.setMaxHealth(20); } } } diff --git a/src/main/java/pw/kaboom/extras/util/Utility.java b/src/main/java/pw/kaboom/extras/util/Utility.java index e10c9bb3..ec56487e 100644 --- a/src/main/java/pw/kaboom/extras/util/Utility.java +++ b/src/main/java/pw/kaboom/extras/util/Utility.java @@ -1,8 +1,11 @@ package pw.kaboom.extras.util; import org.bukkit.Bukkit; +import org.bukkit.attribute.AttributeInstance; +import org.bukkit.attribute.AttributeModifier; import org.bukkit.entity.Player; +import javax.annotation.Nonnull; import javax.annotation.Nullable; public final class Utility { @@ -13,4 +16,24 @@ public final class Utility { .findFirst() .orElse(null); } + + public static void resetAttribute(final AttributeInstance attribute) { + for (final AttributeModifier modifier: attribute.getModifiers()) { + attribute.removeModifier(modifier); + } + + attribute.setBaseValue(attribute.getDefaultValue()); + } + + // TODO: Support hex color codes, too (they aren't supported in Spigot either) + public static String translateLegacyColors(@Nonnull String text) { + char[] b = text.toCharArray(); + for (int i = 0; i < b.length - 1; i++) { + if (b[i] == '&' && "0123456789AaBbCcDdEeFfKkLlMmNnOoRrXx".indexOf(b[i + 1]) > -1) { + b[i] = '\u00a7'; + b[i + 1] = Character.toLowerCase(b[i + 1]); + } + } + return new String(b); + } } From 1a0a0ab0a071e57b7246c7aaa881338812366a28 Mon Sep 17 00:00:00 2001 From: Luna Date: Sat, 1 Jul 2023 20:52:17 -0300 Subject: [PATCH 4/8] Cleanup unused variables --- .../pw/kaboom/extras/modules/entity/EntitySpawn.java | 12 ------------ 1 file changed, 12 deletions(-) diff --git a/src/main/java/pw/kaboom/extras/modules/entity/EntitySpawn.java b/src/main/java/pw/kaboom/extras/modules/entity/EntitySpawn.java index 1eefdf8e..bbf32606 100644 --- a/src/main/java/pw/kaboom/extras/modules/entity/EntitySpawn.java +++ b/src/main/java/pw/kaboom/extras/modules/entity/EntitySpawn.java @@ -168,10 +168,6 @@ void onExplosionPrime(final ExplosionPrimeEvent event) { @EventHandler void onEntitySpawn(final EntitySpawnEvent event) { - final double x = event.getLocation().getX(); - final double y = event.getLocation().getY(); - final double z = event.getLocation().getZ(); - final EntityType entityType = event.getEntityType(); final Chunk chunk = event.getLocation().getChunk(); final World world = event.getLocation().getWorld(); @@ -201,10 +197,6 @@ void onItemSpawn(final ItemSpawnEvent event) { @EventHandler void onLightningStrike(final LightningStrikeEvent event) { final LightningStrike lightning = event.getLightning(); - final double x = lightning.getLocation().getX(); - final double y = lightning.getLocation().getY(); - final double z = lightning.getLocation().getZ(); - final EntityType entityType = EntityType.LIGHTNING; final Chunk chunk = lightning.getChunk(); final World world = event.getWorld(); @@ -256,10 +248,6 @@ void onTNTPrime(final TNTPrimeEvent event) { @EventHandler void onVehicleCreate(final VehicleCreateEvent event) { final Vehicle vehicle = event.getVehicle(); - final double x = vehicle.getLocation().getX(); - final double y = vehicle.getLocation().getY(); - final double z = vehicle.getLocation().getZ(); - final EntityType entityType = vehicle.getType(); final Chunk chunk = vehicle.getChunk(); final World world = vehicle.getWorld(); From 06d34fd3458346ac0c135d7a39c8248d886e61ac Mon Sep 17 00:00:00 2001 From: Luna Date: Sat, 1 Jul 2023 21:06:12 -0300 Subject: [PATCH 5/8] Also limit BlockFormEvent when tps is too low --- .../kaboom/extras/modules/block/BlockPhysics.java | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/src/main/java/pw/kaboom/extras/modules/block/BlockPhysics.java b/src/main/java/pw/kaboom/extras/modules/block/BlockPhysics.java index c7dc0059..f6f5405e 100644 --- a/src/main/java/pw/kaboom/extras/modules/block/BlockPhysics.java +++ b/src/main/java/pw/kaboom/extras/modules/block/BlockPhysics.java @@ -5,6 +5,7 @@ import org.bukkit.entity.EntityType; import org.bukkit.event.EventHandler; import org.bukkit.event.Listener; +import org.bukkit.event.block.BlockFormEvent; import org.bukkit.event.block.BlockPhysicsEvent; import org.bukkit.event.block.BlockRedstoneEvent; import org.bukkit.event.entity.EntityChangeBlockEvent; @@ -12,7 +13,7 @@ import pw.kaboom.extras.Main; public final class BlockPhysics implements Listener { - + private static final double MINIMUM_TPS = 10; // This class contains code to prevent large areas of non-solid blocks // from crashing the server private static double tps = 20; @@ -37,15 +38,20 @@ void onBlockPhysics(final BlockPhysicsEvent event) { @EventHandler void onBlockRedstone(final BlockRedstoneEvent event) { - final int maxTps = 10; - - if (tps < maxTps) { + if (tps < MINIMUM_TPS) { event.setNewCurrent(0); } } private int fallingBlockCount; + @EventHandler + void onBlockForm(final BlockFormEvent event) { + if (tps < MINIMUM_TPS) { + event.setCancelled(true); + } + } + @EventHandler void onEntityChangeBlock(final EntityChangeBlockEvent event) { if (event.getEntityType() == EntityType.FALLING_BLOCK From 56f36294ec225116bcaa1204c8cca4809f07992f Mon Sep 17 00:00:00 2001 From: Luna Date: Sat, 5 Aug 2023 12:57:11 -0300 Subject: [PATCH 6/8] Target 1.19.4 instead of 1.20.1 --- pom.xml | 2 +- src/main/resources/plugin.yml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/pom.xml b/pom.xml index 6ce8e3ea..3adeaf68 100644 --- a/pom.xml +++ b/pom.xml @@ -15,7 +15,7 @@ io.papermc.paper paper-api - 1.20.1-R0.1-SNAPSHOT + 1.19.4-R0.1-SNAPSHOT provided diff --git a/src/main/resources/plugin.yml b/src/main/resources/plugin.yml index ac4755ea..c31060e3 100644 --- a/src/main/resources/plugin.yml +++ b/src/main/resources/plugin.yml @@ -1,7 +1,7 @@ name: Extras main: pw.kaboom.extras.Main description: Plugin that adds extra functionality to the server. -api-version: '1.20' +api-version: '1.19' version: master commands: From b5e1aa0ac093ddab3eaa93d5576532ab08d94540 Mon Sep 17 00:00:00 2001 From: Luna Date: Thu, 17 Aug 2023 18:49:17 -0300 Subject: [PATCH 7/8] Don't randomly cancel TNT unless limit reached --- .../java/pw/kaboom/extras/modules/entity/EntitySpawn.java | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/main/java/pw/kaboom/extras/modules/entity/EntitySpawn.java b/src/main/java/pw/kaboom/extras/modules/entity/EntitySpawn.java index bbf32606..43cb8b90 100644 --- a/src/main/java/pw/kaboom/extras/modules/entity/EntitySpawn.java +++ b/src/main/java/pw/kaboom/extras/modules/entity/EntitySpawn.java @@ -240,7 +240,9 @@ void onSpawnerSpawn(final SpawnerSpawnEvent event) { @EventHandler void onTNTPrime(final TNTPrimeEvent event) { - if (ThreadLocalRandom.current().nextBoolean()) { + if (event.getBlock() + .getWorld().getEntitiesByClass(TNTPrimed.class).size() >= MAX_TNTS_PER_WORLD + && ThreadLocalRandom.current().nextBoolean()) { event.setCancelled(true); } } From b2936da79e6ec84b206d28d2f6a08e83cc65d3a7 Mon Sep 17 00:00:00 2001 From: Luna Date: Thu, 17 Aug 2023 19:07:38 -0300 Subject: [PATCH 8/8] Re-introduce autosave enabler --- src/main/java/pw/kaboom/extras/Main.java | 2 ++ .../extras/modules/server/ServerGameRule.java | 16 ++++++++++++++++ 2 files changed, 18 insertions(+) diff --git a/src/main/java/pw/kaboom/extras/Main.java b/src/main/java/pw/kaboom/extras/Main.java index 37d6c0ee..505525d1 100644 --- a/src/main/java/pw/kaboom/extras/Main.java +++ b/src/main/java/pw/kaboom/extras/Main.java @@ -80,6 +80,8 @@ public void onEnable() { this.getServer().getPluginManager().registerEvents(new PlayerPrefix(), this); /* Server-related modules */ + ServerGameRule.init(this); + this.getServer().getPluginManager().registerEvents(new ServerCommand(), this); this.getServer().getPluginManager().registerEvents(new ServerGameRule(), this); this.getServer().getPluginManager().registerEvents(new ServerTabComplete(), this); diff --git a/src/main/java/pw/kaboom/extras/modules/server/ServerGameRule.java b/src/main/java/pw/kaboom/extras/modules/server/ServerGameRule.java index 22c7e8dd..f891c69c 100644 --- a/src/main/java/pw/kaboom/extras/modules/server/ServerGameRule.java +++ b/src/main/java/pw/kaboom/extras/modules/server/ServerGameRule.java @@ -1,9 +1,13 @@ package pw.kaboom.extras.modules.server; import io.papermc.paper.event.world.WorldGameRuleChangeEvent; +import org.bukkit.Bukkit; import org.bukkit.GameRule; +import org.bukkit.World; import org.bukkit.event.EventHandler; import org.bukkit.event.Listener; +import org.bukkit.scheduler.BukkitScheduler; +import pw.kaboom.extras.Main; public final class ServerGameRule implements Listener { @EventHandler @@ -19,4 +23,16 @@ void onGameRuleChange(final WorldGameRuleChangeEvent event) { event.setCancelled(true); } } + + private static void enableAutoSave() { + for (final World world: Bukkit.getWorlds()) { + world.setAutoSave(true); + } + } + + public static void init(final Main main) { + final BukkitScheduler scheduler = Bukkit.getScheduler(); + + scheduler.runTaskTimer(main, ServerGameRule::enableAutoSave, 0L, 600L); // 30 seconds + } }