mediawiki-extensions-SpamBl.../SpamBlacklist.php

131 lines
3.9 KiB
PHP
Raw Normal View History

2004-12-11 09:59:06 +00:00
<?php
# Loader for spam blacklist feature
# Include this from LocalSettings.php
if ( !defined( 'MEDIAWIKI' ) ) {
exit;
}
2004-12-11 09:59:06 +00:00
$wgExtensionCredits['other'][] = array(
'path' => __FILE__,
'name' => 'SpamBlacklist',
'author' => 'Tim Starling',
'url' => 'http://www.mediawiki.org/wiki/Extension:SpamBlacklist',
'descriptionmsg' => 'spam-blacklist-desc',
);
$dir = dirname(__FILE__) . '/';
$wgExtensionMessagesFiles['SpamBlackList'] = $dir . 'SpamBlacklist.i18n.php';
2004-12-11 09:59:06 +00:00
global $wgFilterCallback, $wgPreSpamFilterCallback;
global $wgSpamBlacklistFiles;
2005-07-08 16:29:22 +00:00
global $wgSpamBlacklistSettings;
2004-12-11 09:59:06 +00:00
$wgSpamBlacklistFiles = false;
2005-07-08 16:29:22 +00:00
$wgSpamBlacklistSettings = array();
2004-12-11 09:59:06 +00:00
$wgPreSpamFilterCallback = false;
if ( defined( 'MW_SUPPORTS_EDITFILTERMERGED' ) ) {
$wgHooks['EditFilterMerged'][] = 'wfSpamBlacklistFilterMerged';
2004-12-11 09:59:06 +00:00
} else {
if ( $wgFilterCallback ) {
$wgPreSpamFilterCallback = $wgFilterCallback;
}
$wgFilterCallback = 'wfSpamBlacklistFilter';
2004-12-11 09:59:06 +00:00
}
$wgHooks['EditFilter'][] = 'wfSpamBlacklistValidate';
$wgHooks['ArticleSaveComplete'][] = 'wfSpamBlacklistArticleSave';
$wgHooks['APIEditBeforeSave'][] = 'wfSpamBlacklistFilterAPIEditBeforeSave';
/**
* Internationalization messages
*/
function wfSpamBlacklistLoadMessages() {
wfLoadExtensionMessages('SpamBlackList');
}
/**
* Get an instance of SpamBlacklist and do some first-call initialisation.
* All actual functionality is implemented in that object
*/
function wfSpamBlacklistObject() {
global $wgSpamBlacklistFiles, $wgSpamBlacklistSettings, $wgPreSpamFilterCallback;
static $spamObj;
if ( !$spamObj ) {
require_once( "SpamBlacklist_body.php" );
$spamObj = new SpamBlacklist( $wgSpamBlacklistSettings );
if( $wgSpamBlacklistFiles ) {
$spamObj->files = $wgSpamBlacklistFiles;
}
$spamObj->previousFilter = $wgPreSpamFilterCallback;
wfSpamBlacklistLoadMessages();
}
return $spamObj;
}
2007-06-29 01:36:09 +00:00
/**
* Hook function for $wgFilterCallback
*/
function wfSpamBlacklistFilter( &$title, $text, $section, &$hookErr, $editSummary ) {
$spamObj = wfSpamBlacklistObject();
$ret = $spamObj->filter( $title, $text, $section, $editSummary );
if ( $ret !== false ) EditPage::spamPage( $ret );
return ( $ret !== false );
}
/**
* Hook function for EditFilterMerged, replaces wfSpamBlacklistFilter
*/
function wfSpamBlacklistFilterMerged( $editPage, $text, &$hookErr, $editSummary ) {
global $wgTitle;
if( is_null( $wgTitle ) ) {
# API mode
# wfSpamBlacklistFilterAPIEditBeforeSave already checked the blacklist
return true;
}
$spamObj = wfSpamBlacklistObject();
$title = $editPage->mArticle->getTitle();
2008-08-16 21:40:30 +00:00
$ret = $spamObj->filter( $title, $text, '', $editSummary, $editPage );
if ( $ret !== false ) $editPage->spamPage( $ret );
// Return convention for hooks is the inverse of $wgFilterCallback
return ( $ret === false );
}
/**
* Hook function for APIEditBeforeSave
*/
function wfSpamBlacklistFilterAPIEditBeforeSave( $editPage, $text, &$resultArr ) {
$spamObj = wfSpamBlacklistObject();
$title = $editPage->mArticle->getTitle();
$ret = $spamObj->filter( $title, $text, '', '', $editPage );
if ( $ret!==false ) {
$resultArr['spamblacklist'] = $ret;
}
// Return convention for hooks is the inverse of $wgFilterCallback
return ( $ret === false );
}
/**
* Hook function for EditFilter
* Confirm that a local blacklist page being saved is valid,
* and toss back a warning to the user if it isn't.
*/
function wfSpamBlacklistValidate( $editPage, $text, $section, &$hookError ) {
$spamObj = wfSpamBlacklistObject();
return $spamObj->validate( $editPage, $text, $section, $hookError );
}
/**
* Hook function for ArticleSaveComplete
* Clear local spam blacklist caches on page save.
*/
function wfSpamBlacklistArticleSave( &$article, &$user, $text, $summary, $isminor, $iswatch, $section ) {
$spamObj = wfSpamBlacklistObject();
return $spamObj->onArticleSave( $article, $user, $text, $summary, $isminor, $iswatch, $section );
}
2007-12-16 18:27:23 +00:00