MediaWiki  1.34.0
FileOp Class Reference

FileBackend helper class for representing operations. More...

Inheritance diagram for FileOp:
Collaboration diagram for FileOp:

Public Member Functions

 __construct (FileBackendStore $backend, array $params, LoggerInterface $logger)
 Build a new batch file operation transaction. More...
 
 applyDependencies (array $deps)
 Update a dependency tracking array to account for this operation. More...
 
 attempt ()
 Attempt the operation. More...
 
 attemptAsync ()
 Attempt the operation in the background. More...
 
 dependsOn (array $deps)
 Check if this operation changes files listed in $paths. More...
 
 failed ()
 Check if this operation failed precheck() or attempt() More...
 
 getBackend ()
 Get the backend this operation is for. More...
 
 getJournalEntries (array $oPredicates, array $nPredicates)
 Get the file journal entries for this file operation. More...
 
 getParam ( $name)
 Get the value of the parameter with the given name. More...
 
 logFailure ( $action)
 Log a file operation failure and preserve any temp files. More...
 
 precheck (array &$predicates)
 Check preconditions of the operation without writing anything. More...
 
 setBatchId ( $batchId)
 Set the batch UUID this operation belongs to. More...
 
 storagePathsChanged ()
 Get a list of storage paths written to for this operation. More...
 
 storagePathsRead ()
 Get a list of storage paths read from for this operation. More...
 

Static Public Member Functions

static newDependencies ()
 Get a new empty dependency tracking array for paths read/written to. More...
 
static newPredicates ()
 Get a new empty predicates array for precheck() More...
 

Public Attributes

const STATE_ATTEMPTED = 3
 
const STATE_CHECKED = 2
 
const STATE_NEW = 1
 

Protected Member Functions

 allowedParams ()
 Get the file operation parameters. More...
 
 doAttempt ()
 
 doPrecheck (array &$predicates)
 
 fileExists ( $source, array $predicates)
 Check if a file will exist in storage when this operation is attempted. More...
 
 fileSha1 ( $source, array $predicates)
 Get the SHA-1 hash a file in storage will have when this operation is attempted. More...
 
 getSourceSha1Base36 ()
 precheckDestExistence() helper function to get the source file SHA-1. More...
 
 precheckDestExistence (array $predicates)
 Check for errors with regards to the destination file already existing. More...
 
 setFlags (array $params)
 Adjust params to FileBackendStore internal file calls. More...
 

Static Protected Member Functions

static normalizeIfValidStoragePath ( $path)
 Normalize a string if it is a valid storage path. More...
 

Protected Attributes

bool $async = false
 
FileBackendStore $backend
 
string $batchId
 
bool $destExists
 
bool $doOperation = true
 Operation is not a no-op. More...
 
bool $failed = false
 
LoggerInterface $logger
 
bool $overwriteSameCase
 
array $params = []
 
string $sourceSha1
 
int $state = self::STATE_NEW
 

Detailed Description

FileBackend helper class for representing operations.

Do not use this class from places outside FileBackend.

Methods called from FileOpBatch::attempt() should avoid throwing exceptions at all costs. FileOp objects should be lightweight in order to support large arrays in memory and serialization.

Since
1.19

Definition at line 36 of file FileOp.php.

Constructor & Destructor Documentation

◆ __construct()

FileOp::__construct ( FileBackendStore  $backend,
array  $params,
LoggerInterface  $logger 
)
final

Build a new batch file operation transaction.

Parameters
FileBackendStore$backend
array$params
LoggerInterface$loggerPSR logger instance
Exceptions
InvalidArgumentException

Definition at line 82 of file FileOp.php.

References $backend, $logger, $params, allowedParams(), and normalizeIfValidStoragePath().

Member Function Documentation

◆ allowedParams()

FileOp::allowedParams ( )
protected

Get the file operation parameters.

Returns
array (required params list, optional params list, list of params that are paths)

Reimplemented in StoreFileOp, CopyFileOp, DeleteFileOp, DescribeFileOp, MoveFileOp, and CreateFileOp.

Definition at line 336 of file FileOp.php.

Referenced by __construct().

◆ applyDependencies()

FileOp::applyDependencies ( array  $deps)
final

Update a dependency tracking array to account for this operation.

Parameters
array$depsPrior path reads/writes; format of FileOp::newPredicates()
Returns
array

Definition at line 176 of file FileOp.php.

References storagePathsChanged(), and storagePathsRead().

◆ attempt()

FileOp::attempt ( )
final

Attempt the operation.

Returns
StatusValue

Definition at line 291 of file FileOp.php.

References $status, doAttempt(), failed(), logFailure(), StatusValue\newFatal(), StatusValue\newGood(), and STATE_ATTEMPTED.

Referenced by attemptAsync().

◆ attemptAsync()

FileOp::attemptAsync ( )
final

Attempt the operation in the background.

Returns
StatusValue

Definition at line 323 of file FileOp.php.

References attempt().

◆ dependsOn()

FileOp::dependsOn ( array  $deps)
final

Check if this operation changes files listed in $paths.

Parameters
array$depsPrior path reads/writes; format of FileOp::newPredicates()
Returns
bool

Definition at line 189 of file FileOp.php.

References $path, storagePathsChanged(), and storagePathsRead().

◆ doAttempt()

FileOp::doAttempt ( )
protected
Returns
StatusValue

Reimplemented in MoveFileOp, CopyFileOp, StoreFileOp, DeleteFileOp, CreateFileOp, and DescribeFileOp.

Definition at line 314 of file FileOp.php.

References StatusValue\newGood().

Referenced by attempt().

◆ doPrecheck()

FileOp::doPrecheck ( array &  $predicates)
protected
Parameters
array&$predicates
Returns
StatusValue

Reimplemented in StoreFileOp, CopyFileOp, MoveFileOp, CreateFileOp, DeleteFileOp, and DescribeFileOp.

Definition at line 282 of file FileOp.php.

References StatusValue\newGood().

Referenced by precheck().

◆ failed()

FileOp::failed ( )
final

Check if this operation failed precheck() or attempt()

Returns
bool

Definition at line 148 of file FileOp.php.

References $failed.

Referenced by attempt(), and precheck().

◆ fileExists()

FileOp::fileExists (   $source,
array  $predicates 
)
finalprotected

Check if a file will exist in storage when this operation is attempted.

Ideally, the file stat entry should already be preloaded via preloadFileStat(). Otherwise, this will query the backend.

Parameters
string$sourceStorage path
array$predicates
Returns
bool|null Whether the file will exist or null on error

Definition at line 433 of file FileOp.php.

References $params, $source, and true.

Referenced by DeleteFileOp\doPrecheck(), DescribeFileOp\doPrecheck(), CopyFileOp\doPrecheck(), MoveFileOp\doPrecheck(), getJournalEntries(), and precheckDestExistence().

◆ fileSha1()

FileOp::fileSha1 (   $source,
array  $predicates 
)
finalprotected

Get the SHA-1 hash a file in storage will have when this operation is attempted.

Ideally, file the stat entry should already be preloaded via preloadFileStat() and the backend tracks hashes as extended attributes. Otherwise, this will query the backend.

Parameters
string$sourceStorage path
array$predicates
Returns
string|bool The SHA-1 hash the file will have or false if non-existent or on error

Definition at line 453 of file FileOp.php.

References $params, $source, and true.

Referenced by DescribeFileOp\doPrecheck(), getJournalEntries(), and precheckDestExistence().

◆ getBackend()

FileOp::getBackend ( )

Get the backend this operation is for.

Returns
FileBackendStore

Definition at line 470 of file FileOp.php.

References $backend.

◆ getJournalEntries()

FileOp::getJournalEntries ( array  $oPredicates,
array  $nPredicates 
)
final

Get the file journal entries for this file operation.

Parameters
array$oPredicatesPre-op info about files (format of FileOp::newPredicates)
array$nPredicatesPost-op info about files (format of FileOp::newPredicates)
Returns
array

Definition at line 211 of file FileOp.php.

References $path, fileExists(), fileSha1(), storagePathsChanged(), and storagePathsRead().

◆ getParam()

FileOp::getParam (   $name)
final

Get the value of the parameter with the given name.

Parameters
string$name
Returns
mixed Returns null if the parameter is not set

Definition at line 139 of file FileOp.php.

Referenced by CopyFileOp\doAttempt(), MoveFileOp\doAttempt(), DeleteFileOp\doPrecheck(), CreateFileOp\doPrecheck(), CopyFileOp\doPrecheck(), MoveFileOp\doPrecheck(), and precheckDestExistence().

◆ getSourceSha1Base36()

FileOp::getSourceSha1Base36 ( )
protected

precheckDestExistence() helper function to get the source file SHA-1.

Subclasses should overwride this if the source is not in storage.

Returns
string|bool Returns false on failure

Reimplemented in StoreFileOp, and CreateFileOp.

Definition at line 419 of file FileOp.php.

Referenced by precheckDestExistence().

◆ logFailure()

FileOp::logFailure (   $action)
final

Log a file operation failure and preserve any temp files.

Parameters
string$action

Definition at line 479 of file FileOp.php.

References $params, and FormatJson\encode().

Referenced by attempt().

◆ newDependencies()

static FileOp::newDependencies ( )
staticfinal

Get a new empty dependency tracking array for paths read/written to.

Returns
array

Definition at line 166 of file FileOp.php.

Referenced by FileOpBatch\attempt().

◆ newPredicates()

static FileOp::newPredicates ( )
staticfinal

Get a new empty predicates array for precheck()

Returns
array

Definition at line 157 of file FileOp.php.

Referenced by FileOpBatch\attempt().

◆ normalizeIfValidStoragePath()

static FileOp::normalizeIfValidStoragePath (   $path)
staticprotected

Normalize a string if it is a valid storage path.

Parameters
string$path
Returns
string

Definition at line 114 of file FileOp.php.

References $path, $res, FileBackend\isStoragePath(), and FileBackend\normalizeStoragePath().

Referenced by __construct().

◆ precheck()

FileOp::precheck ( array &  $predicates)
final

Check preconditions of the operation without writing anything.

This must update $predicates for each path that the op can change except when a failing StatusValue object is returned.

Parameters
array&$predicates
Returns
StatusValue

Definition at line 253 of file FileOp.php.

References $status, doPrecheck(), failed(), StatusValue\newFatal(), StatusValue\newGood(), STATE_CHECKED, storagePathsChanged(), and storagePathsRead().

◆ precheckDestExistence()

FileOp::precheckDestExistence ( array  $predicates)
protected

Check for errors with regards to the destination file already existing.

Also set the destExists, overwriteSameCase and sourceSha1 member variables. A bad StatusValue will be returned if there is no chance it can be overwritten.

Parameters
array$predicates
Returns
StatusValue

Definition at line 376 of file FileOp.php.

References $status, fileExists(), fileSha1(), getParam(), getSourceSha1Base36(), and StatusValue\newGood().

Referenced by CreateFileOp\doPrecheck(), CopyFileOp\doPrecheck(), MoveFileOp\doPrecheck(), and StoreFileOp\doPrecheck().

◆ setBatchId()

FileOp::setBatchId (   $batchId)
final

Set the batch UUID this operation belongs to.

Parameters
string$batchId

Definition at line 129 of file FileOp.php.

References $batchId.

◆ setFlags()

FileOp::setFlags ( array  $params)
protected

Adjust params to FileBackendStore internal file calls.

Parameters
array$params
Returns
array (required params list, optional params list)

Definition at line 346 of file FileOp.php.

References $async, and $params.

Referenced by DescribeFileOp\doAttempt(), CreateFileOp\doAttempt(), DeleteFileOp\doAttempt(), StoreFileOp\doAttempt(), CopyFileOp\doAttempt(), and MoveFileOp\doAttempt().

◆ storagePathsChanged()

FileOp::storagePathsChanged ( )

Get a list of storage paths written to for this operation.

Returns
array

Reimplemented in MoveFileOp, CopyFileOp, StoreFileOp, CreateFileOp, DeleteFileOp, and DescribeFileOp.

Definition at line 364 of file FileOp.php.

Referenced by applyDependencies(), dependsOn(), getJournalEntries(), and precheck().

◆ storagePathsRead()

FileOp::storagePathsRead ( )

Get a list of storage paths read from for this operation.

Returns
array

Reimplemented in MoveFileOp, and CopyFileOp.

Definition at line 355 of file FileOp.php.

Referenced by applyDependencies(), dependsOn(), getJournalEntries(), and precheck().

Member Data Documentation

◆ $async

bool FileOp::$async = false
protected

Definition at line 52 of file FileOp.php.

Referenced by setFlags().

◆ $backend

FileBackendStore FileOp::$backend
protected

Definition at line 41 of file FileOp.php.

Referenced by __construct(), and getBackend().

◆ $batchId

string FileOp::$batchId
protected

Definition at line 55 of file FileOp.php.

Referenced by setBatchId().

◆ $destExists

bool FileOp::$destExists
protected

◆ $doOperation

bool FileOp::$doOperation = true
protected

Operation is not a no-op.

Definition at line 58 of file FileOp.php.

◆ $failed

bool FileOp::$failed = false
protected

Definition at line 49 of file FileOp.php.

Referenced by failed().

◆ $logger

LoggerInterface FileOp::$logger
protected

Definition at line 43 of file FileOp.php.

Referenced by __construct().

◆ $overwriteSameCase

bool FileOp::$overwriteSameCase
protected

Definition at line 64 of file FileOp.php.

◆ $params

array FileOp::$params = []
protected

Definition at line 38 of file FileOp.php.

Referenced by __construct(), fileExists(), fileSha1(), logFailure(), and setFlags().

◆ $sourceSha1

string FileOp::$sourceSha1
protected

◆ $state

int FileOp::$state = self::STATE_NEW
protected

Definition at line 46 of file FileOp.php.

◆ STATE_ATTEMPTED

const FileOp::STATE_ATTEMPTED = 3

Definition at line 72 of file FileOp.php.

Referenced by attempt().

◆ STATE_CHECKED

const FileOp::STATE_CHECKED = 2

Definition at line 71 of file FileOp.php.

Referenced by precheck().

◆ STATE_NEW

const FileOp::STATE_NEW = 1

Definition at line 70 of file FileOp.php.


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