Interface PluginApplicationInterface
Interface for Applications that leverage plugins & events.
Events can be bound to the application event manager during the application's bootstrap and plugin bootstrap.
Method Summary
- 
          addPlugin() publicAdd a plugin to the loaded plugin set. 
- 
          dispatchEvent() publicWrapper for creating and dispatching events. 
- 
          eventManager() public deprecatedReturns the Cake\Event\EventManager manager instance for this object. 
- 
          getEventManager() public @method
- 
          pluginBootstrap() publicRun bootstrap logic for loaded plugins. 
- 
          pluginConsole() publicRun console hooks for plugins 
- 
          pluginMiddleware() publicRun middleware hooks for plugins 
- 
          pluginRoutes() publicRun routes hooks for loaded plugins 
- 
          setEventManager() public @method
Method Detail
addPlugin() ¶ public
addPlugin(string|Cake\Core\PluginInterface $name, array $config = []): $thisAdd a plugin to the loaded plugin set.
If the named plugin does not exist, or does not define a Plugin class, an
instance of Cake\Core\BasePlugin will be used. This generated class will have
all plugin hooks enabled.
Parameters
- 
                string|Cake\Core\PluginInterface$name
- The plugin name or plugin object. 
- 
                array$config optional
- The configuration data for the plugin if using a string for $name 
Returns
$thisdispatchEvent() ¶ public
dispatchEvent(string $name, array|null $data = null, object|null $subject = null): Cake\Event\EventWrapper for creating and dispatching events.
Returns a dispatched event.
Parameters
- 
                string$name
- Name of the event. 
- 
                array|null$data optional
- Any value you wish to be transported with this event to it can be read by listeners. 
- 
                object|null$subject optional
- The object that this event applies to ($this by default). 
Returns
Cake\Event\EventeventManager() ¶ public
eventManager(Cake\Event\EventManager|null $eventManager = null): Cake\Event\EventManagerReturns the Cake\Event\EventManager manager instance for this object.
You can use this instance to register any new listeners or callbacks to the object events, or create your own events and trigger them at will.
Parameters
- 
                Cake\Event\EventManager|null$eventManager optional
- the eventManager to set 
Returns
Cake\Event\EventManagergetEventManager() ¶ public @method
getEventManager(): Cake\Event\EventManagerReturns
Cake\Event\EventManagerpluginBootstrap() ¶ public
pluginBootstrap(): voidRun bootstrap logic for loaded plugins.
Returns
voidpluginConsole() ¶ public
pluginConsole(Cake\Console\CommandCollection $commands): Cake\Console\CommandCollectionRun console hooks for plugins
Parameters
- 
                Cake\Console\CommandCollection$commands
- The CommandCollection to use. 
Returns
Cake\Console\CommandCollectionpluginMiddleware() ¶ public
pluginMiddleware(Cake\Http\MiddlewareQueue $middleware): Cake\Http\MiddlewareQueueRun middleware hooks for plugins
Parameters
- 
                Cake\Http\MiddlewareQueue$middleware
- The MiddlewareQueue to use. 
Returns
Cake\Http\MiddlewareQueuepluginRoutes() ¶ public
pluginRoutes(Cake\Routing\RouteBuilder $routes): Cake\Routing\RouteBuilderRun routes hooks for loaded plugins
Parameters
- 
                Cake\Routing\RouteBuilder$routes
- The route builder to use. 
Returns
Cake\Routing\RouteBuildersetEventManager() ¶ public @method
setEventManager(Cake\Event\EventManager $eventManager): $thisParameters
- 
                Cake\Event\EventManager$eventManager
Returns
$this