wiki.techinc.nl/includes/SpecialNewpages.php
Brion Vibber ee940c906d Replace ugly abuse of log pages to store cached results of query pages
with a table that stores up to 1000 rows for each 'expensive' special
page. This can be paged through, reducing the annoyingness of 50 result
limits on the old system.

Rebuilding the cache can be forced by adding "recache=1" URL parameter,
but this will need to be refined with some sort of controls to prevent
abuse.

Added the user realname update to the installer's updater list, also.
2004-05-09 01:30:34 +00:00

74 lines
1.6 KiB
PHP

<?php
require_once( "QueryPage.php" );
class NewPagesPage extends QueryPage {
function getName() {
return "Newpages";
}
function isExpensive() {
# Indexed on RC, and will *not* work with querycache yet.
return false;
#return parent::isExpensive();
}
function getSQL( $offset, $limit ) {
return
"SELECT 'Newpages' as type,
rc_namespace AS namespace,
rc_title AS title,
rc_cur_id AS value,
rc_user AS user,
rc_user_text AS user_text,
rc_comment as comment,
rc_timestamp AS timestamp,
length(cur_text) as length,
cur_text as text
FROM recentchanges,cur
WHERE rc_cur_id=cur_id AND rc_new=1
AND rc_namespace=0 AND cur_is_redirect=0";
}
function formatResult( $skin, $result ) {
global $wgLang;
$u = $result->user;
$ut = $result->user_text;
$length = wfMsg( "nbytes", $wgLang->formatNum( $result->length ) );
$c = $skin->formatComment($result->comment );
if ( 0 == $u ) { # not by a logged-in user
$ul = $ut;
}
else {
$ul = $skin->makeLink( $wgLang->getNsText(NS_USER) . ":{$ut}", $ut );
}
$d = $wgLang->timeanddate( $result->timestamp, true );
$link = $skin->makeKnownLink( $result->title, "" );
$s = "{$d} {$link} ({$length}) . . {$ul}";
if ( "" != $c && "*" != $c ) {
$s .= " <em>({$c})</em>";
}
return $s;
}
}
function wfSpecialNewpages()
{
global $wgRequest;
list( $limit, $offset ) = wfCheckLimits();
$npp = new NewPagesPage();
if( !$npp->doFeed( $wgRequest->getVal( 'feed' ) ) ) {
$npp->doQuery( $offset, $limit );
}
}
?>