mcMMO.java 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730
  1. package com.gmail.nossr50;
  2. import com.gmail.nossr50.chat.ChatManager;
  3. import com.gmail.nossr50.commands.CommandManager;
  4. import com.gmail.nossr50.config.*;
  5. import com.gmail.nossr50.config.experience.ExperienceConfig;
  6. import com.gmail.nossr50.config.skills.alchemy.PotionConfig;
  7. import com.gmail.nossr50.config.skills.repair.RepairConfigManager;
  8. import com.gmail.nossr50.config.skills.salvage.SalvageConfigManager;
  9. import com.gmail.nossr50.config.treasure.FishingTreasureConfig;
  10. import com.gmail.nossr50.config.treasure.TreasureConfig;
  11. import com.gmail.nossr50.database.DatabaseManager;
  12. import com.gmail.nossr50.database.DatabaseManagerFactory;
  13. import com.gmail.nossr50.datatypes.skills.PrimarySkillType;
  14. import com.gmail.nossr50.datatypes.skills.SkillRegisterImpl;
  15. import com.gmail.nossr50.datatypes.skills.subskills.acrobatics.Roll;
  16. import com.gmail.nossr50.listeners.*;
  17. import com.gmail.nossr50.party.PartyManagerImpl;
  18. import com.gmail.nossr50.runnables.CheckDateTask;
  19. import com.gmail.nossr50.runnables.SaveTimerTask;
  20. import com.gmail.nossr50.runnables.backups.CleanBackupsTask;
  21. import com.gmail.nossr50.runnables.commands.NotifySquelchReminderTask;
  22. import com.gmail.nossr50.runnables.database.UserPurgeTask;
  23. import com.gmail.nossr50.runnables.party.PartyAutoKickTask;
  24. import com.gmail.nossr50.runnables.player.ClearRegisteredXPGainTask;
  25. import com.gmail.nossr50.runnables.player.PlayerProfileLoadingTask;
  26. import com.gmail.nossr50.runnables.player.PowerLevelUpdatingTask;
  27. import com.gmail.nossr50.runnables.skills.BleedTimerTask;
  28. import com.gmail.nossr50.skills.alchemy.Alchemy;
  29. import com.gmail.nossr50.skills.child.ChildConfig;
  30. import com.gmail.nossr50.skills.repair.repairables.Repairable;
  31. import com.gmail.nossr50.skills.repair.repairables.RepairableManager;
  32. import com.gmail.nossr50.skills.repair.repairables.SimpleRepairableManager;
  33. import com.gmail.nossr50.skills.salvage.salvageables.Salvageable;
  34. import com.gmail.nossr50.skills.salvage.salvageables.SalvageableManager;
  35. import com.gmail.nossr50.skills.salvage.salvageables.SimpleSalvageableManager;
  36. import com.gmail.nossr50.util.*;
  37. import com.gmail.nossr50.util.blockmeta.ChunkManager;
  38. import com.gmail.nossr50.util.blockmeta.ChunkManagerFactory;
  39. import com.gmail.nossr50.util.commands.CommandRegistrationManager;
  40. import com.gmail.nossr50.util.compat.CompatibilityManager;
  41. import com.gmail.nossr50.util.experience.FormulaManager;
  42. import com.gmail.nossr50.util.platform.PlatformManager;
  43. import com.gmail.nossr50.util.platform.ServerSoftwareType;
  44. import com.gmail.nossr50.util.player.PlayerLevelUtils;
  45. import com.gmail.nossr50.util.player.UserManager;
  46. import com.gmail.nossr50.util.scoreboards.ScoreboardManager;
  47. import com.gmail.nossr50.util.skills.RankUtils;
  48. import com.gmail.nossr50.util.skills.SmeltingTracker;
  49. import com.gmail.nossr50.util.upgrade.UpgradeManager;
  50. import com.gmail.nossr50.worldguard.WorldGuardManager;
  51. import com.google.common.base.Charsets;
  52. import com.neetgames.mcmmo.api.SkillRegister;
  53. import com.neetgames.mcmmo.party.PartyManager;
  54. import net.kyori.adventure.platform.bukkit.BukkitAudiences;
  55. import net.shatteredlands.shatt.backup.ZipLibrary;
  56. import org.bstats.bukkit.Metrics;
  57. import org.bukkit.Bukkit;
  58. import org.bukkit.entity.Player;
  59. import org.bukkit.event.HandlerList;
  60. import org.bukkit.metadata.FixedMetadataValue;
  61. import org.bukkit.plugin.PluginManager;
  62. import org.bukkit.plugin.java.JavaPlugin;
  63. import org.jetbrains.annotations.NotNull;
  64. import org.jetbrains.annotations.Nullable;
  65. import java.io.File;
  66. import java.io.IOException;
  67. import java.io.InputStream;
  68. import java.io.InputStreamReader;
  69. import java.util.ArrayList;
  70. import java.util.List;
  71. public class mcMMO extends JavaPlugin {
  72. /* Managers */
  73. private static PlatformManager platformManager;
  74. private static ChunkManager placeStore;
  75. private static RepairableManager repairableManager;
  76. private static SalvageableManager salvageableManager;
  77. private static ModManager modManager;
  78. private static DatabaseManager databaseManager;
  79. private static FormulaManager formulaManager;
  80. private static HolidayManager holidayManager;
  81. private static UpgradeManager upgradeManager;
  82. private static MaterialMapStore materialMapStore;
  83. private static PlayerLevelUtils playerLevelUtils;
  84. private static SmeltingTracker smeltingTracker;
  85. private static SpawnedProjectileTracker spawnedProjectileTracker;
  86. private static UserManager userManager;
  87. private static PartyManager partyManager;
  88. private static TransientMetadataTools transientMetadataTools;
  89. private static ChatManager chatManager;
  90. private static CommandManager commandManager; //ACF
  91. private static SkillRegister skillRegister;
  92. private static TransientEntityTracker transientEntityTracker;
  93. private static boolean serverShutdownExecuted = false;
  94. /* Adventure */
  95. private static BukkitAudiences audiences;
  96. /* Blacklist */
  97. private static WorldBlacklist worldBlacklist;
  98. /* File Paths */
  99. private static String mainDirectory;
  100. private static String localesDirectory;
  101. private static String flatFileDirectory;
  102. private static String usersFile;
  103. private static String modDirectory;
  104. public static mcMMO p;
  105. // Jar Stuff
  106. public static File mcmmo;
  107. /* Plugin Checks */
  108. private static boolean healthBarPluginEnabled;
  109. private static boolean projectKorraEnabled;
  110. // API checks
  111. private static boolean serverAPIOutdated = false;
  112. // Config Validation Check
  113. public boolean noErrorsInConfigFiles = true;
  114. // XP Event Check
  115. private boolean xpEventEnabled;
  116. private static boolean isRetroModeEnabled;
  117. /* Metadata Values */
  118. public final static String REPLANT_META_KEY = "mcMMO: Recently Replanted";
  119. public static final String FISH_HOOK_REF_METAKEY = "mcMMO: Fish Hook Tracker";
  120. public static final String DODGE_TRACKER = "mcMMO: Dodge Tracker";
  121. public static final String CUSTOM_DAMAGE_METAKEY = "mcMMO: Custom Damage";
  122. public final static String travelingBlock = "mcMMO: Traveling Block";
  123. public final static String blockMetadataKey = "mcMMO: Piston Tracking";
  124. public final static String tntMetadataKey = "mcMMO: Tracked TNT";
  125. public final static String customNameKey = "mcMMO: Custom Name";
  126. public final static String customVisibleKey = "mcMMO: Name Visibility";
  127. public final static String droppedItemKey = "mcMMO: Tracked Item";
  128. public final static String infiniteArrowKey = "mcMMO: Infinite Arrow";
  129. public final static String trackedArrow = "mcMMO: Tracked Arrow";
  130. public final static String bowForceKey = "mcMMO: Bow Force";
  131. public final static String arrowDistanceKey = "mcMMO: Arrow Distance";
  132. public final static String BONUS_DROPS_METAKEY = "mcMMO: Double Drops";
  133. public final static String disarmedItemKey = "mcMMO: Disarmed Item";
  134. public final static String playerDataKey = "mcMMO: Player Data";
  135. public final static String databaseCommandKey = "mcMMO: Processing Database Command";
  136. public final static String bredMetadataKey = "mcMMO: Bred Animal";
  137. public final static String PROJECTILE_ORIGIN_METAKEY = "mcMMO: Projectile Origin";
  138. public static FixedMetadataValue metadataValue;
  139. public mcMMO() {
  140. p = this;
  141. }
  142. /**
  143. * Things to be run when the plugin is enabled.
  144. */
  145. @Override
  146. public void onEnable() {
  147. try {
  148. //Skill Register
  149. skillRegister = new SkillRegisterImpl();
  150. //Platform Manager
  151. platformManager = new PlatformManager();
  152. getLogger().setFilter(new LogFilter(this));
  153. metadataValue = new FixedMetadataValue(this, true);
  154. PluginManager pluginManager = getServer().getPluginManager();
  155. healthBarPluginEnabled = pluginManager.getPlugin("HealthBar") != null;
  156. projectKorraEnabled = pluginManager.getPlugin("ProjectKorra") != null;
  157. upgradeManager = new UpgradeManager();
  158. setupFilePaths();
  159. modManager = new ModManager();
  160. //Init Material Maps
  161. materialMapStore = new MaterialMapStore();
  162. loadConfigFiles();
  163. if (!noErrorsInConfigFiles) {
  164. return;
  165. }
  166. //Store this value so other plugins can check it
  167. isRetroModeEnabled = Config.getInstance().getIsRetroMode();
  168. if(projectKorraEnabled) {
  169. getLogger().info("ProjectKorra was detected, this can cause some issues with weakness potions and combat skills for mcMMO");
  170. }
  171. if (healthBarPluginEnabled) {
  172. getLogger().info("HealthBar plugin found, mcMMO's healthbars are automatically disabled.");
  173. }
  174. if (pluginManager.getPlugin("NoCheatPlus") != null && pluginManager.getPlugin("CompatNoCheatPlus") == null) {
  175. getLogger().warning("NoCheatPlus plugin found, but CompatNoCheatPlus was not found!");
  176. getLogger().warning("mcMMO will not work properly alongside NoCheatPlus without CompatNoCheatPlus");
  177. }
  178. databaseManager = DatabaseManagerFactory.getDatabaseManager();
  179. //Check for the newer API and tell them what to do if its missing
  180. checkForOutdatedAPI();
  181. if(serverAPIOutdated)
  182. {
  183. Bukkit
  184. .getScheduler()
  185. .scheduleSyncRepeatingTask(this,
  186. () -> getLogger().severe("You are running an outdated version of "+platformManager.getServerSoftware()+", mcMMO will not work unless you update to a newer version!"),
  187. 20, 20*60*30);
  188. if(platformManager.getServerSoftware() == ServerSoftwareType.CRAFT_BUKKIT)
  189. {
  190. Bukkit.getScheduler()
  191. .scheduleSyncRepeatingTask(this,
  192. () -> getLogger().severe("We have detected you are using incompatible server software, our best guess is that you are using CraftBukkit. mcMMO requires Spigot or Paper, if you are not using CraftBukkit, you will still need to update your custom server software before mcMMO will work."),
  193. 20, 20*60*30);
  194. }
  195. } else {
  196. registerEvents();
  197. registerCoreSkills();
  198. registerCustomRecipes();
  199. mcMMO.getPartyManager().loadParties();
  200. formulaManager = new FormulaManager();
  201. holidayManager = new HolidayManager();
  202. for (Player player : getServer().getOnlinePlayers()) {
  203. new PlayerProfileLoadingTask(player).runTaskLaterAsynchronously(mcMMO.p, 1); // 1 Tick delay to ensure the player is marked as online before we begin loading
  204. }
  205. debug("Version " + getDescription().getVersion() + " is enabled!");
  206. scheduleTasks();
  207. CommandRegistrationManager.registerCommands();
  208. placeStore = ChunkManagerFactory.getChunkManager(); // Get our ChunkletManager
  209. if (Config.getInstance().getPTPCommandWorldPermissions()) {
  210. Permissions.generateWorldTeleportPermissions();
  211. }
  212. //Populate Ranked Skill Maps (DO THIS LAST)
  213. RankUtils.populateRanks();
  214. }
  215. //If anonymous statistics are enabled then use them
  216. Metrics metrics;
  217. if(Config.getInstance().getIsMetricsEnabled()) {
  218. metrics = new Metrics(this, 3894);
  219. metrics.addCustomChart(new Metrics.SimplePie("version", () -> getDescription().getVersion()));
  220. if(Config.getInstance().getIsRetroMode())
  221. metrics.addCustomChart(new Metrics.SimplePie("leveling_system", () -> "Retro"));
  222. else
  223. metrics.addCustomChart(new Metrics.SimplePie("leveling_system", () -> "Standard"));
  224. }
  225. }
  226. catch (Throwable t) {
  227. getLogger().severe("There was an error while enabling mcMMO!");
  228. if (!(t instanceof ExceptionInInitializerError)) {
  229. t.printStackTrace();
  230. }
  231. else {
  232. getLogger().info("Please do not replace the mcMMO jar while the server is running.");
  233. }
  234. getServer().getPluginManager().disablePlugin(this);
  235. }
  236. //Init player level values
  237. playerLevelUtils = new PlayerLevelUtils();
  238. //Init the blacklist
  239. worldBlacklist = new WorldBlacklist(this);
  240. //Init smelting tracker
  241. smeltingTracker = new SmeltingTracker();
  242. //Init spawned projectile tracker
  243. spawnedProjectileTracker = new SpawnedProjectileTracker();
  244. //Init Player Data Manager
  245. userManager = new UserManager();
  246. audiences = BukkitAudiences.create(this);
  247. transientMetadataTools = new TransientMetadataTools(this);
  248. chatManager = new ChatManager(this);
  249. commandManager = new CommandManager(this);
  250. transientEntityTracker = new TransientEntityTracker();
  251. setServerShutdown(false); //Reset flag, used to make decisions about async saves
  252. }
  253. public static PlayerLevelUtils getPlayerLevelUtils() {
  254. return playerLevelUtils;
  255. }
  256. public static MaterialMapStore getMaterialMapStore() {
  257. return materialMapStore;
  258. }
  259. private void checkForOutdatedAPI() {
  260. try {
  261. Class<?> checkForClass = Class.forName("org.bukkit.event.block.BlockDropItemEvent");
  262. checkForClass.getMethod("getItems");
  263. Class.forName("net.md_5.bungee.api.chat.BaseComponent");
  264. } catch (ClassNotFoundException | NoSuchMethodException e) {
  265. serverAPIOutdated = true;
  266. String software = platformManager.getServerSoftwareStr();
  267. getLogger().severe("You are running an older version of " + software + " that is not compatible with mcMMO, update your server software!");
  268. }
  269. }
  270. @Override
  271. public void onLoad()
  272. {
  273. if(getServer().getPluginManager().getPlugin("WorldGuard") != null) {
  274. WorldGuardManager.getInstance().registerFlags();
  275. }
  276. }
  277. /**
  278. * Things to be run when the plugin is disabled.
  279. */
  280. @Override
  281. public void onDisable() {
  282. setServerShutdown(true);
  283. //TODO: Write code to catch unfinished async save tasks, for now we just hope they finish in time, which they should in most cases
  284. mcMMO.p.getLogger().info("Server shutdown has been executed, saving and cleaning up data...");
  285. try {
  286. userManager.saveAllSync(); // Make sure to save player information if the server shuts down
  287. userManager.clearAll();
  288. Alchemy.finishAllBrews(); // Finish all partially complete AlchemyBrewTasks to prevent vanilla brewing continuation on restart
  289. mcMMO.getPartyManager().saveParties(); // Save our parties
  290. //TODO: Needed?
  291. if(Config.getInstance().getScoreboardsEnabled())
  292. ScoreboardManager.teardownAll();
  293. formulaManager.saveFormula();
  294. holidayManager.saveAnniversaryFiles();
  295. placeStore.closeAll();
  296. }
  297. catch (Exception e) { e.printStackTrace(); }
  298. if (Config.getInstance().getBackupsEnabled()) {
  299. // Remove other tasks BEFORE starting the Backup, or we just cancel it straight away.
  300. try {
  301. ZipLibrary.mcMMOBackup();
  302. }
  303. catch (IOException e) {
  304. getLogger().severe(e.toString());
  305. }
  306. catch (Throwable e) {
  307. if (e instanceof NoClassDefFoundError) {
  308. getLogger().severe("Backup class not found!");
  309. getLogger().info("Please do not replace the mcMMO jar while the server is running.");
  310. }
  311. else {
  312. getLogger().severe(e.toString());
  313. }
  314. }
  315. }
  316. debug("Canceling all tasks...");
  317. getServer().getScheduler().cancelTasks(this); // This removes our tasks
  318. debug("Unregister all events...");
  319. HandlerList.unregisterAll(this); // Cancel event registrations
  320. databaseManager.onDisable();
  321. debug("Was disabled."); // How informative!
  322. }
  323. public static String getMainDirectory() {
  324. return mainDirectory;
  325. }
  326. public static String getLocalesDirectory() {
  327. return localesDirectory;
  328. }
  329. public static String getFlatFileDirectory() {
  330. return flatFileDirectory;
  331. }
  332. public static String getUsersFilePath() {
  333. return usersFile;
  334. }
  335. public static String getModDirectory() {
  336. return modDirectory;
  337. }
  338. public boolean isXPEventEnabled() {
  339. return xpEventEnabled;
  340. }
  341. public void setXPEventEnabled(boolean enabled) {
  342. this.xpEventEnabled = enabled;
  343. }
  344. public void toggleXpEventEnabled() {
  345. xpEventEnabled = !xpEventEnabled;
  346. }
  347. public void debug(String message) {
  348. getLogger().info("[Debug] " + message);
  349. }
  350. public static FormulaManager getFormulaManager() {
  351. return formulaManager;
  352. }
  353. public static HolidayManager getHolidayManager() {
  354. return holidayManager;
  355. }
  356. public static ChunkManager getPlaceStore() {
  357. return placeStore;
  358. }
  359. public static RepairableManager getRepairableManager() {
  360. return repairableManager;
  361. }
  362. public static SalvageableManager getSalvageableManager() {
  363. return salvageableManager;
  364. }
  365. public static @NotNull DatabaseManager getDatabaseManager() {
  366. return databaseManager;
  367. }
  368. public static ModManager getModManager() {
  369. return modManager;
  370. }
  371. public static UpgradeManager getUpgradeManager() {
  372. return upgradeManager;
  373. }
  374. public static CompatibilityManager getCompatibilityManager() {
  375. return platformManager.getCompatibilityManager();
  376. }
  377. @Deprecated
  378. public static void setDatabaseManager(DatabaseManager databaseManager) {
  379. mcMMO.databaseManager = databaseManager;
  380. }
  381. public static boolean isHealthBarPluginEnabled() {
  382. return healthBarPluginEnabled;
  383. }
  384. /**
  385. * Setup the various storage file paths
  386. */
  387. private void setupFilePaths() {
  388. mcmmo = getFile();
  389. mainDirectory = getDataFolder().getPath() + File.separator;
  390. localesDirectory = mainDirectory + "locales" + File.separator;
  391. flatFileDirectory = mainDirectory + "flatfile" + File.separator;
  392. usersFile = flatFileDirectory + "mcmmo.users";
  393. modDirectory = mainDirectory + "mods" + File.separator;
  394. fixFilePaths();
  395. }
  396. private void fixFilePaths() {
  397. File oldFlatfilePath = new File(mainDirectory + "FlatFileStuff" + File.separator);
  398. File oldModPath = new File(mainDirectory + "ModConfigs" + File.separator);
  399. if (oldFlatfilePath.exists()) {
  400. if (!oldFlatfilePath.renameTo(new File(flatFileDirectory))) {
  401. getLogger().warning("Failed to rename FlatFileStuff to flatfile!");
  402. }
  403. }
  404. if (oldModPath.exists()) {
  405. if (!oldModPath.renameTo(new File(modDirectory))) {
  406. getLogger().warning("Failed to rename ModConfigs to mods!");
  407. }
  408. }
  409. File oldArmorFile = new File(modDirectory + "armor.yml");
  410. File oldBlocksFile = new File(modDirectory + "blocks.yml");
  411. File oldEntitiesFile = new File(modDirectory + "entities.yml");
  412. File oldToolsFile = new File(modDirectory + "tools.yml");
  413. if (oldArmorFile.exists()) {
  414. if (!oldArmorFile.renameTo(new File(modDirectory + "armor.default.yml"))) {
  415. getLogger().warning("Failed to rename armor.yml to armor.default.yml!");
  416. }
  417. }
  418. if (oldBlocksFile.exists()) {
  419. if (!oldBlocksFile.renameTo(new File(modDirectory + "blocks.default.yml"))) {
  420. getLogger().warning("Failed to rename blocks.yml to blocks.default.yml!");
  421. }
  422. }
  423. if (oldEntitiesFile.exists()) {
  424. if (!oldEntitiesFile.renameTo(new File(modDirectory + "entities.default.yml"))) {
  425. getLogger().warning("Failed to rename entities.yml to entities.default.yml!");
  426. }
  427. }
  428. if (oldToolsFile.exists()) {
  429. if (!oldToolsFile.renameTo(new File(modDirectory + "tools.default.yml"))) {
  430. getLogger().warning("Failed to rename tools.yml to tools.default.yml!");
  431. }
  432. }
  433. File currentFlatfilePath = new File(flatFileDirectory);
  434. currentFlatfilePath.mkdirs();
  435. File localesDirectoryPath = new File(localesDirectory);
  436. localesDirectoryPath.mkdirs();
  437. }
  438. private void loadConfigFiles() {
  439. // Force the loading of config files
  440. TreasureConfig.getInstance();
  441. FishingTreasureConfig.getInstance();
  442. HiddenConfig.getInstance();
  443. AdvancedConfig.getInstance();
  444. PotionConfig.getInstance();
  445. CoreSkillsConfig.getInstance();
  446. SoundConfig.getInstance();
  447. RankConfig.getInstance();
  448. new ChildConfig();
  449. List<Repairable> repairables = new ArrayList<>();
  450. // Load repair configs, make manager, and register them at this time
  451. repairables.addAll(new RepairConfigManager(this).getLoadedRepairables());
  452. repairableManager = new SimpleRepairableManager(repairables.size());
  453. repairableManager.registerRepairables(repairables);
  454. // Load salvage configs, make manager and register them at this time
  455. SalvageConfigManager sManager = new SalvageConfigManager(this);
  456. List<Salvageable> salvageables = new ArrayList<>(sManager.getLoadedSalvageables());
  457. salvageableManager = new SimpleSalvageableManager(salvageables.size());
  458. salvageableManager.registerSalvageables(salvageables);
  459. }
  460. private void registerEvents() {
  461. PluginManager pluginManager = getServer().getPluginManager();
  462. // Register events
  463. pluginManager.registerEvents(new PlayerListener(this), this);
  464. pluginManager.registerEvents(new BlockListener(this), this);
  465. pluginManager.registerEvents(new EntityListener(this), this);
  466. pluginManager.registerEvents(new InventoryListener(this), this);
  467. pluginManager.registerEvents(new SelfListener(this), this);
  468. pluginManager.registerEvents(new WorldListener(this), this);
  469. pluginManager.registerEvents(new ChunkListener(), this);
  470. // pluginManager.registerEvents(new CommandListener(this), this);
  471. }
  472. /**
  473. * Registers core skills
  474. * This enables the skills in the new skill system
  475. */
  476. private void registerCoreSkills() {
  477. /*
  478. * Acrobatics skills
  479. */
  480. InteractionManager.initMaps(); //Init maps
  481. if(CoreSkillsConfig.getInstance().isPrimarySkillEnabled(PrimarySkillType.ACROBATICS))
  482. {
  483. getLogger().info("Enabling Acrobatics Skills");
  484. //TODO: Should do this differently
  485. Roll roll = new Roll();
  486. CoreSkillsConfig.getInstance().isSkillEnabled(roll);
  487. InteractionManager.registerSubSkill(new Roll());
  488. }
  489. }
  490. private void registerCustomRecipes() {
  491. getServer().getScheduler().scheduleSyncDelayedTask(this, () -> {
  492. if (Config.getInstance().getChimaeraEnabled()) {
  493. getServer().addRecipe(ChimaeraWing.getChimaeraWingRecipe());
  494. }
  495. }, 40);
  496. }
  497. private void scheduleTasks() {
  498. // Periodic save timer (Saves every 10 minutes by default)
  499. long saveIntervalTicks = Config.getInstance().getSaveInterval() * 1200;
  500. new SaveTimerTask().runTaskTimer(this, saveIntervalTicks, saveIntervalTicks);
  501. // Cleanup the backups folder
  502. new CleanBackupsTask().runTaskAsynchronously(mcMMO.p);
  503. // Bleed timer (Runs every 0.5 seconds)
  504. new BleedTimerTask().runTaskTimer(this, Misc.TICK_CONVERSION_FACTOR, (Misc.TICK_CONVERSION_FACTOR / 2));
  505. // Old & Powerless User remover
  506. long purgeIntervalTicks = Config.getInstance().getPurgeInterval() * 60L * 60L * Misc.TICK_CONVERSION_FACTOR;
  507. if (purgeIntervalTicks == 0) {
  508. new UserPurgeTask().runTaskLaterAsynchronously(this, 2 * Misc.TICK_CONVERSION_FACTOR); // Start 2 seconds after startup.
  509. }
  510. else if (purgeIntervalTicks > 0) {
  511. new UserPurgeTask().runTaskTimerAsynchronously(this, purgeIntervalTicks, purgeIntervalTicks);
  512. }
  513. // Automatically remove old members from parties
  514. long kickIntervalTicks = Config.getInstance().getAutoPartyKickInterval() * 60L * 60L * Misc.TICK_CONVERSION_FACTOR;
  515. if (kickIntervalTicks == 0) {
  516. new PartyAutoKickTask().runTaskLater(this, 2 * Misc.TICK_CONVERSION_FACTOR); // Start 2 seconds after startup.
  517. }
  518. else if (kickIntervalTicks > 0) {
  519. new PartyAutoKickTask().runTaskTimer(this, kickIntervalTicks, kickIntervalTicks);
  520. }
  521. // Update power level tag scoreboards
  522. new PowerLevelUpdatingTask().runTaskTimer(this, 2 * Misc.TICK_CONVERSION_FACTOR, 2 * Misc.TICK_CONVERSION_FACTOR);
  523. if (getHolidayManager().nearingAprilFirst()) {
  524. new CheckDateTask().runTaskTimer(this, 10L * Misc.TICK_CONVERSION_FACTOR, 60L * 60L * Misc.TICK_CONVERSION_FACTOR);
  525. }
  526. // Clear the registered XP data so players can earn XP again
  527. if (ExperienceConfig.getInstance().getDiminishedReturnsEnabled()) {
  528. new ClearRegisteredXPGainTask().runTaskTimer(this, 60, 60);
  529. }
  530. if(AdvancedConfig.getInstance().allowPlayerTips())
  531. {
  532. new NotifySquelchReminderTask().runTaskTimer(this, 60, ((20 * 60) * 60));
  533. }
  534. }
  535. public @Nullable InputStreamReader getResourceAsReader(String fileName) {
  536. InputStream in = getResource(fileName);
  537. return in == null ? null : new InputStreamReader(in, Charsets.UTF_8);
  538. }
  539. /**
  540. * Checks if this plugin is using retro mode
  541. * Retro mode is a 0-1000 skill system
  542. * Standard mode is scaled for 1-100
  543. * @return true if retro mode is enabled
  544. */
  545. public static boolean isRetroModeEnabled() {
  546. return isRetroModeEnabled;
  547. }
  548. public static @NotNull WorldBlacklist getWorldBlacklist() {
  549. return worldBlacklist;
  550. }
  551. public static @NotNull PlatformManager getPlatformManager() {
  552. return platformManager;
  553. }
  554. public static @NotNull SmeltingTracker getSmeltingTracker() {
  555. return smeltingTracker;
  556. }
  557. public static @NotNull SpawnedProjectileTracker getSpawnedProjectileTracker() {
  558. return spawnedProjectileTracker;
  559. }
  560. public static @NotNull UserManager getUserManager() {
  561. return userManager;
  562. }
  563. public static @NotNull PartyManager getPartyManager() {
  564. return partyManager;
  565. }
  566. public static @NotNull BukkitAudiences getAudiences() {
  567. return audiences;
  568. }
  569. public static boolean isProjectKorraEnabled() {
  570. return projectKorraEnabled;
  571. }
  572. public static @NotNull TransientMetadataTools getTransientMetadataTools() {
  573. return transientMetadataTools;
  574. }
  575. public @NotNull ChatManager getChatManager() {
  576. return chatManager;
  577. }
  578. public @NotNull CommandManager getCommandManager() {
  579. return commandManager;
  580. }
  581. public static TransientEntityTracker getTransientEntityTracker() {
  582. return transientEntityTracker;
  583. }
  584. public static synchronized boolean isServerShutdownExecuted() {
  585. return serverShutdownExecuted;
  586. }
  587. private static synchronized void setServerShutdown(boolean bool) {
  588. serverShutdownExecuted = bool;
  589. }
  590. public @NotNull SkillRegister getSkillRegister() { return skillRegister; }
  591. }