mediawiki-extensions-AbuseF.../includes/Pager/AbuseFilterExaminePager.php
Daimona Eaytoy 3413d15b68 Apply proper visibility checks for recentchanges queries
Follow-up: I6063c02fa261c4cc0e6dbbb2db4e111eb85912c2

Bug: T274152
Bug: T274158
Change-Id: I71a6d521bd12931ce60eec4d2dc35af19146000f
2021-03-11 11:52:48 +01:00

107 lines
2.5 KiB
PHP

<?php
namespace MediaWiki\Extension\AbuseFilter\Pager;
use ActorMigration;
use MediaWiki\Extension\AbuseFilter\AbuseFilterChangesList;
use MediaWiki\Extension\AbuseFilter\View\AbuseFilterViewExamine;
use RecentChange;
use ReverseChronologicalPager;
use stdClass;
use Title;
use User;
class AbuseFilterExaminePager extends ReverseChronologicalPager {
/**
* @var AbuseFilterChangesList Our changes list
*/
public $mChangesList;
/**
* @var AbuseFilterViewExamine The associated view
*/
public $mPage;
/**
* @var int Line number of the row, see RecentChange::$counter
*/
public $rcCounter;
/**
* @param AbuseFilterViewExamine $page
* @param AbuseFilterChangesList $changesList
*/
public function __construct( AbuseFilterViewExamine $page, AbuseFilterChangesList $changesList ) {
parent::__construct();
$this->mChangesList = $changesList;
$this->mPage = $page;
$this->rcCounter = 1;
}
/**
* @return array
*/
public function getQueryInfo() {
$dbr = wfGetDB( DB_REPLICA );
$conds = [];
if ( (string)$this->mPage->mSearchUser !== '' ) {
$conds[] = ActorMigration::newMigration()->getWhere(
$dbr, 'rc_user', User::newFromName( $this->mPage->mSearchUser, false )
)['conds'];
}
$startTS = strtotime( $this->mPage->mSearchPeriodStart );
if ( $startTS ) {
$conds[] = 'rc_timestamp>=' . $dbr->addQuotes( $dbr->timestamp( $startTS ) );
}
$endTS = strtotime( $this->mPage->mSearchPeriodEnd );
if ( $endTS ) {
$conds[] = 'rc_timestamp<=' . $dbr->addQuotes( $dbr->timestamp( $endTS ) );
}
$conds[] = $this->mPage->buildTestConditions( $dbr );
$conds = array_merge( $conds, $this->mPage->buildVisibilityConditions( $dbr, $this->getAuthority() ) );
$rcQuery = RecentChange::getQueryInfo();
$info = [
'tables' => $rcQuery['tables'],
'fields' => $rcQuery['fields'],
'conds' => $conds,
'join_conds' => $rcQuery['joins'],
];
return $info;
}
/**
* @param stdClass $row
* @return string
*/
public function formatRow( $row ) {
$rc = RecentChange::newFromRow( $row );
$rc->counter = $this->rcCounter++;
return $this->mChangesList->recentChangesLine( $rc, false );
}
/**
* @codeCoverageIgnore Merely declarative
* @inheritDoc
*/
public function getIndexField() {
return 'rc_id';
}
/**
* @return Title
*/
public function getTitle() {
return $this->mPage->getTitle( 'examine' );
}
/**
* @return string
*/
public function getEmptyBody() {
return $this->msg( 'abusefilter-examine-noresults' )->parseAsBlock();
}
}