*/ /** * Querypage that lists the most wanted files * * @ingroup SpecialPage */ class WantedFilesPage extends WantedQueryPage { function __construct( $name = 'Wantedfiles' ) { parent::__construct( $name ); } function getPageHeader() { # Specifically setting to use "Wanted Files" (NS_MAIN) as title, so as to get what # category would be used on main namespace pages, for those tricky wikipedia # admins who like to do {{#ifeq:{{NAMESPACE}}|foo|bar|....}}. $catMessage = $this->msg( 'broken-file-category' ) ->title( Title::newFromText( "Wanted Files", NS_MAIN ) ) ->inContentLanguage(); if ( !$catMessage->isDisabled() ) { $category = Title::makeTitleSafe( NS_CATEGORY, $catMessage->text() ); } else { $category = false; } $noForeign = ''; if ( !$this->likelyToHaveFalsePositives() ) { // Additional messages for grep: // wantedfiletext-cat-noforeign, wantedfiletext-nocat-noforeign $noForeign = '-noforeign'; } if ( $category ) { return $this ->msg( 'wantedfiletext-cat' . $noForeign ) ->params( $category->getFullText() ) ->parseAsBlock(); } else { return $this ->msg( 'wantedfiletext-nocat' . $noForeign ) ->parseAsBlock(); } } /** * Whether foreign repos are likely to cause false positives * * In its own function to allow subclasses to override. * @see SpecialWantedFilesGUOverride in GlobalUsage extension. * @since 1.24 * @return bool */ protected function likelyToHaveFalsePositives() { return RepoGroup::singleton()->hasForeignRepos(); } /** * KLUGE: The results may contain false positives for files * that exist e.g. in a shared repo. Setting this at least * keeps them from showing up as redlinks in the output, even * if it doesn't fix the real problem (T8220). * * @note could also have existing links here from broken file * redirects. * @return bool */ function forceExistenceCheck() { return true; } /** * Does the file exist? * * Use wfFindFile so we still think file namespace pages without * files are missing, but valid file redirects and foreign files are ok. * * @param Title $title * @return bool */ protected function existenceCheck( Title $title ) { return (bool)wfFindFile( $title ); } function getQueryInfo() { return [ 'tables' => [ 'imagelinks', 'page', 'redirect', 'img1' => 'image', 'img2' => 'image', ], 'fields' => [ 'namespace' => NS_FILE, 'title' => 'il_to', 'value' => 'COUNT(*)' ], 'conds' => [ 'img1.img_name' => null, // We also need to exclude file redirects 'img2.img_name' => null, ], 'options' => [ 'GROUP BY' => 'il_to' ], 'join_conds' => [ 'img1' => [ 'LEFT JOIN', 'il_to = img1.img_name' ], 'page' => [ 'LEFT JOIN', [ 'il_to = page_title', 'page_namespace' => NS_FILE, ] ], 'redirect' => [ 'LEFT JOIN', [ 'page_id = rd_from', 'rd_namespace' => NS_FILE, 'rd_interwiki' => '' ] ], 'img2' => [ 'LEFT JOIN', 'rd_title = img2.img_name' ] ] ]; } protected function getGroupName() { return 'maintenance'; } }