* @author Rob Church */ use Wikimedia\Rdbms\IResultWrapper; use Wikimedia\Rdbms\IDatabase; /** * A special page to show pages ordered by the number of pages linking to them. * * @ingroup SpecialPage */ class MostlinkedPage extends QueryPage { function __construct( $name = 'Mostlinked' ) { parent::__construct( $name ); } public function isExpensive() { return true; } function isSyndicated() { return false; } public function getQueryInfo() { return [ 'tables' => [ 'pagelinks', 'page' ], 'fields' => [ 'namespace' => 'pl_namespace', 'title' => 'pl_title', 'value' => 'COUNT(*)', 'page_namespace' ], 'options' => [ 'HAVING' => 'COUNT(*) > 1', 'GROUP BY' => [ 'pl_namespace', 'pl_title', 'page_namespace' ] ], 'join_conds' => [ 'page' => [ 'LEFT JOIN', [ 'page_namespace = pl_namespace', 'page_title = pl_title' ] ] ] ]; } /** * Pre-fill the link cache * * @param IDatabase $db * @param IResultWrapper $res */ function preprocessResults( $db, $res ) { $this->executeLBFromResultWrapper( $res ); } /** * Make a link to "what links here" for the specified title * * @param Title $title Title being queried * @param string $caption Text to display on the link * @return string */ function makeWlhLink( $title, $caption ) { $wlh = SpecialPage::getTitleFor( 'Whatlinkshere', $title->getPrefixedDBkey() ); $linkRenderer = $this->getLinkRenderer(); return $linkRenderer->makeKnownLink( $wlh, $caption ); } /** * Make links to the page corresponding to the item, * and the "what links here" page for it * * @param Skin $skin Skin to be used * @param object $result Result row * @return string */ function formatResult( $skin, $result ) { $title = Title::makeTitleSafe( $result->namespace, $result->title ); if ( !$title ) { return Html::element( 'span', [ 'class' => 'mw-invalidtitle' ], Linker::getInvalidTitleDescription( $this->getContext(), $result->namespace, $result->title ) ); } $linkRenderer = $this->getLinkRenderer(); $link = $linkRenderer->makeLink( $title ); $wlh = $this->makeWlhLink( $title, $this->msg( 'nlinks' )->numParams( $result->value )->text() ); return $this->getLanguage()->specialList( $link, $wlh ); } protected function getGroupName() { return 'highuse'; } }