MediaWiki REL1_35
|
Web access for files temporarily stored by UploadStash. More...
Public Member Functions | |
__construct () | |
doesWrites () | |
Indicates whether this special page may perform database writes. | |
execute ( $subPage) | |
Execute page – can output a file directly or show a listing of them. | |
showUpload ( $key) | |
If file available in stash, cats it out to the client as a simple HTTP response. | |
Public Member Functions inherited from UnlistedSpecialPage | |
__construct ( $name, $restriction='', $function=false, $file='default') | |
Stable to call. | |
isListed () | |
Whether this special page is listed in Special:SpecialPages Stable to override. | |
Public Member Functions inherited from SpecialPage | |
__construct ( $name='', $restriction='', $listed=true, $function=false, $file='', $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. | |
addHelpLink ( $to, $overrideBaseUrl=false) | |
Adds help link with an icon via page indicators. | |
checkPermissions () | |
Checks if userCanExecute, and if not throws a PermissionsError. | |
checkReadOnly () | |
If the wiki is currently in readonly mode, throws a ReadOnlyError. | |
getConfig () | |
Shortcut to get main config object. | |
getContext () | |
Gets the context this SpecialPage is executed in. | |
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. | |
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. | |
getFullTitle () | |
Return the full title, including $par. | |
getLanguage () | |
Shortcut to get user's language. | |
getLinkRenderer () | |
getLocalName () | |
Get the localised name of the special page Stable to override. | |
getName () | |
Get the name of this Special Page. | |
getOutput () | |
Get the OutputPage being used for this instance. | |
getPageTitle ( $subpage=false) | |
Get a self-referential title object. | |
getRequest () | |
Get the WebRequest being used for this instance. | |
getRestriction () | |
Get the permission that a user must have to execute this page. | |
getSkin () | |
Shortcut to get the skin being used for this instance. | |
getUser () | |
Shortcut to get the User executing this instance. | |
including ( $x=null) | |
Whether the special page is being evaluated via transclusion. | |
isCached () | |
Is this page cached? Expensive pages are cached or disabled in miser mode. | |
isExpensive () | |
Is this page expensive (for some definition of expensive)? Expensive pages are disabled or cached in miser mode. | |
isIncludable () | |
Whether it's allowed to transclude the special page via {{Special:Foo/params}} Stable to override. | |
isRestricted () | |
Can be overridden by subclasses with more complicated permissions schemes. | |
listed ( $x=null) | |
Get or set whether this special page is listed in Special:SpecialPages. | |
maxIncludeCacheTime () | |
How long to cache page when it is being included. | |
msg ( $key,... $params) | |
Wrapper around wfMessage that sets the current context. | |
prefixSearchSubpages ( $search, $limit, $offset) | |
Return an array of subpages beginning with $search that this special page will accept. | |
requireLogin ( $reasonMsg='exception-nologin-text', $titleMsg='exception-nologin') | |
If the user is not logged in, throws UserNotLoggedIn error. | |
run ( $subPage) | |
Entry point. | |
setContext ( $context) | |
Sets the context this SpecialPage is executed in. | |
setHookContainer (HookContainer $hookContainer) | |
setLinkRenderer (LinkRenderer $linkRenderer) | |
setListed ( $listed) | |
Set whether this page is listed in Special:Specialpages, at run-time. | |
userCanExecute (User $user) | |
Checks if the given user (identified by an object) can execute this special page (as defined by $mRestriction). | |
Static Public Member Functions | |
static | tryClearStashedUploads ( $formData, $form) |
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. | |
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. | |
static | getTitleFor ( $name, $subpage=false, $fragment='') |
Get a localised Title object for a specified special page name If you don't need a full Title object, consider using TitleValue through getTitleValueFor() below. | |
static | getTitleValueFor ( $name, $subpage=false, $fragment='') |
Get a localised TitleValue object for a specified special page name. | |
Private Member Functions | |
outputContents ( $content, $contentType) | |
Output HTTP response of raw content Side effect: writes HTTP response to STDOUT. | |
outputLocalFile (File $file) | |
Output HTTP response for file Side effect: writes HTTP response to STDOUT. | |
outputLocallyScaledThumb ( $file, $params, $flags) | |
Scale a file (probably with a locally installed imagemagick, or similar) and output it to STDOUT. | |
outputRemoteScaledThumb ( $file, $params, $flags) | |
Scale a file with a remote "scaler", as exists on the Wikimedia Foundation cluster, and output it to STDOUT. | |
outputThumbFromStash ( $file, $params) | |
Get a thumbnail for file, either generated locally or remotely, and stream it out. | |
parseKey ( $key) | |
Parse the key passed to the SpecialPage. | |
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. | |
Static Private Member Functions | |
static | outputFileHeaders ( $contentType, $size) |
Output headers for streaming. | |
Private Attributes | |
$stash | |
const | MAX_SERVE_BYTES = 1048576 |
Since we are directly writing the file to STDOUT, we should not be reading in really big files and serving them out. | |
Additional Inherited Members | |
Protected Member Functions inherited from SpecialPage | |
addFeedLinks ( $params) | |
Adds RSS/atom links. | |
afterExecute ( $subPage) | |
Gets called after. | |
beforeExecute ( $subPage) | |
Gets called before. | |
buildPrevNextNavigation ( $offset, $limit, array $query=[], $atend=false, $subpage=false) | |
Generate (prev x| next x) (20|50|100...) type links for paging. | |
checkLoginSecurityLevel ( $level=null) | |
Verifies that the user meets the security level, possibly reauthenticating them in the process. | |
displayRestrictionError () | |
Output an error message telling the user what access level they have to have Stable to override. | |
getCacheTTL () | |
Stable to override. | |
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'. | |
getHookContainer () | |
getHookRunner () | |
getLanguageConverter () | |
Shortcut to get language's converter. | |
getLoginSecurityLevel () | |
Tells if the special page does something security-sensitive and needs extra defense against a stolen account (e.g. | |
getRobotPolicy () | |
Return the robot policy. | |
getSubpagesForPrefixSearch () | |
Return an array of subpages that this special page will accept for prefix searches. | |
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. | |
prefixSearchString ( $search, $limit, $offset) | |
Perform a regular substring search for prefixSearchSubpages. | |
setHeaders () | |
Sets headers - this should be called from the execute() method of all derived classes! Stable to override. | |
setReauthPostData (array $data) | |
Record preserved POST data after a reauthentication. | |
useTransactionalTimeLimit () | |
Call wfTransactionalTimeLimit() if this request was POSTed. | |
Static Protected Member Functions inherited from SpecialPage | |
static | prefixSearchArray ( $search, $limit, array $subpages, $offset) |
Helper function for implementations of prefixSearchSubpages() that filter the values in memory (as opposed to making a query). | |
Protected Attributes inherited from SpecialPage | |
IContextSource | $mContext |
Current request context. | |
$mIncludable | |
$mIncluding | |
$mName | |
$mRestriction | |
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 38 of file SpecialUploadStash.php.
SpecialUploadStash::__construct | ( | ) |
Definition at line 54 of file SpecialUploadStash.php.
SpecialUploadStash::doesWrites | ( | ) |
Indicates whether this special page may perform database writes.
Stable to override
Reimplemented from SpecialPage.
Definition at line 58 of file SpecialUploadStash.php.
SpecialUploadStash::execute | ( | $subPage | ) |
Execute page – can output a file directly or show a listing of them.
string | null | $subPage | Subpage, e.g. in https://example.com/wiki/Special:UploadStash/foo.jpg, the "foo.jpg" part |
Reimplemented from SpecialPage.
Definition at line 68 of file SpecialUploadStash.php.
References SpecialPage\checkPermissions(), SpecialPage\getUser(), showUpload(), showUploads(), and SpecialPage\useTransactionalTimeLimit().
|
private |
Output HTTP response of raw content Side effect: writes HTTP response to STDOUT.
string | $content | |
string | $contentType | MIME type |
SpecialUploadStashTooLargeException |
Definition at line 323 of file SpecialUploadStash.php.
References $content, SpecialPage\msg(), outputFileHeaders(), print, and wfResetOutputBuffers().
Referenced by outputRemoteScaledThumb().
|
staticprivate |
Output headers for streaming.
$contentType
as it usually is. 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 345 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 303 of file SpecialUploadStash.php.
References $file, and SpecialPage\msg().
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. [ width => '50' ] ); |
int | $flags | Scaling flags ( see File:: constants ) |
MWException|UploadStashFileNotFoundException |
Definition at line 184 of file SpecialUploadStash.php.
References $file, SpecialPage\msg(), and outputLocalFile().
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. [ width => '50' ] ); |
int | $flags | Scaling flags ( see File:: constants ) |
MWException |
Definition at line 230 of file SpecialUploadStash.php.
References $file, SpecialPage\getConfig(), SpecialPage\msg(), outputContents(), PROTO_CANONICAL, and wfExpandUrl().
Referenced by outputThumbFromStash().
|
private |
Get a thumbnail for file, either generated locally or remotely, and stream it out.
File | $file | |
array | $params |
Definition at line 162 of file SpecialUploadStash.php.
References $file, SpecialPage\getConfig(), 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 121 of file SpecialUploadStash.php.
References $file, $type, and SpecialPage\msg().
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 89 of file SpecialUploadStash.php.
References 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 381 of file SpecialUploadStash.php.
References $file, SpecialPage\$linkRenderer, SpecialPage\getContext(), SpecialPage\getLinkRenderer(), SpecialPage\getOutput(), SpecialPage\getPageTitle(), SpecialPage\msg(), SpecialPage\outputHeader(), and SpecialPage\setHeaders().
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 | |
HTMLForm | $form |
Definition at line 363 of file SpecialUploadStash.php.
|
private |
Definition at line 40 of file SpecialUploadStash.php.
Referenced by tryClearStashedUploads().
|
private |
Since we are directly writing the file to STDOUT, we should not be reading in really big files and serving them out.
We also don't want people using this as a file drop, even if they share credentials.
This service is really for thumbnails and other such previews while uploading.
Definition at line 52 of file SpecialUploadStash.php.