Difference between revisions of "Set up a new bot job"

From Organic Design wiki
m (Creating jobs to be started manually)
m (Creating jobs to be started manually)
Line 37: Line 37:
  
  
And here's the corresponding processing hook function which saves a file if one was specified for upload, and starts a job if a valid file has been specified.
+
And here's the corresponding processing hook function which saves a file into the internal data location (''$wgFoodataDir'') if one has been uploaded with the form, and starts a job if a valid file has been specified from the list or uploaded.
 
{{code|<php>
 
{{code|<php>
 
function onWikidAdminTypeFormProcess_Foo( &$wikidadmin, &$args, &$start ) {
 
function onWikidAdminTypeFormProcess_Foo( &$wikidadmin, &$args, &$start ) {

Revision as of 00:47, 23 November 2009

Procedure.svg Set up a new bot job
Organic Design procedure

First ensure that you have a running wiki daemon (wikid) local to the server and wiki which will be used to administer the jobs. Set up the EventPipe extension and ensure that the daemon is receiving the events either by checking /var/www/tools/wikid.log or by configuring the bot to publish its notifications to an IRC channel. For more details on these aspects, see the install a new server and configure IRC procedures. After the robot framework and necessary extensions are installed you're ready to begin setting up a new job type which is described following.

Job Functions

First you will need to create some functions in Perl which will do the actual work. These can reside anywhere and are made available to the daemon by appending a require statement to /var/www/tools/wikid.conf.

There are three special functions which may be directly called by the daemon, one when an instance of the job type is first started, one which is called iteratively until the job is complete, and another after the job has completed so that any loose ends can be tied up such as closing database connections or file handles. These three functions are init, main and stop and are combined with the name of the job type when defining the functions, for example initFoo. Only the main is mandatory, the init and stop may not be necessary for some kinds of jobs.

When the daemon calls the functions it puts some important data in the global environment...

In addition to the three special job functions, a job script may also define a number of special internal functions to be called by the other main functions when needed. These should follow the naming convention of jobFooBar (the "Bar" function used by functions in the "Foo" job) to avoid possible naming conflicts with other jobs or components.

Creating jobs to be started manually

The usual way to run a job is manually from the WikidAdmin special page. If its functions have been correctly defined and included by the daemon, then the job type will appear in the list in the special page. Simple select the job type and click the start button.

Some jobs require some specific parameters to be set before they can run, for example import jobs require a file to be uploaded or a previously uploaded file to be selected. To create a new job which requires such parameters to be filled in first two additional functions must be written. These functions are MediaWiki hooks written in PHP. The hook names depends on the job name, for example the following hooks may be added to the LocalSettings.php file of the wiki to provide a form for our previous "Foo" job:

{{{1}}}


Here's a typical function definition for the form rendering hook, all that's required here is to set the passed $html variable with the HTML content of the form. In this example we're providing an upload button and a list of files that have been previously uploaded, the files are stored in the internal location specified in $wgFooDataDir.

{{{1}}}


And here's the corresponding processing hook function which saves a file into the internal data location ($wgFoodataDir) if one has been uploaded with the form, and starts a job if a valid file has been specified from the list or uploaded.

{{{1}}}

Creating event-driven jobs

Jobs may be started manually from the WikidAdmin special page, or by various events in the wiki or the Perl environment. To handle wiki events simply define an event handler function for the wiki hook name, this will override any default handler supplied by the daemon. In the following example code, the "Foo" job is started when an article in the "Bar" namespace is edited.

{{{1}}}