package com.Acrobot.ChestShop; import com.Acrobot.ChestShop.Commands.ItemInfo; import com.Acrobot.ChestShop.Commands.Version; import com.Acrobot.ChestShop.Config.Config; import com.Acrobot.ChestShop.Config.Property; import com.Acrobot.ChestShop.DB.Generator; import com.Acrobot.ChestShop.DB.Queue; import com.Acrobot.ChestShop.DB.Transaction; import com.Acrobot.ChestShop.Listeners.Block.BlockBreak; import com.Acrobot.ChestShop.Listeners.Block.BlockPlace; import com.Acrobot.ChestShop.Listeners.Block.Break.ChestBreak; import com.Acrobot.ChestShop.Listeners.Block.EntityExplode; import com.Acrobot.ChestShop.Listeners.Block.SignChange; import com.Acrobot.ChestShop.Listeners.ItemInfoListener; import com.Acrobot.ChestShop.Listeners.Player.PlayerConnect; import com.Acrobot.ChestShop.Listeners.Player.PlayerInteract; import com.Acrobot.ChestShop.Listeners.Player.PlayerInventory; import com.Acrobot.ChestShop.Listeners.Player.ShortNameSaver; import com.Acrobot.ChestShop.Listeners.PostTransaction.EconomicModule; import com.Acrobot.ChestShop.Listeners.PostTransaction.ItemManager; import com.Acrobot.ChestShop.Listeners.PreTransaction.*; import com.Acrobot.ChestShop.Listeners.PostTransaction.EmptyShopDeleter; import com.Acrobot.ChestShop.Listeners.PostTransaction.TransactionLogger; import com.Acrobot.ChestShop.Listeners.PostTransaction.TransactionMessageSender; import com.Acrobot.ChestShop.Logging.FileFormatter; import com.Acrobot.ChestShop.Signs.RestrictedSign; import com.avaje.ebean.EbeanServer; import com.lennardf1989.bukkitex.Database; import org.bukkit.Bukkit; import org.bukkit.Server; import org.bukkit.configuration.file.YamlConfiguration; import org.bukkit.event.Event; import org.bukkit.event.Listener; import org.bukkit.plugin.PluginDescriptionFile; import org.bukkit.plugin.PluginManager; import org.bukkit.plugin.java.JavaPlugin; import java.io.File; import java.io.IOException; import java.util.ArrayList; import java.util.List; import java.util.logging.FileHandler; import java.util.logging.Logger; import static com.Acrobot.ChestShop.Config.Property.ALLOW_PARTIAL_TRANSACTIONS; import static com.Acrobot.ChestShop.Config.Property.SHOP_INTERACTION_INTERVAL; /** * Main file of the plugin * * @author Acrobot */ public class ChestShop extends JavaPlugin { public static File dataFolder = new File("plugins/ChestShop"); private static EbeanServer DB; private static PluginDescriptionFile description; private static Server server; private static Logger logger; private static PluginManager pluginManager; private static ChestShop plugin; private FileHandler handler; public void onEnable() { plugin = this; logger = getLogger(); pluginManager = getServer().getPluginManager(); dataFolder = getDataFolder(); description = getDescription(); server = getServer(); Config.setup(); Dependencies.load(); registerEvents(); if (Config.getBoolean(Property.LOG_TO_DATABASE) || Config.getBoolean(Property.GENERATE_STATISTICS_PAGE)) { setupDB(); } if (Config.getBoolean(Property.GENERATE_STATISTICS_PAGE)) { File htmlFolder = new File(Config.getString(Property.STATISTICS_PAGE_PATH)); scheduleTask(new Generator(htmlFolder), 300L, (long) Config.getDouble(Property.STATISTICS_PAGE_GENERATION_INTERVAL) * 20L); } if (Config.getBoolean(Property.LOG_TO_FILE)) { File log = loadFile(new File(ChestShop.getFolder(), "ChestShop.log")); FileHandler handler = loadHandler(log.getAbsolutePath()); handler.setFormatter(new FileFormatter()); this.handler = handler; logger.addHandler(handler); } if (!Config.getBoolean(Property.LOG_TO_CONSOLE)) { logger.setUseParentHandlers(false); } //Register our commands! getCommand("iteminfo").setExecutor(new ItemInfo()); getCommand("csVersion").setExecutor(new Version()); //Start the statistics pinger startStatistics(); } private static File loadFile(File file) { if (!file.exists()) { try { file.createNewFile(); } catch (IOException e) { e.printStackTrace(); } } return file; } private static FileHandler loadHandler(String path) { FileHandler handler = null; try { handler = new FileHandler(path, true); } catch (IOException ex) { ex.printStackTrace(); } return handler; } public void onDisable() { getServer().getScheduler().cancelTasks(this); if (handler != null) { handler.close(); getLogger().removeHandler(handler); } } ////////////////// REGISTER EVENTS, SCHEDULER & STATS /////////////////////////// private void registerEvents() { registerEvent(new com.Acrobot.ChestShop.Plugins.ChestShop()); //Chest protection registerEvent(new BlockBreak()); registerEvent(new ChestBreak()); registerEvent(new BlockPlace()); registerEvent(new SignChange()); registerEvent(new EntityExplode()); registerEvent(new PlayerConnect()); registerEvent(new PlayerInteract()); registerEvent(new PlayerInventory()); registerEvent(new ItemInfoListener()); registerEvent(new EmptyShopDeleter()); registerEvent(new TransactionLogger()); registerEvent(new TransactionMessageSender()); registerEvent(new EconomicModule()); registerEvent(new ItemManager()); registerEvent(new CreativeModeIgnorer()); registerEvent(new PermissionChecker()); registerEvent(new PriceValidator()); registerEvent(new ShopValidator()); registerEvent(new StockFittingChecker()); registerEvent(new ErrorMessageSender()); registerEvent(new SpamClickProtector(Config.getInteger(SHOP_INTERACTION_INTERVAL))); registerEvent(new RestrictedSign()); registerEvent(new DiscountModule()); if (Config.getBoolean(ALLOW_PARTIAL_TRANSACTIONS)) { registerEvent(new PartialTransactionModule()); } else { registerEvent(new AmountAndPriceChecker()); } registerEvent(new ShortNameSaver()); } public void registerEvent(Listener listener) { getServer().getPluginManager().registerEvents(listener, this); } private void scheduleTask(Runnable runnable, long startTime, long repetetionTime) { server.getScheduler().scheduleAsyncRepeatingTask(this, runnable, startTime, repetetionTime); } private void startStatistics() { try { new Metrics(this).start(); } catch (IOException ex) { ChestShop.getBukkitLogger().severe("There was an error while submitting statistics."); } } ///////////////////// DATABASE STUFF //////////////////////////////// private static YamlConfiguration getBukkitConfig() { return YamlConfiguration.loadConfiguration(new File("bukkit.yml")); } private static Database database; private void setupDB() { database = new Database(this) { protected java.util.List> getDatabaseClasses() { List> list = new ArrayList>(); list.add(Transaction.class); return list; } }; YamlConfiguration config = getBukkitConfig(); database.initializeDatabase( config.getString("database.driver"), config.getString("database.url"), config.getString("database.username"), config.getString("database.password"), config.getString("database.isolation") ); DB = database.getDatabase(); getServer().getScheduler().scheduleAsyncRepeatingTask(this, new Queue(), 200L, 200L); } @Override public EbeanServer getDatabase() { return database.getDatabase(); } /////////////////////////////////////////////////////////////////////////////// public static File getFolder() { return dataFolder; } public static Logger getBukkitLogger() { return logger; } public static Server getBukkitServer() { return server; } public static String getVersion() { return description.getVersion(); } public static String getPluginName() { return description.getName(); } public static EbeanServer getDB() { return DB; } public static List getDependencies() { return description.getSoftDepend(); } public static void registerListener(Listener listener) { plugin.registerEvent(listener); } public static void callEvent(Event event) { pluginManager.callEvent(event); } public static void scheduleRepeating(Runnable runnable, int delay) { Bukkit.getScheduler().scheduleSyncRepeatingTask(plugin, runnable, 0, delay); } }