Disable $wgUseGzip by default since it's wildly incompatible with
[lhc/web/wiklou.git] / includes / SpecialRecentchangeslinked.php
1 <?php
2 require_once( "SpecialRecentchanges.php" );
3
4 function wfSpecialRecentchangeslinked( $par = NULL )
5 {
6 global $wgUser, $wgOut, $wgLang, $wgTitle, $wgRequest;
7 $fname = "wfSpecialRecentchangeslinked";
8
9 $days = $wgRequest->getInt( 'days' );
10 $target = $wgRequest->getText( 'target' );
11 $hideminor = $wgRequest->getBool( 'hideminor' ) ? 1 : 0;
12
13 $wgOut->setPagetitle( wfMsg( "recentchanges" ) );
14 $sk = $wgUser->getSkin();
15
16 if( $par ) {
17 $target = $par;
18 }
19 if ( "" == $target ) {
20 $wgOut->errorpage( "notargettitle", "notargettext" );
21 return;
22 }
23 $nt = Title::newFromURL( $target );
24 if( !$nt ) {
25 $wgOut->errorpage( "notargettitle", "notargettext" );
26 return;
27 }
28 $id = $nt->getArticleId();
29
30 $wgOut->setSubtitle( wfMsg( "rclsub", $nt->getPrefixedText() ) );
31
32 if ( ! $days ) {
33 $days = $wgUser->getOption( "rcdays" );
34 if ( ! $days ) { $days = 7; }
35 }
36 $days = (int)$days;
37 list( $limit, $offset ) = wfCheckLimits( 100, "rclimit" );
38
39 $dbr =& wfGetDB( DB_SLAVE );
40 $cutoff = $dbr->timestamp( time() - ( $days * 86400 ) );
41
42 $hideminor = ($hideminor ? 1 : 0);
43 if ( $hideminor ) {
44 $mlink = $sk->makeKnownLink( $wgLang->specialPage( "Recentchangeslinked" ),
45 WfMsg( "show" ), "target=" . htmlspecialchars( $nt->getPrefixedURL() ) .
46 "&days={$days}&limit={$limit}&hideminor=0" );
47 } else {
48 $mlink = $sk->makeKnownLink( $wgLang->specialPage( "Recentchangeslinked" ),
49 WfMsg( "hide" ), "target=" . htmlspecialchars( $nt->getPrefixedURL() ) .
50 "&days={$days}&limit={$limit}&hideminor=1" );
51 }
52 if ( $hideminor ) {
53 $cmq = "AND cur_minor_edit=0";
54 } else { $cmq = ""; }
55
56 extract( $dbr->tableNames( 'cur', 'links' ) );
57
58 $sql = "SELECT cur_id,cur_namespace,cur_title,cur_user,cur_comment," .
59 "cur_user_text,cur_timestamp,cur_minor_edit,cur_is_new FROM $links, $cur " .
60 "WHERE cur_timestamp > '{$cutoff}' {$cmq} AND l_to=cur_id AND l_from=$id " .
61 "GROUP BY cur_id ORDER BY inverse_timestamp LIMIT {$limit}";
62 $res = $dbr->query( $sql, $fname );
63
64 $wgOut->addHTML("&lt; ".$sk->makeKnownLinkObj($nt, "", "redirect=no" )."<br />\n");
65 $note = wfMsg( "rcnote", $limit, $days );
66 $wgOut->addHTML( "<hr />\n{$note}\n<br />" );
67
68 $note = rcDayLimitlinks( $days, $limit, "Recentchangeslinked",
69 "target=" . $nt->getPrefixedURL() . "&hideminor={$hideminor}",
70 false, $mlink );
71
72 $wgOut->addHTML( "{$note}\n" );
73
74 $s = $sk->beginRecentChangesList();
75 $count = $dbr->numRows( $res );
76
77 $counter = 1;
78 while ( $limit ) {
79 if ( 0 == $count ) { break; }
80 $obj = $dbr->fetchObject( $res );
81 --$count;
82
83 $rc = RecentChange::newFromCurRow( $obj );
84 $rc->counter = $counter++;
85 $s .= $sk->recentChangesLine( $rc );
86 --$limit;
87 }
88 $s .= $sk->endRecentChangesList();
89
90 $dbr->freeResult( $res );
91 $wgOut->addHTML( $s );
92 }
93
94 ?>