Search in sources :

Example 1 with ProcessExternalMessage

use of com.loohp.interactivechat.modules.ProcessExternalMessage in project InteractiveChat by LOOHP.

the class InteractiveChat method onEnable.

@Override
public void onEnable() {
    plugin = this;
    externalProcessor = new ProcessExternalMessage();
    getServer().getPluginManager().registerEvents(new Debug(), this);
    Metrics metrics = new Metrics(this, BSTATS_PLUGIN_ID);
    exactMinecraftVersion = Bukkit.getVersion().substring(Bukkit.getVersion().indexOf("(") + 5, Bukkit.getVersion().indexOf(")"));
    version = MCVersion.fromPackageName(getServer().getClass().getPackage().getName());
    if (!version.isSupported()) {
        getServer().getConsoleSender().sendMessage(ChatColor.RED + "[InteractiveChat] This version of minecraft is unsupported! (" + version.toString() + ")");
    }
    if (!getDataFolder().exists()) {
        getDataFolder().mkdirs();
    }
    try {
        ConfigManager.setup();
    } catch (IOException e) {
        e.printStackTrace();
        getServer().getPluginManager().disablePlugin(this);
        return;
    }
    protocolManager = ProtocolLibrary.getProtocolManager();
    getCommand("interactivechat").setExecutor(new Commands());
    bungeecordMode = ConfigManager.getConfig().getBoolean("Settings.Bungeecord");
    if (bungeecordMode) {
        getServer().getConsoleSender().sendMessage(ChatColor.GREEN + "[InteractiveChat] Registering Plugin Messaging Channels for bungeecord...");
        getServer().getMessenger().registerOutgoingPluginChannel(this, "interchat:main");
        getServer().getMessenger().registerIncomingPluginChannel(this, "interchat:main", bungeeMessageListener = new BungeeMessageListener(this));
        getServer().getPluginManager().registerEvents(new ServerPingListener(), this);
        ServerPingListener.listen();
        Bukkit.getScheduler().runTaskTimerAsynchronously(plugin, () -> {
            if (parsePAPIOnMainThread) {
                Bukkit.getScheduler().runTask(plugin, () -> {
                    for (Player player : Bukkit.getOnlinePlayers()) {
                        PlaceholderParser.parse(ICPlayerFactory.getICPlayer(player), usePlayerNameHoverText);
                        PlaceholderParser.parse(ICPlayerFactory.getICPlayer(player), usePlayerNameClickValue);
                    }
                });
            } else {
                for (Player player : Bukkit.getOnlinePlayers()) {
                    PlaceholderParser.parse(ICPlayerFactory.getICPlayer(player), usePlayerNameHoverText);
                    PlaceholderParser.parse(ICPlayerFactory.getICPlayer(player), usePlayerNameClickValue);
                }
            }
        }, 0, 100);
    }
    BiConsumer<String, Inventory> inventoryRemovalListener = (hash, inv) -> {
        Bukkit.getScheduler().runTask(InteractiveChat.plugin, () -> closeInventoryViews(inv));
    };
    itemDisplay.registerRemovalListener(inventoryRemovalListener);
    inventoryDisplay.registerRemovalListener(inventoryRemovalListener);
    inventoryDisplay1Upper.registerRemovalListener(inventoryRemovalListener);
    inventoryDisplay1Lower.registerRemovalListener(inventoryRemovalListener);
    enderDisplay.registerRemovalListener(inventoryRemovalListener);
    mapDisplay.registerRemovalListener((hash, item) -> {
        Bukkit.getScheduler().runTask(InteractiveChat.plugin, () -> {
            for (Player player : Bukkit.getOnlinePlayers()) {
                boolean removed = MapViewer.MAP_VIEWERS.remove(player, item);
                if (removed) {
                    // noinspection deprecation
                    player.getInventory().setItemInHand(player.getInventory().getItemInHand());
                }
            }
        });
    });
    YamlConfiguration storage = ConfigManager.getStorageConfig();
    database = new Database(false, getDataFolder(), storage.getString("StorageType"), storage.getString("MYSQL.Host"), storage.getString("MYSQL.Database"), storage.getString("MYSQL.Username"), storage.getString("MYSQL.Password"), storage.getInt("MYSQL.Port"));
    database.setup();
    placeholderCooldownManager = new PlaceholderCooldownManager();
    getServer().getPluginManager().registerEvents(new ChatEvents(), this);
    getServer().getPluginManager().registerEvents(new InventoryEvents(), this);
    getServer().getPluginManager().registerEvents(new PlayerUtils(), this);
    getServer().getPluginManager().registerEvents(new OutChatPacket(), this);
    getServer().getPluginManager().registerEvents(new MapViewer(), this);
    OutChatPacket.chatMessageListener();
    if (!version.isLegacy()) {
        OutTabCompletePacket.tabCompleteListener();
    }
    RegisteredServiceProvider<Permission> rsp = getServer().getServicesManager().getRegistration(Permission.class);
    perms = rsp.getProvider();
    if (isPluginEnabled("SuperVanish") || isPluginEnabled("PremiumVanish")) {
        getServer().getConsoleSender().sendMessage(ChatColor.AQUA + "[InteractiveChat] InteractiveChat has hooked into SuperVanish/PremiumVanish!");
        vanishHook = true;
    }
    if (isPluginEnabled("CMI", false)) {
        getServer().getConsoleSender().sendMessage(ChatColor.AQUA + "[InteractiveChat] InteractiveChat has hooked into CMI!");
        cmiHook = true;
    }
    if (isPluginEnabled("Essentials")) {
        getServer().getConsoleSender().sendMessage(ChatColor.AQUA + "[InteractiveChat] InteractiveChat has hooked into Essentials!");
        essentialsHook = true;
        getServer().getPluginManager().registerEvents(new EssentialsNicknames(), this);
        EssentialsNicknames._init_();
    }
    if (isPluginEnabled("EssentialsDiscord")) {
        getServer().getConsoleSender().sendMessage(ChatColor.AQUA + "[InteractiveChat] InteractiveChat has hooked into EssentialsDiscord!");
        essentialsDiscordHook = true;
        getServer().getPluginManager().registerEvents(new EssentialsDiscord(), this);
    }
    if (isPluginEnabled("DiscordSRV")) {
        getServer().getConsoleSender().sendMessage(ChatColor.AQUA + "[InteractiveChat] InteractiveChat has hooked into DiscordSRV!");
        DiscordSRV.api.subscribe(new DiscordSRVEvents());
        discordSrvHook = true;
    }
    if (isPluginEnabled("ViaVersion")) {
        getServer().getConsoleSender().sendMessage(ChatColor.AQUA + "[InteractiveChat] InteractiveChat has hooked into ViaVersion!");
        viaVersionHook = true;
    }
    if (isPluginEnabled("ProtocolSupport")) {
        getServer().getConsoleSender().sendMessage(ChatColor.AQUA + "[InteractiveChat] InteractiveChat has hooked into ProtocolSupport!");
        protocolSupportHook = true;
    }
    if (isPluginEnabled("eco")) {
        getServer().getConsoleSender().sendMessage(ChatColor.AQUA + "[InteractiveChat] InteractiveChat has hooked into Eco (Core)!");
        ecoHook = true;
    }
    if (isPluginEnabled("LuckPerms")) {
        getServer().getConsoleSender().sendMessage(ChatColor.AQUA + "[InteractiveChat] InteractiveChat has hooked into LuckPerms!");
        new LuckPermsEvents(this);
        luckPermsHook = true;
    }
    if (isPluginEnabled("MysqlPlayerDataBridge")) {
        getServer().getConsoleSender().sendMessage(ChatColor.AQUA + "[InteractiveChat] InteractiveChat has hooked into MysqlPlayerDataBridge!");
        mysqlPDBHook = true;
    }
    if (isPluginEnabled("VentureChat")) {
        VentureChatInjection._init_();
        getServer().getConsoleSender().sendMessage(ChatColor.LIGHT_PURPLE + "[InteractiveChat] InteractiveChat has injected into VentureChat!");
        ventureChatHook = true;
    }
    if (isPluginEnabled("dynmap")) {
        getServer().getConsoleSender().sendMessage(ChatColor.LIGHT_PURPLE + "[InteractiveChat] InteractiveChat has injected into Dynmap!");
        DynmapListener._init_();
        dynmapHook = true;
    }
    PlayernameDisplay.setup();
    MentionDisplay.setup();
    Charts.setup(metrics);
    if (updaterEnabled) {
        getServer().getPluginManager().registerEvents(new Updater(), this);
    }
    ClientSettingPacket.clientSettingsListener();
    playerDataManager = new PlayerDataManager(this, database);
    nicknameManager = new NicknameManager(uuid -> InteractiveChatAPI.getNicknames(uuid), () -> InteractiveChatAPI.getOnlineICPlayers().stream().filter(each -> each.isLocal()).map(each -> each.getUniqueId()).collect(Collectors.toSet()), 5000, (uuid, nicknames) -> {
        if (InteractiveChat.bungeecordMode) {
            Player bukkitPlayer = Bukkit.getPlayer(uuid);
            if (bukkitPlayer != null) {
                Set<String> nicks = new HashSet<>(nicknames);
                if (InteractiveChat.useBukkitDisplayName) {
                    nicks.add(bukkitPlayer.getDisplayName());
                }
                try {
                    BungeeMessageSender.forwardNicknames(System.currentTimeMillis(), uuid, nicks);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }
    });
    if (getServer().getPluginManager().getPlugin("PlaceholderAPI") != null) {
        new Placeholders().register();
    }
    getServer().getConsoleSender().sendMessage(ChatColor.GREEN + "[InteractiveChat] InteractiveChat has been Enabled!");
    Bukkit.getScheduler().runTaskTimerAsynchronously(this, () -> {
        if (queueRemoteUpdate && Bukkit.getOnlinePlayers().size() > 0) {
            try {
                if (BungeeMessageSender.resetAndForwardPlaceholderList(System.currentTimeMillis(), InteractiveChat.placeholderList.values())) {
                    queueRemoteUpdate = false;
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }, 0, 100);
    try {
        Logger logger = LogManager.getRootLogger();
        LogFilter filter = new LogFilter();
        Method method = logger.getClass().getMethod("addFilter", Filter.class);
        method.invoke(logger, filter);
    } catch (Exception e) {
        Bukkit.getConsoleSender().sendMessage(ChatColor.YELLOW + "[InteractiveChat] Unable to add filter to logger, safely skipping...");
    }
    gc();
}
Also used : Plugin(org.bukkit.plugin.Plugin) InventoryUtils(com.loohp.interactivechat.utils.InventoryUtils) PlayerUtils(com.loohp.interactivechat.utils.PlayerUtils) ValuePairs(com.loohp.interactivechat.objectholders.ValuePairs) InteractiveChatAPI(com.loohp.interactivechat.api.InteractiveChatAPI) Player(org.bukkit.entity.Player) Inventory(org.bukkit.inventory.Inventory) ClientSettingPacket(com.loohp.interactivechat.listeners.ClientSettingPacket) ICPlayer(com.loohp.interactivechat.objectholders.ICPlayer) InteractiveChatComponentSerializer(com.loohp.interactivechat.utils.InteractiveChatComponentSerializer) Map(java.util.Map) MentionPair(com.loohp.interactivechat.objectholders.MentionPair) NicknameManager(com.loohp.interactivechat.objectholders.NicknameManager) Method(java.lang.reflect.Method) PlayerDataManager(com.loohp.interactivechat.data.PlayerDataManager) PlaceholderCooldownManager(com.loohp.interactivechat.objectholders.PlaceholderCooldownManager) ChatEvents(com.loohp.interactivechat.listeners.ChatEvents) Bukkit(org.bukkit.Bukkit) Placeholders(com.loohp.interactivechat.placeholderapi.Placeholders) CommandSender(org.bukkit.command.CommandSender) BungeeMessageListener(com.loohp.interactivechat.bungeemessaging.BungeeMessageListener) YamlConfiguration(com.loohp.yamlconfiguration.YamlConfiguration) Filter(org.apache.logging.log4j.core.Filter) Updater(com.loohp.interactivechat.updater.Updater) ConcurrentHashMap(java.util.concurrent.ConcurrentHashMap) Set(java.util.Set) EssentialsDiscord(com.loohp.interactivechat.hooks.essentials.EssentialsDiscord) ConcurrentCacheHashMap(com.loohp.interactivechat.objectholders.ConcurrentCacheHashMap) InventoryEvents(com.loohp.interactivechat.listeners.InventoryEvents) UUID(java.util.UUID) Collectors(java.util.stream.Collectors) OutTabCompletePacket(com.loohp.interactivechat.listeners.OutTabCompletePacket) ItemStack(org.bukkit.inventory.ItemStack) JavaPlugin(org.bukkit.plugin.java.JavaPlugin) ComponentSerializer(net.md_5.bungee.chat.ComponentSerializer) List(java.util.List) Logger(org.apache.logging.log4j.Logger) Optional(java.util.Optional) Pattern(java.util.regex.Pattern) ProtocolManager(com.comphenix.protocol.ProtocolManager) Charts(com.loohp.interactivechat.metrics.Charts) Permission(net.milkbowl.vault.permission.Permission) ProtocolLibrary(com.comphenix.protocol.ProtocolLibrary) BungeeMessageSender(com.loohp.interactivechat.bungeemessaging.BungeeMessageSender) DynmapListener(com.loohp.interactivechat.hooks.dynmap.DynmapListener) MCVersion(com.loohp.interactivechat.utils.MCVersion) MentionDisplay(com.loohp.interactivechat.modules.MentionDisplay) HashMap(java.util.HashMap) ClickEvent(net.kyori.adventure.text.event.ClickEvent) EssentialsNicknames(com.loohp.interactivechat.hooks.essentials.EssentialsNicknames) Function(java.util.function.Function) ArrayList(java.util.ArrayList) Database(com.loohp.interactivechat.data.Database) HashSet(java.util.HashSet) LinkedHashMap(java.util.LinkedHashMap) DiscordSRV(github.scarsz.discordsrv.DiscordSRV) ProcessExternalMessage(com.loohp.interactivechat.modules.ProcessExternalMessage) Component(net.kyori.adventure.text.Component) BiConsumer(java.util.function.BiConsumer) ICPlaceholder(com.loohp.interactivechat.objectholders.ICPlaceholder) LegacyComponentSerializer(net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer) WeakHashMap(java.util.WeakHashMap) VentureChatInjection(com.loohp.interactivechat.hooks.venturechat.VentureChatInjection) OutChatPacket(com.loohp.interactivechat.listeners.OutChatPacket) ConfigManager(com.loohp.interactivechat.config.ConfigManager) LuckPermsEvents(com.loohp.interactivechat.hooks.luckperms.LuckPermsEvents) Metrics(com.loohp.interactivechat.metrics.Metrics) Debug(com.loohp.interactivechat.debug.Debug) IOException(java.io.IOException) MapViewer(com.loohp.interactivechat.listeners.MapViewer) AtomicLong(java.util.concurrent.atomic.AtomicLong) PlayernameDisplay(com.loohp.interactivechat.modules.PlayernameDisplay) EventPriority(org.bukkit.event.EventPriority) ICPlayerFactory(com.loohp.interactivechat.objectholders.ICPlayerFactory) DiscordSRVEvents(com.loohp.interactivechat.hooks.discordsrv.DiscordSRVEvents) LogFilter(com.loohp.interactivechat.objectholders.LogFilter) ChatColor(org.bukkit.ChatColor) PlaceholderParser(com.loohp.interactivechat.utils.PlaceholderParser) LogManager(org.apache.logging.log4j.LogManager) RegisteredServiceProvider(org.bukkit.plugin.RegisteredServiceProvider) Collections(java.util.Collections) ServerPingListener(com.loohp.interactivechat.bungeemessaging.ServerPingListener) Set(java.util.Set) HashSet(java.util.HashSet) ServerPingListener(com.loohp.interactivechat.bungeemessaging.ServerPingListener) ProcessExternalMessage(com.loohp.interactivechat.modules.ProcessExternalMessage) YamlConfiguration(com.loohp.yamlconfiguration.YamlConfiguration) EssentialsDiscord(com.loohp.interactivechat.hooks.essentials.EssentialsDiscord) Logger(org.apache.logging.log4j.Logger) Metrics(com.loohp.interactivechat.metrics.Metrics) Updater(com.loohp.interactivechat.updater.Updater) Database(com.loohp.interactivechat.data.Database) Permission(net.milkbowl.vault.permission.Permission) Debug(com.loohp.interactivechat.debug.Debug) PlayerUtils(com.loohp.interactivechat.utils.PlayerUtils) Player(org.bukkit.entity.Player) ICPlayer(com.loohp.interactivechat.objectholders.ICPlayer) InventoryEvents(com.loohp.interactivechat.listeners.InventoryEvents) ChatEvents(com.loohp.interactivechat.listeners.ChatEvents) DiscordSRVEvents(com.loohp.interactivechat.hooks.discordsrv.DiscordSRVEvents) IOException(java.io.IOException) Method(java.lang.reflect.Method) EssentialsNicknames(com.loohp.interactivechat.hooks.essentials.EssentialsNicknames) NicknameManager(com.loohp.interactivechat.objectholders.NicknameManager) IOException(java.io.IOException) PlayerDataManager(com.loohp.interactivechat.data.PlayerDataManager) Placeholders(com.loohp.interactivechat.placeholderapi.Placeholders) MapViewer(com.loohp.interactivechat.listeners.MapViewer) OutChatPacket(com.loohp.interactivechat.listeners.OutChatPacket) LuckPermsEvents(com.loohp.interactivechat.hooks.luckperms.LuckPermsEvents) BungeeMessageListener(com.loohp.interactivechat.bungeemessaging.BungeeMessageListener) PlaceholderCooldownManager(com.loohp.interactivechat.objectholders.PlaceholderCooldownManager) Inventory(org.bukkit.inventory.Inventory) LogFilter(com.loohp.interactivechat.objectholders.LogFilter)

Aggregations

ProtocolLibrary (com.comphenix.protocol.ProtocolLibrary)1 ProtocolManager (com.comphenix.protocol.ProtocolManager)1 InteractiveChatAPI (com.loohp.interactivechat.api.InteractiveChatAPI)1 BungeeMessageListener (com.loohp.interactivechat.bungeemessaging.BungeeMessageListener)1 BungeeMessageSender (com.loohp.interactivechat.bungeemessaging.BungeeMessageSender)1 ServerPingListener (com.loohp.interactivechat.bungeemessaging.ServerPingListener)1 ConfigManager (com.loohp.interactivechat.config.ConfigManager)1 Database (com.loohp.interactivechat.data.Database)1 PlayerDataManager (com.loohp.interactivechat.data.PlayerDataManager)1 Debug (com.loohp.interactivechat.debug.Debug)1 DiscordSRVEvents (com.loohp.interactivechat.hooks.discordsrv.DiscordSRVEvents)1 DynmapListener (com.loohp.interactivechat.hooks.dynmap.DynmapListener)1 EssentialsDiscord (com.loohp.interactivechat.hooks.essentials.EssentialsDiscord)1 EssentialsNicknames (com.loohp.interactivechat.hooks.essentials.EssentialsNicknames)1 LuckPermsEvents (com.loohp.interactivechat.hooks.luckperms.LuckPermsEvents)1 VentureChatInjection (com.loohp.interactivechat.hooks.venturechat.VentureChatInjection)1 ChatEvents (com.loohp.interactivechat.listeners.ChatEvents)1 ClientSettingPacket (com.loohp.interactivechat.listeners.ClientSettingPacket)1 InventoryEvents (com.loohp.interactivechat.listeners.InventoryEvents)1 MapViewer (com.loohp.interactivechat.listeners.MapViewer)1