package com.earth2me.essentials.xmpp; import com.earth2me.essentials.EssentialsLogger; import com.earth2me.essentials.IEssentials; import com.earth2me.essentials.metrics.MetricsWrapper; import net.ess3.api.IUser; import org.bstats.charts.SimplePie; import org.bukkit.command.Command; import org.bukkit.command.CommandSender; import org.bukkit.entity.Player; import org.bukkit.plugin.PluginManager; import org.bukkit.plugin.java.JavaPlugin; import java.util.List; import java.util.Locale; import java.util.logging.Level; import java.util.logging.Logger; import static com.earth2me.essentials.I18n.tl; public class EssentialsXMPP extends JavaPlugin implements IEssentialsXMPP { private static EssentialsXMPP instance = null; private transient UserManager users; private transient XMPPManager xmpp; private transient IEssentials ess; private transient MetricsWrapper metrics = null; static IEssentialsXMPP getInstance() { return instance; } static void updatePresence() { instance.xmpp.updatePresence(); } @Override public void onEnable() { EssentialsLogger.updatePluginLogger(this); instance = this; final PluginManager pluginManager = getServer().getPluginManager(); ess = (IEssentials) pluginManager.getPlugin("Essentials"); if (!this.getDescription().getVersion().equals(ess.getDescription().getVersion())) { getLogger().log(Level.WARNING, tl("versionMismatchAll")); } if (!ess.isEnabled()) { this.setEnabled(false); return; } final EssentialsXMPPPlayerListener playerListener = new EssentialsXMPPPlayerListener(ess); pluginManager.registerEvents(playerListener, this); users = new UserManager(this.getDataFolder()); xmpp = new XMPPManager(this); ess.addReloadListener(users); ess.addReloadListener(xmpp); if (metrics == null) { metrics = new MetricsWrapper(this, 3818, true); metrics.addCustomChart(new SimplePie("config-valid", () -> xmpp.isConfigValid() ? "yes" : "no")); } } public static Logger getWrappedLogger() { try { return EssentialsLogger.getLoggerProvider("EssentialsXMPP"); } catch (Throwable ignored) { // In case Essentials isn't installed/loaded return Logger.getLogger("EssentialsXMPP"); } } @Override public void onDisable() { if (xmpp != null) { xmpp.disconnect(); } instance = null; } @Override public boolean onCommand(final CommandSender sender, final Command command, final String commandLabel, final String[] args) { metrics.markCommand(command.getName(), true); return ess.onCommandEssentials(sender, command, commandLabel, args, EssentialsXMPP.class.getClassLoader(), "com.earth2me.essentials.xmpp.Command", "essentials.", null); } @Override public void setAddress(final Player user, final String address) { final String username = user.getName().toLowerCase(Locale.ENGLISH); instance.users.setAddress(username, address); } @Override public String getAddress(final String name) { return instance.users.getAddress(name); } @Override public IUser getUserByAddress(final String address) { final String username = instance.users.getUserByAddress(address); return username == null ? null : ess.getUser(username); } @Override public boolean toggleSpy(final Player user) { final String username = user.getName().toLowerCase(Locale.ENGLISH); final boolean spy = !instance.users.isSpy(username); instance.users.setSpy(username, spy); return spy; } @Override public String getAddress(final Player user) { return instance.users.getAddress(user.getName()); } @Override public boolean sendMessage(final Player user, final String message) { return instance.xmpp.sendMessage(instance.users.getAddress(user.getName()), message); } @Override public boolean sendMessage(final String address, final String message) { return instance.xmpp.sendMessage(address, message); } @Override public List getSpyUsers() { return instance.users.getSpyUsers(); } @Override public void broadcastMessage(final IUser sender, final String message, final String xmppAddress) { ess.broadcastMessage(sender, message); try { for (final String address : getSpyUsers()) { if (!address.equalsIgnoreCase(xmppAddress)) { sendMessage(address, message); } } } catch (final Exception ignored) { } } @Override public IEssentials getEss() { return ess; } }