package me.totalfreedom.plex; import lombok.Getter; import lombok.Setter; import me.totalfreedom.plex.cache.MongoPlayerData; import me.totalfreedom.plex.cache.SQLPlayerData; import me.totalfreedom.plex.config.MainConfig; import me.totalfreedom.plex.listener.ChatListener; import me.totalfreedom.plex.listener.PlayerListener; import me.totalfreedom.plex.rank.RankManager; import me.totalfreedom.plex.storage.MongoConnection; import me.totalfreedom.plex.storage.RedisConnection; import me.totalfreedom.plex.storage.SQLConnection; import me.totalfreedom.plex.storage.StorageType; import me.totalfreedom.plex.util.PlexLog; import me.totalfreedom.plex.util.PlexUtils; import me.totalfreedom.plex.world.impl.Flatlands; import org.bukkit.World; import org.bukkit.plugin.java.JavaPlugin; @Getter @Setter public class Plex extends JavaPlugin { private static Plex plugin; public MainConfig config; private StorageType storageType = StorageType.SQLITE; private SQLConnection sqlConnection; private MongoConnection mongoConnection; private RedisConnection redisConnection; private MongoPlayerData mongoPlayerData; private SQLPlayerData sqlPlayerData; private RankManager rankManager; public World flatlands; public static Plex get() { return plugin; } @Override public void onLoad() { plugin = this; config = new MainConfig(this); saveResource("database.db", false); sqlConnection = new SQLConnection(); mongoConnection = new MongoConnection(); redisConnection = new RedisConnection(); /*try { redisConnection.openPool(); PlexLog.log("Successfully opened redis pool. Closing."); } catch (Exception e) { e.printStackTrace(); } redisConnection.getJedis().close();*/ } @Override public void onEnable() { config.load(); try { PlexUtils.testConnections(); PlexLog.log("Connected to " + storageType.name().toUpperCase()); } catch (Exception e) { PlexLog.error("Failed to connect to " + storageType.name().toUpperCase()); e.printStackTrace(); } if (storageType == StorageType.MONGO) { mongoPlayerData = new MongoPlayerData(); } else { sqlPlayerData = new SQLPlayerData(); } getServer().getPluginManager().registerEvents(new PlayerListener(), this); getServer().getPluginManager().registerEvents(new ChatListener(), this); rankManager = new RankManager(); rankManager.generateDefaultRanks(); rankManager.importDefaultRanks(); PlexLog.log("Rank Manager initialized"); generateWorlds(); } @Override public void onDisable() { /*if (redisConnection.getJedis().isConnected()) { PlexLog.log("Disabling Redis/Jedis. No memory leaks in this Anarchy server !"); redisConnection.getJedis().close(); }*/ } private void generateWorlds() { PlexLog.log("Generating any worlds if needed..."); flatlands = new Flatlands().generate(); PlexLog.log("Finished with world generation!"); } }