mediawiki-extensions-AbuseF.../includes/pagers/AbuseLogPager.php
Daimona Eaytoy 3c3a521fec Fix coding conventions exclusion rules
This should fix every error with excluded rules, leaving only the one
for $wgTitle. A double check would be nice in order to avoid regressions
due to stupid mistakes.

Bug: T178007
Change-Id: I22c179f3a01d652640304b59e43fcb5b5a9abac3
2018-04-20 08:40:18 +00:00

90 lines
1.5 KiB
PHP

<?php
use Wikimedia\Rdbms\ResultWrapper;
class AbuseLogPager extends ReverseChronologicalPager {
/**
* @var SpecialAbuseLog
*/
public $mForm;
/**
* @var array
*/
public $mConds;
/**
* @param SpecialAbuseLog $form
* @param array $conds
*/
public function __construct( $form, $conds = [] ) {
$this->mForm = $form;
$this->mConds = $conds;
parent::__construct();
}
/**
* @param object $row
* @return string
*/
public function formatRow( $row ) {
return $this->mForm->formatRow( $row );
}
/**
* @return array
*/
public function getQueryInfo() {
$conds = $this->mConds;
$info = [
'tables' => [ 'abuse_filter_log', 'abuse_filter' ],
'fields' => '*',
'conds' => $conds,
'join_conds' =>
[ 'abuse_filter' =>
[
'LEFT JOIN',
'af_id=afl_filter',
],
],
];
if ( !$this->mForm->canSeeHidden() ) {
$db = $this->mDb;
$info['conds'][] = SpecialAbuseLog::getNotDeletedCond( $db );
}
return $info;
}
/**
* @param ResultWrapper $result
*/
protected function preprocessResults( $result ) {
if ( $this->getNumRows() === 0 ) {
return;
}
$lb = new LinkBatch();
$lb->setCaller( __METHOD__ );
foreach ( $result as $row ) {
// Only for local wiki results
if ( !$row->afl_wiki ) {
$lb->add( $row->afl_namespace, $row->afl_title );
$lb->add( NS_USER, $row->afl_user );
$lb->add( NS_USER_TALK, $row->afl_user_text );
}
}
$lb->execute();
$result->seek( 0 );
}
/**
* @return string
*/
public function getIndexField() {
return 'afl_timestamp';
}
}