MediaWiki
1.23.0
|
Web access for files temporarily stored by UploadStash. More...
Public Member Functions | |
__construct () | |
execute ( $subPage) | |
Execute page – can output a file directly or show a listing of them. More... | |
showUpload ( $key) | |
If file available in stash, cats it out to the client as a simple HTTP response. More... | |
Public Member Functions inherited from UnlistedSpecialPage | |
__construct ( $name, $restriction='', $function=false, $file='default') | |
isListed () | |
Whether this special page is listed in Special:SpecialPages. More... | |
Public Member Functions inherited from SpecialPage | |
__construct ( $name='', $restriction='', $listed=true, $function=false, $file='default', $includable=false) | |
Default constructor for special pages Derivative classes should call this from their constructor Note that if the user does not have the required level, an error message will be displayed by the default execute() method, without the global function ever being called. More... | |
checkPermissions () | |
Checks if userCanExecute, and if not throws a PermissionsError. More... | |
checkReadOnly () | |
If the wiki is currently in readonly mode, throws a ReadOnlyError. More... | |
displayRestrictionError () | |
Output an error message telling the user what access level they have to have. More... | |
getContext () | |
Gets the context this SpecialPage is executed in. More... | |
getDescription () | |
Returns the name that goes in the <h1> in the special page itself, and also the name that will be listed in Special:Specialpages. More... | |
getFile () | |
Get the file which will be included by SpecialPage::execute() if your extension is still stuck in the past and hasn't overridden the execute() method. More... | |
getFinalGroupName () | |
Get the group that the special page belongs in on Special:SpecialPage Use this method, instead of getGroupName to allow customization of the group name from the wiki side. More... | |
getFullTitle () | |
Return the full title, including $par. More... | |
getLang () | |
Shortcut to get user's language. More... | |
getLanguage () | |
Shortcut to get user's language. More... | |
getLocalName () | |
Get the localised name of the special page. More... | |
getName () | |
Get the name of this Special Page. More... | |
getOutput () | |
Get the OutputPage being used for this instance. More... | |
getPageTitle ( $subpage=false) | |
Get a self-referential title object. More... | |
getRequest () | |
Get the WebRequest being used for this instance. More... | |
getRestriction () | |
Get the permission that a user must have to execute this page. More... | |
getSkin () | |
Shortcut to get the skin being used for this instance. More... | |
getTitle ( $subpage=false) | |
Get a self-referential title object. More... | |
getUser () | |
Shortcut to get the User executing this instance. More... | |
including ( $x=null) | |
Whether the special page is being evaluated via transclusion. More... | |
isCached () | |
Is this page cached? Expensive pages are cached or disabled in miser mode. More... | |
isExpensive () | |
Is this page expensive (for some definition of expensive)? Expensive pages are disabled or cached in miser mode. More... | |
isIncludable () | |
Whether it's allowed to transclude the special page via {{Special:Foo/params}}. More... | |
isRestricted () | |
Can be overridden by subclasses with more complicated permissions schemes. More... | |
listed ( $x=null) | |
Get or set whether this special page is listed in Special:SpecialPages. More... | |
msg () | |
Wrapper around wfMessage that sets the current context. More... | |
outputHeader ( $summaryMessageKey='') | |
Outputs a summary message on top of special pages Per default the message key is the canonical name of the special page May be overridden, i.e. More... | |
requireLogin ( $reasonMsg=null, $titleMsg=null) | |
If the user is not logged in, throws UserNotLoggedIn error. More... | |
run ( $subPage) | |
Entry point. More... | |
setContext ( $context) | |
Sets the context this SpecialPage is executed in. More... | |
setHeaders () | |
Sets headers - this should be called from the execute() method of all derived classes! More... | |
setListed ( $listed) | |
Set whether this page is listed in Special:Specialpages, at run-time. More... | |
userCanExecute (User $user) | |
Checks if the given user (identified by an object) can execute this special page (as defined by $mRestriction). More... | |
Static Public Member Functions | |
static | tryClearStashedUploads ( $formData) |
Static callback for the HTMLForm in showUploads, to process Note the stash has to be recreated since this is being called in a static context. More... | |
Static Public Member Functions inherited from SpecialPage | |
static | getSafeTitleFor ( $name, $subpage=false) |
Get a localised Title object for a page name with a possibly unvalidated subpage. More... | |
static | getTitleFor ( $name, $subpage=false, $fragment='') |
Get a localised Title object for a specified special page name. More... | |
Public Attributes | |
const | MAX_SERVE_BYTES = 1048576 |
Private Member Functions | |
outputContents ( $content, $contentType) | |
Output HTTP response of raw content Side effect: writes HTTP response to STDOUT. More... | |
outputLocalFile (File $file) | |
Output HTTP response for file Side effect: writes HTTP response to STDOUT. More... | |
outputLocallyScaledThumb ( $file, $params, $flags) | |
Scale a file (probably with a locally installed imagemagick, or similar) and output it to STDOUT. More... | |
outputRemoteScaledThumb ( $file, $params, $flags) | |
Scale a file with a remote "scaler", as exists on the Wikimedia Foundation cluster, and output it to STDOUT. More... | |
outputThumbFromStash ( $file, $params) | |
Get a thumbnail for file, either generated locally or remotely, and stream it out. More... | |
parseKey ( $key) | |
Parse the key passed to the SpecialPage. More... | |
showUploads () | |
Default action when we don't have a subpage – just show links to the uploads we have, Also show a button to clear stashed files. More... | |
Static Private Member Functions | |
static | outputFileHeaders ( $contentType, $size) |
Output headers for streaming. More... | |
Private Attributes | |
$stash | |
Additional Inherited Members | |
Protected Member Functions inherited from SpecialPage | |
addFeedLinks ( $params) | |
Adds RSS/atom links. More... | |
afterExecute ( $subPage) | |
Gets called after. More... | |
beforeExecute ( $subPage) | |
Gets called before. More... | |
getGroupName () | |
Under which header this special page is listed in Special:SpecialPages See messages 'specialpages-group-*' for valid names This method defaults to group 'other'. More... | |
getRobotPolicy () | |
Return the robot policy. More... | |
Protected Attributes inherited from SpecialPage | |
IContextSource | $mContext |
Current request context. More... | |
$mIncludable | |
$mIncluding | |
$mName | |
Web access for files temporarily stored by UploadStash.
For example – files that were uploaded with the UploadWizard extension are stored temporarily before committing them to the db. But we want to see their thumbnails and get other information about them.
Since this is based on the user's session, in effect this creates a private temporary file area. However, the URLs for the files cannot be shared.
Definition at line 35 of file SpecialUploadStash.php.
SpecialUploadStash::__construct | ( | ) |
Definition at line 49 of file SpecialUploadStash.php.
References $e, and RepoGroup\singleton().
SpecialUploadStash::execute | ( | $subPage | ) |
Execute page – can output a file directly or show a listing of them.
string | $subPage | subpage, e.g. in http://example.com/wiki/Special:UploadStash/foo.jpg, the "foo.jpg" part |
Reimplemented from SpecialPage.
Definition at line 64 of file SpecialUploadStash.php.
References SpecialPage\checkPermissions(), showUpload(), and showUploads().
|
private |
Output HTTP response of raw content Side effect: writes HTTP response to STDOUT.
string | $content | content |
string | $contentType | mime type |
SpecialUploadStashTooLargeException |
Definition at line 302 of file SpecialUploadStash.php.
References $size, and outputFileHeaders().
Referenced by outputRemoteScaledThumb().
|
staticprivate |
Output headers for streaming.
Side effect: preps PHP to write headers to STDOUT.
string | $contentType | String suitable for content-type header |
string | $size | Length in bytes |
Definition at line 322 of file SpecialUploadStash.php.
Referenced by outputContents().
|
private |
Output HTTP response for file Side effect: writes HTTP response to STDOUT.
File | $file | File object with a local path (e.g. UnregisteredLocalFile, LocalFile. Oddly these don't share an ancestor!) |
SpecialUploadStashTooLargeException |
Definition at line 283 of file SpecialUploadStash.php.
References $file, array(), and MAX_SERVE_BYTES.
Referenced by outputLocallyScaledThumb(), and showUpload().
|
private |
Scale a file (probably with a locally installed imagemagick, or similar) and output it to STDOUT.
$file | File | |
array | $params | Scaling parameters ( e.g. array( width => '50' ) ); |
int | $flags | Scaling flags ( see File:: constants ) |
MWException|UploadStashFileNotFoundException |
Definition at line 186 of file SpecialUploadStash.php.
References $file, $flags, $params, false, outputLocalFile(), and File\RENDER_NOW.
Referenced by outputThumbFromStash().
|
private |
Scale a file with a remote "scaler", as exists on the Wikimedia Foundation cluster, and output it to STDOUT.
Note: Unlike the usual thumbnail process, the web client never sees the cluster URL; we do the whole HTTP transaction to the scaler ourselves and cat the results out. Note: We rely on NFS to have propagated the file contents to the scaler. However, we do not rely on the thumbnail being created in NFS and then propagated back to our filesystem. Instead we take the results of the HTTP request instead. Note: No caching is being done here, although we are instructing the client to cache it forever.
File | $file | |
array | $params | Scaling parameters ( e.g. array( width => '50' ) ); |
int | $flags | Scaling flags ( see File:: constants ) |
MWException |
Definition at line 232 of file SpecialUploadStash.php.
References $file, $params, array(), MWHttpRequest\factory(), global, outputContents(), PROTO_CANONICAL, and wfExpandUrl().
Referenced by outputThumbFromStash().
|
private |
Get a thumbnail for file, either generated locally or remotely, and stream it out.
$file | |
$params | array |
Definition at line 161 of file SpecialUploadStash.php.
References $file, $flags, $params, global, outputLocallyScaledThumb(), and outputRemoteScaledThumb().
Referenced by showUpload().
|
private |
Parse the key passed to the SpecialPage.
Returns an array containing the associated file object, the type ('file' or 'thumb') and if application the transform parameters
string | $key |
UploadStashBadPathException |
Definition at line 123 of file SpecialUploadStash.php.
References $file, $params, $type, and array().
Referenced by showUpload().
SpecialUploadStash::showUpload | ( | $key | ) |
If file available in stash, cats it out to the client as a simple HTTP response.
n.b. Most sanity checking done in UploadStashLocalFile, so this is straightforward.
string | $key | the key of a particular requested file |
HttpError |
Definition at line 82 of file SpecialUploadStash.php.
References $e, $params, SpecialPage\getOutput(), outputLocalFile(), outputThumbFromStash(), and parseKey().
Referenced by execute().
|
private |
Default action when we don't have a subpage – just show links to the uploads we have, Also show a button to clear stashed files.
Definition at line 357 of file SpecialUploadStash.php.
References $file, $files, $form, array(), as, Html\element(), SpecialPage\getContext(), SpecialPage\getOutput(), SpecialPage\getPageTitle(), SpecialPage\msg(), SpecialPage\outputHeader(), Html\rawElement(), SpecialPage\setHeaders(), and text.
Referenced by execute().
|
static |
Static callback for the HTMLForm in showUploads, to process Note the stash has to be recreated since this is being called in a static context.
This works, because there really is only one stash per logged-in user, despite appearances.
array | $formData |
Definition at line 339 of file SpecialUploadStash.php.
References $stash, Status\newFatal(), Status\newGood(), RepoGroup\singleton(), true, and wfDebug().
|
private |
Definition at line 37 of file SpecialUploadStash.php.
Referenced by tryClearStashedUploads().
const SpecialUploadStash::MAX_SERVE_BYTES = 1048576 |
Definition at line 47 of file SpecialUploadStash.php.
Referenced by outputLocalFile().