Tags:
create new tag
, view all tags

Module name TWiki::Plugins PluginsDotPm
Location TWIKIROOT/lib/TWiki/Plugins.pm
Summary this is the plugin discoverer, loader and runner
Primary Author AndreaSterbini
CVS history CVS:lib/TWiki/Plugins.pm
CVS alpha CVSget:lib/TWiki/Plugins.pm
Contributing authors (see CVS History)
Is Class NO
First Release to be filled out
File Hierarchy
  TWIKIROOT
  lib
  TWiki
  Plugins.pm

Please see CodevDocumentationProject and CodevDocumentationProjectDev for comments on the format of these pages.

Purpose

To dicover, load, initialize and run all the plugins.

Used by

This module is primarily used to expose several hooks during several phases of the twiki execution.

Callback handlers with version

The column Version shows when the handler has been introduced.

Existing Plugin Hooks in latest Alpha

$VERSION Hook parameters Description
1.000 InitPlugin $topic, $web, $user, $installWeb Called once at startup as the plugin system is initialised
1.010 RegistrationHandler $webName, $wikiName, $loginName Called from register script. Can be used for sending cookies, (UserCookiePlugin) or any other SessionPlugin processing
1.000 CommonTagsHandler $text, $topic, $web Called once per line of the text
1.000 StartRenderingHandler $text, $topic, $web, $meta Called just prior to the mainloop
1.000 OutsidePREHandler $text, $web Called once per line, before any changes - as long as outside PRE & verbatim
1.000 InsidePREHandler $text, $web Called after closing any lists when in a PRE or VERBATIM area, before any other changes
1.000 EndRenderingHandler $text, $topic, $web Called after almost all modifications to a topic - ie this is the result of getRenderedVersion. <nop> tags are removed after this
1.010 BeforeEditHandler $text, $topic, $web Called when the text is edited to allow pre-processing of edited text. See TranslateTagPlugin
1.010 AfterEditHandler $text, $topic, $web Called when the text is previewed (or checkpoint-saved) to allow post-processing of edited text
1.010 BeforeSaveHandler $text, $topic, $web BeforeSaveHandler
1.010 WriteHeaderHandler $query Called just prior to writing header. Returns a single result: a string containing HTTP headers, delimited by CR/LF and with no blank lines. If returns FALSE, the default header gets written. Plugin generated headers may be modified by core code before they are output, to fix bugs or manage caching. Plugins should no longer write headers to standard output.
1.010 RedirectCgiQueryHandler $query, $url Generic Hook into the redirect functionality.
1.010 GetSessionValueHandler $key Called to get a session value... Used perhaps in a plugin..?
1.010 SetSessionValueHandler $key, $value Called to set a session value... Used perhaps in a plugin..?
1.023 BeforeAttachmentSaveHandler \%attachAttributes, $topic, $web Called before an attachment is saved
1.023 AfterAttachmentSaveHandler \%attachAttributes, $topic, $web Called after an attachment is saved
????? BeforeCommonTagsHandler $text, $topic, $web Callback at the very beginning of the common tags handler; needed for Plugin that caches variables

See PluginHandlersProposed for handlers that have been suggested but not implemented, and TWiki.InstalledPlugins for hooks and handlers active on TWikiDotOrg.

Note: Below documentation is extracted from the currently installed TWiki:: Perl module, which is done by the PerlDocPlugin

%PERLDOC{"TWiki::Plugins"}%

Contributors:
-- MartinCleaver - 23 Jun 2002
-- AndreaSterbini - 12 Sep 2003
-- PeterThoeny - 02 Feb 2004

Discussions

Has anyone noticed that a plugin does no know what version of a topic it is looking at? I'm going to add a $rev to the initPlugin in my test system, but even this is a continuation of a mess. To stop doing all this the hard way (I will need access to $meta, from 2-3 versions of a topic, and also know which i am displaying, and a few other things) I'd like to suggest that we begin looking at passing around a reference to a topic object. This TopicObject would contain references to all loaded information (as each version is loaded it is cached, and references to these cached bits are kept for the duration of the transaction (or more for mod_perl). Obviously there is a requested version/DateTime in this TopicObject, which would also allow us to display an object as it was back then, rather than INCLUDEing current topics when showing a previous version of a topic.

This work is being done for my workplaces iso9001 web, and will probably be extended to indlude the idea of documentation versions.

-- SvenDowideit - 16 Apr 2004

Somehow, I like the idea of the TopicObject smile

Anyway, if the plugin has access to the topic metadata, then is pretty easy to get the information.

-- RafaelAlvarez - 24 Aug 2004

I was thinking about the current mechanism to handle the plugins. Right now it first scans the plugins to register the handlers that the plugin can use, and then it calls only those plugins that has the hook defined.

If the idea in RefactorPluginApi of having a "Base Plugin" and make the other plugins to subclass it, then an improvement can be done: The base plugin could have an empty implementation of each handler, and for each hook call the handler in all the plugins. I have tested it, and the improve over calling an empty method over calling "defined &sub " is between 8% and 10% .

(more on that later)

-- RafaelAlvarez - 24 Aug 2004

Topic revision: r11 - 2006-05-04 - SamHasler
 
Twitter Delicious Facebook Digg Google Bookmarks E-mail LinkedIn Reddit StumbleUpon    
  • Download TWiki
TWiki logo Powered by PerlIdeas, requests, problems regarding TWiki? Send feedback. Ask community in the support forum.
Copyright © 1999-2012 by the contributing authors. All material on this collaboration platform is the property of the contributing authors.