including(); if ( $inc ) { $this->limit = (int)$par; $this->offset = 0; } $this->setListoutput( $inc ); $this->shownavigation = !$inc; parent::execute( $par ); } function getQueryInfo() { $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 ( '" . NS_USER . "', '" . NS_USER_TALK . "' )", "pg2.page_namespace != '" . NS_MEDIAWIKI . "'" ], 'options' => [ 'HAVING' => [ "COUNT(*) > $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 Hooks::run( 'WantedPages::getQueryInfo', [ &$this, &$query ] ); return $query; } protected function getGroupName() { return 'maintenance'; } }