2008-06-27 06:18:51 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
class AbuseFilterHooks {
|
2015-09-28 18:03:35 +00:00
|
|
|
public static $successful_action_vars = false;
|
2012-02-10 23:41:05 +00:00
|
|
|
/** @var WikiPage|Article|bool */
|
2015-09-28 18:03:35 +00:00
|
|
|
public static $last_edit_page = false; // make sure edit filter & edit save hooks match
|
2011-08-26 20:12:34 +00:00
|
|
|
// So far, all of the error message out-params for these hooks accept HTML.
|
|
|
|
// Hooray!
|
2011-08-24 22:11:52 +00:00
|
|
|
|
2016-06-03 18:01:56 +00:00
|
|
|
/**
|
|
|
|
* Called right after configuration has been loaded.
|
|
|
|
*/
|
|
|
|
public static function onRegistration() {
|
|
|
|
global $wgAbuseFilterAvailableActions, $wgAbuseFilterRestrictedActions;
|
|
|
|
|
|
|
|
if ( isset( $wgAbuseFilterAvailableActions ) || isset( $wgAbuseFilterRestrictedActions ) ) {
|
|
|
|
wfWarn( '$wgAbuseFilterAvailableActions and $wgAbuseFilterRestrictedActions have been'
|
|
|
|
. 'removed. Please use $wgAbuseFilterActions and $wgAbuseFilterRestrictions'
|
|
|
|
. 'instead. The format is the same except the action names are the keys of the'
|
|
|
|
. 'array and the values are booleans.' );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-07-04 00:25:25 +00:00
|
|
|
/**
|
|
|
|
* Entry point for the APIEditBeforeSave hook.
|
2016-04-07 05:06:02 +00:00
|
|
|
*
|
|
|
|
* This is needed to give a useful error for API edits on MediaWiki before 1.25 (T34216).
|
2013-07-04 00:25:25 +00:00
|
|
|
*
|
|
|
|
* @see https://www.mediawiki.org/wiki/Manual:Hooks/APIEditBeforeSave
|
|
|
|
*
|
|
|
|
* @param EditPage $editPage
|
|
|
|
* @param string $text New text of the article (has yet to be saved)
|
2013-07-08 18:27:10 +00:00
|
|
|
* @param array &$result Data in this array will be added to the API result
|
2013-07-04 00:25:25 +00:00
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function onAPIEditBeforeSave( $editPage, $text, &$result ) {
|
2016-04-07 05:06:02 +00:00
|
|
|
// Don't use the APIEditBeforeSave hook if EditFilterMergedContent allows us to produce error
|
|
|
|
// details for the API, it lies in case of autoresolved edit conflicts (T73947).
|
|
|
|
if ( defined( 'MW_EDITFILTERMERGED_SUPPORTS_API' ) ) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2016-03-17 19:44:43 +00:00
|
|
|
if ( $editPage->undidRev > 0 ) {
|
|
|
|
// This hook is also (unlike the non-API hooks) being run on undo,
|
|
|
|
// but we don't want to filter in that case. T126861
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2013-07-04 00:25:25 +00:00
|
|
|
$context = $editPage->mArticle->getContext();
|
|
|
|
|
|
|
|
$status = Status::newGood();
|
|
|
|
$minoredit = $editPage->minoredit;
|
|
|
|
$summary = $editPage->summary;
|
|
|
|
|
|
|
|
// poor man's PST, see bug 20310
|
|
|
|
$text = str_replace( "\r\n", "\n", $text );
|
|
|
|
|
2013-10-14 19:39:35 +00:00
|
|
|
self::filterEdit( $context, null, $text, $status, $summary, $minoredit );
|
2013-07-04 00:25:25 +00:00
|
|
|
|
|
|
|
if ( !$status->isOK() ) {
|
2016-04-07 05:06:02 +00:00
|
|
|
$result = self::getEditApiResult( $status );
|
2013-07-04 00:25:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return $status->isOK();
|
|
|
|
}
|
|
|
|
|
2013-01-04 15:37:56 +00:00
|
|
|
/**
|
2016-04-07 05:06:02 +00:00
|
|
|
* Entry point for the EditFilterMergedContent hook.
|
2013-01-04 15:37:56 +00:00
|
|
|
*
|
|
|
|
* @param IContextSource $context the context of the edit
|
|
|
|
* @param Content $content the new Content generated by the edit
|
2015-09-28 18:03:35 +00:00
|
|
|
* @param Status $status Error message to return
|
2013-01-04 15:37:56 +00:00
|
|
|
* @param string $summary Edit summary for page
|
|
|
|
* @param User $user the user performing the edit
|
|
|
|
* @param bool $minoredit whether this is a minor edit according to the user.
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function onEditFilterMergedContent( IContextSource $context, Content $content,
|
|
|
|
Status $status, $summary, User $user, $minoredit ) {
|
|
|
|
|
2016-05-13 04:17:51 +00:00
|
|
|
$text = AbuseFilter::contentToString( $content );
|
2013-01-04 15:37:56 +00:00
|
|
|
|
2013-07-08 18:27:10 +00:00
|
|
|
$continue = self::filterEdit( $context, $content, $text, $status, $summary, $minoredit );
|
2015-09-28 18:03:35 +00:00
|
|
|
|
2016-04-07 05:06:02 +00:00
|
|
|
if ( defined( 'MW_EDITFILTERMERGED_SUPPORTS_API' ) && !$status->isOK() ) {
|
|
|
|
// Produce a useful error message for API edits (T34216) without APIEditBeforeSave (T73947)
|
|
|
|
$status->apiHookResult = self::getEditApiResult( $status );
|
|
|
|
}
|
|
|
|
|
2013-01-04 15:37:56 +00:00
|
|
|
return $continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-04-07 05:06:02 +00:00
|
|
|
* Common implementation for the APIEditBeforeSave and EditFilterMergedContent hooks.
|
2013-01-04 15:37:56 +00:00
|
|
|
*
|
|
|
|
* @param IContextSource $context the context of the edit
|
|
|
|
* @param Content|null $content the new Content generated by the edit
|
|
|
|
* @param string $text new page content (subject of filtering)
|
2015-09-28 18:03:35 +00:00
|
|
|
* @param Status $status Error message to return
|
2013-01-04 15:37:56 +00:00
|
|
|
* @param string $summary Edit summary for page
|
|
|
|
* @param bool $minoredit whether this is a minor edit according to the user.
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function filterEdit( IContextSource $context, $content, $text,
|
2015-09-28 18:03:35 +00:00
|
|
|
Status $status, $summary, $minoredit ) {
|
2013-01-04 15:37:56 +00:00
|
|
|
// Load vars
|
2013-07-04 00:25:25 +00:00
|
|
|
$vars = new AbuseFilterVariableHolder();
|
|
|
|
|
|
|
|
$title = $context->getTitle();
|
|
|
|
|
|
|
|
// Some edits are running through multiple hooks, but we only want to filter them once
|
|
|
|
if ( isset( $title->editAlreadyFiltered ) ) {
|
|
|
|
return true;
|
2013-07-10 01:39:01 +00:00
|
|
|
} elseif ( $title ) {
|
|
|
|
$title->editAlreadyFiltered = true;
|
2013-07-04 00:25:25 +00:00
|
|
|
}
|
2013-01-04 15:37:56 +00:00
|
|
|
|
2012-02-10 23:41:05 +00:00
|
|
|
self::$successful_action_vars = false;
|
|
|
|
self::$last_edit_page = false;
|
|
|
|
|
2013-07-08 18:27:10 +00:00
|
|
|
$user = $context->getUser();
|
|
|
|
|
2009-09-17 09:52:40 +00:00
|
|
|
$oldtext = '';
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2013-02-14 11:39:51 +00:00
|
|
|
if ( ( $title instanceof Title ) && $title->canExist() && $title->exists() ) {
|
2011-10-25 12:46:05 +00:00
|
|
|
// Make sure we load the latest text saved in database (bug 31656)
|
2013-01-04 15:37:56 +00:00
|
|
|
$page = $context->getWikiPage();
|
|
|
|
$revision = $page->getRevision();
|
2012-05-03 23:35:23 +00:00
|
|
|
if ( !$revision ) {
|
|
|
|
return true;
|
|
|
|
}
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2015-11-23 09:59:11 +00:00
|
|
|
$oldcontent = $revision->getContent( Revision::RAW );
|
|
|
|
$oldtext = AbuseFilter::contentToString( $oldcontent );
|
2011-10-25 12:46:05 +00:00
|
|
|
|
2013-01-04 15:37:56 +00:00
|
|
|
// Cache article object so we can share a parse operation
|
|
|
|
$articleCacheKey = $title->getNamespace() . ':' . $title->getText();
|
|
|
|
AFComputedVariable::$articleCache[$articleCacheKey] = $page;
|
2014-09-10 21:33:27 +00:00
|
|
|
|
|
|
|
// Don't trigger for null edits.
|
|
|
|
if ( $content && isset( $oldcontent ) && $content->equals( $oldcontent ) ) {
|
|
|
|
// Compare Content objects if available
|
|
|
|
return true;
|
|
|
|
} elseif ( strcmp( $oldtext, $text ) == 0 ) {
|
|
|
|
// Otherwise, compare strings
|
|
|
|
return true;
|
|
|
|
}
|
2013-01-04 15:37:56 +00:00
|
|
|
} else {
|
|
|
|
$page = null;
|
|
|
|
}
|
|
|
|
|
2013-03-06 06:21:55 +00:00
|
|
|
$vars->addHolders(
|
|
|
|
AbuseFilter::generateUserVars( $user ),
|
2015-09-28 18:03:35 +00:00
|
|
|
AbuseFilter::generateTitleVars( $title, 'ARTICLE' )
|
2013-03-06 06:21:55 +00:00
|
|
|
);
|
2012-11-16 17:06:34 +00:00
|
|
|
|
2012-02-10 23:41:05 +00:00
|
|
|
$vars->setVar( 'action', 'edit' );
|
|
|
|
$vars->setVar( 'summary', $summary );
|
2013-01-04 15:37:56 +00:00
|
|
|
$vars->setVar( 'minor_edit', $minoredit );
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2009-07-03 14:01:43 +00:00
|
|
|
$vars->setVar( 'old_wikitext', $oldtext );
|
2009-03-17 20:44:53 +00:00
|
|
|
$vars->setVar( 'new_wikitext', $text );
|
2008-06-27 06:18:51 +00:00
|
|
|
|
2013-01-04 15:37:56 +00:00
|
|
|
// TODO: set old_content and new_content vars, use them
|
|
|
|
|
2013-03-06 06:21:55 +00:00
|
|
|
$vars->addHolders( AbuseFilter::getEditVars( $title, $page ) );
|
2009-01-28 01:12:34 +00:00
|
|
|
|
2011-11-09 08:36:26 +00:00
|
|
|
$filter_result = AbuseFilter::filterAction( $vars, $title );
|
2008-10-24 08:58:32 +00:00
|
|
|
|
2013-01-08 14:52:49 +00:00
|
|
|
if ( !$filter_result->isOK() ) {
|
|
|
|
$status->merge( $filter_result );
|
2015-09-28 18:03:35 +00:00
|
|
|
|
2013-01-04 15:37:56 +00:00
|
|
|
return true; // re-show edit form
|
2008-06-27 09:26:54 +00:00
|
|
|
}
|
2012-02-10 23:41:05 +00:00
|
|
|
|
|
|
|
self::$successful_action_vars = $vars;
|
2013-01-04 15:37:56 +00:00
|
|
|
self::$last_edit_page = $page;
|
2012-02-10 23:41:05 +00:00
|
|
|
|
2012-02-10 23:41:05 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2016-04-07 05:06:02 +00:00
|
|
|
/**
|
|
|
|
* Common implementation for the APIEditBeforeSave and EditFilterMergedContent hooks.
|
|
|
|
*
|
|
|
|
* @param Status $status Error message details
|
|
|
|
* @return array API result
|
|
|
|
*/
|
|
|
|
public static function getEditApiResult( Status $status ) {
|
|
|
|
$msg = $status->getErrorsArray();
|
|
|
|
$msg = $msg[0];
|
|
|
|
|
|
|
|
// Use the error message key name as error code, the first parameter is the filter description.
|
|
|
|
if ( $msg instanceof Message ) {
|
|
|
|
// For forward compatibility: In case we switch over towards using Message objects someday.
|
|
|
|
// (see the todo for AbuseFilter::buildStatus)
|
|
|
|
$code = $msg->getKey();
|
|
|
|
$filterDescription = $msg->getParams();
|
|
|
|
$filterDescription = $filterDescription[0];
|
|
|
|
$warning = $msg->parse();
|
|
|
|
} else {
|
|
|
|
$code = array_shift( $msg );
|
|
|
|
$filterDescription = $msg[0];
|
|
|
|
$warning = wfMessage( $code )->params( $msg )->parse();
|
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'code' => $code,
|
|
|
|
'info' => 'Hit AbuseFilter: ' . $filterDescription,
|
|
|
|
'warning' => $warning
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2012-02-10 23:41:05 +00:00
|
|
|
public static function onArticleSaveComplete(
|
|
|
|
&$article, &$user, $text, $summary, $minoredit, $watchthis, $sectionanchor,
|
|
|
|
&$flags, $revision
|
|
|
|
) {
|
2015-09-28 18:03:35 +00:00
|
|
|
if ( !self::$successful_action_vars || !$revision ) {
|
2012-02-10 23:41:05 +00:00
|
|
|
self::$successful_action_vars = false;
|
2015-09-28 18:03:35 +00:00
|
|
|
|
2012-02-10 23:41:05 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
$vars = self::$successful_action_vars;
|
|
|
|
|
2015-09-28 18:03:35 +00:00
|
|
|
if ( $vars->getVar( 'article_prefixedtext' )->toString() !==
|
2013-03-19 00:26:20 +00:00
|
|
|
$article->getTitle()->getPrefixedText()
|
2012-02-10 23:41:05 +00:00
|
|
|
) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( !self::identicalPageObjects( $article, self::$last_edit_page ) ) {
|
|
|
|
return true; // this isn't the edit $successful_action_vars was set for
|
|
|
|
}
|
|
|
|
self::$last_edit_page = false;
|
|
|
|
|
2015-09-28 18:03:35 +00:00
|
|
|
if ( $vars->getVar( 'local_log_ids' ) ) {
|
2012-02-10 23:41:05 +00:00
|
|
|
// Now actually do our storage
|
2015-09-28 18:03:35 +00:00
|
|
|
$log_ids = $vars->getVar( 'local_log_ids' )->toNative();
|
2012-02-10 23:41:05 +00:00
|
|
|
$dbw = wfGetDB( DB_MASTER );
|
|
|
|
|
2015-09-28 18:03:35 +00:00
|
|
|
if ( count( $log_ids ) ) {
|
2012-02-10 23:41:05 +00:00
|
|
|
$dbw->update( 'abuse_filter_log',
|
|
|
|
array( 'afl_rev_id' => $revision->getId() ),
|
|
|
|
array( 'afl_id' => $log_ids ),
|
|
|
|
__METHOD__
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-09-28 18:03:35 +00:00
|
|
|
if ( $vars->getVar( 'global_log_ids' ) ) {
|
|
|
|
$log_ids = $vars->getVar( 'global_log_ids' )->toNative();
|
2012-02-10 23:41:05 +00:00
|
|
|
|
2015-09-28 18:03:35 +00:00
|
|
|
if ( count( $log_ids ) ) {
|
2013-09-13 21:35:40 +00:00
|
|
|
global $wgAbuseFilterCentralDB;
|
|
|
|
$fdb = wfGetDB( DB_MASTER, array(), $wgAbuseFilterCentralDB );
|
|
|
|
|
2012-02-10 23:41:05 +00:00
|
|
|
$fdb->update( 'abuse_filter_log',
|
|
|
|
array( 'afl_rev_id' => $revision->getId() ),
|
|
|
|
array( 'afl_id' => $log_ids, 'afl_wiki' => wfWikiId() ),
|
|
|
|
__METHOD__
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if two article objects are identical or have an identical WikiPage
|
|
|
|
* @param $page1 Article|WikiPage
|
|
|
|
* @param $page2 Article|WikiPage
|
2012-09-02 11:07:02 +00:00
|
|
|
* @return bool
|
2012-02-10 23:41:05 +00:00
|
|
|
*/
|
|
|
|
protected static function identicalPageObjects( $page1, $page2 ) {
|
2015-09-28 18:03:35 +00:00
|
|
|
if ( method_exists( 'Article', 'getPage' ) ) {
|
2012-02-10 23:41:05 +00:00
|
|
|
$wpage1 = ( $page1 instanceof Article ) ? $page1->getPage() : $page1;
|
|
|
|
$wpage2 = ( $page2 instanceof Article ) ? $page2->getPage() : $page2;
|
2015-09-28 18:03:35 +00:00
|
|
|
|
2012-02-10 23:41:05 +00:00
|
|
|
return ( $wpage1 === $wpage2 );
|
|
|
|
} else { // b/c for before WikiPage
|
|
|
|
return ( $page1 === $page2 ); // should be two Article objects
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-03-11 20:32:31 +00:00
|
|
|
/**
|
|
|
|
* @param $user
|
|
|
|
* @param $promote
|
|
|
|
* @return bool
|
|
|
|
*/
|
2008-06-27 06:18:51 +00:00
|
|
|
public static function onGetAutoPromoteGroups( $user, &$promote ) {
|
2015-08-06 00:17:38 +00:00
|
|
|
if ( $promote ) {
|
|
|
|
$key = AbuseFilter::autoPromoteBlockKey( $user );
|
2016-05-14 12:05:24 +00:00
|
|
|
$blocked = (bool)ObjectCache::getInstance( 'hash' )->getWithSetCallback(
|
2016-04-30 21:30:46 +00:00
|
|
|
$key,
|
|
|
|
30,
|
|
|
|
function () use ( $key ) {
|
2016-05-14 12:05:24 +00:00
|
|
|
return (int)ObjectCache::getMainStashInstance()->get( $key );
|
2016-04-30 21:30:46 +00:00
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
if ( $blocked ) {
|
2015-08-06 00:17:38 +00:00
|
|
|
$promote = array();
|
|
|
|
}
|
2008-06-27 06:18:51 +00:00
|
|
|
}
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2008-06-27 06:18:51 +00:00
|
|
|
return true;
|
|
|
|
}
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2015-09-28 18:03:35 +00:00
|
|
|
public static function onMovePageCheckPermissions( Title $oldTitle, Title $newTitle,
|
|
|
|
User $user, $reason, Status $status
|
|
|
|
) {
|
2014-10-27 17:55:33 +00:00
|
|
|
$vars = new AbuseFilterVariableHolder;
|
|
|
|
$vars->addHolders(
|
|
|
|
AbuseFilter::generateUserVars( $user ),
|
|
|
|
AbuseFilter::generateTitleVars( $oldTitle, 'MOVED_FROM' ),
|
|
|
|
AbuseFilter::generateTitleVars( $newTitle, 'MOVED_TO' )
|
|
|
|
);
|
|
|
|
$vars->setVar( 'SUMMARY', $reason );
|
|
|
|
$vars->setVar( 'ACTION', 'move' );
|
|
|
|
|
|
|
|
$result = AbuseFilter::filterAction( $vars, $oldTitle );
|
|
|
|
$status->merge( $result );
|
|
|
|
|
|
|
|
return $result->isOK();
|
|
|
|
}
|
|
|
|
|
2012-03-11 20:32:31 +00:00
|
|
|
/**
|
|
|
|
* @param $oldTitle Title
|
|
|
|
* @param $newTitle Title
|
|
|
|
* @param $user User
|
|
|
|
* @param $error
|
|
|
|
* @param $reason
|
|
|
|
* @return bool
|
|
|
|
*/
|
2008-08-07 13:53:18 +00:00
|
|
|
public static function onAbortMove( $oldTitle, $newTitle, $user, &$error, $reason ) {
|
2008-06-27 06:18:51 +00:00
|
|
|
global $wgUser;
|
2014-07-23 06:02:09 +00:00
|
|
|
// HACK: This is a secret userright so system actions
|
|
|
|
// can bypass AbuseFilter. Should not be assigned to
|
|
|
|
// normal users. This should be turned into a proper
|
|
|
|
// userright in bug 67936.
|
|
|
|
if ( $wgUser->isAllowed( 'abusefilter-bypass' ) ) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2014-10-27 17:55:33 +00:00
|
|
|
$status = new Status();
|
|
|
|
self::onMovePageCheckPermissions( $oldTitle, $newTitle, $wgUser, $reason, $status );
|
|
|
|
if ( !$status->isOK() ) {
|
|
|
|
$error = $status->getHTML();
|
|
|
|
}
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2014-10-27 17:55:33 +00:00
|
|
|
return $status->isOK();
|
2008-06-27 06:18:51 +00:00
|
|
|
}
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2012-03-11 20:32:31 +00:00
|
|
|
/**
|
|
|
|
* @param $article Article
|
|
|
|
* @param $user User
|
|
|
|
* @param $reason string
|
|
|
|
* @param $error
|
2013-01-08 14:52:49 +00:00
|
|
|
* @param $status
|
2012-03-11 20:32:31 +00:00
|
|
|
* @return bool
|
|
|
|
*/
|
2013-01-08 14:52:49 +00:00
|
|
|
public static function onArticleDelete( &$article, &$user, &$reason, &$error, &$status ) {
|
2009-02-26 12:15:14 +00:00
|
|
|
$vars = new AbuseFilterVariableHolder;
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2008-06-27 06:18:51 +00:00
|
|
|
global $wgUser;
|
2013-03-06 06:21:55 +00:00
|
|
|
$vars->addHolders(
|
|
|
|
AbuseFilter::generateUserVars( $wgUser ),
|
|
|
|
AbuseFilter::generateTitleVars( $article->getTitle(), 'ARTICLE' )
|
|
|
|
);
|
|
|
|
|
2009-02-26 12:15:14 +00:00
|
|
|
$vars->setVar( 'SUMMARY', $reason );
|
|
|
|
$vars->setVar( 'ACTION', 'delete' );
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2012-03-11 20:32:31 +00:00
|
|
|
$filter_result = AbuseFilter::filterAction( $vars, $article->getTitle() );
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2013-01-08 14:52:49 +00:00
|
|
|
$status->merge( $filter_result );
|
2015-01-26 19:34:46 +00:00
|
|
|
$error = $filter_result->isOK() ? '' : $filter_result->getHTML();
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2013-01-08 14:52:49 +00:00
|
|
|
return $filter_result->isOK();
|
2008-06-27 06:18:51 +00:00
|
|
|
}
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2012-03-11 20:32:31 +00:00
|
|
|
/**
|
|
|
|
* @param $user User
|
|
|
|
* @param $message
|
2012-05-10 08:08:48 +00:00
|
|
|
* @param $autocreate bool Indicates whether the account is created automatically.
|
2012-03-11 20:32:31 +00:00
|
|
|
* @return bool
|
|
|
|
*/
|
2012-05-10 08:08:48 +00:00
|
|
|
private static function checkNewAccount( $user, &$message, $autocreate ) {
|
2012-09-02 11:07:02 +00:00
|
|
|
if ( $user->getName() == wfMessage( 'abusefilter-blocker' )->inContentLanguage()->text() ) {
|
|
|
|
$message = wfMessage( 'abusefilter-accountreserved' )->text();
|
|
|
|
|
2008-06-27 09:49:26 +00:00
|
|
|
return false;
|
|
|
|
}
|
2012-09-02 11:07:02 +00:00
|
|
|
|
2009-03-01 01:49:34 +00:00
|
|
|
$vars = new AbuseFilterVariableHolder;
|
2012-09-02 11:07:02 +00:00
|
|
|
|
2011-08-24 00:29:26 +00:00
|
|
|
// Add variables only for a registered user, so IP addresses of
|
|
|
|
// new users won't be exposed
|
|
|
|
global $wgUser;
|
2016-02-03 17:51:40 +00:00
|
|
|
if ( !$autocreate && $wgUser->getId() ) {
|
2013-03-06 06:21:55 +00:00
|
|
|
$vars->addHolders( AbuseFilter::generateUserVars( $wgUser ) );
|
2011-08-24 00:29:26 +00:00
|
|
|
}
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2012-05-10 08:08:48 +00:00
|
|
|
$vars->setVar( 'ACTION', $autocreate ? 'autocreateaccount' : 'createaccount' );
|
2009-02-26 12:15:14 +00:00
|
|
|
$vars->setVar( 'ACCOUNTNAME', $user->getName() );
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2010-02-13 14:10:36 +00:00
|
|
|
$filter_result = AbuseFilter::filterAction(
|
2009-02-07 09:34:11 +00:00
|
|
|
$vars, SpecialPage::getTitleFor( 'Userlogin' ) );
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2013-01-08 14:52:49 +00:00
|
|
|
$message = $filter_result->isOK() ? '' : $filter_result->getWikiText();
|
2015-09-28 18:03:35 +00:00
|
|
|
|
2013-01-08 14:52:49 +00:00
|
|
|
return $filter_result->isOK();
|
2008-06-27 06:18:51 +00:00
|
|
|
}
|
2009-01-23 19:23:19 +00:00
|
|
|
|
2012-05-10 08:08:48 +00:00
|
|
|
/**
|
|
|
|
* @param $user User
|
|
|
|
* @param $message
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function onAbortNewAccount( $user, &$message ) {
|
|
|
|
return self::checkNewAccount( $user, $message, false );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param $user User
|
|
|
|
* @param $message
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function onAbortAutoAccount( $user, &$message ) {
|
|
|
|
// FIXME: ERROR MESSAGE IS SHOWN IN A WEIRD WAY, BEACUSE $message
|
|
|
|
// HERE MEANS NAME OF THE MESSAGE, NOT THE TEXT OF THE MESSAGE AS
|
|
|
|
// IN AbortNewAccount HOOK WHICH WE CANNOT PROVIDE!
|
|
|
|
return self::checkNewAccount( $user, $message, true );
|
|
|
|
}
|
|
|
|
|
2012-03-11 20:32:31 +00:00
|
|
|
/**
|
|
|
|
* @param $recentChange RecentChange
|
|
|
|
* @return bool
|
|
|
|
*/
|
2009-01-28 19:08:18 +00:00
|
|
|
public static function onRecentChangeSave( $recentChange ) {
|
2009-10-07 13:57:06 +00:00
|
|
|
$title = Title::makeTitle(
|
2012-03-11 20:32:31 +00:00
|
|
|
$recentChange->getAttribute( 'rc_namespace' ),
|
|
|
|
$recentChange->getAttribute( 'rc_title' )
|
2009-10-07 13:57:06 +00:00
|
|
|
);
|
2010-02-13 14:10:36 +00:00
|
|
|
$action = $recentChange->mAttribs['rc_log_type'] ?
|
2009-02-07 09:34:11 +00:00
|
|
|
$recentChange->mAttribs['rc_log_type'] : 'edit';
|
2009-01-28 19:08:18 +00:00
|
|
|
$actionID = implode( '-', array(
|
2015-09-28 18:03:35 +00:00
|
|
|
$title->getPrefixedText(), $recentChange->mAttribs['rc_user_text'], $action
|
|
|
|
) );
|
2009-01-23 19:23:19 +00:00
|
|
|
|
2010-02-13 14:10:36 +00:00
|
|
|
if ( !empty( AbuseFilter::$tagsToSet[$actionID] )
|
2015-09-28 18:03:35 +00:00
|
|
|
&& count( $tags = AbuseFilter::$tagsToSet[$actionID] )
|
|
|
|
) {
|
2009-10-07 13:57:06 +00:00
|
|
|
ChangeTags::addTags(
|
|
|
|
$tags,
|
|
|
|
$recentChange->mAttribs['rc_id'],
|
2009-02-07 09:34:11 +00:00
|
|
|
$recentChange->mAttribs['rc_this_oldid'],
|
2009-10-07 13:57:06 +00:00
|
|
|
$recentChange->mAttribs['rc_logid']
|
|
|
|
);
|
2009-01-28 19:08:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2012-03-11 20:32:31 +00:00
|
|
|
/**
|
2015-01-29 13:07:04 +00:00
|
|
|
* @param array $tags
|
|
|
|
* @param bool $enabled
|
2012-03-11 20:32:31 +00:00
|
|
|
* @return bool
|
|
|
|
*/
|
2015-01-29 13:07:04 +00:00
|
|
|
private static function fetchAllTags( array &$tags, $enabled ) {
|
2015-09-25 14:24:51 +00:00
|
|
|
global $wgAbuseFilterCentralDB, $wgAbuseFilterIsCentral;
|
|
|
|
|
2010-02-13 14:10:36 +00:00
|
|
|
# This is a pretty awful hack.
|
2009-01-28 19:08:18 +00:00
|
|
|
$dbr = wfGetDB( DB_SLAVE );
|
|
|
|
|
2015-02-21 16:47:49 +00:00
|
|
|
$where = array( 'afa_consequence' => 'tag', 'af_deleted' => false );
|
2015-01-29 13:07:04 +00:00
|
|
|
if ( $enabled ) {
|
|
|
|
$where['af_enabled'] = true;
|
|
|
|
}
|
2009-10-07 13:57:06 +00:00
|
|
|
$res = $dbr->select(
|
|
|
|
array( 'abuse_filter_action', 'abuse_filter' ),
|
2010-02-13 14:10:36 +00:00
|
|
|
'afa_parameters',
|
2015-01-29 13:07:04 +00:00
|
|
|
$where,
|
2009-10-07 13:57:06 +00:00
|
|
|
__METHOD__,
|
|
|
|
array(),
|
|
|
|
array( 'abuse_filter' => array( 'INNER JOIN', 'afa_filter=af_id' ) )
|
|
|
|
);
|
2009-01-28 19:08:18 +00:00
|
|
|
|
2011-02-10 17:25:25 +00:00
|
|
|
foreach ( $res as $row ) {
|
2015-01-29 13:07:04 +00:00
|
|
|
$tags = array_filter(
|
|
|
|
array_merge( explode( "\n", $row->afa_parameters ), $tags )
|
2009-02-07 09:34:11 +00:00
|
|
|
);
|
2009-01-28 19:08:18 +00:00
|
|
|
}
|
|
|
|
|
2015-09-25 14:24:51 +00:00
|
|
|
if ( $wgAbuseFilterCentralDB && !$wgAbuseFilterIsCentral ) {
|
|
|
|
$dbr = wfGetDB( DB_SLAVE, array(), $wgAbuseFilterCentralDB );
|
|
|
|
$where['af_global'] = 1;
|
|
|
|
$res = $dbr->select(
|
|
|
|
array( 'abuse_filter_action', 'abuse_filter' ),
|
|
|
|
'afa_parameters',
|
|
|
|
$where,
|
|
|
|
__METHOD__,
|
|
|
|
array(),
|
|
|
|
array( 'abuse_filter' => array( 'INNER JOIN', 'afa_filter=af_id' ) )
|
|
|
|
);
|
|
|
|
|
|
|
|
foreach ( $res as $row ) {
|
|
|
|
$tags = array_filter(
|
|
|
|
array_merge( explode( "\n", $row->afa_parameters ), $tags )
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-01-28 19:08:18 +00:00
|
|
|
return true;
|
|
|
|
}
|
2009-01-29 00:37:53 +00:00
|
|
|
|
2015-01-29 13:07:04 +00:00
|
|
|
/**
|
|
|
|
* @param array $tags
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function onListDefinedTags( array &$tags ) {
|
|
|
|
return self::fetchAllTags( $tags, false );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param array $tags
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function onChangeTagsListActive( array &$tags ) {
|
|
|
|
return self::fetchAllTags( $tags, true );
|
|
|
|
}
|
|
|
|
|
2011-02-10 17:32:57 +00:00
|
|
|
/**
|
|
|
|
* @param $updater DatabaseUpdater
|
2012-03-11 20:32:31 +00:00
|
|
|
* @throws MWException
|
2011-02-10 17:32:57 +00:00
|
|
|
* @return bool
|
|
|
|
*/
|
2010-10-03 15:51:04 +00:00
|
|
|
public static function onLoadExtensionSchemaUpdates( $updater = null ) {
|
2009-01-30 18:51:37 +00:00
|
|
|
$dir = dirname( __FILE__ );
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2011-12-27 16:35:30 +00:00
|
|
|
if ( $updater->getDB()->getType() == 'mysql' || $updater->getDB()->getType() == 'sqlite' ) {
|
|
|
|
if ( $updater->getDB()->getType() == 'mysql' ) {
|
2015-09-28 18:03:35 +00:00
|
|
|
$updater->addExtensionUpdate( array( 'addTable', 'abuse_filter',
|
|
|
|
"$dir/abusefilter.tables.sql", true ) );
|
|
|
|
$updater->addExtensionUpdate( array( 'addTable', 'abuse_filter_history',
|
|
|
|
"$dir/db_patches/patch-abuse_filter_history.sql", true ) );
|
2011-11-08 03:07:01 +00:00
|
|
|
} else {
|
2015-09-28 18:03:35 +00:00
|
|
|
$updater->addExtensionUpdate( array( 'addTable', 'abuse_filter',
|
|
|
|
"$dir/abusefilter.tables.sqlite.sql", true ) );
|
|
|
|
$updater->addExtensionUpdate( array( 'addTable', 'abuse_filter_history',
|
|
|
|
"$dir/db_patches/patch-abuse_filter_history.sqlite.sql", true ) );
|
2010-10-03 15:51:04 +00:00
|
|
|
}
|
2015-09-28 18:03:35 +00:00
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'addField', 'abuse_filter_history', 'afh_changed_fields',
|
|
|
|
"$dir/db_patches/patch-afh_changed_fields.sql", true
|
|
|
|
) );
|
|
|
|
$updater->addExtensionUpdate( array( 'addField', 'abuse_filter', 'af_deleted',
|
|
|
|
"$dir/db_patches/patch-af_deleted.sql", true ) );
|
|
|
|
$updater->addExtensionUpdate( array( 'addField', 'abuse_filter', 'af_actions',
|
|
|
|
"$dir/db_patches/patch-af_actions.sql", true ) );
|
|
|
|
$updater->addExtensionUpdate( array( 'addField', 'abuse_filter', 'af_global',
|
|
|
|
"$dir/db_patches/patch-global_filters.sql", true ) );
|
|
|
|
$updater->addExtensionUpdate( array( 'addField', 'abuse_filter_log', 'afl_rev_id',
|
|
|
|
"$dir/db_patches/patch-afl_action_id.sql", true ) );
|
2011-12-27 16:35:30 +00:00
|
|
|
if ( $updater->getDB()->getType() == 'mysql' ) {
|
2015-09-28 18:03:35 +00:00
|
|
|
$updater->addExtensionUpdate( array( 'addIndex', 'abuse_filter_log',
|
|
|
|
'filter_timestamp', "$dir/db_patches/patch-fix-indexes.sql", true ) );
|
2011-12-27 16:35:30 +00:00
|
|
|
} else {
|
2015-09-28 18:03:35 +00:00
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'addIndex', 'abuse_filter_log', 'afl_filter_timestamp',
|
|
|
|
"$dir/db_patches/patch-fix-indexes.sqlite.sql", true
|
|
|
|
) );
|
2011-12-27 16:35:30 +00:00
|
|
|
}
|
2012-05-06 06:44:45 +00:00
|
|
|
|
2015-09-28 18:03:35 +00:00
|
|
|
$updater->addExtensionUpdate( array( 'addField', 'abuse_filter',
|
|
|
|
'af_group', "$dir/db_patches/patch-af_group.sql", true ) );
|
2012-08-03 21:55:35 +00:00
|
|
|
|
|
|
|
if ( $updater->getDB()->getType() == 'mysql' ) {
|
2015-09-28 18:03:35 +00:00
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'addIndex', 'abuse_filter_log', 'wiki_timestamp',
|
|
|
|
"$dir/db_patches/patch-global_logging_wiki-index.sql", true
|
|
|
|
) );
|
2012-08-03 21:55:35 +00:00
|
|
|
} else {
|
2015-09-28 18:03:35 +00:00
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'addIndex', 'abuse_filter_log', 'afl_wiki_timestamp',
|
|
|
|
"$dir/db_patches/patch-global_logging_wiki-index.sqlite.sql", true
|
|
|
|
) );
|
2012-08-03 21:55:35 +00:00
|
|
|
}
|
|
|
|
|
2014-01-30 20:27:52 +00:00
|
|
|
if ( $updater->getDB()->getType() == 'mysql' ) {
|
2015-09-28 18:03:35 +00:00
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'modifyField', 'abuse_filter_log', 'afl_namespace',
|
|
|
|
"$dir/db_patches/patch-afl-namespace_int.sql", true
|
|
|
|
) );
|
2014-01-30 20:27:52 +00:00
|
|
|
} else {
|
2015-09-28 18:03:35 +00:00
|
|
|
/**
|
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'modifyField',
|
|
|
|
'abuse_filter_log',
|
|
|
|
'afl_namespace',
|
|
|
|
"$dir/db_patches/patch-afl-namespace_int.sqlite.sql",
|
|
|
|
true
|
|
|
|
) );
|
|
|
|
*/
|
|
|
|
/* @todo Modify a column in sqlite, which do not support such
|
|
|
|
* things create backup, drop, create with new schema, copy,
|
|
|
|
* drop backup or simply see
|
|
|
|
* https://www.mediawiki.org/wiki/Manual:SQLite#About_SQLite :
|
|
|
|
* Several extensions are known to have database update or
|
|
|
|
* installation issues with SQLite: AbuseFilter, ...
|
|
|
|
*/
|
2014-01-30 20:27:52 +00:00
|
|
|
}
|
2011-12-27 16:35:30 +00:00
|
|
|
} elseif ( $updater->getDB()->getType() == 'postgres' ) {
|
2015-09-28 18:03:35 +00:00
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'addTable', 'abuse_filter', "$dir/abusefilter.tables.pg.sql", true ) );
|
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'addTable', 'abuse_filter_history',
|
|
|
|
"$dir/db_patches/patch-abuse_filter_history.pg.sql", true
|
|
|
|
) );
|
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'addPgField', 'abuse_filter', 'af_actions', "TEXT NOT NULL DEFAULT ''" ) );
|
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'addPgField', 'abuse_filter', 'af_deleted', 'SMALLINT NOT NULL DEFAULT 0' ) );
|
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'addPgField', 'abuse_filter', 'af_global', 'SMALLINT NOT NULL DEFAULT 0' ) );
|
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'addPgField', 'abuse_filter_log', 'afl_wiki', 'TEXT' ) );
|
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'addPgField', 'abuse_filter_log', 'afl_deleted', 'SMALLINT' ) );
|
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'changeField', 'abuse_filter_log', 'afl_filter', 'TEXT', '' ) );
|
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'addPgExtIndex', 'abuse_filter_log', 'abuse_filter_log_ip', "(afl_ip)" ) );
|
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'addPgExtIndex', 'abuse_filter_log', 'abuse_filter_log_wiki', "(afl_wiki)" ) );
|
|
|
|
$updater->addExtensionUpdate( array(
|
|
|
|
'changeField', 'abuse_filter_log', 'afl_namespace', "INTEGER" ) );
|
2011-12-27 16:35:30 +00:00
|
|
|
}
|
|
|
|
|
2012-03-19 09:50:48 +00:00
|
|
|
$updater->addExtensionUpdate( array( array( __CLASS__, 'createAbuseFilterUser' ) ) );
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Updater callback to create the AbuseFilter user after the user tables have been updated.
|
2012-06-21 13:31:09 +00:00
|
|
|
* @param $updater DatabaseUpdater
|
2012-03-19 09:50:48 +00:00
|
|
|
*/
|
|
|
|
public static function createAbuseFilterUser( $updater ) {
|
2015-09-17 15:31:51 +00:00
|
|
|
$username = wfMessage( 'abusefilter-blocker' )->inContentLanguage()->text();
|
|
|
|
$user = User::newFromName( $username );
|
2011-12-27 16:35:30 +00:00
|
|
|
|
2012-01-18 02:37:14 +00:00
|
|
|
if ( $user && !$updater->updateRowExists( 'create abusefilter-blocker-user' ) ) {
|
2015-09-17 15:31:51 +00:00
|
|
|
if ( method_exists( 'User', 'newSystemUser' ) ) {
|
|
|
|
$user = User::newSystemUser( $username, array( 'steal' => true ) );
|
2011-11-08 03:07:01 +00:00
|
|
|
} else {
|
2015-09-17 15:31:51 +00:00
|
|
|
if ( !$user->getId() ) {
|
|
|
|
$user->addToDatabase();
|
|
|
|
$user->saveSettings();
|
|
|
|
# Increment site_stats.ss_users
|
|
|
|
$ssu = new SiteStatsUpdate( 0, 0, 0, 0, 1 );
|
|
|
|
$ssu->doUpdate();
|
|
|
|
} else {
|
|
|
|
// Sorry dude, we need this account.
|
|
|
|
$user->setPassword( null );
|
|
|
|
$user->setEmail( null );
|
|
|
|
$user->saveSettings();
|
|
|
|
}
|
2010-10-03 15:51:04 +00:00
|
|
|
}
|
2011-12-27 16:35:30 +00:00
|
|
|
$updater->insertUpdateRow( 'create abusefilter-blocker-user' );
|
|
|
|
# Promote user so it doesn't look too crazy.
|
|
|
|
$user->addGroup( 'sysop' );
|
2009-03-23 14:18:35 +00:00
|
|
|
}
|
2009-01-29 00:37:53 +00:00
|
|
|
}
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2012-03-11 20:32:31 +00:00
|
|
|
/**
|
|
|
|
* @param $id
|
|
|
|
* @param $nt Title
|
|
|
|
* @param $tools
|
|
|
|
* @return bool
|
|
|
|
*/
|
2009-10-07 13:57:06 +00:00
|
|
|
public static function onContributionsToolLinks( $id, $nt, &$tools ) {
|
|
|
|
global $wgUser;
|
2010-02-13 14:10:36 +00:00
|
|
|
if ( $wgUser->isAllowed( 'abusefilter-log' ) ) {
|
2015-09-28 18:03:35 +00:00
|
|
|
$tools[] = Linker::link(
|
|
|
|
SpecialPage::getTitleFor( 'AbuseLog' ),
|
|
|
|
wfMessage( 'abusefilter-log-linkoncontribs' )->text(),
|
|
|
|
array( 'title' => wfMessage( 'abusefilter-log-linkoncontribs-text' )->parse() ),
|
|
|
|
array( 'wpSearchUser' => $nt->getText() )
|
|
|
|
);
|
2009-04-24 01:53:12 +00:00
|
|
|
}
|
2015-09-28 18:03:35 +00:00
|
|
|
|
2009-04-24 01:53:12 +00:00
|
|
|
return true;
|
2009-10-07 13:57:06 +00:00
|
|
|
}
|
|
|
|
|
2012-03-11 20:32:31 +00:00
|
|
|
/**
|
2013-02-28 01:25:59 +00:00
|
|
|
* Handler for the UploadVerifyFile hook
|
|
|
|
*
|
|
|
|
* @param $upload UploadBase
|
|
|
|
* @param $mime
|
|
|
|
* @param $error array
|
|
|
|
*
|
2012-03-11 20:32:31 +00:00
|
|
|
* @return bool
|
|
|
|
*/
|
2013-02-28 01:25:59 +00:00
|
|
|
public static function onUploadVerifyFile( $upload, $mime, &$error ) {
|
2015-09-28 18:03:35 +00:00
|
|
|
global $wgUser;
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2013-02-28 01:25:59 +00:00
|
|
|
$vars = new AbuseFilterVariableHolder;
|
|
|
|
$title = $upload->getTitle();
|
2013-06-11 13:21:26 +00:00
|
|
|
|
|
|
|
if ( !$title ) {
|
|
|
|
// If there's no valid title assigned to the upload
|
|
|
|
// it wont proceed anyway, so no point in filtering it.
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2013-03-06 06:21:55 +00:00
|
|
|
$vars->addHolders(
|
|
|
|
AbuseFilter::generateUserVars( $wgUser ),
|
2016-04-02 22:04:19 +00:00
|
|
|
AbuseFilter::generateTitleVars( $title, 'ARTICLE' )
|
2009-10-07 13:57:06 +00:00
|
|
|
);
|
|
|
|
|
2009-06-03 15:10:44 +00:00
|
|
|
$vars->setVar( 'ACTION', 'upload' );
|
2013-02-28 01:25:59 +00:00
|
|
|
|
2015-11-23 09:55:06 +00:00
|
|
|
// We use the hexadecimal version of the file sha1.
|
|
|
|
// Use UploadBase::getTempFileSha1Base36 so that we don't have to calculate the sha1 sum again
|
2015-09-28 18:03:35 +00:00
|
|
|
$sha1 = Wikimedia\base_convert( $upload->getTempFileSha1Base36(), 36, 16, 40 );
|
2013-02-28 01:25:59 +00:00
|
|
|
|
|
|
|
$vars->setVar( 'file_sha1', $sha1 );
|
2015-01-08 04:56:35 +00:00
|
|
|
$vars->setVar( 'file_size', $upload->getFileSize() );
|
2009-10-07 13:57:06 +00:00
|
|
|
|
Add more file_* variables for file metadata
* file_mime
The MIME type of the file, e.g. 'image/png'.
* file_mediatype
The media type of the file, one of 'UNKNOWN', 'BITMAP', 'DRAWING',
'AUDIO', 'VIDEO', 'MULTIMEDIA', 'OFFICE', 'TEXT', 'EXECUTABLE', 'ARCHIVE'.
* file_width
Width of the image in pixels, or 0 if it's inapplicable (e.g. for
audio files).
* file_height
Height of the image in pixels, or 0 if it's inapplicable (e.g. for
audio files).
* file_bits_per_channel
Bits per color channel of the image, or 0 if it's inapplicable (e.g.
for audio files). The most common value is 8.
Bug: T131643
Change-Id: Id355515a18d3674393332c0f4094e34f9f522623
2016-04-04 19:12:08 +00:00
|
|
|
// UploadBase makes it absolutely impossible to get these out of it, even though it knows them.
|
|
|
|
$props = FSFile::getPropsFromPath( $upload->getTempPath() );
|
|
|
|
$vars->setVar( 'file_mime', $props['mime'] );
|
|
|
|
$vars->setVar( 'file_mediatype', MimeMagic::singleton()->getMediaType( null, $props['mime'] ) );
|
|
|
|
$vars->setVar( 'file_width', $props['width'] );
|
|
|
|
$vars->setVar( 'file_height', $props['height'] );
|
|
|
|
$vars->setVar( 'file_bits_per_channel', $props['bits'] );
|
|
|
|
|
2009-07-21 16:29:12 +00:00
|
|
|
$filter_result = AbuseFilter::filterAction( $vars, $title );
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2013-02-28 01:25:59 +00:00
|
|
|
if ( !$filter_result->isOK() ) {
|
|
|
|
$error = $filter_result->getErrorsArray();
|
|
|
|
$error = $error[0];
|
|
|
|
}
|
2009-10-07 13:57:06 +00:00
|
|
|
|
2013-01-08 14:52:49 +00:00
|
|
|
return $filter_result->isOK();
|
2009-10-07 13:57:06 +00:00
|
|
|
}
|
2011-08-26 20:12:34 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds global variables to the Javascript as needed
|
|
|
|
*
|
|
|
|
* @param array $vars
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function onMakeGlobalVariablesScript( array &$vars ) {
|
2014-02-07 15:05:52 +00:00
|
|
|
if ( isset( AbuseFilter::$editboxName ) && AbuseFilter::$editboxName !== null ) {
|
2011-08-26 20:26:57 +00:00
|
|
|
$vars['abuseFilterBoxName'] = AbuseFilter::$editboxName;
|
2011-08-26 20:12:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if ( AbuseFilterViewExamine::$examineType !== null ) {
|
2011-08-26 20:26:57 +00:00
|
|
|
$vars['abuseFilterExamine'] = array(
|
|
|
|
'type' => AbuseFilterViewExamine::$examineType,
|
|
|
|
'id' => AbuseFilterViewExamine::$examineId,
|
|
|
|
);
|
2011-08-26 20:12:34 +00:00
|
|
|
}
|
2015-09-28 18:03:35 +00:00
|
|
|
|
2011-08-26 20:12:34 +00:00
|
|
|
return true;
|
|
|
|
}
|
2013-07-02 01:43:18 +00:00
|
|
|
|
2014-07-10 03:57:02 +00:00
|
|
|
/**
|
|
|
|
* Tables that Extension:UserMerge needs to update
|
|
|
|
*
|
|
|
|
* @param array $updateFields
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function onUserMergeAccountFields( array &$updateFields ) {
|
|
|
|
$updateFields[] = array( 'abuse_filter', 'af_user', 'af_user_text' );
|
|
|
|
$updateFields[] = array( 'abuse_filter_log', 'afl_user', 'afl_user_text' );
|
|
|
|
$updateFields[] = array( 'abuse_filter_history', 'afh_user', 'afh_user_text' );
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2016-01-27 01:37:58 +00:00
|
|
|
/**
|
|
|
|
* Warms the cache for getLastPageAuthors() - T116557
|
|
|
|
*
|
|
|
|
* @param WikiPage $page
|
|
|
|
* @param Content $content
|
|
|
|
* @param ParserOutput $output
|
|
|
|
*/
|
|
|
|
public static function onParserOutputStashForEdit(
|
|
|
|
WikiPage $page, Content $content, ParserOutput $output
|
|
|
|
) {
|
|
|
|
AFComputedVariable::getLastPageAuthors( $page->getTitle() );
|
|
|
|
}
|
|
|
|
|
2013-07-02 01:43:18 +00:00
|
|
|
/**
|
|
|
|
* Hook to add PHPUnit test cases.
|
|
|
|
* @see https://www.mediawiki.org/wiki/Manual:Hooks/UnitTestsList
|
|
|
|
*
|
|
|
|
* @param array $files
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function onUnitTestsList( array &$files ) {
|
|
|
|
$testDir = __DIR__ . '/tests/phpunit';
|
|
|
|
|
|
|
|
$files = array_merge(
|
|
|
|
$files,
|
|
|
|
glob( $testDir . '/*Test.php' )
|
|
|
|
);
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
2008-06-27 06:18:51 +00:00
|
|
|
}
|