Search in sources :

Example 1 with FirstStat

use of com.gmail.stefvanschiedev.buildinggame.events.stats.saved.FirstStat in project buildinggame by stefvanschie.

the class Main method loadPlugin.

/**
 * Loads the entire plugin
 *
 * @since 2.1.0
 */
public void loadPlugin(boolean reload) {
    long start = System.currentTimeMillis();
    // this has to be done quite early
    if (!reload) {
        Gui.registerProperty("particle-type", Particle::valueOf);
        Gui.registerProperty("biome", Biome::valueOf);
        Gui.registerProperty("dye-color", DyeColor::valueOf);
        Gui.registerProperty("material", Material::valueOf);
    }
    getLogger().info("Loading files");
    SettingsManager.getInstance().setup(this, false);
    getLogger().info("Loading arenas");
    ArenaManager.getInstance().setup();
    ArenaModeManager.getInstance().setup();
    BuildTimerManager.getInstance().setup();
    LobbyManager.getInstance().setup();
    LobbyTimerManager.getInstance().setup();
    MinPlayersManager.getInstance().setup();
    MatchesManager.getInstance().setup();
    VoteTimerManager.getInstance().setup();
    WinTimerManager.getInstance().setup();
    getLogger().info("Loading plots");
    PlotManager.getInstance().setup();
    // has to be down here for some config stuff
    MaxPlayersManager.getInstance().setup();
    LocationManager.getInstance().setup();
    BoundaryManager.getInstance().setup();
    FloorManager.getInstance().setup();
    getLogger().info("Loading main spawn");
    MainSpawnManager.getInstance().setup();
    PluginManager pm = Bukkit.getPluginManager();
    getLogger().info("Loading soft dependencies");
    if (pm.isPluginEnabled("Vault"))
        SDVault.getInstance().setup();
    if (pm.isPluginEnabled("PlaceholderAPI")) {
        try {
            String version = pm.getPlugin("PlaceholderAPI").getDescription().getVersion();
            var number = Integer.parseInt(version.replace(".", ""));
            // This ensures the versions don't get mixed up (e.g. 2.7.5 being bigger than 2.9).
            for (var i = version.split("\\.").length; i < 3; i++) number *= 10;
            // 290 is the first version with offline player support
            if (number >= 290) {
                if (!new PlaceholderAPIPlaceholders().register())
                    getLogger().warning("Unable to register placeholders for PlaceholderAPI");
            } else
                getLogger().warning("PlaceholderAPI is outdated, update to a later version to keep BuildingGame compatible with PlaceholderAPI.");
        } catch (NumberFormatException e) {
            getLogger().warning("Unable to get PlaceholderAPI version, contact the plugin author about this.");
            e.printStackTrace();
        }
    }
    if (pm.isPluginEnabled("MVdWPlaceholderAPI")) {
        PlaceholderSupplier.getPlaceholderReplacements().forEach((placeholder, biFunction) -> PlaceholderAPI.registerPlaceholder(this, placeholder, event -> biFunction.apply(event.getOfflinePlayer(), event.getPlaceholder())));
    }
    getLogger().info("Loading commands");
    if (!reload) {
        var manager = new BukkitCommandManager(this);
        // noinspection deprecation
        manager.enableUnstableAPI("help");
        // register contexts
        manager.getCommandContexts().registerContext(Arena.class, context -> {
            var arena = ArenaManager.getInstance().getArena(context.popFirstArg());
            if (arena == null)
                throw new InvalidCommandArgument("This arena doesn't exist");
            return arena;
        });
        manager.getCommandContexts().registerContext(ArenaMode.class, context -> {
            var mode = ArenaMode.valueOf(context.popFirstArg().toUpperCase(Locale.getDefault()));
            if (mode == null)
                throw new InvalidCommandArgument("This game mode doesn't exist");
            return mode;
        });
        manager.getCommandContexts().registerContext(StatType.class, context -> {
            var type = StatType.valueOf(context.popFirstArg().toUpperCase(Locale.getDefault()));
            if (type == null)
                throw new InvalidCommandArgument("This statistic type doesn't exist");
            return type;
        });
        // register completions
        manager.getCommandCompletions().registerCompletion("arenas", context -> ArenaManager.getInstance().getArenas().stream().map(Arena::getName).collect(Collectors.toList()));
        manager.getCommandCompletions().registerCompletion("arenamodes", context -> Stream.of(ArenaMode.values()).map(mode -> mode.toString().toUpperCase(Locale.getDefault())).collect(Collectors.toList()));
        manager.getCommandCompletions().registerCompletion("stattypes", context -> Stream.of(StatType.values()).map(Enum::toString).collect(Collectors.toList()));
        manager.getCommandCompletions().registerCompletion("holograms", context -> TopStatHologram.getHolograms().stream().map(TopStatHologram::getName).collect(Collectors.toList()));
        // register conditions
        manager.getCommandConditions().addCondition(String.class, "arenanotexist", (context, executionContext, string) -> {
            if (ArenaManager.getInstance().getArena(string) != null || string.equals("main-spawn"))
                throw new ConditionFailedException("Arena already exists");
        });
        // hd stands for Holographic Displays, but it's shorten to hd since the full name is a bit long
        manager.getCommandConditions().addCondition("hdenabled", context -> pm.isPluginEnabled("HolographicDisplays"));
        manager.registerCommand(new CommandManager());
    }
    getLogger().info("Loading stats");
    StatManager.getInstance().setup();
    // loading achievements should happen after the statistics have been loaded
    Achievement.loadAchievements();
    getLogger().info("Loading listeners");
    if (!reload) {
        pm.registerEvents(new BlockDispenseItem(), this);
        pm.registerEvents(new BlockEdit(), this);
        pm.registerEvents(new JoinSignCreate(), this);
        pm.registerEvents(new LeaveSignCreate(), this);
        pm.registerEvents(new StatSignCreate(), this);
        pm.registerEvents(new UpdateLoadedSigns(), this);
        pm.registerEvents(new SpectateSignCreate(), this);
        pm.registerEvents(new SignBreak(), this);
        pm.registerEvents(new LiquidFlow(), this);
        pm.registerEvents(new PistonBlockMove(), this);
        // starts the connection to bungeecord
        if (SettingsManager.getInstance().getConfig().getBoolean("bungeecord.enable"))
            BungeeCordHandler.getInstance();
        // per world inventory compatibility fix
        if (pm.isPluginEnabled("PerWorldInventory")) {
            try {
                String version = pm.getPlugin("PerWorldInventory").getDescription().getVersion();
                var number = Integer.parseInt(version.replace(".", ""));
                // This ensures the versions don't get mixed up (e.g. 1.7.5 being bigger than 1.11).
                for (var i = version.split("\\.").length; i < 3; i++) number *= 10;
                // 200 is the first version with the new package name
                if (number >= 200)
                    pm.registerEvents(new PerWorldInventoryCancel(), this);
                else
                    getLogger().warning("PerWorldInventory is outdated, update to a later version to keep BuildingGame compatible with PerWorldInventory.");
            } catch (NumberFormatException e) {
                getLogger().warning("Unable to get PerWorldInventory version, contact the plugin author about this.");
                e.printStackTrace();
            }
        }
        if (pm.isPluginEnabled("WorldEdit"))
            WorldEdit.getInstance().getEventBus().register(new WorldEditBoundaryAssertion());
        if (pm.isPluginEnabled("Citizens")) {
            pm.registerEvents(new NPCCreate(), this);
            TraitInfo traitInfo = TraitInfo.create(NPCFloorChangeTrait.class).withName("buildinggame:floorchange");
            CitizensAPI.getTraitFactory().registerTrait(traitInfo);
        }
        pm.registerEvents(new ClickJoinSign(), this);
        pm.registerEvents(new ClickLeaveSign(), this);
        pm.registerEvents(new ClickSpectateSign(), this);
        pm.registerEvents(new Drop(), this);
        pm.registerEvents(new Interact(), this);
        pm.registerEvents(new Leave(), this);
        pm.registerEvents(new Move(), this);
        pm.registerEvents(new PlaceBucket(), this);
        pm.registerEvents(new PlaceIgnoreSpectators(), this);
        if (SettingsManager.getInstance().getConfig().getBoolean("chat.adjust"))
            pm.registerEvents(new Chat(), this);
        pm.registerEvents(new CommandBlocker(), this);
        pm.registerEvents(new EntityDamage(), this);
        pm.registerEvents(new TakeDamage(), this);
        pm.registerEvents(new LoseFood(), this);
        // entity events
        pm.registerEvents(new ChickenSpawnByEgg(), this);
        pm.registerEvents(new EntityExplode(), this);
        pm.registerEvents(new EntityOptionsMenu(), this);
        pm.registerEvents(new EntitySpawn(), this);
        // scoreboards
        pm.registerEvents(new MainScoreboardJoinShow(), this);
        pm.registerEvents(new MainScoreboardWorldChange(), this);
        // stats
        // saved
        pm.registerEvents(new BreakStat(), this);
        pm.registerEvents(new FirstStat(), this);
        pm.registerEvents(new PlaceStat(), this);
        pm.registerEvents(new PlaysStat(), this);
        pm.registerEvents(new SecondStat(), this);
        pm.registerEvents(new ThirdStat(), this);
        // unsaved
        pm.registerEvents(new UnsavedStatsPlace(), this);
        // structure
        pm.registerEvents(new TreeGrow(), this);
        if (StatManager.getInstance().getMySQLDatabase() != null) {
            pm.registerEvents(new JoinPlayerStats(), this);
            pm.registerEvents(new QuitPlayerStats(), this);
        }
    }
    getLogger().info("Loading signs");
    SignManager.getInstance().setup();
    getLogger().info("Loading timer");
    new ParticleRender().runTaskTimer(this, 0L, 10L);
    new ScoreboardUpdater().runTaskTimer(this, 0L, SettingsManager.getInstance().getConfig().getLong("scoreboard-update-delay"));
    new StatSaveTimer().runTaskTimerAsynchronously(this, 0L, SettingsManager.getInstance().getConfig().getLong("stats.save-delay"));
    new EntityTimer().runTaskTimer(this, 0L, 20L);
    new StatSignUpdater().runTaskTimerAsynchronously(this, 0L, 1L);
    long end = System.currentTimeMillis();
    long duration = end - start;
    String time;
    if (duration < 1000) {
        time = duration + " milliseconds";
    } else if (duration < 60000) {
        time = duration / 1000.0 + " seconds";
    } else {
        time = (duration / 60000) + ":" + (duration % 60000) / 1000.0 + " minutes";
    }
    getLogger().info("BuildingGame has been enabled in " + time + '!');
}
Also used : CommandManager(com.gmail.stefvanschiedev.buildinggame.managers.commands.CommandManager) LocationManager(com.gmail.stefvanschiedev.buildinggame.managers.plots.LocationManager) EntityExplode(com.gmail.stefvanschiedev.buildinggame.events.entity.EntityExplode) Biome(org.bukkit.block.Biome) UnsavedStatsPlace(com.gmail.stefvanschiedev.buildinggame.events.stats.unsaved.UnsavedStatsPlace) CitizensAPI(net.citizensnpcs.api.CitizensAPI) PerWorldInventoryCancel(com.gmail.stefvanschiedev.buildinggame.events.softdependencies.PerWorldInventoryCancel) EntitySpawn(com.gmail.stefvanschiedev.buildinggame.events.entity.EntitySpawn) LiquidFlow(com.gmail.stefvanschiedev.buildinggame.events.block.LiquidFlow) PlotManager(com.gmail.stefvanschiedev.buildinggame.managers.plots.PlotManager) TopStatHologram(com.gmail.stefvanschiedev.buildinggame.utils.TopStatHologram) NPCFloorChangeTrait(com.gmail.stefvanschiedev.buildinggame.utils.NPCFloorChangeTrait) ClickSpectateSign(com.gmail.stefvanschiedev.buildinggame.events.player.signs.ClickSpectateSign) Gui(com.github.stefvanschie.inventoryframework.gui.type.util.Gui) Material(org.bukkit.Material) Bukkit(org.bukkit.Bukkit) JoinPlayerStats(com.gmail.stefvanschiedev.buildinggame.events.stats.database.JoinPlayerStats) EntityOptionsMenu(com.gmail.stefvanschiedev.buildinggame.events.entity.EntityOptionsMenu) ArenaMode(com.gmail.stefvanschiedev.buildinggame.utils.arena.ArenaMode) com.gmail.stefvanschiedev.buildinggame.events.block.signs(com.gmail.stefvanschiedev.buildinggame.events.block.signs) FirstStat(com.gmail.stefvanschiedev.buildinggame.events.stats.saved.FirstStat) SettingsManager(com.gmail.stefvanschiedev.buildinggame.managers.files.SettingsManager) Collectors(java.util.stream.Collectors) MainScoreboardJoinShow(com.gmail.stefvanschiedev.buildinggame.events.scoreboards.MainScoreboardJoinShow) ThirdStat(com.gmail.stefvanschiedev.buildinggame.events.stats.saved.ThirdStat) JavaPlugin(org.bukkit.plugin.java.JavaPlugin) Contract(org.jetbrains.annotations.Contract) Stream(java.util.stream.Stream) com.gmail.stefvanschiedev.buildinggame.managers.arenas(com.gmail.stefvanschiedev.buildinggame.managers.arenas) TreeGrow(com.gmail.stefvanschiedev.buildinggame.events.structure.TreeGrow) FloorManager(com.gmail.stefvanschiedev.buildinggame.managers.plots.FloorManager) Achievement(com.gmail.stefvanschiedev.buildinggame.utils.Achievement) NotNull(org.jetbrains.annotations.NotNull) StatType(com.gmail.stefvanschiedev.buildinggame.utils.stats.StatType) QuitPlayerStats(com.gmail.stefvanschiedev.buildinggame.events.stats.database.QuitPlayerStats) PlaysStat(com.gmail.stefvanschiedev.buildinggame.events.stats.saved.PlaysStat) java.util(java.util) BreakStat(com.gmail.stefvanschiedev.buildinggame.events.stats.saved.BreakStat) InvalidCommandArgument(co.aikar.commands.InvalidCommandArgument) com.gmail.stefvanschiedev.buildinggame.events.player(com.gmail.stefvanschiedev.buildinggame.events.player) PlaceholderAPIPlaceholders(com.gmail.stefvanschiedev.buildinggame.managers.softdependencies.PlaceholderAPIPlaceholders) MetricsLite(org.bstats.bukkit.MetricsLite) BlockDispenseItem(com.gmail.stefvanschiedev.buildinggame.events.block.BlockDispenseItem) ChickenSpawnByEgg(com.gmail.stefvanschiedev.buildinggame.events.entity.ChickenSpawnByEgg) WorldEditBoundaryAssertion(com.gmail.stefvanschiedev.buildinggame.events.softdependencies.WorldEditBoundaryAssertion) BungeeCordHandler(com.gmail.stefvanschiedev.buildinggame.utils.bungeecord.BungeeCordHandler) Interact(com.gmail.stefvanschiedev.buildinggame.events.player.voting.Interact) NPCCreate(com.gmail.stefvanschiedev.buildinggame.events.softdependencies.NPCCreate) BukkitCommandManager(co.aikar.commands.BukkitCommandManager) PistonBlockMove(com.gmail.stefvanschiedev.buildinggame.events.block.PistonBlockMove) ConditionFailedException(co.aikar.commands.ConditionFailedException) WorldEdit(com.sk89q.worldedit.WorldEdit) SDVault(com.gmail.stefvanschiedev.buildinggame.managers.softdependencies.SDVault) BoundaryManager(com.gmail.stefvanschiedev.buildinggame.managers.plots.BoundaryManager) BlockEdit(com.gmail.stefvanschiedev.buildinggame.events.block.BlockEdit) PlaceholderAPI(be.maximvdw.placeholderapi.PlaceholderAPI) Particle(org.bukkit.Particle) TraitInfo(net.citizensnpcs.api.trait.TraitInfo) ClickJoinSign(com.gmail.stefvanschiedev.buildinggame.events.player.signs.ClickJoinSign) MainScoreboardWorldChange(com.gmail.stefvanschiedev.buildinggame.events.scoreboards.MainScoreboardWorldChange) PlaceholderSupplier(com.gmail.stefvanschiedev.buildinggame.utils.PlaceholderSupplier) StatManager(com.gmail.stefvanschiedev.buildinggame.managers.stats.StatManager) com.gmail.stefvanschiedev.buildinggame.timers(com.gmail.stefvanschiedev.buildinggame.timers) PlaceStat(com.gmail.stefvanschiedev.buildinggame.events.stats.saved.PlaceStat) Arena(com.gmail.stefvanschiedev.buildinggame.utils.arena.Arena) DyeColor(org.bukkit.DyeColor) ClickLeaveSign(com.gmail.stefvanschiedev.buildinggame.events.player.signs.ClickLeaveSign) SecondStat(com.gmail.stefvanschiedev.buildinggame.events.stats.saved.SecondStat) MainSpawnManager(com.gmail.stefvanschiedev.buildinggame.managers.mainspawn.MainSpawnManager) PluginManager(org.bukkit.plugin.PluginManager) BlockDispenseItem(com.gmail.stefvanschiedev.buildinggame.events.block.BlockDispenseItem) BreakStat(com.gmail.stefvanschiedev.buildinggame.events.stats.saved.BreakStat) TreeGrow(com.gmail.stefvanschiedev.buildinggame.events.structure.TreeGrow) PlaysStat(com.gmail.stefvanschiedev.buildinggame.events.stats.saved.PlaysStat) JoinPlayerStats(com.gmail.stefvanschiedev.buildinggame.events.stats.database.JoinPlayerStats) Interact(com.gmail.stefvanschiedev.buildinggame.events.player.voting.Interact) Particle(org.bukkit.Particle) PluginManager(org.bukkit.plugin.PluginManager) CommandManager(com.gmail.stefvanschiedev.buildinggame.managers.commands.CommandManager) BukkitCommandManager(co.aikar.commands.BukkitCommandManager) InvalidCommandArgument(co.aikar.commands.InvalidCommandArgument) TraitInfo(net.citizensnpcs.api.trait.TraitInfo) EntitySpawn(com.gmail.stefvanschiedev.buildinggame.events.entity.EntitySpawn) SecondStat(com.gmail.stefvanschiedev.buildinggame.events.stats.saved.SecondStat) PlaceStat(com.gmail.stefvanschiedev.buildinggame.events.stats.saved.PlaceStat) TopStatHologram(com.gmail.stefvanschiedev.buildinggame.utils.TopStatHologram) ChickenSpawnByEgg(com.gmail.stefvanschiedev.buildinggame.events.entity.ChickenSpawnByEgg) DyeColor(org.bukkit.DyeColor) Arena(com.gmail.stefvanschiedev.buildinggame.utils.arena.Arena) ClickSpectateSign(com.gmail.stefvanschiedev.buildinggame.events.player.signs.ClickSpectateSign) QuitPlayerStats(com.gmail.stefvanschiedev.buildinggame.events.stats.database.QuitPlayerStats) ThirdStat(com.gmail.stefvanschiedev.buildinggame.events.stats.saved.ThirdStat) WorldEditBoundaryAssertion(com.gmail.stefvanschiedev.buildinggame.events.softdependencies.WorldEditBoundaryAssertion) MainScoreboardWorldChange(com.gmail.stefvanschiedev.buildinggame.events.scoreboards.MainScoreboardWorldChange) PerWorldInventoryCancel(com.gmail.stefvanschiedev.buildinggame.events.softdependencies.PerWorldInventoryCancel) ClickLeaveSign(com.gmail.stefvanschiedev.buildinggame.events.player.signs.ClickLeaveSign) PlaceholderAPIPlaceholders(com.gmail.stefvanschiedev.buildinggame.managers.softdependencies.PlaceholderAPIPlaceholders) Biome(org.bukkit.block.Biome) ConditionFailedException(co.aikar.commands.ConditionFailedException) PistonBlockMove(com.gmail.stefvanschiedev.buildinggame.events.block.PistonBlockMove) ClickJoinSign(com.gmail.stefvanschiedev.buildinggame.events.player.signs.ClickJoinSign) EntityExplode(com.gmail.stefvanschiedev.buildinggame.events.entity.EntityExplode) FirstStat(com.gmail.stefvanschiedev.buildinggame.events.stats.saved.FirstStat) NPCFloorChangeTrait(com.gmail.stefvanschiedev.buildinggame.utils.NPCFloorChangeTrait) NPCCreate(com.gmail.stefvanschiedev.buildinggame.events.softdependencies.NPCCreate) EntityOptionsMenu(com.gmail.stefvanschiedev.buildinggame.events.entity.EntityOptionsMenu) BukkitCommandManager(co.aikar.commands.BukkitCommandManager) LiquidFlow(com.gmail.stefvanschiedev.buildinggame.events.block.LiquidFlow) Material(org.bukkit.Material) PistonBlockMove(com.gmail.stefvanschiedev.buildinggame.events.block.PistonBlockMove) UnsavedStatsPlace(com.gmail.stefvanschiedev.buildinggame.events.stats.unsaved.UnsavedStatsPlace) BlockEdit(com.gmail.stefvanschiedev.buildinggame.events.block.BlockEdit) MainScoreboardJoinShow(com.gmail.stefvanschiedev.buildinggame.events.scoreboards.MainScoreboardJoinShow)

Aggregations

PlaceholderAPI (be.maximvdw.placeholderapi.PlaceholderAPI)1 BukkitCommandManager (co.aikar.commands.BukkitCommandManager)1 ConditionFailedException (co.aikar.commands.ConditionFailedException)1 InvalidCommandArgument (co.aikar.commands.InvalidCommandArgument)1 Gui (com.github.stefvanschie.inventoryframework.gui.type.util.Gui)1 BlockDispenseItem (com.gmail.stefvanschiedev.buildinggame.events.block.BlockDispenseItem)1 BlockEdit (com.gmail.stefvanschiedev.buildinggame.events.block.BlockEdit)1 LiquidFlow (com.gmail.stefvanschiedev.buildinggame.events.block.LiquidFlow)1 PistonBlockMove (com.gmail.stefvanschiedev.buildinggame.events.block.PistonBlockMove)1 com.gmail.stefvanschiedev.buildinggame.events.block.signs (com.gmail.stefvanschiedev.buildinggame.events.block.signs)1 ChickenSpawnByEgg (com.gmail.stefvanschiedev.buildinggame.events.entity.ChickenSpawnByEgg)1 EntityExplode (com.gmail.stefvanschiedev.buildinggame.events.entity.EntityExplode)1 EntityOptionsMenu (com.gmail.stefvanschiedev.buildinggame.events.entity.EntityOptionsMenu)1 EntitySpawn (com.gmail.stefvanschiedev.buildinggame.events.entity.EntitySpawn)1 com.gmail.stefvanschiedev.buildinggame.events.player (com.gmail.stefvanschiedev.buildinggame.events.player)1 ClickJoinSign (com.gmail.stefvanschiedev.buildinggame.events.player.signs.ClickJoinSign)1 ClickLeaveSign (com.gmail.stefvanschiedev.buildinggame.events.player.signs.ClickLeaveSign)1 ClickSpectateSign (com.gmail.stefvanschiedev.buildinggame.events.player.signs.ClickSpectateSign)1 Interact (com.gmail.stefvanschiedev.buildinggame.events.player.voting.Interact)1 MainScoreboardJoinShow (com.gmail.stefvanschiedev.buildinggame.events.scoreboards.MainScoreboardJoinShow)1