MediaWiki  master
StatusValue Class Reference

Generic operation result class Has warning/error list, boolean status and arbitrary value. More...

Inheritance diagram for StatusValue:

Public Member Functions

 __toString ()
 Returns a string representation of the status for debugging. More...
 
 error ( $message,... $parameters)
 Add an error, do not set fatal flag This can be used for non-fatal errors. More...
 
 fatal ( $message,... $parameters)
 Add an error and set OK to false, indicating that the operation as a whole was fatal. More...
 
 getErrors ()
 Get the list of errors. More...
 
 getErrorsByType ( $type)
 Returns a list of status messages of the given type. More...
 
 getValue ()
 
 hasMessage ( $message)
 Returns true if the specified message is present as a warning or error. More...
 
 isGood ()
 Returns whether the operation completed and didn't have any error or warnings. More...
 
 isOK ()
 Returns whether the operation completed. More...
 
 merge ( $other, $overwriteValue=false)
 Merge another status object into this one. More...
 
 replaceMessage ( $source, $dest)
 If the specified source message exists, replace it with the specified destination message, but keep the same parameters as in the original error. More...
 
 setOK ( $ok)
 Change operation status. More...
 
 setResult ( $ok, $value=null)
 Change operation result. More...
 
 splitByErrorType ()
 Splits this StatusValue object into two new StatusValue objects, one which contains only the error messages, and one that contains the warnings, only. More...
 
 warning ( $message,... $parameters)
 Add a new warning. More...
 

Static Public Member Functions

static newFatal ( $message,... $parameters)
 Factory function for fatal errors. More...
 
static newGood ( $value=null)
 Factory function for good results. More...
 

Public Attributes

int $failCount = 0
 Counter for batch operations. More...
 
bool[] $success = []
 Map of (key => bool) to indicate success of each part of batch operations. More...
 
int $successCount = 0
 Counter for batch operations. More...
 
mixed $value
 

Protected Member Functions

 getStatusArray ( $type=false)
 Returns a list of status messages of the given type (or all if false) More...
 

Protected Attributes

array[] $errors = []
 
bool $ok = true
 

Detailed Description

Generic operation result class Has warning/error list, boolean status and arbitrary value.

"Good" means the operation was completed with no warnings or errors.

"OK" means the operation was partially or wholly completed.

An operation which is not OK should have errors so that the user can be informed as to what went wrong. Calling the fatal() function sets an error message and simultaneously switches off the OK flag.

The recommended pattern for Status objects is to return a StatusValue unconditionally, i.e. both on success and on failure – so that the developer of the calling code is reminded that the function can fail, and so that a lack of error-handling will be explicit.

The use of Message objects should be avoided when serializability is needed.

Stability: newable
Since
1.25

Definition at line 46 of file StatusValue.php.

Member Function Documentation

◆ __toString()

StatusValue::__toString ( )

Returns a string representation of the status for debugging.

This is fairly verbose and may change without notice.

Returns
string

Definition at line 383 of file StatusValue.php.

References $type, and isOK().

◆ error()

StatusValue::error (   $message,
  $parameters 
)

Add an error, do not set fatal flag This can be used for non-fatal errors.

Parameters
string | MessageSpecifier | MessageValue$messageMessage key or object
mixed...$parameters
Returns
$this

Definition at line 255 of file StatusValue.php.

Referenced by fatal().

◆ fatal()

◆ getErrors()

StatusValue::getErrors ( )

Get the list of errors.

Each error is a (message:string or MessageSpecifier,params:array) map

Returns
array[]

Definition at line 152 of file StatusValue.php.

References $errors.

Referenced by Status\__get(), ApiErrorFormatter\addMessagesFromStatus(), ApiErrorFormatter\arrayFromStatus(), ApiErrorFormatter_BackCompat\arrayFromStatus(), Status\getMessage(), and Status\getWikiText().

◆ getErrorsByType()

StatusValue::getErrorsByType (   $type)

Returns a list of status messages of the given type.

Each entry is a map of:

  • message: string message key or MessageSpecifier
  • params: array list of parameters
Parameters
string$type
Returns
array[]

Definition at line 308 of file StatusValue.php.

References $type.

Referenced by ApiErrorFormatter_BackCompat\arrayFromStatus(), and ApiBase\dieStatus().

◆ getStatusArray()

StatusValue::getStatusArray (   $type = false)
protected

Returns a list of status messages of the given type (or all if false)

Note
this handles RawMessage poorly
Parameters
string | bool$type
Returns
array[]

Definition at line 470 of file StatusValue.php.

References $type.

Referenced by Status\getErrorsArray(), and Status\getWarningsArray().

◆ getValue()

StatusValue::getValue ( )

◆ hasMessage()

StatusValue::hasMessage (   $message)

Returns true if the specified message is present as a warning or error.

Parameters
string | MessageSpecifier | MessageValue$messageMessage key or object to search for
Returns
bool

Definition at line 326 of file StatusValue.php.

Referenced by ApiBase\addBlockInfoToStatus().

◆ isGood()

◆ isOK()

StatusValue::isOK ( )

Returns whether the operation completed.

Returns
bool

Definition at line 134 of file StatusValue.php.

References $ok.

Referenced by Status\__get(), __toString(), Status\getMessage(), Status\getWikiText(), EditPage\internalAttemptSave(), and splitByErrorType().

◆ merge()

StatusValue::merge (   $other,
  $overwriteValue = false 
)

Merge another status object into this one.

Parameters
StatusValue$other
bool$overwriteValueWhether to override the "value" member
Returns
$this

Definition at line 285 of file StatusValue.php.

Referenced by ScopedLock\factory(), and FileOpBatch\runParallelBatches().

◆ newFatal()

static StatusValue::newFatal (   $message,
  $parameters 
)
static

Factory function for fatal errors.

Parameters
string | MessageSpecifier$messageMessage key or object
mixed...$parameters
Returns
static

Definition at line 73 of file StatusValue.php.

Referenced by CliInstaller\__construct(), MWHttpRequest\__construct(), UploadFromChunks\addChunk(), User\addToDatabase(), MediaWiki\Watchlist\WatchlistManager\addWatchIgnoringRights(), FileOp\attempt(), MediaWiki\Auth\AuthManager\autoCreateUser(), ChangeTags\canActivateTag(), ChangeTags\canAddTagsAccompanyingChange(), MediaWiki\Auth\AuthManager\canCreateAccount(), ChangeTags\canCreateTag(), ChangeTags\canDeactivateTag(), ChangeTags\canDeleteTag(), Page\DeletePage\canProbablyDeleteAssociatedTalk(), Page\UndeletePage\canProbablyUndeleteAssociatedTalk(), ChangeTags\canUpdateTags(), SpecialPageLanguage\changePageLanguage(), ImportReporter\close(), UploadBase\convertVerifyErrorToStatus(), Installer\createSysop(), SpecialRedirect\dispatchFile(), SpecialRedirect\dispatchLog(), SpecialRedirect\dispatchPage(), SpecialRedirect\dispatchRevision(), SpecialRedirect\dispatchUser(), Installer\doEnvironmentChecks(), WikiPage\doUpdateRestrictions(), UserrightsPage\execute(), PoolCounterWork\execute(), LoginSignupSpecialPage\execute(), SpecialChangeCredentials\execute(), SpecialLinkAccounts\execute(), SpecialUnlinkAccounts\execute(), ApiEmailUser\execute(), ApiImageRotate\execute(), CliInstaller\execute(), PasswordReset\execute(), UploadFromUrl\fetchFile(), Article\fetchRevisionRecord(), UserrightsPage\fetchUser(), PoolCounterRedis\getConnection(), Installer\getExtensionInfo(), MediaWiki\Auth\LocalPasswordPrimaryAuthenticationProvider\getPasswordResetData(), WebInstallerExistingWiki\handleExistingUpgrade(), ApiUpload\handleStashException(), Deflate\inflate(), EditPage\internalAttemptSave(), ChangeTags\isTagNameValid(), ApiAuthManagerHelper\logAuthenticationResult(), BotPassword\login(), SqliteInstaller\makeStubDBFile(), DatabaseInstaller\meetsMinimumRequirement(), MovePage\moveSubpagesIfAllowed(), FileRepo\newFatal(), User\newFatalPermissionDeniedStatus(), ImportStreamSource\newFromFile(), ImportStreamSource\newFromInterwiki(), ImportStreamSource\newFromUpload(), ImportStreamSource\newFromURL(), FileBackend\newStatus(), ApiUsageException\newWithMessage(), SpecialRedirectWithAction\onFormSubmit(), McrUndoAction\onSubmit(), RevertAction\onSubmit(), SpecialChangeContentModel\onSubmit(), SpecialLockdb\onSubmit(), SpecialPageLanguage\onSubmit(), SpecialRandomInCategory\onSubmit(), SpecialUnlockdb\onSubmit(), SpecialExpandTemplates\onSubmitInput(), FormatJson\parse(), UploadBase\performUpload(), MediaWiki\Block\BlockUser\placeBlock(), DatabaseInstaller\populateInterwikiTable(), MediaWiki\Auth\UserDataAuthenticationRequest\populateUser(), FileOp\precheck(), PoolCounter\precheckAcquire(), AbstractContent\prepareSave(), UploadFromUrl\reallyFetchFile(), PoolCounterRedis\release(), LocalFileDeleteBatch\removeNonexistentFiles(), LocalFileMoveBatch\removeNonexistentFiles(), LocalFileRestoreBatch\removeNonexistentFiles(), MediaWiki\Watchlist\WatchlistManager\removeWatchIgnoringRights(), PoolWorkArticleView\renderRevision(), ChangeTags\restrictedTagError(), Page\RollbackPage\rollback(), AssembleUploadChunksJob\run(), PublishStashedFileJob\run(), MediaWiki\Preferences\DefaultPreferencesFactory\saveFormData(), MediaWiki\Storage\PageUpdater\saveRevision(), UserrightsPage\saveUserGroups(), UserMailer\send(), SpecialEmailUser\sendEmailForm(), UserMailer\sendInternal(), UserMailer\sendWithPear(), User\setEmailWithConfirmation(), SqliteInstaller\setupDatabase(), PostgresInstaller\setupPLpgSQL(), PostgresInstaller\setupSchema(), PostgresInstaller\setupUser(), RevDelList\setVisibility(), MediaTransformOutput\streamFileWithStatus(), WebInstallerDBConnect\submit(), SpecialEditTags\submit(), SpecialEmailUser\submit(), SpecialConfirmEmail\submitSend(), MysqlInstaller\submitSettingsForm(), PostgresInstaller\submitSettingsForm(), DatabaseInstaller\submitWebUserBox(), SpecialLinkAccounts\success(), MediaWiki\Auth\TemporaryPasswordPrimaryAuthenticationProvider\testForAccountCreation(), MediaWiki\Auth\CheckBlocksSecondaryAuthenticationProvider\testUserForCreation(), UploadBase\tryStashFile(), UploadFromChunks\tryStashFile(), AuthManagerSpecialPage\trySubmit(), MediaWiki\Storage\PageUpdater\updateRevision(), ChangeTags\updateTagsWithChecks(), ContentHandler\validateSave(), JsonContentHandler\validateSave(), and PoolCounterRedis\waitForSlotOrNotif().

◆ newGood()

static StatusValue::newGood (   $value = null)
static

Factory function for good results.

Parameters
mixed | null$value
Returns
static

Definition at line 85 of file StatusValue.php.

References $value.

Referenced by MWHttpRequest\__construct(), MediaWiki\EditPage\Constraint\EditFilterMergedContentHookConstraint\__construct(), PoolCounterNull\acquireForAnyone(), PoolCounterNull\acquireForMe(), RevDelList\acquireItemLocks(), LocalFileMoveBatch\acquireSourceLock(), LocalFileMoveBatch\acquireTargetLock(), ChangeTags\activateTagWithChecks(), ChangeTags\addTagsAccompanyingChangeWithChecks(), User\addToDatabase(), MediaWiki\Auth\AuthManager\allowsAuthenticationDataChange(), FileOp\attempt(), FileOpBatch\attempt(), MediaWiki\Auth\AuthManager\autoCreateUser(), ChangeTags\canActivateTag(), ChangeTags\canAddTagsAccompanyingChange(), MediaWiki\Auth\AuthManager\canCreateAccount(), ChangeTags\canCreateTag(), ChangeTags\canDeactivateTag(), ChangeTags\canDeleteTag(), ChangeTags\canUpdateTags(), User\changeAuthenticationData(), SpecialPageLanguage\changePageLanguage(), MWRestrictions\check(), PasswordPolicyChecks\checkMaximalPasswordLength(), PasswordPolicyChecks\checkMinimalPasswordLength(), PasswordPolicyChecks\checkMinimumPasswordLengthToLogin(), PasswordPolicyChecks\checkPasswordCannotBeSubstringInUsername(), PasswordPolicyChecks\checkPasswordCannotMatchDefaults(), PasswordPolicyChecks\checkPasswordNotInCommonList(), User\checkPasswordValidity(), DatabaseInstaller\checkPrerequisites(), LocalRepo\cleanupDeletedBatch(), ImportReporter\close(), QuorumLockManager\collectPledgeQuorum(), PostgresInstaller\commitChanges(), MediaWiki\Auth\ConfirmLinkSecondaryAuthenticationProvider\continueLinkAttempt(), Installer\createMainpage(), PostgresInstaller\createManualTables(), SqliteInstaller\createManualTables(), Installer\createSysop(), ChangeTags\createTagWithChecks(), ChangeTags\deactivateTagWithChecks(), ChangeTags\deleteTagEverywhere(), ApiBase\dieStatus(), ApiUpload\dieStatusWithCode(), SpecialRedirect\dispatchFile(), SpecialRedirect\dispatchLog(), SpecialRedirect\dispatchPage(), SpecialRedirect\dispatchRevision(), SpecialRedirect\dispatchUser(), CopyFileOp\doAttempt(), CreateFileOp\doAttempt(), FileOp\doAttempt(), MoveFileOp\doAttempt(), StoreFileOp\doAttempt(), ContentModelChange\doContentModelChange(), Installer\doEnvironmentChecks(), Installer\doGenerateKeys(), MySqlLockManager\doGetLocksOnServer(), PostgreSqlLockManager\doGetLocksOnServer(), FSLockManager\doLock(), NullLockManager\doLock(), LockManager\doLockByType(), QuorumLockManager\doLockByType(), RevDelArchiveList\doPostCommitUpdates(), RevDelFileList\doPostCommitUpdates(), RevDelList\doPostCommitUpdates(), RevDelRevisionList\doPostCommitUpdates(), CopyFileOp\doPrecheck(), CreateFileOp\doPrecheck(), DeleteFileOp\doPrecheck(), DescribeFileOp\doPrecheck(), FileOp\doPrecheck(), MoveFileOp\doPrecheck(), StoreFileOp\doPrecheck(), RevDelArchiveList\doPreCommitUpdates(), RevDelFileList\doPreCommitUpdates(), RevDelList\doPreCommitUpdates(), RevDelRevisionList\doPreCommitUpdates(), SearchEngine\doSearchArchiveTitle(), FSLockManager\doSingleLock(), FSLockManager\doSingleUnlock(), FSLockManager\doUnlock(), NullLockManager\doUnlock(), LockManager\doUnlockByType(), QuorumLockManager\doUnlockByType(), WikiPage\doUpdateRestrictions(), ApiBase\errorArrayToStatus(), SpecialUnlinkAccounts\execute(), LocalFileDeleteBatch\execute(), CliInstaller\execute(), PasswordReset\execute(), PoolWorkArticleViewCurrent\fallback(), UploadBase\fetchFile(), Article\fetchRevisionRecord(), UserrightsPage\fetchUser(), Installer\findExtensionsByType(), DBLockManager\freeLocksOnServer(), MemcLockManager\freeLocksOnServer(), RedisLockManager\freeLocksOnServer(), MediaWiki\Storage\SqlBlobStore\getBlobBatch(), PoolWorkArticleViewCurrent\getCachedWork(), PoolWorkArticleViewOld\getCachedWork(), DatabaseInstaller\getConnection(), PoolCounterRedis\getConnection(), Installer\getExtensionInfo(), MediaWiki\EditPage\Constraint\ChangeTagsConstraint\getLegacyStatus(), DBLockManager\getLocksOnServer(), MemcLockManager\getLocksOnServer(), RedisLockManager\getLocksOnServer(), PostgresInstaller\getPgConnection(), AuthManagerSpecialPage\handleFormSubmit(), SpecialChangeCredentials\handleFormSubmit(), SpecialUnlinkAccounts\handleFormSubmit(), WebInstallerExistingWiki\importVariables(), Installer\includeExtensions(), Deflate\inflate(), EditPage\internalAttemptSave(), ChangeTags\isTagNameValid(), RevDelItem\lock(), ApiAuthManagerHelper\logAuthenticationResult(), BotPassword\login(), LoginSignupSpecialPage\mainLoginForm(), SqliteInstaller\makeStubDBFile(), DatabaseInstaller\meetsMinimumRequirement(), ImportStreamSource\newFromFile(), ImportStreamSource\newFromURL(), FileRepo\newGood(), FileBackend\newStatus(), McrUndoAction\onSubmit(), SpecialBotPasswords\onSubmit(), SpecialLockdb\onSubmit(), SpecialUnlockdb\onSubmit(), SpecialExpandTemplates\onSubmitInput(), MysqlInstaller\openConnection(), SqliteInstaller\openConnection(), PostgresInstaller\openConnectionToAnyDB(), PostgresInstaller\openConnectionWithParams(), FormatJson\parse(), ApiUpload\performUpload(), DatabaseInstaller\populateInterwikiTable(), Installer\populateSiteStats(), MediaWiki\Auth\UserDataAuthenticationRequest\populateUser(), FileOp\precheck(), PoolCounter\precheckAcquire(), FileOp\precheckDestExistence(), AbstractContent\prepareSave(), MediaWiki\Auth\LocalPasswordPrimaryAuthenticationProvider\providerAllowsAuthenticationDataChange(), MediaWiki\Auth\TemporaryPasswordPrimaryAuthenticationProvider\providerAllowsAuthenticationDataChange(), PoolCounterNull\release(), PoolCounterRedis\release(), MySqlLockManager\releaseAllLocks(), MemcLockManager\releaseAllLocks(), PostgreSqlLockManager\releaseAllLocks(), RedisLockManager\releaseAllLocks(), RevDelList\releaseItemLocks(), QuorumLockManager\releasePledges(), LocalFileDeleteBatch\removeNonexistentFiles(), LocalFileMoveBatch\removeNonexistentFiles(), LocalFileRestoreBatch\removeNonexistentFiles(), Installer\restoreServices(), Page\RollbackPage\rollback(), AssembleUploadChunksJob\run(), PublishStashedFileJob\run(), ApiQueryRevisions\run(), BotPassword\save(), MediaWiki\Storage\PageUpdater\saveRevision(), UserrightsPage\saveUserGroups(), UserMailer\send(), UserMailer\sendInternal(), UserMailer\sendWithPear(), User\setEmailWithConfirmation(), ContentModelChange\setTags(), WikiImporter\setTargetRootPage(), PostgresInstaller\setupDatabase(), SqliteInstaller\setupDatabase(), PostgresInstaller\setupPLpgSQL(), PostgresInstaller\setupSchema(), MysqlInstaller\setupUser(), PostgresInstaller\setupUser(), RevDelList\setVisibility(), MediaWiki\Watchlist\WatchlistManager\setWatch(), LocalRepo\skipWriteOperationIfSha1(), MediaTransformOutput\streamFileWithStatus(), SpecialEmailUser\submit(), MysqlInstaller\submitConnectForm(), PostgresInstaller\submitConnectForm(), MediaWiki\Preferences\DefaultPreferencesFactory\submitForm(), DatabaseInstaller\submitInstallUserBox(), SpecialConfirmEmail\submitSend(), DatabaseInstaller\submitSettingsForm(), MysqlInstaller\submitSettingsForm(), PostgresInstaller\submitSettingsForm(), DatabaseInstaller\submitWebUserBox(), MediaWiki\Auth\LocalPasswordPrimaryAuthenticationProvider\testForAccountCreation(), MediaWiki\Auth\TemporaryPasswordPrimaryAuthenticationProvider\testForAccountCreation(), MediaWiki\Auth\CheckBlocksSecondaryAuthenticationProvider\testUserForCreation(), UploadBase\tryStashFile(), HTMLForm\trySubmit(), AuthManagerSpecialPage\trySubmit(), RevDelItem\unlock(), ChangeTagsLogList\updateChangeTagsOnAll(), ChangeTagsRevisionList\updateChangeTagsOnAll(), MediaWiki\Storage\PageUpdater\updateRevision(), ChangeTags\updateTagsWithChecks(), HTMLRestrictionsField\validate(), ContentHandler\validateSave(), MediaHandler\verifyUpload(), and PoolCounterRedis\waitForSlotOrNotif().

◆ replaceMessage()

StatusValue::replaceMessage (   $source,
  $dest 
)

If the specified source message exists, replace it with the specified destination message, but keep the same parameters as in the original error.

Note, due to the lack of tools for comparing IStatusMessage objects, this function will not work when using such an object as the search parameter.

Parameters
MessageSpecifier | MessageValue | string$sourceMessage key or object to search for
MessageSpecifier | MessageValue | string$destReplacement message key or object
Returns
bool Return true if the replacement was done, false otherwise.

Definition at line 357 of file StatusValue.php.

References $source.

Referenced by ApiBase\addBlockInfoToStatus().

◆ setOK()

StatusValue::setOK (   $ok)

Change operation status.

Parameters
bool$ok
Returns
$this

Definition at line 162 of file StatusValue.php.

References $ok.

Referenced by Status\__set(), and ApiBase\dieStatus().

◆ setResult()

◆ splitByErrorType()

StatusValue::splitByErrorType ( )

Splits this StatusValue object into two new StatusValue objects, one which contains only the error messages, and one that contains the warnings, only.

The returned array is defined as: [ 0 => object(StatusValue) # the StatusValue with error messages, only 1 => object(StatusValue) # The StatusValue with warning messages, only ]

Returns
static[]

Reimplemented in Status.

Definition at line 102 of file StatusValue.php.

References getValue(), and isOK().

◆ warning()

StatusValue::warning (   $message,
  $parameters 
)

Add a new warning.

Parameters
string | MessageSpecifier | MessageValue$messageMessage key or object
mixed...$parameters
Returns
$this

Definition at line 237 of file StatusValue.php.

Member Data Documentation

◆ $errors

array [] StatusValue::$errors = []
protected

Definition at line 52 of file StatusValue.php.

Referenced by Status\getErrorMessageArray(), getErrors(), Status\getWikiText(), and isGood().

◆ $failCount

int StatusValue::$failCount = 0

Counter for batch operations.

Definition at line 64 of file StatusValue.php.

◆ $ok

bool StatusValue::$ok = true
protected

Definition at line 49 of file StatusValue.php.

Referenced by isOK(), setOK(), and setResult().

◆ $success

bool [] StatusValue::$success = []

Map of (key => bool) to indicate success of each part of batch operations.

Definition at line 58 of file StatusValue.php.

◆ $successCount

int StatusValue::$successCount = 0

Counter for batch operations.

Definition at line 61 of file StatusValue.php.

◆ $value

mixed StatusValue::$value

Definition at line 55 of file StatusValue.php.

Referenced by Status\__set(), getValue(), newGood(), and setResult().


The documentation for this class was generated from the following file: