/* * Quartz * Copyright (c) 2015, Minecrell <https://github.com/Minecrell> * * Based on Sponge and SpongeAPI, licensed under the MIT License (MIT). * Copyright (c) SpongePowered.org <http://www.spongepowered.org> * Copyright (c) contributors * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */ package net.minecrell.quartz; import com.google.common.base.Throwables; import com.google.inject.Guice; import com.google.inject.Injector; import net.minecrell.quartz.event.QuartzEventFactory; import net.minecrell.quartz.guice.QuartzGuiceModule; import net.minecrell.quartz.launch.QuartzLaunch; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.spongepowered.api.Game; import org.spongepowered.api.event.state.ConstructionEvent; import org.spongepowered.api.event.state.InitializationEvent; import org.spongepowered.api.event.state.LoadCompleteEvent; import org.spongepowered.api.event.state.PostInitializationEvent; import org.spongepowered.api.event.state.PreInitializationEvent; import org.spongepowered.api.event.state.StateEvent; import org.spongepowered.api.plugin.PluginContainer; import org.spongepowered.api.service.ProviderExistsException; import org.spongepowered.api.service.command.CommandService; import org.spongepowered.api.service.command.SimpleCommandService; import java.io.IOException; import java.nio.file.Files; import java.nio.file.Path; public final class Quartz implements PluginContainer { public static final Quartz instance = new Quartz(); private static final Injector injector = Guice.createInjector(new QuartzGuiceModule()); public static Injector getInjector() { return injector; } private final Logger logger = LogManager.getLogger(); private final Path gameDir; private final Path pluginsDir; private final Path configDir; private QuartzGame game; private Quartz() { this.gameDir = QuartzLaunch.getGameDirectory(); this.pluginsDir = gameDir.resolve("plugins"); this.configDir = gameDir.resolve("config"); } public Game getGame() { return game; } public Logger getLogger() { return logger; } public Path getGameDirectory() { return gameDir; } public Path getPluginsDirectory() { return pluginsDir; } public Path getConfigDirectory() { return configDir; } public void load() { try { logger.info("Loading Quartz..."); this.game = injector.getInstance(QuartzGame.class); try { SimpleCommandService commandService = new SimpleCommandService(game.getPluginManager()); game.getServiceManager().setProvider(this, CommandService.class, commandService); game.getEventManager().register(this, commandService); } catch (ProviderExistsException e) { logger.warn("An unknown CommandService was already registered", e); } if (Files.notExists(gameDir) || Files.notExists(pluginsDir)) { Files.createDirectories(pluginsDir); } getLogger().info("Loading plugins..."); game.getPluginManager().loadPlugins(); postState(ConstructionEvent.class); getLogger().info("Initializing plugins..."); postState(PreInitializationEvent.class); } catch (IOException e) { throw Throwables.propagate(e); } } public void initialize() { postState(InitializationEvent.class); postState(PostInitializationEvent.class); getLogger().info("Successfully loaded and initialized plugins."); postState(LoadCompleteEvent.class); } public void postState(Class<? extends StateEvent> type) { game.getEventManager().post(QuartzEventFactory.createStateEvent(type, game)); } @Override public String getId() { return "quartz"; } @Override public String getName() { return "Quartz"; } @Override public String getVersion() { return game.getImplementationVersion(); } @Override public Object getInstance() { return this; } }