including(); if ( $inc ) { $this->limit = (int)$par; $this->offset = 0; } $this->setListoutput( $inc ); $this->shownavigation = !$inc; parent::execute( $par ); } function getQueryInfo() { $dbr = wfGetDB( DB_REPLICA ); $count = $this->getConfig()->get( 'WantedPagesThreshold' ) - 1; $query = [ 'tables' => [ 'pagelinks', 'pg1' => 'page', 'pg2' => 'page' ], 'fields' => [ 'namespace' => 'pl_namespace', 'title' => 'pl_title', 'value' => 'COUNT(*)' ], 'conds' => [ 'pg1.page_namespace IS NULL', 'pl_namespace NOT IN (' . $dbr->makeList( [ NS_USER, NS_USER_TALK ] ) . ')', 'pg2.page_namespace != ' . $dbr->addQuotes( NS_MEDIAWIKI ), ], 'options' => [ 'HAVING' => [ 'COUNT(*) > ' . $dbr->addQuotes( $count ), 'COUNT(*) > SUM(pg2.page_is_redirect)' ], 'GROUP BY' => [ 'pl_namespace', 'pl_title' ] ], 'join_conds' => [ 'pg1' => [ 'LEFT JOIN', [ 'pg1.page_namespace = pl_namespace', 'pg1.page_title = pl_title' ] ], 'pg2' => [ 'LEFT JOIN', 'pg2.page_id = pl_from' ] ] ]; // Replacement for the WantedPages::getSQL hook // Avoid PHP 7.1 warning from passing $this by reference $wantedPages = $this; Hooks::run( 'WantedPages::getQueryInfo', [ &$wantedPages, &$query ] ); return $query; } protected function getGroupName() { return 'maintenance'; } }