TF-EssentialsX/Essentials/src/com/earth2me/essentials/EssentialsPlayerListener.java

649 lines
17 KiB
Java
Raw Normal View History

2011-09-28 23:38:56 +00:00
package com.earth2me.essentials;
2011-12-01 13:42:39 +00:00
import static com.earth2me.essentials.I18n._;
import com.earth2me.essentials.textreader.IText;
import com.earth2me.essentials.textreader.KeywordReplacer;
import com.earth2me.essentials.textreader.TextInput;
import com.earth2me.essentials.textreader.TextPager;
import java.io.IOException;
2011-09-28 23:38:56 +00:00
import java.util.Iterator;
import java.util.List;
import java.util.Locale;
2011-09-28 23:38:56 +00:00
import java.util.logging.Level;
import java.util.logging.Logger;
import org.bukkit.GameMode;
2011-09-28 23:38:56 +00:00
import org.bukkit.Location;
import org.bukkit.Material;
import org.bukkit.World;
import org.bukkit.entity.HumanEntity;
2011-09-28 23:38:56 +00:00
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener;
import org.bukkit.event.inventory.InventoryClickEvent;
import org.bukkit.event.inventory.InventoryCloseEvent;
import org.bukkit.event.inventory.InventoryType;
2011-11-18 17:42:26 +00:00
import org.bukkit.event.player.*;
import org.bukkit.event.player.PlayerLoginEvent.Result;
import org.bukkit.event.player.PlayerTeleportEvent.TeleportCause;
2013-01-01 18:39:23 +00:00
import org.bukkit.inventory.Inventory;
import org.bukkit.inventory.InventoryHolder;
2011-09-28 23:38:56 +00:00
import org.bukkit.inventory.ItemStack;
public class EssentialsPlayerListener implements Listener
2011-09-28 23:38:56 +00:00
{
private static final Logger LOGGER = Logger.getLogger("Minecraft");
private final transient IEssentials ess;
2012-04-15 22:13:34 +00:00
private static final int AIR = Material.AIR.getId();
private static final int BED = Material.BED_BLOCK.getId();
2011-09-28 23:38:56 +00:00
public EssentialsPlayerListener(final IEssentials parent)
{
this.ess = parent;
}
@EventHandler(priority = EventPriority.NORMAL)
2011-09-28 23:38:56 +00:00
public void onPlayerRespawn(final PlayerRespawnEvent event)
{
final User user = ess.getUser(event.getPlayer());
updateCompass(user);
2012-03-21 23:54:57 +00:00
user.setDisplayNick();
2011-09-28 23:38:56 +00:00
}
@EventHandler(priority = EventPriority.LOWEST)
public void onPlayerChat(final AsyncPlayerChatEvent event)
2011-09-28 23:38:56 +00:00
{
final User user = ess.getUser(event.getPlayer());
if (user.isMuted())
{
event.setCancelled(true);
user.sendMessage(_("playerMuted"));
LOGGER.info(_("mutedUserSpeaks", user.getName()));
2011-09-28 23:38:56 +00:00
}
final Iterator<Player> it = event.getRecipients().iterator();
while (it.hasNext())
{
final User u = ess.getUser(it.next());
if (u.isIgnoredPlayer(user))
2011-09-28 23:38:56 +00:00
{
it.remove();
}
}
user.updateActivity(true);
2012-03-21 23:54:57 +00:00
user.setDisplayNick();
2011-09-28 23:38:56 +00:00
}
@EventHandler(priority = EventPriority.HIGH, ignoreCancelled = true)
2011-09-28 23:38:56 +00:00
public void onPlayerMove(final PlayerMoveEvent event)
{
2012-12-31 05:44:20 +00:00
if (!ess.getSettings().cancelAfkOnMove() && !ess.getSettings().getFreezeAfkPlayers())
{
2012-12-31 12:15:51 +00:00
event.getHandlers().unregister(this);
2012-12-31 05:44:20 +00:00
if (ess.getSettings().isDebug())
{
LOGGER.log(Level.INFO, "Unregistering move listener");
}
return;
}
if (event.getFrom().getBlockX() == event.getTo().getBlockX()
&& event.getFrom().getBlockZ() == event.getTo().getBlockZ()
&& event.getFrom().getBlockY() == event.getTo().getBlockY())
{
return;
}
2011-09-28 23:38:56 +00:00
final User user = ess.getUser(event.getPlayer());
if (user.isAfk() && ess.getSettings().getFreezeAfkPlayers())
2011-09-28 23:38:56 +00:00
{
final Location from = event.getFrom();
final Location origTo = event.getTo();
final Location to = origTo.clone();
if (ess.getSettings().cancelAfkOnMove() && origTo.getY() >= from.getBlockY() + 1)
{
user.updateActivity(true);
return;
}
to.setX(from.getX());
to.setY(from.getY());
to.setZ(from.getZ());
try
{
event.setTo(Util.getSafeDestination(to));
}
catch (Exception ex)
{
event.setTo(to);
}
return;
}
final Location afk = user.getAfkPosition();
if (afk == null || !event.getTo().getWorld().equals(afk.getWorld()) || afk.distanceSquared(event.getTo()) > 9)
{
user.updateActivity(true);
2011-09-28 23:38:56 +00:00
}
}
@EventHandler(priority = EventPriority.MONITOR)
2011-09-28 23:38:56 +00:00
public void onPlayerQuit(final PlayerQuitEvent event)
{
final User user = ess.getUser(event.getPlayer());
if (ess.getSettings().removeGodOnDisconnect() && user.isGodModeEnabled())
{
2012-06-10 18:20:24 +00:00
user.setGodModeEnabled(false);
2011-09-28 23:38:56 +00:00
}
2012-06-10 23:17:19 +00:00
if (user.isVanished())
{
user.toggleVanished();
}
user.setLogoutLocation();
if (user.isRecipeSee())
{
user.getPlayer().getOpenInventory().getTopInventory().clear();
}
2011-09-28 23:38:56 +00:00
user.updateActivity(false);
user.dispose();
}
@EventHandler(priority = EventPriority.MONITOR)
2011-09-28 23:38:56 +00:00
public void onPlayerJoin(final PlayerJoinEvent event)
{
ess.runTaskAsynchronously(new Runnable()
{
@Override
public void run()
{
delayedJoin(event.getPlayer());
}
});
}
2012-03-25 16:27:06 +00:00
public void delayedJoin(final Player player)
{
if (!player.isOnline())
{
return;
}
ess.getBackup().onPlayerJoin();
final User user = ess.getUser(player);
if (user.isNPC())
{
user.setNPC(false);
}
final long currentTime = System.currentTimeMillis();
user.checkMuteTimeout(currentTime);
2011-09-28 23:38:56 +00:00
user.updateActivity(false);
2013-01-29 23:51:42 +00:00
ess.scheduleSyncDelayedTask(new Runnable()
{
@Override
public void run()
{
user.setLastLogin(currentTime);
2013-01-29 23:51:42 +00:00
user.setDisplayNick();
updateCompass(user);
if (!ess.getVanishedPlayers().isEmpty() && !user.isAuthorized("essentials.vanish.see"))
{
for (String p : ess.getVanishedPlayers())
{
Player toVanish = ess.getServer().getPlayerExact(p);
if (toVanish != null && toVanish.isOnline())
{
user.hidePlayer(toVanish);
}
}
2012-09-09 19:13:03 +00:00
}
if (user.isAuthorized("essentials.sleepingignored"))
{
user.setSleepingIgnored(true);
}
2011-09-28 23:38:56 +00:00
if (!ess.getSettings().isCommandDisabled("motd") && user.isAuthorized("essentials.motd"))
{
try
{
final IText input = new TextInput(user, "motd", true, ess);
final IText output = new KeywordReplacer(input, user, ess);
final TextPager pager = new TextPager(output, true);
pager.showPage("1", null, "motd", user);
}
catch (IOException ex)
{
if (ess.getSettings().isDebug())
{
LOGGER.log(Level.WARNING, ex.getMessage(), ex);
}
else
{
LOGGER.log(Level.WARNING, ex.getMessage());
}
}
}
2011-09-28 23:38:56 +00:00
if (!ess.getSettings().isCommandDisabled("mail") && user.isAuthorized("essentials.mail"))
{
final List<String> mail = user.getMails();
if (mail.isEmpty())
{
final String msg = _("noNewMail");
if (!msg.isEmpty())
{
user.sendMessage(msg);
}
}
else
{
user.sendMessage(_("youHaveNewMail", mail.size()));
}
}
2013-01-29 23:51:42 +00:00
if (user.isAuthorized("essentials.fly.safelogin"))
{
final World world = user.getLocation().getWorld();
final int x = user.getLocation().getBlockX();
int y = user.getLocation().getBlockY();
final int z = user.getLocation().getBlockZ();
while (Util.isBlockUnsafe(world, x, y, z) && y > -1)
{
y--;
}
if (user.getLocation().getBlockY() - y > 1 || y < 0)
{
user.setAllowFlight(true);
user.setFlying(true);
user.sendMessage(_("flyMode", _("enabled"), user.getDisplayName()));
}
}
}
});
2011-09-28 23:38:56 +00:00
}
2012-10-22 10:27:01 +00:00
// Makes the compass item ingame always point to the first essentials home. #EasterEgg
private void updateCompass(final User user)
{
Location loc = user.getHome(user.getLocation());
if (loc == null)
{
loc = user.getBedSpawnLocation();
}
if (loc != null)
{
final Location updateLoc = loc;
2013-01-29 23:51:42 +00:00
user.setCompassTarget(updateLoc);
}
}
@EventHandler(priority = EventPriority.HIGH)
2011-09-28 23:38:56 +00:00
public void onPlayerLogin(final PlayerLoginEvent event)
{
switch (event.getResult())
{
2012-03-03 05:09:03 +00:00
case KICK_FULL:
case KICK_BANNED:
2012-03-03 05:09:03 +00:00
break;
default:
return;
2011-09-28 23:38:56 +00:00
}
final User user = ess.getUser(event.getPlayer());
2011-09-28 23:38:56 +00:00
if (event.getResult() == Result.KICK_BANNED || user.isBanned())
2011-09-28 23:38:56 +00:00
{
final boolean banExpired = user.checkBanTimeout(System.currentTimeMillis());
if (!banExpired)
{
String banReason = user.getBanReason();
if (banReason == null || banReason.isEmpty() || banReason.equalsIgnoreCase("ban"))
{
banReason = _("defaultBanReason");
}
if (user.getBanTimeout() > 0)
{
//TODO: TL This
banReason += "\n\n" + "Expires in " + Util.formatDateDiff(user.getBanTimeout());
}
event.disallow(Result.KICK_BANNED, banReason);
return;
}
2011-09-28 23:38:56 +00:00
}
if (event.getResult() == Result.KICK_FULL && !user.isAuthorized("essentials.joinfullserver"))
2011-09-28 23:38:56 +00:00
{
event.disallow(Result.KICK_FULL, _("serverFull"));
2011-09-28 23:38:56 +00:00
return;
}
event.allow();
}
@EventHandler(priority = EventPriority.HIGH, ignoreCancelled = true)
public void onPlayerTeleport(final PlayerTeleportEvent event)
{
final boolean backListener = ess.getSettings().registerBackInListener();
final boolean teleportInvulnerability = ess.getSettings().isTeleportInvulnerability();
2012-03-30 20:44:14 +00:00
if (backListener || teleportInvulnerability)
{
2012-03-30 20:44:14 +00:00
final User user = ess.getUser(event.getPlayer());
//There is TeleportCause.COMMMAND but plugins have to actively pass the cause in on their teleports.
if (backListener && (event.getCause() == TeleportCause.PLUGIN || event.getCause() == TeleportCause.COMMAND))
{
user.setLastLocation();
}
if (teleportInvulnerability)
{
user.enableInvulnerabilityAfterTeleport();
}
}
2011-09-28 23:38:56 +00:00
}
@EventHandler(priority = EventPriority.HIGH, ignoreCancelled = true)
2011-09-28 23:38:56 +00:00
public void onPlayerEggThrow(final PlayerEggThrowEvent event)
{
final User user = ess.getUser(event.getPlayer());
final ItemStack stack = new ItemStack(Material.EGG, 1);
if (user.hasUnlimited(stack))
2011-09-28 23:38:56 +00:00
{
user.getInventory().addItem(stack);
2011-09-28 23:38:56 +00:00
user.updateInventory();
}
}
@EventHandler(priority = EventPriority.HIGH, ignoreCancelled = true)
2011-09-28 23:38:56 +00:00
public void onPlayerBucketEmpty(final PlayerBucketEmptyEvent event)
{
final User user = ess.getUser(event.getPlayer());
if (user.hasUnlimited(new ItemStack(event.getBucket())))
{
event.getItemStack().setType(event.getBucket());
ess.scheduleSyncDelayedTask(new Runnable()
{
2011-11-18 18:07:28 +00:00
@Override
2011-09-28 23:38:56 +00:00
public void run()
{
user.updateInventory();
}
});
}
}
@EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true)
2011-09-28 23:38:56 +00:00
public void onPlayerCommandPreprocess(final PlayerCommandPreprocessEvent event)
{
final Player player = event.getPlayer();
final String cmd = event.getMessage().toLowerCase(Locale.ENGLISH).split(" ")[0].replace("/", "").toLowerCase(Locale.ENGLISH);
if (ess.getSettings().getSocialSpyCommands().contains(cmd))
2011-09-28 23:38:56 +00:00
{
for (Player onlinePlayer : ess.getServer().getOnlinePlayers())
2011-09-28 23:38:56 +00:00
{
final User spyer = ess.getUser(onlinePlayer);
if (spyer.isSocialSpyEnabled() && !player.equals(onlinePlayer))
2011-09-28 23:38:56 +00:00
{
onlinePlayer.sendMessage(player.getDisplayName() + " : " + event.getMessage());
2011-09-28 23:38:56 +00:00
}
}
}
else if (!cmd.equalsIgnoreCase("afk"))
2011-09-28 23:38:56 +00:00
{
final User user = ess.getUser(player);
2011-09-28 23:38:56 +00:00
user.updateActivity(true);
}
}
@EventHandler(priority = EventPriority.NORMAL)
public void onPlayerChangedWorldHack(final PlayerChangedWorldEvent event)
{
final User user = ess.getUser(event.getPlayer());
if (user.getGameMode() != GameMode.CREATIVE && !user.isAuthorized("essentials.fly"))
{
user.setAllowFlight(false);
}
user.setFlySpeed(0.1f);
user.setWalkSpeed(0.2f);
}
@EventHandler(priority = EventPriority.MONITOR)
public void onPlayerChangedWorld(final PlayerChangedWorldEvent event)
{
final User user = ess.getUser(event.getPlayer());
final String newWorld = event.getPlayer().getLocation().getWorld().getName();
2012-03-21 23:54:57 +00:00
user.setDisplayNick();
updateCompass(user);
if (ess.getSettings().getNoGodWorlds().contains(newWorld) && user.isGodModeEnabledRaw())
{
user.sendMessage(_("noGodWorldWarning"));
}
if (!user.getWorld().getName().equals(newWorld))
{
user.sendMessage(_("currentWorld", newWorld));
}
if (user.isVanished())
{
user.setVanished(user.isAuthorized("essentials.vanish"));
}
}
@EventHandler(priority = EventPriority.NORMAL)
public void onPlayerInteract(final PlayerInteractEvent event)
{
switch (event.getAction())
{
case RIGHT_CLICK_BLOCK:
2012-04-15 22:13:34 +00:00
if (!event.isCancelled() && event.getClickedBlock().getTypeId() == BED && ess.getSettings().getUpdateBedAtDaytime())
{
User player = ess.getUser(event.getPlayer());
if (player.isAuthorized("essentials.sethome.bed"))
{
player.setBedSpawnLocation(event.getClickedBlock().getLocation());
2013-02-07 06:48:34 +00:00
player.sendMessage(_("bedSet", player.getLocation().getWorld().getName(), player.getLocation().getBlockX(), player.getLocation().getBlockY(), player.getLocation().getBlockZ()));
}
}
break;
2012-03-29 02:06:52 +00:00
case LEFT_CLICK_AIR:
2012-09-09 19:13:03 +00:00
if (event.getPlayer().isFlying())
{
final User user = ess.getUser(event.getPlayer());
if (user.isFlyClickJump())
{
useFlyClickJump(user);
return;
}
}
2012-03-30 20:44:14 +00:00
case LEFT_CLICK_BLOCK:
2012-04-15 22:13:34 +00:00
if (event.getItem() != null && event.getItem().getTypeId() != AIR)
{
2012-03-30 20:44:14 +00:00
final User user = ess.getUser(event.getPlayer());
2012-12-03 09:08:56 +00:00
user.updateActivity(true);
2012-03-30 20:44:14 +00:00
if (user.hasPowerTools() && user.arePowerToolsEnabled() && usePowertools(user, event.getItem().getTypeId()))
{
event.setCancelled(true);
}
}
break;
default:
break;
}
}
2012-10-06 02:31:34 +00:00
// This method allows the /jump lock feature to work, allows teleporting while flying #EasterEgg
private void useFlyClickJump(final User user)
{
try
{
final Location otarget = Util.getTarget(user);
ess.scheduleSyncDelayedTask(
new Runnable()
{
@Override
public void run()
{
Location loc = user.getLocation();
loc.setX(otarget.getX());
loc.setZ(otarget.getZ());
2012-09-09 19:13:03 +00:00
while (Util.isBlockDamaging(loc.getWorld(), loc.getBlockX(), loc.getBlockY() - 1, loc.getBlockZ()))
{
loc.setY(loc.getY() + 1d);
}
user.getBase().teleport(loc, TeleportCause.PLUGIN);
}
});
}
catch (Exception ex)
{
if (ess.getSettings().isDebug())
{
LOGGER.log(Level.WARNING, ex.getMessage(), ex);
}
}
}
2012-03-30 20:44:14 +00:00
private boolean usePowertools(final User user, final int id)
{
final List<String> commandList = user.getPowertool(id);
if (commandList == null || commandList.isEmpty())
{
return false;
}
boolean used = false;
// We need to loop through each command and execute
for (final String command : commandList)
{
2012-03-30 20:44:14 +00:00
if (command.contains("{player}"))
{
continue;
}
else if (command.startsWith("c:"))
{
used = true;
user.chat(command.substring(2));
}
else
{
used = true;
ess.scheduleSyncDelayedTask(
new Runnable()
{
@Override
public void run()
{
user.getServer().dispatchCommand(user.getBase(), command);
2012-08-31 17:52:40 +00:00
LOGGER.log(Level.INFO, String.format("[PT] %s issued server command: /%s", user.getName(), command));
}
});
}
}
return used;
}
@EventHandler(priority = EventPriority.LOW, ignoreCancelled = true)
public void onPlayerPickupItem(final PlayerPickupItemEvent event)
{
if (ess.getSettings().getDisableItemPickupWhileAfk())
{
if (ess.getUser(event.getPlayer()).isAfk())
{
event.setCancelled(true);
}
}
}
@EventHandler(priority = EventPriority.LOWEST, ignoreCancelled = true)
public void onInventoryClickEvent(final InventoryClickEvent event)
{
2013-01-01 18:39:23 +00:00
final Inventory top = event.getView().getTopInventory();
final InventoryType type = top.getType();
if (type == InventoryType.PLAYER)
{
final User user = ess.getUser(event.getWhoClicked());
2013-01-01 18:39:23 +00:00
final InventoryHolder invHolder = top.getHolder();
if (invHolder != null && invHolder instanceof HumanEntity)
{
final User invOwner = ess.getUser((HumanEntity)invHolder);
if (user.isInvSee() && (!user.isAuthorized("essentials.invsee.modify")
|| invOwner.isAuthorized("essentials.invsee.preventmodify")
|| !invOwner.isOnline()))
{
event.setCancelled(true);
2013-01-01 19:34:32 +00:00
user.updateInventory();
}
}
}
2013-01-01 18:39:23 +00:00
else if (type == InventoryType.ENDER_CHEST)
{
final User user = ess.getUser(event.getWhoClicked());
if (user.isEnderSee() && (!user.isAuthorized("essentials.enderchest.modify")))
{
event.setCancelled(true);
}
}
2013-01-01 18:39:23 +00:00
else if (type == InventoryType.WORKBENCH)
2012-12-19 03:57:12 +00:00
{
User user = ess.getUser(event.getWhoClicked());
if (user.isRecipeSee())
{
event.setCancelled(true);
}
}
2013-01-01 18:39:23 +00:00
else if (type == InventoryType.CHEST && top.getSize() == 9)
{
2013-01-01 19:34:32 +00:00
final User user = ess.getUser(event.getWhoClicked());
final InventoryHolder invHolder = top.getHolder();
2013-01-01 19:48:08 +00:00
if (invHolder != null && invHolder instanceof HumanEntity && user.isInvSee())
2013-01-01 18:39:23 +00:00
{
2013-01-01 19:48:08 +00:00
event.setCancelled(true);
2013-01-01 18:39:23 +00:00
}
}
}
@EventHandler(priority = EventPriority.MONITOR)
public void onInventoryCloseEvent(final InventoryCloseEvent event)
{
2013-01-01 18:39:23 +00:00
final Inventory top = event.getView().getTopInventory();
final InventoryType type = top.getType();
if (type == InventoryType.PLAYER)
{
final User user = ess.getUser(event.getPlayer());
user.setInvSee(false);
}
2013-01-01 18:39:23 +00:00
else if (type == InventoryType.ENDER_CHEST)
{
final User user = ess.getUser(event.getPlayer());
user.setEnderSee(false);
}
2013-01-01 18:39:23 +00:00
else if (type == InventoryType.WORKBENCH)
2012-12-19 03:57:12 +00:00
{
final User user = ess.getUser(event.getPlayer());
if (user.isRecipeSee())
2012-12-19 03:57:12 +00:00
{
user.setRecipeSee(false);
event.getView().getTopInventory().clear();
}
}
2013-01-01 18:39:23 +00:00
else if (type == InventoryType.CHEST && top.getSize() == 9)
{
2013-01-01 19:34:32 +00:00
final InventoryHolder invHolder = top.getHolder();
if (invHolder != null && invHolder instanceof HumanEntity)
{
final User user = ess.getUser(event.getPlayer());
user.setInvSee(false);
}
2013-01-01 18:39:23 +00:00
}
}
2012-12-19 03:57:12 +00:00
@EventHandler(priority = EventPriority.LOW, ignoreCancelled = true)
public void onPlayerFishEvent(final PlayerFishEvent event)
{
final User user = ess.getUser(event.getPlayer());
user.updateActivity(true);
}
2012-12-16 16:03:04 +00:00
}