revision.php

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

PHP
800
字号
	 */	function getRawComment() {		return $this->mComment;	}	/**	 * @return bool	 */	function isMinor() {		return (bool)$this->mMinorEdit;	}	/**	 * int $field one of DELETED_* bitfield constants	 * @return bool	 */	function isDeleted( $field ) {		return ($this->mDeleted & $field) == $field;	}	/**	 * Fetch revision text if it's available to all users	 * @return string	 */	function getText() {		if( $this->isDeleted( self::DELETED_TEXT ) ) {			return "";		} else {			return $this->getRawText();		}	}		/**	 * Fetch revision text without regard for view restrictions	 * @return string	 */	function getRawText() {		if( is_null( $this->mText ) ) {			// Revision text is immutable. Load on demand:			$this->mText = $this->loadText();		}		return $this->mText;	}	/**	 * @return string	 */	function getTimestamp() {		return wfTimestamp(TS_MW, $this->mTimestamp);	}	/**	 * @return bool	 */	function isCurrent() {		return $this->mCurrent;	}	/**	 * @return Revision	 */	function getPrevious() {		$prev = $this->mTitle->getPreviousRevisionID( $this->mId );		if ( $prev ) {			return Revision::newFromTitle( $this->mTitle, $prev );		} else {			return null;		}	}	/**	 * @return Revision	 */	function getNext() {		$next = $this->mTitle->getNextRevisionID( $this->mId );		if ( $next ) {			return Revision::newFromTitle( $this->mTitle, $next );		} else {			return null;		}	}	/**#@-*/	/**	  * Get revision text associated with an old or archive row	  * $row is usually an object from wfFetchRow(), both the flags and the text	  * field must be included	  * @static	  * @param integer $row Id of a row	  * @param string $prefix table prefix (default 'old_')	  * @return string $text|false the text requested	  */	function getRevisionText( $row, $prefix = 'old_' ) {		$fname = 'Revision::getRevisionText';		wfProfileIn( $fname );		# Get data		$textField = $prefix . 'text';		$flagsField = $prefix . 'flags';		if( isset( $row->$flagsField ) ) {			$flags = explode( ',', $row->$flagsField );		} else {			$flags = array();		}		if( isset( $row->$textField ) ) {			$text = $row->$textField;		} else {			wfProfileOut( $fname );			return false;		}		# Use external methods for external objects, text in table is URL-only then		if ( in_array( 'external', $flags ) ) {			$url=$text;			@list($proto,$path)=explode('://',$url,2);			if ($path=="") {				wfProfileOut( $fname );				return false;			}			require_once('ExternalStore.php');			$text=ExternalStore::fetchFromURL($url);		}		// If the text was fetched without an error, convert it		if ( $text !== false ) {			if( in_array( 'gzip', $flags ) ) {				# Deal with optional compression of archived pages.				# This can be done periodically via maintenance/compressOld.php, and				# as pages are saved if $wgCompressRevisions is set.				$text = gzinflate( $text );			}			if( in_array( 'object', $flags ) ) {				# Generic compressed storage				$obj = unserialize( $text );				if ( !is_object( $obj ) ) {					// Invalid object					wfProfileOut( $fname );					return false;				}				$text = $obj->getText();			}			global $wgLegacyEncoding;			if( $wgLegacyEncoding && !in_array( 'utf-8', $flags ) ) {				# Old revisions kept around in a legacy encoding?				# Upconvert on demand.				global $wgInputEncoding, $wgContLang;				$text = $wgContLang->iconv( $wgLegacyEncoding, $wgInputEncoding . '//IGNORE', $text );			}		}		wfProfileOut( $fname );		return $text;	}	/**	 * If $wgCompressRevisions is enabled, we will compress data.	 * The input string is modified in place.	 * Return value is the flags field: contains 'gzip' if the	 * data is compressed, and 'utf-8' if we're saving in UTF-8	 * mode.	 *	 * @static	 * @param mixed $text reference to a text	 * @return string	 */	function compressRevisionText( &$text ) {		global $wgCompressRevisions;		$flags = array();		# Revisions not marked this way will be converted		# on load if $wgLegacyCharset is set in the future.		$flags[] = 'utf-8';		if( $wgCompressRevisions ) {			if( function_exists( 'gzdeflate' ) ) {				$text = gzdeflate( $text );				$flags[] = 'gzip';			} else {				wfDebug( "Revision::compressRevisionText() -- no zlib support, not compressing\n" );			}		}		return implode( ',', $flags );	}	/**	 * Insert a new revision into the database, returning the new revision ID	 * number on success and dies horribly on failure.	 *	 * @param Database $dbw	 * @return int	 */	function insertOn( &$dbw ) {		global $wgDefaultExternalStore;				$fname = 'Revision::insertOn';		wfProfileIn( $fname );		$data = $this->mText;		$flags = Revision::compressRevisionText( $data );		# Write to external storage if required		if ( $wgDefaultExternalStore ) {			if ( is_array( $wgDefaultExternalStore ) ) {				// Distribute storage across multiple clusters				$store = $wgDefaultExternalStore[mt_rand(0, count( $wgDefaultExternalStore ) - 1)];			} else {				$store = $wgDefaultExternalStore;			}			require_once('ExternalStore.php');			// Store and get the URL			$data = ExternalStore::insert( $store, $data );			if ( !$data ) {				# This should only happen in the case of a configuration error, where the external store is not valid				throw new MWException( "Unable to store text to external storage $store" );			}			if ( $flags ) {				$flags .= ',';			}			$flags .= 'external';		}		# Record the text (or external storage URL) to the text table		if( !isset( $this->mTextId ) ) {			$old_id = $dbw->nextSequenceValue( 'text_old_id_val' );			$dbw->insert( 'text',				array(					'old_id'    => $old_id,					'old_text'  => $data,					'old_flags' => $flags,				), $fname			);			$this->mTextId = $dbw->insertId();		}		# Record the edit in revisions		$rev_id = isset( $this->mId )			? $this->mId			: $dbw->nextSequenceValue( 'rev_rev_id_val' );		$dbw->insert( 'revision',			array(				'rev_id'         => $rev_id,				'rev_page'       => $this->mPage,				'rev_text_id'    => $this->mTextId,				'rev_comment'    => $this->mComment,				'rev_minor_edit' => $this->mMinorEdit ? 1 : 0,				'rev_user'       => $this->mUser,				'rev_user_text'  => $this->mUserText,				'rev_timestamp'  => $dbw->timestamp( $this->mTimestamp ),				'rev_deleted'    => $this->mDeleted,			), $fname		);		$this->mId = !is_null($rev_id) ? $rev_id : $dbw->insertId();		wfProfileOut( $fname );		return $this->mId;	}	/**	 * Lazy-load the revision's text.	 * Currently hardcoded to the 'text' table storage engine.	 *	 * @return string	 * @access private	 */	function loadText() {		$fname = 'Revision::loadText';		wfProfileIn( $fname );		$dbr =& wfGetDB( DB_SLAVE );		$row = $dbr->selectRow( 'text',			array( 'old_text', 'old_flags' ),			array( 'old_id' => $this->getTextId() ),			$fname);		if( !$row ) {			$dbw =& wfGetDB( DB_MASTER );			$row = $dbw->selectRow( 'text',				array( 'old_text', 'old_flags' ),				array( 'old_id' => $this->getTextId() ),				$fname);		}		$text = Revision::getRevisionText( $row );		wfProfileOut( $fname );		return $text;	}	/**	 * Create a new null-revision for insertion into a page's	 * history. This will not re-save the text, but simply refer	 * to the text from the previous version.	 *	 * Such revisions can for instance identify page rename	 * operations and other such meta-modifications.	 *	 * @param Database $dbw	 * @param int      $pageId ID number of the page to read from	 * @param string   $summary	 * @param bool     $minor	 * @return Revision	 */	function newNullRevision( &$dbw, $pageId, $summary, $minor ) {		$fname = 'Revision::newNullRevision';		wfProfileIn( $fname );		$current = $dbw->selectRow(			array( 'page', 'revision' ),			array( 'page_latest', 'rev_text_id' ),			array(				'page_id' => $pageId,				'page_latest=rev_id',				),			$fname );		if( $current ) {			$revision = new Revision( array(				'page'       => $pageId,				'comment'    => $summary,				'minor_edit' => $minor,				'text_id'    => $current->rev_text_id,				) );		} else {			$revision = null;		}		wfProfileOut( $fname );		return $revision;	}		/**	 * Determine if the current user is allowed to view a particular	 * field of this revision, if it's marked as deleted.	 * @param int $field one of self::DELETED_TEXT,	 *                          self::DELETED_COMMENT,	 *                          self::DELETED_USER	 * @return bool	 */	function userCan( $field ) {		if( ( $this->mDeleted & $field ) == $field ) {			global $wgUser;			$permission = ( $this->mDeleted & self::DELETED_RESTRICTED ) == self::DELETED_RESTRICTED				? 'hiderevision'				: 'deleterevision';			wfDebug( "Checking for $permission due to $field match on $this->mDeleted\n" );			return $wgUser->isAllowed( $permission );		} else {			return true;		}	}	/**	 * Get rev_timestamp from rev_id, without loading the rest of the row	 * @param integer $id	 */	static function getTimestampFromID( $id ) {		$timestamp = $dbr->selectField( 'revision', 'rev_timestamp', 			array( 'rev_id' => $id ), __METHOD__ );		if ( $timestamp === false ) {			# Not in slave, try master			$dbw =& wfGetDB( DB_MASTER );			$timestamp = $dbw->selectField( 'revision', 'rev_timestamp', 				array( 'rev_id' => $id ), __METHOD__ );		}		return $timestamp;	}		static function countByPageId( $db, $id ) {		$row = $db->selectRow( 'revision', 'COUNT(*) AS revCount',			array( 'rev_page' => $id ), __METHOD__ );		if( $row ) {			return $row->revCount;		}		return 0;	}		static function countByTitle( $db, $title ) {		$id = $title->getArticleId();		if( $id ) {			return Revision::countByPageId( $db, $id );		}		return 0;	}}/** * Aliases for backwards compatibility with 1.6 */define( 'MW_REV_DELETED_TEXT', Revision::DELETED_TEXT );define( 'MW_REV_DELETED_COMMENT', Revision::DELETED_COMMENT );define( 'MW_REV_DELETED_USER', Revision::DELETED_USER );define( 'MW_REV_DELETED_RESTRICTED', Revision::DELETED_RESTRICTED );?>

⌨️ 快捷键说明

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