2004-02-18 02:15:00 +00:00
|
|
|
<?php
|
2007-04-19 10:19:27 +00:00
|
|
|
|
2004-09-02 23:28:24 +00:00
|
|
|
/**
|
2007-04-19 10:19:27 +00:00
|
|
|
* Special page to direct the user to a random page
|
|
|
|
|
*
|
2007-01-20 15:09:52 +00:00
|
|
|
* @addtogroup SpecialPage
|
2007-04-19 10:19:27 +00:00
|
|
|
* @author Rob Church <robchur@gmail.com>, Ilmari Karonen
|
|
|
|
|
* @license GNU General Public Licence 2.0 or later
|
2004-09-02 23:28:24 +00:00
|
|
|
*/
|
|
|
|
|
|
2007-04-20 08:55:14 +00:00
|
|
|
/**
|
|
|
|
|
* Special page to direct the user to a random page
|
|
|
|
|
*
|
|
|
|
|
* @addtogroup SpecialPage
|
|
|
|
|
*/
|
2008-01-14 10:23:48 +00:00
|
|
|
class RandomPage extends SpecialPage {
|
2007-04-19 10:19:27 +00:00
|
|
|
private $namespace = NS_MAIN; // namespace to select pages from
|
|
|
|
|
|
2008-01-14 12:50:20 +00:00
|
|
|
function __construct( $name = 'Randompage' ){
|
2008-04-14 07:45:50 +00:00
|
|
|
parent::__construct( $name );
|
2008-01-14 10:23:48 +00:00
|
|
|
}
|
2008-01-14 12:50:20 +00:00
|
|
|
|
|
|
|
|
public function getNamespace() {
|
|
|
|
|
return $this->namespace;
|
2008-01-14 10:23:48 +00:00
|
|
|
}
|
2008-04-14 07:45:50 +00:00
|
|
|
|
2007-04-19 10:19:27 +00:00
|
|
|
public function setNamespace ( $ns ) {
|
|
|
|
|
if( $ns < NS_MAIN ) $ns = NS_MAIN;
|
|
|
|
|
$this->namespace = $ns;
|
|
|
|
|
}
|
2008-04-14 07:45:50 +00:00
|
|
|
|
2008-01-14 12:50:20 +00:00
|
|
|
// select redirects instead of normal pages?
|
|
|
|
|
// Overriden by SpecialRandomredirect
|
|
|
|
|
public function isRedirect(){
|
|
|
|
|
return false;
|
2007-04-19 10:19:27 +00:00
|
|
|
}
|
2008-04-14 07:45:50 +00:00
|
|
|
|
2008-01-14 12:50:20 +00:00
|
|
|
public function execute( $par ) {
|
2008-01-14 10:23:48 +00:00
|
|
|
global $wgOut, $wgContLang;
|
|
|
|
|
|
|
|
|
|
if ($par)
|
|
|
|
|
$this->setNamespace( $wgContLang->getNsIndex( $par ) );
|
|
|
|
|
|
|
|
|
|
$title = $this->getRandomTitle();
|
|
|
|
|
|
|
|
|
|
if( is_null( $title ) ) {
|
2008-01-14 12:50:20 +00:00
|
|
|
$this->setHeaders();
|
2008-02-18 07:25:35 +00:00
|
|
|
$wgOut->addWikiMsg( strtolower( $this->mName ) . '-nopages' );
|
2008-01-14 10:23:48 +00:00
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2008-01-14 12:50:20 +00:00
|
|
|
$query = $this->isRedirect() ? 'redirect=no' : '';
|
|
|
|
|
$wgOut->redirect( $title->getFullUrl( $query ) );
|
2008-01-14 10:23:48 +00:00
|
|
|
}
|
|
|
|
|
|
2007-04-19 10:19:27 +00:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Choose a random title.
|
|
|
|
|
* @return Title object (or null if nothing to choose from)
|
|
|
|
|
*/
|
2008-01-14 12:50:20 +00:00
|
|
|
public function getRandomTitle() {
|
2007-04-19 10:19:27 +00:00
|
|
|
$randstr = wfRandom();
|
|
|
|
|
$row = $this->selectRandomPageFromDB( $randstr );
|
|
|
|
|
|
2007-04-19 10:54:48 +00:00
|
|
|
/* If we picked a value that was higher than any in
|
|
|
|
|
* the DB, wrap around and select the page with the
|
|
|
|
|
* lowest value instead! One might think this would
|
|
|
|
|
* skew the distribution, but in fact it won't cause
|
|
|
|
|
* any more bias than what the page_random scheme
|
|
|
|
|
* causes anyway. Trust me, I'm a mathematician. :)
|
|
|
|
|
*/
|
|
|
|
|
if( !$row )
|
|
|
|
|
$row = $this->selectRandomPageFromDB( "0" );
|
2007-04-19 10:19:27 +00:00
|
|
|
|
|
|
|
|
if( $row )
|
|
|
|
|
return Title::makeTitleSafe( $this->namespace, $row->page_title );
|
|
|
|
|
else
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
2008-01-14 12:50:20 +00:00
|
|
|
private function selectRandomPageFromDB( $randstr ) {
|
2007-04-19 10:19:27 +00:00
|
|
|
global $wgExtraRandompageSQL;
|
|
|
|
|
$fname = 'RandomPage::selectRandomPageFromDB';
|
|
|
|
|
|
|
|
|
|
$dbr = wfGetDB( DB_SLAVE );
|
|
|
|
|
|
2007-04-19 10:54:48 +00:00
|
|
|
$use_index = $dbr->useIndexClause( 'page_random' );
|
|
|
|
|
$page = $dbr->tableName( 'page' );
|
|
|
|
|
|
|
|
|
|
$ns = (int) $this->namespace;
|
2008-01-14 12:50:20 +00:00
|
|
|
$redirect = $this->isRedirect() ? 1 : 0;
|
2007-04-19 10:19:27 +00:00
|
|
|
|
2007-04-19 10:54:48 +00:00
|
|
|
$extra = $wgExtraRandompageSQL ? "AND ($wgExtraRandompageSQL)" : "";
|
|
|
|
|
$sql = "SELECT page_title
|
|
|
|
|
FROM $page $use_index
|
|
|
|
|
WHERE page_namespace = $ns
|
|
|
|
|
AND page_is_redirect = $redirect
|
|
|
|
|
AND page_random >= $randstr
|
|
|
|
|
$extra
|
2007-04-19 10:19:27 +00:00
|
|
|
ORDER BY page_random";
|
|
|
|
|
|
|
|
|
|
$sql = $dbr->limitResult( $sql, 1, 0 );
|
|
|
|
|
$res = $dbr->query( $sql, $fname );
|
|
|
|
|
return $dbr->fetchObject( $res );
|
|
|
|
|
}
|
|
|
|
|
}
|