MediaWiki
REL1_19
|
Class representing a MediaWiki article and history. More...
Public Member Functions | |
__construct (Title $title) | |
Constructor and clear the article. | |
checkFlags ($flags) | |
Check flags and add EDIT_NEW or EDIT_UPDATE to them as needed. | |
checkTouched () | |
Loads page_touched and returns a value indicating if it should be used. | |
clear () | |
Clear the object. | |
commitRollback ($fromP, $summary, $bot, &$resultDetails, User $guser) | |
Backend implementation of doRollback(), please refer there for parameter and return value documentation. | |
createUpdates ($rev) | |
Perform article updates on a special page creation. | |
doCascadeProtectionUpdates (ParserOutput $parserOutput) | |
Updates cascading protections. | |
doDeleteArticle ($reason, $suppress=false, $id=0, $commit=true, &$error= '', User $user=null) | |
Same as doDeleteArticleReal(), but returns more detailed success/failure status Deletes the article with database consistency, writes logs, purges caches. | |
doDeleteArticleReal ($reason, $suppress=false, $id=0, $commit=true, &$error= '', User $user=null) | |
Back-end article deletion Deletes the article with database consistency, writes logs, purges caches. | |
doDeleteUpdates ($id) | |
Do some database updates after deletion. | |
doEdit ($text, $summary, $flags=0, $baseRevId=false, $user=null) | |
Change an existing article or create a new article. | |
doEditUpdates (Revision $revision, User $user, array $options=array()) | |
Do standard deferred updates after page edit. | |
doPurge () | |
Perform the actions of a page purging. | |
doQuickEdit ($text, User $user, $comment= '', $minor=0) | |
Edit an article without doing all that other stuff The article must already exist; link tables etc are not updated, caches are not flushed. | |
doRollback ($fromP, $summary, $token, $bot, &$resultDetails, User $user) | |
Roll back the most recent consecutive set of edits to a page from the same user; fails if there are no eligible edits to roll back to, e.g. | |
doUpdateRestrictions (array $limit, array $expiry, &$cascade, $reason, User $user) | |
Update the article's restriction field, and leave a log entry. | |
doViewUpdates (User $user) | |
Do standard deferred updates after page view. | |
estimateRevisionCount () | |
Get the approximate revision count of this page. | |
exists () | |
followRedirect () | |
Get the Title object or URL this page redirects to. | |
getActionOverrides () | |
Returns overrides for action handlers. | |
getAutoDeleteReason (&$hasHistory) | |
Auto-generates a deletion reason. | |
getComment ($audience=Revision::FOR_PUBLIC) | |
getContributors () | |
Get a list of users who have edited this article, not including the user who made the most recent revision, which you can get from $article->getUser() if you want it. | |
getCount () | |
getHiddenCategories () | |
#@- | |
getId () | |
getLastNAuthors ($num, $revLatest=0) | |
Get the last N authors. | |
getLatest () | |
Get the page_latest field. | |
getMinorEdit () | |
Returns true if last revision was marked as "minor edit". | |
getParserOutput (ParserOptions $parserOptions, $oldid=null) | |
Get a ParserOutput for the given ParserOptions and revision ID. | |
getRawText () | |
Get the text of the current revision. | |
getRedirectTarget () | |
If this page is a redirect, get its target. | |
getRedirectURL ($rt) | |
Get the Title object or URL to use for a redirect. | |
getRevision () | |
Get the latest revision. | |
getText ($audience=Revision::FOR_PUBLIC) | |
Get the text of the current revision. | |
getTimestamp () | |
getTitle () | |
Get the title object of the article. | |
getTouched () | |
Get the page_touched field. | |
getUndoText (Revision $undo, Revision $undoafter=null) | |
Get the text that needs to be saved in order to undo all revisions between $undo and $undoafter. | |
getUsedTemplates () | |
Return a list of templates used by this article. | |
getUser ($audience=Revision::FOR_PUBLIC) | |
getUserText ($audience=Revision::FOR_PUBLIC) | |
hasViewableContent () | |
Check if this page is something we're going to be showing some sort of sensible content for. | |
insertOn ($dbw) | |
Insert a new empty page record for this article. | |
insertRedirect () | |
Insert an entry for this page into the redirect table. | |
insertRedirectEntry ($rt) | |
Insert or update the redirect table entry for this page to indicate it redirects to $rt . | |
isBigDeletion () | |
Check whether the number of revisions of this page surpasses $wgDeleteRevisionsLimit. | |
isCountable ($editInfo=false) | |
Determine whether a page would be suitable for being counted as an article in the site_stats table based on the title & its content. | |
isParserCacheUsed (ParserOptions $parserOptions, $oldid) | |
Should the parser cache be used? | |
isRedirect ($text=false) | |
Tests if the article text represents a redirect. | |
loadPageData ($data= 'fromdb') | |
Set the general counter, title etc data loaded from some source. | |
makeParserOptions ($user) | |
Get parser options suitable for rendering the primary article wikitext. | |
pageDataFromId ($dbr, $id) | |
Fetch a page record matching the requested ID. | |
pageDataFromTitle ($dbr, $title) | |
Fetch a page record matching the Title object's namespace and title using a sanitized title string. | |
prepareTextForEdit ($text, $revid=null, User $user=null) | |
Prepare text which is about to be saved. | |
preSaveTransform ($text, User $user=null, ParserOptions $popts=null) | |
This function is called right before saving the wikitext, so we can do things like signatures and links-in-context. | |
quickEdit ($text, $comment= '', $minor=0) | |
replaceSection ($section, $text, $sectionTitle= '', $edittime=null) | |
setCachedLastEditTime ($timestamp) | |
Set the cached timestamp for the last time the page changed. | |
setTimestamp ($ts) | |
Set the page timestamp (use only to avoid DB queries) | |
updateCategoryCounts ($added, $deleted) | |
Update all the appropriate counts in the category table, given that we've added the categories $added and deleted the categories $deleted. | |
updateIfNewerOn ($dbw, $revision) | |
If the given revision is newer than the currently set page_latest, update the page record. | |
updateRedirectOn ($dbw, $redirectTitle, $lastRevIsRedirect=null) | |
Add row to the redirect table if this is a redirect, remove otherwise. | |
updateRestrictions ($limit=array(), $reason= '', &$cascade=0, $expiry=array(), User $user=null) | |
Update the article's restriction field, and leave a log entry. | |
updateRevisionOn ($dbw, $revision, $lastRevision=null, $lastRevIsRedirect=null) | |
Update the page record to point to a newly saved revision. | |
useParserCache ($oldid) | |
viewUpdates () | |
Static Public Member Functions | |
static | factory (Title $title) |
Create a WikiPage object of the appropriate class for the given title. | |
static | getAutosummary ($oldtext, $newtext, $flags) |
Return an applicable autosummary if one exists for the given edit. | |
static | newFromID ($id) |
Constructor from a page id. | |
static | onArticleCreate ($title) |
The onArticle*() functions are supposed to be a kind of hooks which should be called whenever any of the specified actions are done. | |
static | onArticleDelete ($title) |
Clears caches when article is deleted. | |
static | onArticleEdit ($title) |
Purge caches on page update etc. | |
static | selectFields () |
Return the list of revision fields that should be selected to create a new page. | |
Public Attributes | |
$mTitle = null | |
const | DELETE_HOOK_ABORTED = -1 |
Delete operation aborted by hook. | |
const | DELETE_NO_PAGE = 1 |
Page not found. | |
const | DELETE_NO_REVISIONS = 2 |
No revisions found to delete. | |
const | DELETE_SUCCESS = 0 |
Deletion successful. | |
$mDataLoaded = false | |
$mIsRedirect = false | |
$mLatest = false | |
$mPreparedEdit = false | |
Protected Member Functions | |
getCachedLastEditTime () | |
Get the cached timestamp for the last time the page changed. | |
loadLastEdit () | |
Loads everything except the text This isn't necessary for all uses, so it's only done if needed. | |
pageData ($dbr, $conditions) | |
Fetch a page record with the given conditions. | |
setLastEdit (Revision $revision) | |
Set the latest revision. | |
Static Protected Member Functions | |
static | flattenRestrictions ($limit) |
Take an array of page restrictions and flatten it to a string suitable for insertion into the page_restrictions field. | |
Protected Attributes | |
$mCounter = null | |
$mLastRevision = null | |
$mRedirectTarget = null | |
$mTimestamp = '' | |
$mTouched = '19700101000000' |
Class representing a MediaWiki article and history.
Some fields are public only for backwards-compatibility. Use accessors. In the past, this class was part of Article.php and everything was public.
Definition at line 15 of file WikiPage.php.
WikiPage::__construct | ( | Title $ | title | ) |
WikiPage::checkFlags | ( | $ | flags | ) |
Check flags and add EDIT_NEW or EDIT_UPDATE to them as needed.
$flags | Int |
Definition at line 1186 of file WikiPage.php.
Referenced by doEdit().
Loads page_touched and returns a value indicating if it should be used.
Definition at line 341 of file WikiPage.php.
References loadPageData().
WikiPage::clear | ( | ) |
Clear the object.
Definition at line 156 of file WikiPage.php.
Referenced by doPurge().
WikiPage::commitRollback | ( | $ | fromP, |
$ | summary, | ||
$ | bot, | ||
&$ | resultDetails, | ||
User $ | guser | ||
) |
Backend implementation of doRollback(), please refer there for parameter and return value documentation.
NOTE: This function does NOT check ANY permissions, it just commits the rollback to the DB. Therefore, you should only call this function direct- ly if you want to use custom permissions checks. If you don't, use doRollback() instead.
$fromP | String: Name of the user whose edits to rollback. |
$summary | String: Custom summary. Set to default summary if empty. |
$bot | Boolean: If true, mark all reverted edits as bot. |
$resultDetails | Array: contains result-specific array of additional values |
$guser | User The user performing the rollback |
Definition at line 2173 of file WikiPage.php.
References $wgContLang, $wgUseRCPatrol, Revision\DELETED_TEXT, Revision\DELETED_USER, doEdit(), getRevision(), User\isAllowed(), User\isAllowedAny(), Revision\newFromId(), wfGetDB(), wfMsgForContent(), wfMsgReplaceArgs(), wfReadOnly(), wfRunHooks(), and wfTimestamp().
Referenced by doRollback().
WikiPage::createUpdates | ( | $ | rev | ) |
Perform article updates on a special page creation.
$rev | Revision object |
Definition at line 2701 of file WikiPage.php.
References $wgUser, doEditUpdates(), and wfDeprecated().
WikiPage::doCascadeProtectionUpdates | ( | ParserOutput $ | parserOutput | ) |
Updates cascading protections.
$parserOutput | ParserOutput object for the current version |
Definition at line 2634 of file WikiPage.php.
References $dbr, $res, ParserOutput\getTemplates(), wfGetDB(), and wfReadOnly().
WikiPage::doDeleteArticle | ( | $ | reason, |
$ | suppress = false , |
||
$ | id = 0 , |
||
$ | commit = true , |
||
&$ | error = '' , |
||
User $ | user = null |
||
) |
Same as doDeleteArticleReal(), but returns more detailed success/failure status Deletes the article with database consistency, writes logs, purges caches.
$reason | string delete reason for deletion log |
$suppress | bitfield Revision::DELETED_TEXT Revision::DELETED_COMMENT Revision::DELETED_USER Revision::DELETED_RESTRICTED |
$id | int article ID |
$commit | boolean defaults to true, triggers transaction end |
&$error | Array of errors to append to |
$user | User The deleting user |
Definition at line 1931 of file WikiPage.php.
References DELETE_SUCCESS, and doDeleteArticleReal().
WikiPage::doDeleteArticleReal | ( | $ | reason, |
$ | suppress = false , |
||
$ | id = 0 , |
||
$ | commit = true , |
||
&$ | error = '' , |
||
User $ | user = null |
||
) |
Back-end article deletion Deletes the article with database consistency, writes logs, purges caches.
$reason | string delete reason for deletion log |
$suppress | bitfield Revision::DELETED_TEXT Revision::DELETED_COMMENT Revision::DELETED_USER Revision::DELETED_RESTRICTED |
$id | int article ID |
$commit | boolean defaults to true, triggers transaction end |
&$error | Array of errors to append to |
$user | User The deleting user |
Definition at line 1954 of file WikiPage.php.
References $ok, $t, $user, $wgUser, DELETE_HOOK_ABORTED, DELETE_NO_PAGE, DELETE_NO_REVISIONS, DELETE_SUCCESS, Revision\DELETED_COMMENT, Revision\DELETED_RESTRICTED, Revision\DELETED_TEXT, Revision\DELETED_USER, doDeleteUpdates(), Title\GAID_FOR_UPDATE, wfDebug(), wfGetDB(), and wfRunHooks().
Referenced by doDeleteArticle().
WikiPage::doDeleteUpdates | ( | $ | id | ) |
Do some database updates after deletion.
$id | Int: page_id value of the page being deleted |
Definition at line 2054 of file WikiPage.php.
References $res, DeferredUpdates\addUpdate(), isCountable(), onArticleDelete(), updateCategoryCounts(), and wfGetDB().
Referenced by doDeleteArticleReal().
WikiPage::doEdit | ( | $ | text, |
$ | summary, | ||
$ | flags = 0 , |
||
$ | baseRevId = false , |
||
$ | user = null |
||
) |
Change an existing article or create a new article.
Updates RC and all necessary caches, optionally via the deferred update array.
$text | String: new text |
$summary | String: edit summary |
$flags | Integer bitfield: EDIT_NEW Article is known or assumed to be non-existent, create a new one EDIT_UPDATE Article is known or assumed to be pre-existing, update it EDIT_MINOR Mark this edit minor, if the user is allowed to do so EDIT_SUPPRESS_RC Do not log the change in recentchanges EDIT_FORCE_BOT Mark the edit a "bot" edit regardless of user rights EDIT_DEFER_UPDATES Defer some of the updates until the end of index.php EDIT_AUTOSUMMARY Fill in blank summaries with generated text where possible |
If neither EDIT_NEW nor EDIT_UPDATE is specified, the status of the article will be detected. If EDIT_UPDATE is specified and the article doesn't exist, the function will return an edit-gone-missing error. If EDIT_NEW is specified and the article does exist, an edit-already-exists error will be returned. These two conditions are also possible with auto-detection due to MediaWiki's performance-optimised locking strategy.
$baseRevId | the revision ID this edit was based off, if any |
$user | User the user doing the edit |
Extensions may define additional errors.
$return->value will contain an associative array with members as follows: new: Boolean indicating if the function attempted to create a new article revision: The revision object for the inserted revision, or null
Compatibility note: this function previously returned a boolean value indicating success/failure
Definition at line 1244 of file WikiPage.php.
References $changed, $ok, $user, $wgDBtransactions, $wgUseAutomaticEditSummaries, $wgUseNPPatrol, $wgUser, $wgUseRCPatrol, checkFlags(), doEditUpdates(), DeferredUpdates\doUpdates(), getAutosummary(), getId(), getLatest(), getRawText(), getTimestamp(), insertOn(), isCountable(), isRedirect(), loadPageData(), Status\newGood(), RecentChange\notifyEdit(), RecentChange\notifyNew(), prepareTextForEdit(), PatrolLog\record(), updateRevisionOn(), wfDebug(), wfGetDB(), wfProfileIn(), wfProfileOut(), wfRunHooks(), and wfTimestampNow().
Referenced by commitRollback().
WikiPage::doEditUpdates | ( | Revision $ | revision, |
User $ | user, | ||
array $ | options = array() |
||
) |
Do standard deferred updates after page edit.
Update links tables, site stats, search index and message cache. Purges pages that include this page if the text was changed here. Every 100th edit, prune the recent changes table.
$revision | Revision object |
$user | User object that did the revision |
$options | Array of options, following indexes are used:
|
Definition at line 1547 of file WikiPage.php.
References $options, $title, $total, $user, $wgEnableParserCache, $wgRCMaxAge, DeferredUpdates\addUpdate(), getId(), Revision\getId(), Revision\getText(), User\getTitleKey(), User\isAllowed(), isCountable(), User\isIP(), Revision\isMinor(), User\newFromName(), onArticleCreate(), onArticleEdit(), prepareTextForEdit(), ParserCache\singleton(), MessageCache\singleton(), wfDebug(), wfGetDB(), wfProfileIn(), wfProfileOut(), and wfRunHooks().
Referenced by createUpdates(), and doEdit().
Perform the actions of a page purging.
Reimplemented in WikiFilePage.
Definition at line 892 of file WikiPage.php.
References $wgUseSquid, clear(), getRawText(), SquidUpdate\newSimplePurge(), MessageCache\singleton(), wfGetDB(), and wfRunHooks().
WikiPage::doQuickEdit | ( | $ | text, |
User $ | user, | ||
$ | comment = '' , |
||
$ | minor = 0 |
||
) |
Edit an article without doing all that other stuff The article must already exist; link tables etc are not updated, caches are not flushed.
$text | String: text submitted |
$user | User The relevant user |
$comment | String: comment submitted |
$minor | Boolean: whereas it's a minor modification |
Definition at line 1665 of file WikiPage.php.
References $comment, getId(), Revision\insertOn(), updateRevisionOn(), wfGetDB(), wfProfileIn(), wfProfileOut(), and wfRunHooks().
Referenced by quickEdit().
WikiPage::doRollback | ( | $ | fromP, |
$ | summary, | ||
$ | token, | ||
$ | bot, | ||
&$ | resultDetails, | ||
User $ | user | ||
) |
Roll back the most recent consecutive set of edits to a page from the same user; fails if there are no eligible edits to roll back to, e.g.
user is the sole contributor. This function performs permissions checks on $user, then calls commitRollback() to do the dirty work
$fromP | String: Name of the user whose edits to rollback. |
$summary | String: Custom summary. Set to default summary if empty. |
$token | String: Rollback token. |
$bot | Boolean: If true, mark all reverted edits as bot. |
$resultDetails | Array: contains result-specific array of additional values 'alreadyrolled' : 'current' (rev) success : 'summary' (str), 'current' (rev), 'target' (rev) |
$user | User The user performing the rollback |
Definition at line 2132 of file WikiPage.php.
References commitRollback(), User\matchEditToken(), User\pingLimiter(), and wfArrayDiff2().
WikiPage::doUpdateRestrictions | ( | array $ | limit, |
array $ | expiry, | ||
&$ | cascade, | ||
$ | reason, | ||
User $ | user | ||
) |
Update the article's restriction field, and leave a log entry.
This works for protection both existing and non-existing pages.
$limit | Array: set of restriction keys |
$reason | String |
&$cascade | Integer. Set to false if cascading protection isn't allowed. |
$expiry | Array: per restriction type expiration |
$user | User The user updating the restrictions |
Definition at line 1694 of file WikiPage.php.
References $changed, $wgContLang, User\getId(), getLatest(), Status\newFatal(), Status\newGood(), Revision\newNullRevision(), Title\purgeExpiredRestrictions(), wfGetDB(), wfMsgForContent(), wfReadOnly(), wfReadOnlyReason(), wfRunHooks(), and wfTimestampNow().
Referenced by updateRestrictions().
WikiPage::doViewUpdates | ( | User $ | user | ) |
Do standard deferred updates after page view.
$user | User The relevant user |
Definition at line 873 of file WikiPage.php.
References $wgDisableCounters, DeferredUpdates\addUpdate(), User\clearNotification(), getId(), User\isAllowed(), and wfReadOnly().
Referenced by viewUpdates().
Get the approximate revision count of this page.
Definition at line 2750 of file WikiPage.php.
References wfDeprecated().
WikiPage::exists | ( | ) |
Definition at line 292 of file WikiPage.php.
static WikiPage::factory | ( | Title $ | title | ) | [static] |
Create a WikiPage object of the appropriate class for the given title.
$title | Title |
Definition at line 93 of file WikiPage.php.
References $page, and Title\getNamespace().
Referenced by ParserTest\addArticle(), MediaWikiTestCase\addCoreDBData(), Orphans\checkSeparation(), CleanupSpam\cleanupArticle(), Installer\createMainpage(), ApiTestCaseUpload\deleteFileByTitle(), FileDeleteForm\doDelete(), MovePageForm\doSubmit(), ImportSiteScripts\execute(), DeleteDefaultMessages\execute(), RollbackEdits\execute(), ApiProtect\execute(), Protect\execute(), AttachLatest\execute(), EditCLI\execute(), ApiPurge\execute(), DeleteBatch\execute(), ApiDelete\execute(), ApiRollback\execute(), RefreshLinks\fixRedirect(), SearchEngine\getNearMatchInternal(), ApiParse\getParsedSectionOrText(), EditPage\getPreloadedText(), ListredirectsPage\getRedirectTarget(), ApiPageSet\getRedirectTargets(), RequestContext\getWikiPage(), WikiRevision\importOldRevision(), SearchEngineTest\insertPage(), SpecialMergeHistory\merge(), Title\moveToInternal(), newFromID(), Title\newFromRedirectArray(), XmlDumpWriter\openPage(), DifferenceEngine\renderNewRevision(), ImportReporter\reportPage(), ArticleTablesTest\testbug14404(), ParserOptionsTest\testGetParserCacheKeyWithDynamicDates(), ArticleTest\testWikiPageFactory(), PageArchive\undeleteRevisions(), SpecialEditWatchlist\unwatchTitles(), LinksUpdate\updateCategoryCounts(), and Title\updateTitleProtection().
static WikiPage::flattenRestrictions | ( | $ | limit | ) | [static, protected] |
Take an array of page restrictions and flatten it to a string suitable for insertion into the page_restrictions field.
$limit | Array |
Definition at line 1898 of file WikiPage.php.
References $limit.
Get the Title object or URL this page redirects to.
Reimplemented in WikiFilePage.
Definition at line 663 of file WikiPage.php.
References getRedirectTarget(), and getRedirectURL().
Returns overrides for action handlers.
Classes listed here will be used instead of the default one when (and only when) $wgActions[$action] === true. This allows subclasses to override the default behavior.
Reimplemented in WikiFilePage.
Definition at line 141 of file WikiPage.php.
WikiPage::getAutoDeleteReason | ( | &$ | hasHistory | ) |
Auto-generates a deletion reason.
&$hasHistory | Boolean: whether the page has a history |
Definition at line 2478 of file WikiPage.php.
References $res, $wgContLang, Revision\DELETED_USER, getRevision(), wfGetDB(), and wfMsgForContent().
static WikiPage::getAutosummary | ( | $ | oldtext, |
$ | newtext, | ||
$ | flags | ||
) | [static] |
Return an applicable autosummary if one exists for the given edit.
$oldtext | String: the previous text of the page. |
$newtext | String: The submitted text of the page. |
$flags | Int bitmask: a bitmask of flags submitted for the edit. |
Definition at line 2423 of file WikiPage.php.
References $wgContLang, Title\newFromRedirect(), and wfMsgForContent().
Referenced by doEdit().
WikiPage::getCachedLastEditTime | ( | ) | [protected] |
Get the cached timestamp for the last time the page changed.
This is only used to help handle slave lag by comparing to page_touched.
Definition at line 527 of file WikiPage.php.
References $wgMemc, and wfMemcKey().
Referenced by loadPageData().
WikiPage::getComment | ( | $ | audience = Revision::FOR_PUBLIC | ) |
$audience | Integer: one of: Revision::FOR_PUBLIC to be displayed to all users Revision::FOR_THIS_USER to be displayed to $wgUser Revision::RAW get the text regardless of permissions |
Definition at line 499 of file WikiPage.php.
References loadLastEdit().
Get a list of users who have edited this article, not including the user who made the most recent revision, which you can get from $article->getUser() if you want it.
Definition at line 715 of file WikiPage.php.
References $dbr, $options, $res, $user, getId(), getUser(), and wfGetDB().
Definition at line 311 of file WikiPage.php.
References loadPageData().
#@-
Returns a list of hidden categories this page is a member of. Uses the page_props and categorylinks tables.
Definition at line 2392 of file WikiPage.php.
References $dbr, $res, $result, Title\makeTitle(), and wfGetDB().
WikiPage::getId | ( | ) |
Definition at line 285 of file WikiPage.php.
Referenced by doEdit(), doEditUpdates(), doQuickEdit(), doViewUpdates(), getContributors(), getRedirectTarget(), insertRedirectEntry(), isCountable(), loadLastEdit(), replaceSection(), updateIfNewerOn(), updateRedirectOn(), and updateRevisionOn().
WikiPage::getLastNAuthors | ( | $ | num, |
$ | revLatest = 0 |
||
) |
Get the last N authors.
$num | Integer: number of revisions to get |
$revLatest | String: the latest rev_id, selected from the master (optional) |
Definition at line 767 of file WikiPage.php.
References $res, wfGetDB(), wfProfileIn(), and wfProfileOut().
Get the page_latest field.
Definition at line 363 of file WikiPage.php.
References loadPageData().
Referenced by doEdit(), doUpdateRestrictions(), getParserOutput(), isParserCacheUsed(), and loadLastEdit().
Returns true if last revision was marked as "minor edit".
Definition at line 513 of file WikiPage.php.
References loadLastEdit().
WikiPage::getParserOutput | ( | ParserOptions $ | parserOptions, |
$ | oldid = null |
||
) |
Get a ParserOutput for the given ParserOptions and revision ID.
The parser cache will be used if possible.
$parserOptions | ParserOptions to use for the parse operation |
$oldid | Revision ID to get the text from, passing null or 0 will get the current revision (default value) |
Definition at line 840 of file WikiPage.php.
References getLatest(), ParserOptions\getStubThreshold(), isParserCacheUsed(), ParserCache\singleton(), wfDebug(), wfIncrStats(), wfProfileIn(), and wfProfileOut().
Get the text of the current revision.
No side-effects...
Definition at line 432 of file WikiPage.php.
References loadLastEdit().
Referenced by doEdit(), doPurge(), getUndoText(), insertRedirect(), isCountable(), prepareTextForEdit(), and replaceSection().
If this page is a redirect, get its target.
The target will be fetched from the redirect table if possible. If this page doesn't have an entry there, call insertRedirect()
Reimplemented in WikiFilePage.
Definition at line 595 of file WikiPage.php.
References $dbr, getId(), insertRedirect(), Title\makeTitle(), and wfGetDB().
Referenced by followRedirect().
WikiPage::getRedirectURL | ( | $ | rt | ) |
Get the Title object or URL to use for a redirect.
We use Title objects for same-wiki, non-special redirects and URLs for everything else.
$rt | Title Redirect target |
Definition at line 674 of file WikiPage.php.
Referenced by followRedirect().
Get the latest revision.
Definition at line 402 of file WikiPage.php.
References loadLastEdit().
Referenced by commitRollback(), and getAutoDeleteReason().
WikiPage::getText | ( | $ | audience = Revision::FOR_PUBLIC | ) |
Get the text of the current revision.
No side-effects...
$audience | Integer: one of: Revision::FOR_PUBLIC to be displayed to all users Revision::FOR_THIS_USER to be displayed to $wgUser Revision::RAW get the text regardless of permissions |
Definition at line 419 of file WikiPage.php.
References loadLastEdit().
Definition at line 443 of file WikiPage.php.
References loadLastEdit(), and wfTimestamp().
Referenced by doEdit().
Get the title object of the article.
Definition at line 149 of file WikiPage.php.
Referenced by Article\newFromWikiPage(), and updateRedirectOn().
Get the page_touched field.
Definition at line 352 of file WikiPage.php.
References loadPageData().
WikiPage::getUndoText | ( | Revision $ | undo, |
Revision $ | undoafter = null |
||
) |
Get the text that needs to be saved in order to undo all revisions between $undo and $undoafter.
Revisions must belong to the same page, must exist and must not be deleted
Definition at line 1104 of file WikiPage.php.
References getRawText(), Revision\getText(), and wfMerge().
Return a list of templates used by this article.
Uses the templatelinks table
Definition at line 2687 of file WikiPage.php.
WikiPage::getUser | ( | $ | audience = Revision::FOR_PUBLIC | ) |
$audience | Integer: one of: Revision::FOR_PUBLIC to be displayed to all users Revision::FOR_THIS_USER to be displayed to $wgUser Revision::RAW get the text regardless of permissions |
Definition at line 467 of file WikiPage.php.
References loadLastEdit().
Referenced by getContributors().
WikiPage::getUserText | ( | $ | audience = Revision::FOR_PUBLIC | ) |
$audience | Integer: one of: Revision::FOR_PUBLIC to be displayed to all users Revision::FOR_THIS_USER to be displayed to $wgUser Revision::RAW get the text regardless of permissions |
Definition at line 483 of file WikiPage.php.
References loadLastEdit().
Check if this page is something we're going to be showing some sort of sensible content for.
If we return false, page views (plain action=view) will return an HTTP 404 response, so spiders and robots can know they're following a bad link.
Reimplemented in WikiCategoryPage.
Definition at line 304 of file WikiPage.php.
WikiPage::insertOn | ( | $ | dbw | ) |
Insert a new empty page record for this article.
This *must* be followed up by creating a revision and running $this->updateRevisionOn( ... ); or else the record will be left in a funky state. Best if all done inside a transaction.
$dbw | DatabaseBase |
Definition at line 935 of file WikiPage.php.
References wfProfileIn(), wfProfileOut(), and wfRandom().
Referenced by doEdit().
Insert an entry for this page into the redirect table.
Don't call this function directly unless you know what you're doing.
Definition at line 629 of file WikiPage.php.
References getRawText(), insertRedirectEntry(), and Title\newFromRedirectRecurse().
Referenced by getRedirectTarget().
WikiPage::insertRedirectEntry | ( | $ | rt | ) |
Insert or update the redirect table entry for this page to indicate it redirects to $rt .
$rt | Title redirect target |
Definition at line 644 of file WikiPage.php.
References getId(), and wfGetDB().
Referenced by insertRedirect(), and updateRedirectOn().
Check whether the number of revisions of this page surpasses $wgDeleteRevisionsLimit.
Definition at line 2739 of file WikiPage.php.
References wfDeprecated().
WikiPage::isCountable | ( | $ | editInfo = false | ) |
Determine whether a page would be suitable for being counted as an article in the site_stats table based on the title & its content.
$editInfo | Object or false: object returned by prepareTextForEdit(), if false, the current database state will be used |
Definition at line 553 of file WikiPage.php.
References $wgArticleCountMethod, getId(), getRawText(), isRedirect(), and wfGetDB().
Referenced by doDeleteUpdates(), doEdit(), and doEditUpdates().
WikiPage::isParserCacheUsed | ( | ParserOptions $ | parserOptions, |
$ | oldid | ||
) |
Should the parser cache be used?
$parserOptions | ParserOptions to check |
$oldid | int |
Definition at line 820 of file WikiPage.php.
References $wgEnableParserCache, getLatest(), and ParserOptions\getStubThreshold().
Referenced by getParserOutput(), and useParserCache().
WikiPage::isRedirect | ( | $ | text = false | ) |
Tests if the article text represents a redirect.
$text | mixed string containing article contents, or boolean |
Reimplemented in WikiFilePage.
Definition at line 325 of file WikiPage.php.
References loadPageData(), and Title\newFromRedirect().
Referenced by doEdit(), and isCountable().
WikiPage::loadLastEdit | ( | ) | [protected] |
Loads everything except the text This isn't necessary for all uses, so it's only done if needed.
Definition at line 374 of file WikiPage.php.
References getId(), getLatest(), Revision\newFromPageId(), and setLastEdit().
Referenced by getComment(), getMinorEdit(), getRawText(), getRevision(), getText(), getTimestamp(), getUser(), and getUserText().
WikiPage::loadPageData | ( | $ | data = 'fromdb' | ) |
Set the general counter, title etc data loaded from some source.
$data | Object|String One of the following: A DB query result object or... "fromdb" to get from a slave DB or... "fromdbmaster" to get from the master DB |
Definition at line 244 of file WikiPage.php.
References getCachedLastEditTime(), pageDataFromTitle(), LinkCache\singleton(), wfGetDB(), and wfTimestamp().
Referenced by checkTouched(), doEdit(), getCount(), getLatest(), getTouched(), and isRedirect().
WikiPage::makeParserOptions | ( | $ | user | ) |
Get parser options suitable for rendering the primary article wikitext.
Definition at line 1486 of file WikiPage.php.
References $options, $user, $wgContLang, ParserOptions\newFromUser(), and ParserOptions\newFromUserAndLang().
Referenced by prepareTextForEdit().
static WikiPage::newFromID | ( | $ | id | ) | [static] |
Constructor from a page id.
$id | Int article ID to load |
Definition at line 123 of file WikiPage.php.
static WikiPage::onArticleCreate | ( | $ | title | ) | [static] |
The onArticle*() functions are supposed to be a kind of hooks which should be called whenever any of the specified actions are done.
This is a good place to put code to clear caches, for instance.
This is called on page move and undelete, as well as edit
$title | Title object |
Definition at line 2302 of file WikiPage.php.
References $title.
Referenced by doEditUpdates(), and Title\moveToInternal().
static WikiPage::onArticleDelete | ( | $ | title | ) | [static] |
Clears caches when article is deleted.
$title | Title |
Definition at line 2323 of file WikiPage.php.
References $title, HTMLFileCache\clearFileCache(), false, User\newFromName(), User\setNewtalk(), RepoGroup\singleton(), and MessageCache\singleton().
Referenced by doDeleteUpdates(), and Title\moveToInternal().
static WikiPage::onArticleEdit | ( | $ | title | ) | [static] |
Purge caches on page update etc.
$title | Title object |
Definition at line 2369 of file WikiPage.php.
References $title, DeferredUpdates\addHTMLCacheUpdate(), and HTMLFileCache\clearFileCache().
Referenced by doEditUpdates().
WikiPage::pageData | ( | $ | dbr, |
$ | conditions | ||
) | [protected] |
Fetch a page record with the given conditions.
$dbr | DatabaseBase object |
$conditions | Array |
Definition at line 197 of file WikiPage.php.
References $dbr, selectFields(), and wfRunHooks().
Referenced by pageDataFromId(), and pageDataFromTitle().
WikiPage::pageDataFromId | ( | $ | dbr, |
$ | id | ||
) |
Fetch a page record matching the requested ID.
$dbr | DatabaseBase |
$id | Integer |
Definition at line 230 of file WikiPage.php.
References $dbr, and pageData().
WikiPage::pageDataFromTitle | ( | $ | dbr, |
$ | title | ||
) |
Fetch a page record matching the Title object's namespace and title using a sanitized title string.
$dbr | DatabaseBase object |
$title | Title object |
Definition at line 217 of file WikiPage.php.
References $dbr, $title, and pageData().
Referenced by loadPageData().
WikiPage::prepareTextForEdit | ( | $ | text, |
$ | revid = null , |
||
User $ | user = null |
||
) |
Prepare text which is about to be saved.
Returns a stdclass with source, pst and output members
Definition at line 1502 of file WikiPage.php.
References $user, $wgContLang, $wgParser, $wgUser, getRawText(), makeParserOptions(), ParserOptions\newFromUserAndLang(), and wfRunHooks().
Referenced by doEdit(), and doEditUpdates().
WikiPage::preSaveTransform | ( | $ | text, |
User $ | user = null , |
||
ParserOptions $ | popts = null |
||
) |
This function is called right before saving the wikitext, so we can do things like signatures and links-in-context.
$text | String article contents |
$user | User object: user doing the edit |
$popts | ParserOptions object: parser options, default options for the user loaded if null given |
Definition at line 2719 of file WikiPage.php.
References $user, $wgParser, $wgUser, ParserOptions\newFromUser(), and wfDeprecated().
WikiPage::quickEdit | ( | $ | text, |
$ | comment = '' , |
||
$ | minor = 0 |
||
) |
Definition at line 2779 of file WikiPage.php.
References $comment, $wgUser, doQuickEdit(), and wfDeprecated().
WikiPage::replaceSection | ( | $ | section, |
$ | text, | ||
$ | sectionTitle = '' , |
||
$ | edittime = null |
||
) |
$section | empty/null/false or a section number (0, 1, 2, T1, T2...) |
$text | String: new text of the section |
$sectionTitle | String: new section's subject, only if $section is 'new' |
$edittime | String: revision timestamp or null to use the current revision |
Definition at line 1133 of file WikiPage.php.
References $section, $wgParser, getId(), getRawText(), Revision\loadFromTimestamp(), wfDebug(), wfGetDB(), wfMsgForContent(), wfProfileIn(), wfProfileOut(), and wfRunHooks().
static WikiPage::selectFields | ( | ) | [static] |
Return the list of revision fields that should be selected to create a new page.
Definition at line 175 of file WikiPage.php.
Referenced by pageData(), and ArticleTest\testStaticFunctions().
WikiPage::setCachedLastEditTime | ( | $ | timestamp | ) |
Set the cached timestamp for the last time the page changed.
This is only used to help handle slave lag by comparing to page_touched.
$timestamp | string |
Definition at line 539 of file WikiPage.php.
References $wgMemc, wfMemcKey(), and wfTimestamp().
Referenced by updateRevisionOn().
WikiPage::setLastEdit | ( | Revision $ | revision | ) | [protected] |
Set the latest revision.
Definition at line 393 of file WikiPage.php.
References Revision\getTimestamp().
Referenced by loadLastEdit(), and updateRevisionOn().
WikiPage::setTimestamp | ( | $ | ts | ) |
Set the page timestamp (use only to avoid DB queries)
$ts | string MW timestamp of last article revision |
Definition at line 456 of file WikiPage.php.
References wfTimestamp().
WikiPage::updateCategoryCounts | ( | $ | added, |
$ | deleted | ||
) |
Update all the appropriate counts in the category table, given that we've added the categories $added and deleted the categories $deleted.
$added | array The names of categories that were added |
$deleted | array The names of categories that were deleted |
Definition at line 2573 of file WikiPage.php.
References wfGetDB().
Referenced by doDeleteUpdates().
WikiPage::updateIfNewerOn | ( | $ | dbw, |
$ | revision | ||
) |
If the given revision is newer than the currently set page_latest, update the page record.
Otherwise, do nothing.
Definition at line 1066 of file WikiPage.php.
References getId(), updateRevisionOn(), wfProfileIn(), wfProfileOut(), and wfTimestamp().
WikiPage::updateRedirectOn | ( | $ | dbw, |
$ | redirectTitle, | ||
$ | lastRevIsRedirect = null |
||
) |
Add row to the redirect table if this is a redirect, remove otherwise.
$dbw | DatabaseBase |
$redirectTitle | Title object pointing to the redirect target, or NULL if this is not a redirect |
$lastRevIsRedirect | If given, will optimize adding and removing rows in redirect table. |
Definition at line 1031 of file WikiPage.php.
References getId(), getTitle(), insertRedirectEntry(), RepoGroup\singleton(), wfProfileIn(), and wfProfileOut().
Referenced by updateRevisionOn().
WikiPage::updateRestrictions | ( | $ | limit = array() , |
$ | reason = '' , |
||
&$ | cascade = 0 , |
||
$ | expiry = array() , |
||
User $ | user = null |
||
) |
Update the article's restriction field, and leave a log entry.
$limit | Array: set of restriction keys |
$reason | String |
&$cascade | Integer. Set to false if cascading protection isn't allowed. |
$expiry | Array: per restriction type expiration |
$user | User The user updating the restrictions |
Definition at line 2766 of file WikiPage.php.
References $limit, $user, $wgUser, and doUpdateRestrictions().
WikiPage::updateRevisionOn | ( | $ | dbw, |
$ | revision, | ||
$ | lastRevision = null , |
||
$ | lastRevIsRedirect = null |
||
) |
Update the page record to point to a newly saved revision.
$dbw | DatabaseBase: object |
$revision | Revision: For ID number, and text used to set length and redirect status fields |
$lastRevision | Integer: if given, will not overwrite the page field when different from the currently set value. Giving 0 indicates the new page flag should be set on. |
$lastRevIsRedirect | Boolean: if given, will optimize adding and removing rows in redirect table. |
Definition at line 979 of file WikiPage.php.
References $result, getId(), Title\newFromRedirectRecurse(), setCachedLastEditTime(), setLastEdit(), LinkCache\singleton(), updateRedirectOn(), wfProfileIn(), wfProfileOut(), and wfTimestampNow().
Referenced by doEdit(), doQuickEdit(), and updateIfNewerOn().
WikiPage::useParserCache | ( | $ | oldid | ) |
Definition at line 2797 of file WikiPage.php.
References $wgUser, isParserCacheUsed(), ParserOptions\newFromUser(), and wfDeprecated().
Definition at line 2788 of file WikiPage.php.
References $wgUser, doViewUpdates(), and wfDeprecated().
WikiPage::$mCounter = null [protected] |
Definition at line 77 of file WikiPage.php.
WikiPage::$mDataLoaded = false |
WikiPage::$mIsRedirect = false |
WikiPage::$mLastRevision = null [protected] |
Definition at line 62 of file WikiPage.php.
WikiPage::$mLatest = false |
WikiPage::$mPreparedEdit = false |
WikiPage::$mRedirectTarget = null [protected] |
Definition at line 57 of file WikiPage.php.
WikiPage::$mTimestamp = '' [protected] |
Definition at line 67 of file WikiPage.php.
WikiPage::$mTitle = null |
Definition at line 43 of file WikiPage.php.
WikiPage::$mTouched = '19700101000000' [protected] |
Definition at line 72 of file WikiPage.php.
const WikiPage::DELETE_HOOK_ABORTED = -1 |
Delete operation aborted by hook.
Definition at line 23 of file WikiPage.php.
Referenced by doDeleteArticleReal().
const WikiPage::DELETE_NO_PAGE = 1 |
const WikiPage::DELETE_NO_REVISIONS = 2 |
No revisions found to delete.
Definition at line 38 of file WikiPage.php.
Referenced by doDeleteArticleReal().
const WikiPage::DELETE_SUCCESS = 0 |
Deletion successful.
Definition at line 28 of file WikiPage.php.
Referenced by FileDeleteForm\doDelete(), doDeleteArticle(), and doDeleteArticleReal().