specialwatchlist.php

来自「php 开发的内容管理系统」· PHP 代码 · 共 514 行 · 第 1/2 页

PHP
514
字号
<?php/** * * @package MediaWiki * @subpackage SpecialPage *//** * */require_once( 'SpecialRecentchanges.php' );/** * Constructor * @todo Document $par parameter. * @param $par String: FIXME */function wfSpecialWatchlist( $par ) {	global $wgUser, $wgOut, $wgLang, $wgMemc, $wgRequest, $wgContLang;	global $wgUseWatchlistCache, $wgWLCacheTimeout, $wgDBname;	global $wgRCShowWatchingUsers, $wgEnotifWatchlist, $wgShowUpdatedMarker;	global $wgEnotifWatchlist;	$fname = 'wfSpecialWatchlist';	$skin =& $wgUser->getSkin();	$specialTitle = Title::makeTitle( NS_SPECIAL, 'Watchlist' );	$wgOut->setRobotPolicy( 'noindex,nofollow' );	# Anons don't get a watchlist	if( $wgUser->isAnon() ) {		$wgOut->setPageTitle( wfMsg( 'watchnologin' ) );		$llink = $skin->makeKnownLinkObj( Title::makeTitle( NS_SPECIAL, 'Userlogin' ), wfMsgHtml( 'loginreqlink' ), 'returnto=' . $specialTitle->getPrefixedUrl() );		$wgOut->addHtml( wfMsgWikiHtml( 'watchlistanontext', $llink ) );		return;	} else {		$wgOut->setPageTitle( wfMsg( 'watchlist' ) );		$wgOut->setSubtitle( wfMsgWikiHtml( 'watchlistfor', htmlspecialchars( $wgUser->getName() ) ) );	}	if( wlHandleClear( $wgOut, $wgRequest, $par ) ) {		return;	}	$defaults = array(	/* float */ 'days' => floatval( $wgUser->getOption( 'watchlistdays' ) ), /* 3.0 or 0.5, watch further below */	/* bool  */ 'hideOwn' => (int)$wgUser->getBoolOption( 'watchlisthideown' ),	/* bool  */ 'hideBots' => (int)$wgUser->getBoolOption( 'watchlisthidebots' ),	/* ?     */ 'namespace' => 'all',	);	extract($defaults);	# Extract variables from the request, falling back to user preferences or	# other default values if these don't exist	$prefs['days'    ] = floatval( $wgUser->getOption( 'watchlistdays' ) );	$prefs['hideown' ] = $wgUser->getBoolOption( 'watchlisthideown' );	$prefs['hidebots'] = $wgUser->getBoolOption( 'watchlisthidebots' );	# Get query variables	$days = $wgRequest->getVal( 'days', $prefs['days'] );	$hideOwn = $wgRequest->getBool( 'hideOwn', $prefs['hideown'] );	$hideBots = $wgRequest->getBool( 'hideBots', $prefs['hidebots'] );		# Get namespace value, if supplied, and prepare a WHERE fragment	$nameSpace = $wgRequest->getIntOrNull( 'namespace' );	if( !is_null( $nameSpace ) ) {		$nameSpace = intval( $nameSpace );		$nameSpaceClause = " AND rc_namespace = $nameSpace";	} else {		$nameSpace = '';		$nameSpaceClause = '';	}	# Watchlist editing	$action = $wgRequest->getVal( 'action' );	$remove = $wgRequest->getVal( 'remove' );	$id = $wgRequest->getArray( 'id' );	$uid = $wgUser->getID();	if( $wgEnotifWatchlist && $wgRequest->getVal( 'reset' ) && $wgRequest->wasPosted() ) {		$wgUser->clearAllNotifications( $uid );	}  # Deleting items from watchlist	if(($action == 'submit') && isset($remove) && is_array($id)) {		$wgOut->addWikiText( wfMsg( 'removingchecked' ) );		$wgOut->addHTML( '<p>' );		foreach($id as $one) {			$t = Title::newFromURL( $one );			if( !is_null( $t ) ) {				$wl = WatchedItem::fromUserTitle( $wgUser, $t );				if( $wl->removeWatch() === false ) {					$wgOut->addHTML( "<br />\n" . wfMsg( 'couldntremove', htmlspecialchars($one) ) );				} else {					wfRunHooks('UnwatchArticle', array(&$wgUser, new Article($t)));					$wgOut->addHTML( ' (' . htmlspecialchars($one) . ')' );				}			} else {				$wgOut->addHTML( "<br />\n" . wfMsg( 'iteminvalidname', htmlspecialchars($one) ) );			}		}		$wgOut->addHTML( "<br />\n" . wfMsg( 'wldone' ) . "</p>\n" );	}	if ( $wgUseWatchlistCache ) {		$memckey = "$wgDBname:watchlist:id:" . $wgUser->getId();		$cache_s = @$wgMemc->get( $memckey );		if( $cache_s ){			$wgOut->addWikiText( wfMsg('wlsaved') );			$wgOut->addHTML( $cache_s );			return;		}	}	$dbr =& wfGetDB( DB_SLAVE );	extract( $dbr->tableNames( 'page', 'revision', 'watchlist', 'recentchanges' ) );	$sql = "SELECT COUNT(*) AS n FROM $watchlist WHERE wl_user=$uid";	$res = $dbr->query( $sql, $fname );	$s = $dbr->fetchObject( $res );	#	Patch *** A1 *** (see A2 below)#	adjust for page X, talk:page X, which are both stored separately, but treated together	$nitems = floor($s->n / 2);#	$nitems = $s->n;	if($nitems == 0) {		$wgOut->addWikiText( wfMsg( 'nowatchlist' ) );		return;	}	if( is_null($days) || !is_numeric($days) ) {		$big = 1000; /* The magical big */		if($nitems > $big) {			# Set default cutoff shorter			$days = $defaults['days'] = (12.0 / 24.0); # 12 hours...		} else {			$days = $defaults['days']; # default cutoff for shortlisters		}	} else {		$days = floatval($days);	}	// Dump everything here	$nondefaults = array();	wfAppendToArrayIfNotDefault( 'days', $days, $defaults, $nondefaults);	wfAppendToArrayIfNotDefault( 'hideOwn', (int)$hideOwn, $defaults, $nondefaults);	wfAppendToArrayIfNotDefault( 'hideBots', (int)$hideBots, $defaults, $nondefaults);	wfAppendToArrayIfNotDefault( 'namespace', $nameSpace, $defaults, $nondefaults );	if ( $days <= 0 ) {		$docutoff = '';		$cutoff = false;		$npages = wfMsg( 'watchlistall1' );	} else {	        $docutoff = "AND rev_timestamp > '" .		  ( $cutoff = $dbr->timestamp( time() - intval( $days * 86400 ) ) )		  . "'";	          /*	          $sql = "SELECT COUNT(*) AS n FROM $page, $revision  WHERE rev_timestamp>'$cutoff' AND page_id=rev_page";	          $res = $dbr->query( $sql, $fname );	          $s = $dbr->fetchObject( $res );	          $npages = $s->n;	          */	          $npages = 40000 * $days;	}	/* Edit watchlist form */	if($wgRequest->getBool('edit') || $par == 'edit' ) {		$wgOut->addWikiText( wfMsg( 'watchlistcontains', $wgLang->formatNum( $nitems ) ) .			"\n\n" . wfMsg( 'watcheditlist' ) );		$wgOut->addHTML( '<form action=\'' .			$specialTitle->escapeLocalUrl( 'action=submit' ) .			"' method='post'>\n" );#		Patch A2#		The following was proposed by KTurner 07.11.2004 to T.Gries#		$sql = "SELECT distinct (wl_namespace & ~1),wl_title FROM $watchlist WHERE wl_user=$uid";		$sql = "SELECT wl_namespace, wl_title, page_is_redirect FROM $watchlist LEFT JOIN $page ON wl_namespace = page_namespace AND wl_title = page_title WHERE wl_user=$uid";		$res = $dbr->query( $sql, $fname );				# Batch existence check		$linkBatch = new LinkBatch();		while( $row = $dbr->fetchObject( $res ) )			$linkBatch->addObj( Title::makeTitleSafe( $row->wl_namespace, $row->wl_title ) );		$linkBatch->execute();		if( $dbr->numRows( $res ) > 0 )			$dbr->dataSeek( $res, 0 ); # Let's do the time warp again!				$sk = $wgUser->getSkin();		$list = array();		while( $s = $dbr->fetchObject( $res ) ) {			$list[$s->wl_namespace][$s->wl_title] = $s->page_is_redirect;		}		// TODO: Display a TOC		foreach($list as $ns => $titles) {			if (Namespace::isTalk($ns))				continue;			if ($ns != NS_MAIN)				$wgOut->addHTML( '<h2>' . $wgContLang->getFormattedNsText( $ns ) . '</h2>' );			$wgOut->addHTML( '<ul>' );			foreach( $titles as $title => $redir ) {				$titleObj = Title::makeTitle( $ns, $title );				if( is_null( $titleObj ) ) {					$wgOut->addHTML(						'<!-- bad title "' .						htmlspecialchars( $s->wl_title ) . '" in namespace ' . $s->wl_namespace . " -->\n"					);				} else {					global $wgContLang;					$toolLinks = array();					$titleText = $titleObj->getPrefixedText();					$pageLink = $sk->makeLinkObj( $titleObj );					$toolLinks[] = $sk->makeLinkObj( $titleObj->getTalkPage(), $wgLang->getNsText( NS_TALK ) );					if( $titleObj->exists() )						$toolLinks[] = $sk->makeKnownLinkObj( $titleObj, wfMsgHtml( 'history_short' ), 'action=history' );					$toolLinks = '(' . implode( ' | ', $toolLinks ) . ')';					$checkbox = '<input type="checkbox" name="id[]" value="' . htmlspecialchars( $titleObj->getPrefixedText() ) . '" /> ' . ( $wgContLang->isRTL() ? '&rlm;' : '&lrm;' );					if( $redir ) {						$spanopen = '<span class="watchlistredir">';						$spanclosed = '</span>';					} else {						$spanopen = $spanclosed = '';					}										$wgOut->addHTML( "<li>{$checkbox}{$spanopen}{$pageLink}{$spanclosed} {$toolLinks}</li>\n" );				}			}			$wgOut->addHTML( '</ul>' );		}		$wgOut->addHTML(			"<input type='submit' name='remove' value=\"" .			htmlspecialchars( wfMsg( "removechecked" ) ) . "\" />\n" .			"</form>\n"		);		return;	}	# If the watchlist is relatively short, it's simplest to zip	# down its entirety and then sort the results.	# If it's relatively long, it may be worth our while to zip	# through the time-sorted page list checking for watched items.	# Up estimate of watched items by 15% to compensate for talk pages...	# Toggles	$andHideOwn = $hideOwn ? "AND (rc_user <> $uid)" : '';	$andHideBots = $hideBots ? "AND (rc_bot = 0)" : '';

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?