Newer
Older
ultramine_bukkit / src / main / java / org / bukkit / plugin / Plugin.java
@vlad20012 vlad20012 on 24 Feb 2017 5 KB initial
package org.bukkit.plugin;

import com.avaje.ebean.EbeanServer;
import org.bukkit.Server;
import org.bukkit.command.TabExecutor;
import org.bukkit.configuration.file.FileConfiguration;
import org.bukkit.generator.ChunkGenerator;

import java.io.File;
import java.io.InputStream;
import java.util.logging.Logger;

/**
 * Represents a Plugin
 * <p>
 * The use of {@link PluginBase} is recommended for actual Implementation
 */
public interface Plugin extends TabExecutor
{
	/**
	 * Returns the folder that the plugin data's files are located in. The
	 * folder may not yet exist.
	 *
	 * @return The folder
	 */
	public File getDataFolder();

	/**
	 * Returns the plugin.yaml file containing the details for this plugin
	 *
	 * @return Contents of the plugin.yaml file
	 */
	public PluginDescriptionFile getDescription();

	/**
	 * Gets a {@link FileConfiguration} for this plugin, read through
	 * "config.yml"
	 * <p>
	 * If there is a default config.yml embedded in this plugin, it will be
	 * provided as a default for this Configuration.
	 *
	 * @return Plugin configuration
	 */
	public FileConfiguration getConfig();

	/**
	 * Gets an embedded resource in this plugin
	 *
	 * @param filename Filename of the resource
	 * @return File if found, otherwise null
	 */
	public InputStream getResource(String filename);

	/**
	 * Saves the {@link FileConfiguration} retrievable by {@link #getConfig()}.
	 */
	public void saveConfig();

	/**
	 * Saves the raw contents of the default config.yml file to the location
	 * retrievable by {@link #getConfig()}. If there is no default config.yml
	 * embedded in the plugin, an empty config.yml file is saved. This should
	 * fail silently if the config.yml already exists.
	 */
	public void saveDefaultConfig();

	/**
	 * Saves the raw contents of any resource embedded with a plugin's .jar
	 * file assuming it can be found using {@link #getResource(String)}.
	 * <p>
	 * The resource is saved into the plugin's data folder using the same
	 * hierarchy as the .jar file (subdirectories are preserved).
	 *
	 * @param resourcePath the embedded resource path to look for within the
	 *                     plugin's .jar file. (No preceding slash).
	 * @param replace      if true, the embedded resource will overwrite the
	 *                     contents of an existing file.
	 * @throws IllegalArgumentException if the resource path is null, empty,
	 *                                  or points to a nonexistent resource.
	 */
	public void saveResource(String resourcePath, boolean replace);

	/**
	 * Discards any data in {@link #getConfig()} and reloads from disk.
	 */
	public void reloadConfig();

	/**
	 * Gets the associated PluginLoader responsible for this plugin
	 *
	 * @return PluginLoader that controls this plugin
	 */
	public PluginLoader getPluginLoader();

	/**
	 * Returns the Server instance currently running this plugin
	 *
	 * @return Server running this plugin
	 */
	public Server getServer();

	/**
	 * Returns a value indicating whether or not this plugin is currently
	 * enabled
	 *
	 * @return true if this plugin is enabled, otherwise false
	 */
	public boolean isEnabled();

	/**
	 * Called when this plugin is disabled
	 */
	public void onDisable();

	/**
	 * Called after a plugin is loaded but before it has been enabled.
	 * <p>
	 * When mulitple plugins are loaded, the onLoad() for all plugins is
	 * called before any onEnable() is called.
	 */
	public void onLoad();

	/**
	 * Called when this plugin is enabled
	 */
	public void onEnable();

	/**
	 * Simple boolean if we can still nag to the logs about things
	 *
	 * @return boolean whether we can nag
	 */
	public boolean isNaggable();

	/**
	 * Set naggable state
	 *
	 * @param canNag is this plugin still naggable?
	 */
	public void setNaggable(boolean canNag);

	/**
	 * Gets the {@link EbeanServer} tied to this plugin. This will only be
	 * available if enabled in the {@link
	 * PluginDescriptionFile#isDatabaseEnabled()}
	 * <p>
	 * <i>For more information on the use of <a href="http://www.avaje.org/">
	 * Avaje Ebeans ORM</a>, see <a
	 * href="http://www.avaje.org/ebean/documentation.html">Avaje Ebeans
	 * Documentation</a></i>
	 * <p>
	 * <i>For an example using Ebeans ORM, see <a
	 * href="https://github.com/Bukkit/HomeBukkit">Bukkit's Homebukkit Plugin
	 * </a></i>
	 *
	 * @return ebean server instance or null if not enabled
	 */
	public EbeanServer getDatabase();

	/**
	 * Gets a {@link ChunkGenerator} for use in a default world, as specified
	 * in the server configuration
	 *
	 * @param worldName Name of the world that this will be applied to
	 * @param id        Unique ID, if any, that was specified to indicate which
	 *                  generator was requested
	 * @return ChunkGenerator for use in the default world generation
	 */
	public ChunkGenerator getDefaultWorldGenerator(String worldName, String id);

	/**
	 * Returns the plugin logger associated with this server's logger. The
	 * returned logger automatically tags all log messages with the plugin's
	 * name.
	 *
	 * @return Logger associated with this plugin
	 */
	public Logger getLogger();

	/**
	 * Returns the name of the plugin.
	 * <p>
	 * This should return the bare name of the plugin and should be used for
	 * comparison.
	 *
	 * @return name of the plugin
	 */
	public String getName();
}