75 lines
2.2 KiB
Java
75 lines
2.2 KiB
Java
|
|
package org.bukkit.plugin;
|
|
|
|
import java.io.File;
|
|
import org.bukkit.event.player.PlayerEvent;
|
|
|
|
/**
|
|
* Handles all plugin management from the Server
|
|
*/
|
|
public interface PluginManager {
|
|
|
|
/**
|
|
* Registers the specified plugin loader
|
|
*
|
|
* @param loader Class name of the PluginLoader to register
|
|
* @throws IllegalArgumentException Thrown when the given Class is not a valid PluginLoader
|
|
*/
|
|
public void RegisterInterface(Class loader) throws IllegalArgumentException;
|
|
|
|
/**
|
|
* Checks if the given plugin is loaded and returns it when applicable
|
|
*
|
|
* Please note that the name of the plugin is case-sensitive
|
|
*
|
|
* @param name Name of the plugin to check
|
|
* @return Plugin if it exists, otherwise null
|
|
*/
|
|
public Plugin getPlugin(String name);
|
|
|
|
/**
|
|
* Checks if the given plugin is enabled or not
|
|
*
|
|
* Please note that the name of the plugin is case-sensitive.
|
|
*
|
|
* @param name Name of the plugin to check
|
|
* @return true if the plugin is enabled, otherwise false
|
|
*/
|
|
public boolean isPluginEnabled(String name);
|
|
|
|
/**
|
|
* Checks if the given plugin is enabled or not
|
|
*
|
|
* @param plugin Plugin to check
|
|
* @return true if the plugin is enabled, otherwise false
|
|
*/
|
|
public boolean isPluginEnabled(Plugin plugin);
|
|
|
|
/**
|
|
* Loads the plugin in the specified file
|
|
*
|
|
* File must be valid according to the current enabled Plugin interfaces
|
|
*
|
|
* @param file File containing the plugin to load
|
|
* @return The Plugin loaded, or null if it was invalid
|
|
* @throws InvalidPluginException Thrown when the specified file is not a valid plugin
|
|
*/
|
|
public Plugin loadPlugin(File file) throws InvalidPluginException;
|
|
|
|
/**
|
|
* Loads the plugins contained within the specified directory
|
|
*
|
|
* @param directory Directory to check for plugins
|
|
* @return A list of all plugins loaded
|
|
*/
|
|
public Plugin[] loadPlugins(File directory);
|
|
|
|
/**
|
|
* Calls a player related event with the given details
|
|
*
|
|
* @param type Type of player related event to call
|
|
* @param event Event details
|
|
*/
|
|
public void callEvent(PlayerEvent.EventType type, PlayerEvent event);
|
|
}
|