Extension:EventPipe
<?php /**Template:Php
* EventPipe extension - Allows selected events (hooks) to be forwarded to a local pipe * * @package MediaWiki * @subpackage Extensions * @author User:Nad * @copyright © 2009 User:Nad * @licence GNU General Public Licence 2.0 or later */
if ( !defined( 'MEDIAWIKI' ) ) die( 'Not an entry point.' );
define( 'EVENTPIPE_VERSION', '1.0.0, 2009-05-25' );
$wgEventPipePort = '2012'; $wgEventPipeList = array('PrefsPasswordAudit','ArticleSaveComplete');
$wgExtensionCredits['other'][] = array( 'name' => 'EventPipe', 'author' => 'User:Nad', 'description' => 'Allows selected events (hooks) to be forwarded to a local pipe', 'url' => 'http://www.organicdesign.co.nz/Extension:EventPipe', 'version' => EVENTPIPE_VERSION );
$wgExtensionFunctions[] = 'wfSetupEventPipe'; function wfSetupEventPipe() { global $wgHooks, $wgEventPipeList; foreach ( $wgEventPipeList as $hook ) { $callback = $wgHooks[$hook][] = "wfEventPipeOn$hook"; eval( "function $callback() { \$args=func_get_args();return wfEventPipeSend('$hook',\$args); }" ); } }
function wfEventPipeSend( $hook, $args ) { global $wgEventPipePort; file_get_contents( "http://127.0.0.1:$wgEventPipePort/$hook" ); # var_export( $args, true ), FILE_APPEND ); return true; }