lib/Extension/ActionPlugin.php, before called DokuWiki_Action_Plugin which is still available as aliasAction plugins are designed to work with DokuWiki events to allow for customisation/extension of any part of DokuWiki that signals its activity using events. They are a way to modify many aspects of how DokuWiki behaves in certain cases independent of a page's syntax. To be able to modify a DokuWiki internal behavior it needs to trigger an event. Your action plugin can register as a handler for such an event and then work with the given event data.
Action plugins are loaded before any significant DokuWiki processing takes place. Immediately after loading, each plugin is called by its register() method to give it the opportunity to register any of its event handlers.  When an event is signaled all event handlers registered for that event are called in turn in ascending order of the $seq number used to register them (Since release 2014-05-05 “Ponder Stibbons”, before it was in no particular order) and passed the Event object. The handler has the opportunity to take action based on the event data and to alter either the event data or the event's subsequent processing.  
For more details of how the events system works and lists of events refer to the events page.
An Action Plugin Example needs:
action_plugin_examplelib/plugins/example/action.php.Moreover, a plugin.info.txt file is needed. For full details of plugins and their files and how to create more action components refer to plugin file structure.
register() and some handler that is registered there.An action plugin requires at least two methods:
register(EventHandler $controller) Use this method to register your handlers with the DokuWiki's event controller<event handler>(Event $event, $param) Your event handler(s), that perform your actions when they are triggered.
You can register multiple events in a single action plugin. When doing this you may need multiple <event handler>() functions.
The register() method is used to subscribe an event. The following code shows a generic version to register an event.
/** * plugin should use this method to register its handlers with the DokuWiki's * event controller * * @param EventHandler $controller DokuWiki's event controller object. * Also available as global $EVENT_HANDLER * @return void not required */ public function register(EventHandler $controller) { $controller->register_hook(<EVENT NAME>, <EVENT ADVISE>, $this, <event handler function>, <parameter to be passed to event handler>, <sequence number>); }
The $controller->register_hook() function is used to register the event. The parameters are:
<EVENT NAME>: Name of the event. All available events can be found at the Event Reference List.<EVENT ADVISE>: can be either BEFORE or AFTER. This determines when you want to invoke the given event.$this: An object reference to your action class containing the <event handler function>, usually $this.<event handler function>: Name of the function to handle the event as string.<parameter>: (optional) parameter will passed directly and unchanged to your <event handler function>(Event $event, $parameter) as second argument.<sequence number>: (optional) used to affect the order in which hooks are executed. Defaults to 0. It is recommended to use ranges of sequence numbers and avoid +/- PHP_INT_MAX:| -3999 - -3000 | for “very early” | 
| -2999 - -2000 | for “earlier” | 
| -1999 - -1000 | for “early” | 
| -999 - -1 | for “earlier than default” | 
| 0 | default | 
| 1 - 999 | for “later than default” | 
| 1000 - 1999 | for “late” | 
| 2000 - 2999 | for “later” | 
| 3000 - 3999 | for “very late” | 
Have as many as necessary, can be given any name not already in use in this plugin or its ancestor classes. This function must be public. It will be called by DokuWiki's event controller.
/** * custom event handler * * @param Event $event event object by reference * @param mixed $param (optional) the parameters passed to register_hook() * when this handler was registered * * @return void not required */ public function <event_handler>(Event $event, $param) { // custom script statements ... }
The passed arguments are:
$event: The event object. Further information on the passed event object can be found on the Event page.$param: Data passed to the register_hook() function, when this handler was registered. Can be left out if not used.Here some examples:
Insert a javascript script link in all pages.
<?php use dokuwiki\Extension\ActionPlugin; use dokuwiki\Extension\EventHandler; use dokuwiki\Extension\Event; /** * Example Action Plugin: Example Component. * * @author Samuele Tognini <samuele@cli.di.unipi.it> */ class action_plugin_example extends ActionPlugin { /** * Register its handlers with the DokuWiki's event controller * * @param EventHandler $controller event controller object */ public function register(EventHandler $controller) { $controller->register_hook('TPL_METAHEADER_OUTPUT', 'BEFORE', $this, 'hookJsScript'); } /** * Hook js script into page headers. * * @param Event $event event object * * @author Samuele Tognini <samuele@cli.di.unipi.it> */ public function hookJsScript(Event $event) { $event->data['script'][] = [ 'type' => 'text/javascript', 'charset' => 'utf-8', '_data' => '', 'src' => DOKU_PLUGIN . 'example/example.js' ]; } }
Inserts a button into the editor toolbar:
data<?php use dokuwiki\Extension\ActionPlugin; use dokuwiki\Extension\EventHandler; use dokuwiki\Extension\Event; /** * Example Action Plugin: Inserts a button into the toolbar * * @author Gina Haeussge <osd@foosel.net> */ class action_plugin_example extends ActionPlugin { /** * Register the event handlers * * @param EventHandler $controller DokuWiki's event controller object */ public function register(EventHandler $controller) { $controller->register_hook('TOOLBAR_DEFINE', 'AFTER', $this, 'insert_button', []); } /** * Inserts the toolbar button * * @param Event $event event object * @param mixed $param [the parameters passed as fifth argument to * register_hook() when this handler was registered, * here just an empty array..] */ public function insert_button(Event $event, $param) { $event->data[] = [ 'type' => 'format', 'title' => $this->getLang('qb_abutton'), 'icon' => '../../plugins/actionexample/abutton.png', 'open' => '<abutton>', 'close' => '</abutton>', ]; } }
lib/Extension/ActionPlugin.php, before called DokuWiki_Action_Plugin which is still available as alias