MediaWiki
1.23.0
|
UploadStash is intended to accomplish a few things: More...
Public Member Functions | |
__construct (FileRepo $repo, $user=null) | |
Represents a temporary filestore, with metadata in the database. More... | |
clear () | |
Remove all files from the stash. More... | |
getFile ( $key, $noAuth=false) | |
Get a file and its metadata from the stash. More... | |
getFileProps ( $key) | |
Getter for fileProps. More... | |
getMetadata ( $key) | |
Getter for file metadata. More... | |
listFiles () | |
List all files in the stash. More... | |
removeFile ( $key) | |
Remove a particular file from the stash. More... | |
removeFileNoAuth ( $key) | |
Remove a file (see removeFile), but doesn't check ownership first. More... | |
stashFile ( $path, $sourceType=null) | |
Stash a file in a temp directory and record that we did this in the database, along with other metadata. More... | |
Static Public Member Functions | |
static | getExtensionForPath ( $path) |
Find or guess extension – ensuring that our extension matches our mime type. More... | |
Public Attributes | |
$isLoggedIn | |
LocalRepo | $repo |
repository that this uses to store temp files public because we sometimes need to get a LocalFile within the same repo. More... | |
$userId | |
const | KEY_FORMAT_REGEX = '/^[\w-\.]+\.\w*$/' |
Protected Member Functions | |
fetchFileMetadata ( $key, $readFromDB=DB_SLAVE) | |
Helper function: do the actual database query to fetch file metadata. More... | |
initFile ( $key) | |
Helper function: Initialize the UploadStashFile for a given file. More... | |
Protected Attributes | |
$fileMetadata = array() | |
$fileProps = array() | |
$files = array() | |
$user | |
UploadStash is intended to accomplish a few things:
UploadStash right now is mostly intended to show you one user's slice of the entire stash. The user parameter is only optional because there are few cases where we clean out the stash from an automated script. In the future we might refactor this.
UploadStash represents the entire stash of temporary files. UploadStashFile is a filestore for the actual physical disk files. UploadFromStash extends UploadBase, and represents a single stashed file as it is moved from the stash to the regular file repository
Definition at line 44 of file UploadStash.php.
UploadStash::__construct | ( | FileRepo | $repo, |
$user = null |
|||
) |
Represents a temporary filestore, with metadata in the database.
Designed to be compatible with the session stashing code in UploadBase (should replace it eventually).
Definition at line 76 of file UploadStash.php.
UploadStash::clear | ( | ) |
Remove all files from the stash.
Does not clean up files in the repo, just the record of them.
UploadStashNotLoggedInException |
Definition at line 297 of file UploadStash.php.
|
protected |
|
static |
Find or guess extension – ensuring that our extension matches our mime type.
Since these files are constructed from php tempnames they may not start off with an extension. XXX this is somewhat redundant with the checks that ApiUpload.php does with incoming uploads versus the desired filename. Maybe we can get that passed to us...
$path |
UploadStashFileException |
Definition at line 424 of file UploadStash.php.
References $extensions, $n, $path, global, and File\normalizeExtension().
Referenced by stashFile().
UploadStash::getFile | ( | $key, | |
$noAuth = false |
|||
) |
Get a file and its metadata from the stash.
The noAuth param is a bit janky but is required for automated scripts which clean out the stash.
string | $key | key under which file information is stored |
$noAuth | Boolean (optional) Don't check authentication. Used by maintenance scripts. |
UploadStashFileNotFoundException | |
UploadStashNotLoggedInException | |
UploadStashWrongOwnerException | |
UploadStashBadPathException |
Definition at line 107 of file UploadStash.php.
References $path, DB_MASTER, fetchFileMetadata(), initFile(), and wfDebug().
Referenced by getFileProps(), getMetadata(), removeFileNoAuth(), and stashFile().
UploadStash::getFileProps | ( | $key | ) |
Getter for fileProps.
string | $key | key under which file information is stored |
Definition at line 171 of file UploadStash.php.
References getFile().
UploadStash::getMetadata | ( | $key | ) |
Getter for file metadata.
string | $key | key under which file information is stored |
Definition at line 160 of file UploadStash.php.
References getFile().
|
protected |
Helper function: Initialize the UploadStashFile for a given file.
string | $key | key under which to store the object |
UploadStashZeroLengthFileException |
Definition at line 498 of file UploadStash.php.
References $file.
Referenced by getFile(), and stashFile().
UploadStash::listFiles | ( | ) |
List all files in the stash.
UploadStashNotLoggedInException |
Definition at line 387 of file UploadStash.php.
UploadStash::removeFile | ( | $key | ) |
Remove a particular file from the stash.
Also removes it from the repo.
string | $key |
UploadStashNoSuchKeyException|UploadStashNotLoggedInException|UploadStashWrongOwnerException |
Definition at line 324 of file UploadStash.php.
References array(), and removeFileNoAuth().
UploadStash::removeFileNoAuth | ( | $key | ) |
Remove a file (see removeFile), but doesn't check ownership first.
string | $key |
Definition at line 357 of file UploadStash.php.
References array(), getFile(), and wfDebug().
Referenced by removeFile().
UploadStash::stashFile | ( | $path, | |
$sourceType = null |
|||
) |
Stash a file in a temp directory and record that we did this in the database, along with other metadata.
string | $path | Path to file you want stashed |
string | $sourceType | The type of upload that generated this file (currently, I believe, 'file' or null) |
Definition at line 186 of file UploadStash.php.
References $error, $fileProps, $path, $userId, array(), getExtensionForPath(), getFile(), FSFile\getPropsFromPath(), initFile(), list, text, wfBaseConvert(), wfDebug(), and wfMessage().
|
protected |
Definition at line 60 of file UploadStash.php.
|
protected |
Definition at line 63 of file UploadStash.php.
Referenced by stashFile().
|
protected |
Definition at line 57 of file UploadStash.php.
UploadStash::$isLoggedIn |
Definition at line 66 of file UploadStash.php.
LocalRepo UploadStash::$repo |
repository that this uses to store temp files public because we sometimes need to get a LocalFile within the same repo.
Definition at line 54 of file UploadStash.php.
Referenced by __construct().
|
protected |
Definition at line 66 of file UploadStash.php.
Referenced by __construct().
UploadStash::$userId |
Definition at line 66 of file UploadStash.php.
Referenced by stashFile().
Definition at line 47 of file UploadStash.php.
Referenced by UploadFromStash\isValidKey().