wiki.techinc.nl/includes/specials/SpecialUnusedImages.php
Umherirrender e97ba4a5b0 Inject DBLoadBalancer into abstract QueryPage (part 2)
Every QueryPage needs a database to work

Bug: T259960
Change-Id: Ibcc192c21fa68371ea047b668e131e3293868fe2
2020-11-02 11:26:51 +00:00

97 lines
2.5 KiB
PHP

<?php
/**
* Implements Special:Unusedimages
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
* http://www.gnu.org/copyleft/gpl.html
*
* @file
* @ingroup SpecialPage
*/
use Wikimedia\Rdbms\ILoadBalancer;
/**
* A special page that lists unused images
*
* @ingroup SpecialPage
*/
class SpecialUnusedImages extends ImageQueryPage {
/**
* @param ILoadBalancer $loadBalancer
*/
public function __construct( ILoadBalancer $loadBalancer ) {
parent::__construct( 'Unusedimages' );
$this->setDBLoadBalancer( $loadBalancer );
}
public function isExpensive() {
return true;
}
protected function sortDescending() {
return false;
}
public function isSyndicated() {
return false;
}
public function getQueryInfo() {
$retval = [
'tables' => [ 'image', 'imagelinks' ],
'fields' => [
'namespace' => NS_FILE,
'title' => 'img_name',
'value' => 'img_timestamp',
],
'conds' => [ 'il_to IS NULL' ],
'join_conds' => [ 'imagelinks' => [ 'LEFT JOIN', 'il_to = img_name' ] ]
];
if ( $this->getConfig()->get( 'CountCategorizedImagesAsUsed' ) ) {
// Order is significant
$retval['tables'] = [ 'image', 'page', 'categorylinks',
'imagelinks' ];
$retval['conds']['page_namespace'] = NS_FILE;
$retval['conds'][] = 'cl_from IS NULL';
$retval['conds'][] = 'img_name = page_title';
$retval['join_conds']['categorylinks'] = [
'LEFT JOIN', 'cl_from = page_id' ];
$retval['join_conds']['imagelinks'] = [
'LEFT JOIN', 'il_to = page_title' ];
}
return $retval;
}
public function usesTimestamps() {
return true;
}
protected function getPageHeader() {
if ( $this->getConfig()->get( 'CountCategorizedImagesAsUsed' ) ) {
return $this->msg(
'unusedimagestext-categorizedimgisused'
)->parseAsBlock();
}
return $this->msg( 'unusedimagestext' )->parseAsBlock();
}
protected function getGroupName() {
return 'maintenance';
}
}