diff options
author | Pierre Schmitz <pierre@archlinux.de> | 2006-10-11 18:12:39 +0000 |
---|---|---|
committer | Pierre Schmitz <pierre@archlinux.de> | 2006-10-11 18:12:39 +0000 |
commit | 183851b06bd6c52f3cae5375f433da720d410447 (patch) | |
tree | a477257decbf3360127f6739c2f9d0ec57a03d39 /includes/SpecialRecentchangeslinked.php |
MediaWiki 1.7.1 wiederhergestellt
Diffstat (limited to 'includes/SpecialRecentchangeslinked.php')
-rw-r--r-- | includes/SpecialRecentchangeslinked.php | 173 |
1 files changed, 173 insertions, 0 deletions
diff --git a/includes/SpecialRecentchangeslinked.php b/includes/SpecialRecentchangeslinked.php new file mode 100644 index 00000000..2a611c4d --- /dev/null +++ b/includes/SpecialRecentchangeslinked.php @@ -0,0 +1,173 @@ +<?php +/** + * This is to display changes made to all articles linked in an article. + * @package MediaWiki + * @subpackage SpecialPage + */ + +/** + * + */ +require_once( 'SpecialRecentchanges.php' ); + +/** + * Entrypoint + * @param string $par parent page we will look at + */ +function wfSpecialRecentchangeslinked( $par = NULL ) { + global $wgUser, $wgOut, $wgLang, $wgContLang, $wgRequest; + $fname = 'wfSpecialRecentchangeslinked'; + + $days = $wgRequest->getInt( 'days' ); + $target = isset($par) ? $par : $wgRequest->getText( 'target' ); + $hideminor = $wgRequest->getBool( 'hideminor' ) ? 1 : 0; + + $wgOut->setPagetitle( wfMsg( 'recentchangeslinked' ) ); + $sk = $wgUser->getSkin(); + + # Validate the title + $nt = Title::newFromURL( $target ); + if( !is_object( $nt ) ) { + $wgOut->errorPage( 'notargettitle', 'notargettext' ); + return; + } + + # Check for existence + # Do a quiet redirect back to the page itself if it doesn't + if( !$nt->exists() ) { + $wgOut->redirect( $nt->getLocalUrl() ); + return; + } + + $id = $nt->getArticleId(); + + $wgOut->setSubtitle( htmlspecialchars( wfMsg( 'rclsub', $nt->getPrefixedText() ) ) ); + + if ( ! $days ) { + $days = $wgUser->getOption( 'rcdays' ); + if ( ! $days ) { $days = 7; } + } + $days = (int)$days; + list( $limit, $offset ) = wfCheckLimits( 100, 'rclimit' ); + + $dbr =& wfGetDB( DB_SLAVE ); + $cutoff = $dbr->timestamp( time() - ( $days * 86400 ) ); + + $hideminor = ($hideminor ? 1 : 0); + if ( $hideminor ) { + $mlink = $sk->makeKnownLink( $wgContLang->specialPage( 'Recentchangeslinked' ), + wfMsg( 'show' ), 'target=' . htmlspecialchars( $nt->getPrefixedURL() ) . + "&days={$days}&limit={$limit}&hideminor=0" ); + } else { + $mlink = $sk->makeKnownLink( $wgContLang->specialPage( "Recentchangeslinked" ), + wfMsg( "hide" ), "target=" . htmlspecialchars( $nt->getPrefixedURL() ) . + "&days={$days}&limit={$limit}&hideminor=1" ); + } + if ( $hideminor ) { + $cmq = 'AND rc_minor=0'; + } else { $cmq = ''; } + + extract( $dbr->tableNames( 'recentchanges', 'categorylinks', 'pagelinks', 'revision', 'page' , "watchlist" ) ); + + $uid = $wgUser->getID(); + + // If target is a Category, use categorylinks and invert from and to + if( $nt->getNamespace() == NS_CATEGORY ) { + $catkey = $dbr->addQuotes( $nt->getDBKey() ); + $sql = "SELECT /* wfSpecialRecentchangeslinked */ + rc_id, + rc_cur_id, + rc_namespace, + rc_title, + rc_this_oldid, + rc_last_oldid, + rc_user, + rc_comment, + rc_user_text, + rc_timestamp, + rc_minor, + rc_bot, + rc_new, + rc_patrolled, + rc_type +" . ($uid ? ",wl_user" : "") . " + FROM $categorylinks, $recentchanges +" . ($uid ? "LEFT OUTER JOIN $watchlist ON wl_user={$uid} AND wl_title=rc_title AND wl_namespace=rc_namespace " : "") . " + WHERE rc_timestamp > '{$cutoff}' + {$cmq} + AND cl_from=rc_cur_id + AND cl_to=$catkey + GROUP BY rc_cur_id,rc_namespace,rc_title, + rc_user,rc_comment,rc_user_text,rc_timestamp,rc_minor, + rc_new + ORDER BY rc_timestamp DESC + LIMIT {$limit}; + "; + } else { + $sql = +"SELECT /* wfSpecialRecentchangeslinked */ + rc_id, + rc_cur_id, + rc_namespace, + rc_title, + rc_user, + rc_comment, + rc_user_text, + rc_this_oldid, + rc_last_oldid, + rc_timestamp, + rc_minor, + rc_bot, + rc_new, + rc_patrolled, + rc_type +" . ($uid ? ",wl_user" : "") . " + FROM $pagelinks, $recentchanges +" . ($uid ? " LEFT OUTER JOIN $watchlist ON wl_user={$uid} AND wl_title=rc_title AND wl_namespace=rc_namespace " : "") . " + WHERE rc_timestamp > '{$cutoff}' + {$cmq} + AND pl_namespace=rc_namespace + AND pl_title=rc_title + AND pl_from=$id +GROUP BY rc_cur_id,rc_namespace,rc_title, + rc_user,rc_comment,rc_user_text,rc_timestamp,rc_minor, + rc_new +ORDER BY rc_timestamp DESC + LIMIT {$limit}"; + } + $res = $dbr->query( $sql, $fname ); + + $wgOut->addHTML("< ".$sk->makeKnownLinkObj($nt, "", "redirect=no" )."<br />\n"); + $note = wfMsg( "rcnote", $limit, $days, $wgLang->timeAndDate( wfTimestampNow(), true ) ); + $wgOut->addHTML( "<hr />\n{$note}\n<br />" ); + + $note = rcDayLimitlinks( $days, $limit, "Recentchangeslinked", + "target=" . $nt->getPrefixedURL() . "&hideminor={$hideminor}", + false, $mlink ); + + $wgOut->addHTML( $note."\n" ); + + $list = ChangesList::newFromUser( $wgUser ); + $s = $list->beginRecentChangesList(); + $count = $dbr->numRows( $res ); + + $counter = 1; + while ( $limit ) { + if ( 0 == $count ) { break; } + $obj = $dbr->fetchObject( $res ); + --$count; +# print_r ( $obj ) ; +# print "<br/>\n" ; + + $rc = RecentChange::newFromRow( $obj ); + $rc->counter = $counter++; + $s .= $list->recentChangesLine( $rc , !empty( $obj->wl_user) ); + --$limit; + } + $s .= $list->endRecentChangesList(); + + $dbr->freeResult( $res ); + $wgOut->addHTML( $s ); +} + +?> |