setSquidMaxage( 10 ); if( $wgOut->checkLastModified( $s->lastmod ) ){ # Client cache fresh and headers sent, nothing more to do. return; } $rctext = wfMsg( "recentchangestext" ); # The next few lines can probably be commented out now that wfMsg can get text from the DB $sql = "SELECT cur_text FROM cur WHERE cur_namespace=4 AND cur_title='Recentchanges'"; $res = wfQuery( $sql, DB_READ, $fname ); if( ( $s = wfFetchObject( $res ) ) and ( $s->cur_text != "" ) ) { $rctext = $s->cur_text; } $wgOut->addWikiText( $rctext ); if ( ! $days ) { $days = $wgUser->getOption( "rcdays" ); if ( ! $days ) { $days = 3; } } $days = (int)$days; list( $limit, $offset ) = wfCheckLimits( 100, "rclimit" ); $now = wfTimestampNow(); $cutoff_unixtime = time() - ( $days * 86400 ); $cutoff_unixtime = $cutoff_unixtime - ($cutoff_unixtime % 86400); $cutoff = wfUnix2Timestamp( $cutoff_unixtime ); if(preg_match('/^[0-9]{14}$/', $from) and $from > $cutoff) { $cutoff = $from; } else { unset($from); } $sk = $wgUser->getSkin(); $showhide = array( wfMsg( "show" ), wfMsg( "hide" )); if ( ! isset( $hideminor ) ) { $hideminor = $wgUser->getOption( "hideminor" ); } $hideminor = ($hideminor ? 1 : 0); if ( $hideminor ) { $hidem = "AND rc_minor=0"; } else { $hidem = ""; } if ( !isset( $hidebots ) ) { $hidebots = 1; } if( $hidebots ) { $hidem .= " AND rc_bot=0"; } $hidebots = ($hidebots ? 1 : 0); if ( !isset( $hideliu ) ) { $hideliu = 0; } if ( $hideliu ) { $hidem .= " AND rc_user=0"; } $hideliu = ($hideliu ? 1 : 0); #$hideparams = "hideminor={$hideminor}&hideliu={$hideliu}&hidebots={$hidebots}"; $urlparams = array( "hideminor" => $hideminor, "hideliu" => $hideliu, "hidebots" => $hidebots ); $hideparams = wfArrayToCGI( $urlparams ); $minorLink = $sk->makeKnownLink( $wgLang->specialPage( "Recentchanges" ), $showhide[1-$hideminor], wfArrayToCGI( array( "hideminor" => 1-$hideminor ), $urlparams ) ); $botLink = $sk->makeKnownLink( $wgLang->specialPage( "Recentchanges" ), $showhide[1-$hidebots], wfArrayToCGI( array( "hidebots" => 1-$hidebots ), $urlparams ) ); $liuLink = $sk->makeKnownLink( $wgLang->specialPage( "Recentchanges" ), $showhide[1-$hideliu], wfArrayToCGI( array( "hideliu" => 1-$hideliu ), $urlparams ) ); $uid = $wgUser->getID(); $sql2 = "SELECT recentchanges.*" . ($uid ? ",wl_user" : "") . " FROM recentchanges " . ($uid ? "LEFT OUTER JOIN watchlist ON wl_user={$uid} AND wl_title=rc_title AND wl_namespace=rc_namespace & 65534 " : "") . "WHERE rc_timestamp > '{$cutoff}' {$hidem} " . "ORDER BY rc_timestamp DESC LIMIT {$limit}"; $res = wfQuery( $sql2, DB_READ, $fname ); $rows = array(); while( $row = wfFetchObject( $res ) ){ $rows[] = $row; } if(isset($from)) { $note = wfMsg( "rcnotefrom", $wgLang->formatNum( $limit ), $wgLang->timeanddate( $from, true ) ); } else { $note = wfMsg( "rcnote", $wgLang->formatNum( $limit ), $wgLang->formatNum( $days ) ); } $wgOut->addHTML( "\n