public final class SimplePluginManager extends Object implements PluginManager
Constructor and Description |
---|
SimplePluginManager(Server instance,
SimpleCommandMap commandMap) |
Modifier and Type | Method and Description |
---|---|
void |
addPermission(Permission perm)
Adds a
Permission to this plugin manager. |
void |
addPermission(Permission perm,
boolean dirty)
Deprecated.
|
void |
callEvent(Event event)
Calls an event with the given details.
|
void |
clearPermissions() |
void |
clearPlugins()
Disables and removes all plugins
|
void |
dirtyPermissibles()
Deprecated.
|
void |
disablePlugin(Plugin plugin)
Disables the specified plugin
|
void |
disablePlugin(Plugin plugin,
boolean closeClassloader)
Disables the specified plugin
|
void |
disablePlugins()
Disables all the loaded plugins
|
void |
disablePlugins(boolean closeClassloaders) |
void |
enablePlugin(Plugin plugin)
Enables the specified plugin
|
Set<Permission> |
getDefaultPermissions(boolean op)
Gets the default permissions for the given op status
|
Set<Permissible> |
getDefaultPermSubscriptions(boolean op)
Gets a set containing all subscribed
Permissible s to the given
default list, by op status |
Permission |
getPermission(String name)
Gets a
Permission from its fully qualified name |
Set<Permission> |
getPermissions()
Gets a set of all registered permissions.
|
Set<Permissible> |
getPermissionSubscriptions(String permission)
Gets a set containing all subscribed
Permissible s to the given
permission, by name |
Plugin |
getPlugin(String name)
Checks if the given plugin is loaded and returns it when applicable
|
Plugin[] |
getPlugins()
Gets a list of all currently loaded plugins
|
void |
ignore(URL... urls) |
void |
ignore(URL url) |
boolean |
isPluginEnabled(Plugin plugin)
Checks if the given plugin is enabled or not
|
boolean |
isPluginEnabled(String name)
Checks if the given plugin is enabled or not
|
Plugin |
loadPlugin(File file)
Loads the plugin in the specified file
|
Plugin[] |
loadPlugins(File directory)
Loads the plugins contained within the specified directory
|
Plugin[] |
loadPlugins(String directory,
File... files)
Loads multiple plugins from a folder
|
void |
recalculatePermissionDefaults(Permission perm)
Recalculates the defaults for the given
Permission . |
void |
registerEvent(Class<? extends Event> event,
Listener listener,
EventPriority priority,
EventExecutor executor,
Plugin plugin)
Registers the specified executor to the given event class
|
void |
registerEvent(Class<? extends Event> event,
Listener listener,
EventPriority priority,
EventExecutor executor,
Plugin plugin,
boolean ignoreCancelled)
Registers the given event to the specified listener using a directly
passed EventExecutor
|
void |
registerEvents(Listener listener,
Plugin plugin)
Registers all the events in the given listener class
|
void |
registerInterface(Class<? extends PluginLoader> loader)
Registers the specified plugin loader
|
void |
removePermission(Permission perm)
Removes a
Permission registration from this plugin manager. |
void |
removePermission(String name)
Removes a
Permission registration from this plugin manager. |
void |
subscribeToDefaultPerms(boolean op,
Permissible permissible)
Subscribes to the given Default permissions by operator status
|
void |
subscribeToPermission(String permission,
Permissible permissible)
Subscribes the given Permissible for information about the requested
Permission, by name.
|
void |
unsubscribeFromDefaultPerms(boolean op,
Permissible permissible)
Unsubscribes from the given Default permissions by operator status
|
void |
unsubscribeFromPermission(String permission,
Permissible permissible)
Unsubscribes the given Permissible for information about the requested
Permission, by name.
|
boolean |
useTimings()
Returns whether or not timing code should be used for event calls
|
void |
useTimings(boolean use)
Sets whether or not per event timing code should be used
|
public SimplePluginManager(Server instance, SimpleCommandMap commandMap)
public void registerInterface(Class<? extends PluginLoader> loader) throws IllegalArgumentException
registerInterface
in interface PluginManager
loader
- Class name of the PluginLoader to registerIllegalArgumentException
- Thrown when the given Class is not a
valid PluginLoaderpublic Plugin[] loadPlugins(File directory)
loadPlugins
in interface PluginManager
directory
- Directory to check for pluginspublic Plugin[] loadPlugins(String directory, File... files)
PluginManager
loadPlugins
in interface PluginManager
directory
- Directory containing the plugin files (for error messages)files
- Plugin files to loadpublic void ignore(URL url)
ignore
in interface PluginManager
public void ignore(URL... urls)
ignore
in interface PluginManager
public Plugin loadPlugin(File file) throws InvalidPluginException, UnknownDependencyException
File must be valid according to the current enabled Plugin interfaces
loadPlugin
in interface PluginManager
file
- File containing the plugin to loadInvalidPluginException
- Thrown when the specified file is not a
valid pluginUnknownDependencyException
- If a required dependency could not
be foundpublic Plugin getPlugin(String name)
Please note that the name of the plugin is case-sensitive
getPlugin
in interface PluginManager
name
- Name of the plugin to checkpublic Plugin[] getPlugins()
PluginManager
getPlugins
in interface PluginManager
public boolean isPluginEnabled(String name)
Please note that the name of the plugin is case-sensitive.
isPluginEnabled
in interface PluginManager
name
- Name of the plugin to checkpublic boolean isPluginEnabled(Plugin plugin)
isPluginEnabled
in interface PluginManager
plugin
- Plugin to checkpublic void enablePlugin(Plugin plugin)
PluginManager
Attempting to enable a plugin that is already enabled will have no effect
enablePlugin
in interface PluginManager
plugin
- Plugin to enablepublic void disablePlugins()
PluginManager
disablePlugins
in interface PluginManager
public void disablePlugins(boolean closeClassloaders)
public void disablePlugin(Plugin plugin)
PluginManager
Attempting to disable a plugin that is not enabled will have no effect
disablePlugin
in interface PluginManager
plugin
- Plugin to disablepublic void disablePlugin(Plugin plugin, boolean closeClassloader)
PluginManager
Attempting to disable a plugin that is not enabled will have no effect
disablePlugin
in interface PluginManager
plugin
- Plugin to disablecloseClassloader
- if the classloader for the Plugin should be closedpublic void clearPlugins()
PluginManager
clearPlugins
in interface PluginManager
public void callEvent(Event event)
This method only synchronizes when the event is not asynchronous.
callEvent
in interface PluginManager
event
- Event detailspublic void registerEvents(Listener listener, Plugin plugin)
PluginManager
registerEvents
in interface PluginManager
listener
- Listener to registerplugin
- Plugin to registerpublic void registerEvent(Class<? extends Event> event, Listener listener, EventPriority priority, EventExecutor executor, Plugin plugin)
PluginManager
registerEvent
in interface PluginManager
event
- Event type to registerlistener
- Listener to registerpriority
- Priority to register this event atexecutor
- EventExecutor to registerplugin
- Plugin to registerpublic void registerEvent(Class<? extends Event> event, Listener listener, EventPriority priority, EventExecutor executor, Plugin plugin, boolean ignoreCancelled)
registerEvent
in interface PluginManager
event
- Event class to registerlistener
- PlayerListener to registerpriority
- Priority of this eventexecutor
- EventExecutor to registerplugin
- Plugin to registerignoreCancelled
- Do not call executor if event was already
cancelledpublic Permission getPermission(String name)
PluginManager
Permission
from its fully qualified namegetPermission
in interface PluginManager
name
- Name of the permissionpublic void addPermission(Permission perm)
PluginManager
Permission
to this plugin manager.
If a permission is already defined with the given name of the new permission, an exception will be thrown.
addPermission
in interface PluginManager
perm
- Permission to add@Deprecated public void addPermission(Permission perm, boolean dirty)
public Set<Permission> getDefaultPermissions(boolean op)
PluginManager
getDefaultPermissions
in interface PluginManager
op
- Which set of default permissions to getpublic void removePermission(Permission perm)
PluginManager
Permission
registration from this plugin manager.
If the specified permission does not exist in this plugin manager, nothing will happen.
Removing a permission registration will not remove the
permission from any Permissible
s that have it.
removePermission
in interface PluginManager
perm
- Permission to removepublic void removePermission(String name)
PluginManager
Permission
registration from this plugin manager.
If the specified permission does not exist in this plugin manager, nothing will happen.
Removing a permission registration will not remove the
permission from any Permissible
s that have it.
removePermission
in interface PluginManager
name
- Permission to removepublic void recalculatePermissionDefaults(Permission perm)
PluginManager
Permission
.
This will have no effect if the specified permission is not registered here.
recalculatePermissionDefaults
in interface PluginManager
perm
- Permission to recalculate@Deprecated public void dirtyPermissibles()
public void subscribeToPermission(String permission, Permissible permissible)
PluginManager
If the specified Permission changes in any form, the Permissible will be asked to recalculate.
subscribeToPermission
in interface PluginManager
permission
- Permission to subscribe topermissible
- Permissible subscribingpublic void unsubscribeFromPermission(String permission, Permissible permissible)
PluginManager
unsubscribeFromPermission
in interface PluginManager
permission
- Permission to unsubscribe frompermissible
- Permissible subscribingpublic Set<Permissible> getPermissionSubscriptions(String permission)
PluginManager
Permissible
s to the given
permission, by namegetPermissionSubscriptions
in interface PluginManager
permission
- Permission to query forpublic void subscribeToDefaultPerms(boolean op, Permissible permissible)
PluginManager
If the specified defaults change in any form, the Permissible will be asked to recalculate.
subscribeToDefaultPerms
in interface PluginManager
op
- Default list to subscribe topermissible
- Permissible subscribingpublic void unsubscribeFromDefaultPerms(boolean op, Permissible permissible)
PluginManager
unsubscribeFromDefaultPerms
in interface PluginManager
op
- Default list to unsubscribe frompermissible
- Permissible subscribingpublic Set<Permissible> getDefaultPermSubscriptions(boolean op)
PluginManager
Permissible
s to the given
default list, by op statusgetDefaultPermSubscriptions
in interface PluginManager
op
- Default list to query forpublic Set<Permission> getPermissions()
PluginManager
This set is a copy and will not be modified live.
getPermissions
in interface PluginManager
public boolean useTimings()
PluginManager
useTimings
in interface PluginManager
public void useTimings(boolean use)
use
- True if per event timing code should be usedpublic void clearPermissions()
Copyright © 2021. All rights reserved.