2012-01-17 06:13:46 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Hooks for the spam blacklist extension
|
|
|
|
*/
|
|
|
|
class SpamBlacklistHooks {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Hook function for EditFilterMerged
|
|
|
|
*
|
|
|
|
* @param $editPage EditPage
|
|
|
|
* @param $text string
|
|
|
|
* @param $hookErr string
|
|
|
|
* @param $editSummary string
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
static function filterMerged( $editPage, $text, &$hookErr, $editSummary ) {
|
|
|
|
global $wgTitle;
|
|
|
|
if( is_null( $wgTitle ) ) {
|
|
|
|
# API mode
|
|
|
|
# wfSpamBlacklistFilterAPIEditBeforeSave already checked the blacklist
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
$spamObj = BaseBlacklist::getInstance( 'spam' );
|
|
|
|
$title = $editPage->mArticle->getTitle();
|
|
|
|
$ret = $spamObj->filter( $title, $text, '', $editSummary, $editPage );
|
|
|
|
if ( $ret !== false ) {
|
|
|
|
// spamPageWithContent() method was added in MW 1.17
|
|
|
|
if ( method_exists( $editPage, 'spamPageWithContent' ) ) {
|
|
|
|
$editPage->spamPageWithContent( $ret );
|
|
|
|
} else {
|
|
|
|
$editPage->spamPage( $ret );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// Return convention for hooks is the inverse of $wgFilterCallback
|
|
|
|
return ( $ret === false );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Hook function for APIEditBeforeSave
|
|
|
|
*
|
|
|
|
* @param $editPage EditPage
|
|
|
|
* @param $text string
|
|
|
|
* @param $resultArr array
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
static function filterAPIEditBeforeSave( $editPage, $text, &$resultArr ) {
|
|
|
|
$spamObj = BaseBlacklist::getInstance( 'spam' );
|
|
|
|
$title = $editPage->mArticle->getTitle();
|
|
|
|
$ret = $spamObj->filter( $title, $text, '', '', $editPage );
|
|
|
|
if ( $ret!==false ) {
|
2012-03-27 20:42:49 +00:00
|
|
|
$resultArr['spamblacklist'] = implode( '|', $ret );
|
2012-01-17 06:13:46 +00:00
|
|
|
}
|
|
|
|
// Return convention for hooks is the inverse of $wgFilterCallback
|
|
|
|
return ( $ret === false );
|
|
|
|
}
|
|
|
|
|
2012-01-18 23:29:37 +00:00
|
|
|
/**
|
|
|
|
* Verify that the user can send emails
|
|
|
|
*
|
|
|
|
* @param $user User
|
|
|
|
* @param $hookErr array
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function userCanSendEmail( &$user, &$hookErr ) {
|
|
|
|
/** @var $blacklist EmailBlacklist */
|
|
|
|
$blacklist = BaseBlacklist::getInstance( 'email' );
|
|
|
|
if ( $blacklist->checkUser( $user ) ) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
$hookErr = array( 'spam-blacklisted-email', 'spam-blacklisted-email-text', null );
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2012-01-21 15:05:49 +00:00
|
|
|
* Processes new accounts for valid e-mail addresses
|
2012-01-18 23:29:37 +00:00
|
|
|
*
|
|
|
|
* @param $user User
|
|
|
|
* @param $abortError
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function abortNewAccount( $user, &$abortError ) {
|
|
|
|
/** @var $blacklist EmailBlacklist */
|
|
|
|
$blacklist = BaseBlacklist::getInstance( 'email' );
|
|
|
|
if ( $blacklist->checkUser( $user ) ) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
$abortError = wfMessage( 'spam-blacklisted-email-signup' )->escaped();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2012-01-17 06:13:46 +00:00
|
|
|
/**
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* @param $editPage EditPage
|
|
|
|
* @param $text string
|
|
|
|
* @param $section string
|
|
|
|
* @param $hookError string
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
static function validate( $editPage, $text, $section, &$hookError ) {
|
|
|
|
$thisPageName = $editPage->mTitle->getPrefixedDBkey();
|
|
|
|
|
|
|
|
if( !BaseBlacklist::isLocalSource( $editPage->mTitle ) ) {
|
|
|
|
wfDebugLog( 'SpamBlacklist', "Spam blacklist validator: [[$thisPageName]] not a local blacklist\n" );
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2012-01-18 23:29:37 +00:00
|
|
|
$type = BaseBlacklist::getTypeFromTitle( $editPage->mTitle );
|
|
|
|
if ( $type === false ) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2012-01-17 06:13:46 +00:00
|
|
|
$lines = explode( "\n", $text );
|
|
|
|
|
2012-01-18 23:29:37 +00:00
|
|
|
$badLines = SpamRegexBatch::getBadLines( $lines, BaseBlacklist::getInstance( $type ) );
|
2012-01-17 06:13:46 +00:00
|
|
|
if( $badLines ) {
|
|
|
|
wfDebugLog( 'SpamBlacklist', "Spam blacklist validator: [[$thisPageName]] given invalid input lines: " .
|
|
|
|
implode( ', ', $badLines ) . "\n" );
|
|
|
|
|
|
|
|
$badList = "*<tt>" .
|
|
|
|
implode( "</tt>\n*<tt>",
|
|
|
|
array_map( 'wfEscapeWikiText', $badLines ) ) .
|
|
|
|
"</tt>\n";
|
|
|
|
$hookError =
|
|
|
|
"<div class='errorbox'>" .
|
|
|
|
wfMsgExt( 'spam-invalid-lines', array( 'parsemag' ), count( $badLines ) ) . "<br />" .
|
|
|
|
$badList .
|
|
|
|
"</div>\n" .
|
|
|
|
"<br clear='all' />\n";
|
|
|
|
} else {
|
|
|
|
wfDebugLog( 'SpamBlacklist', "Spam blacklist validator: [[$thisPageName]] ok or empty blacklist\n" );
|
|
|
|
}
|
2012-01-18 23:29:37 +00:00
|
|
|
|
|
|
|
return true;
|
2012-01-17 06:13:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Hook function for ArticleSaveComplete
|
|
|
|
* Clear local spam blacklist caches on page save.
|
|
|
|
*
|
|
|
|
* @param $article Article
|
|
|
|
* @param $user User
|
|
|
|
* @param $text string
|
|
|
|
* @param $summary string
|
|
|
|
* @param $isminor
|
|
|
|
* @param $iswatch
|
|
|
|
* @param $section
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
static function articleSave( &$article, &$user, $text, $summary, $isminor, $iswatch, $section ) {
|
|
|
|
if( !BaseBlacklist::isLocalSource( $article->getTitle() ) ) {
|
2012-02-15 14:58:26 +00:00
|
|
|
return true;
|
2012-01-17 06:13:46 +00:00
|
|
|
}
|
|
|
|
global $wgMemc, $wgDBname;
|
|
|
|
|
|
|
|
// This sucks because every Blacklist needs to be cleared
|
|
|
|
foreach ( BaseBlacklist::getBlacklistTypes() as $type => $class ) {
|
|
|
|
$wgMemc->delete( "$wgDBname:{$type}_blacklist_regexes" );
|
|
|
|
}
|
2012-02-02 22:12:43 +00:00
|
|
|
return true;
|
2012-01-17 06:13:46 +00:00
|
|
|
}
|
|
|
|
}
|