MediaWiki  1.23.0
SpecialUploadStash Class Reference

Web access for files temporarily stored by UploadStash. More...

Inheritance diagram for SpecialUploadStash:
Collaboration diagram for SpecialUploadStash:

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
 

Detailed Description

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.

Constructor & Destructor Documentation

◆ __construct()

SpecialUploadStash::__construct ( )

Definition at line 49 of file SpecialUploadStash.php.

References $e, and RepoGroup\singleton().

Member Function Documentation

◆ execute()

SpecialUploadStash::execute (   $subPage)

Execute page – can output a file directly or show a listing of them.

Parameters
string$subPagesubpage, e.g. in http://example.com/wiki/Special:UploadStash/foo.jpg, the "foo.jpg" part
Returns
Boolean: success

Reimplemented from SpecialPage.

Definition at line 64 of file SpecialUploadStash.php.

References SpecialPage\checkPermissions(), showUpload(), and showUploads().

◆ outputContents()

SpecialUploadStash::outputContents (   $content,
  $contentType 
)
private

Output HTTP response of raw content Side effect: writes HTTP response to STDOUT.

Parameters
string$contentcontent
string$contentTypemime type
Exceptions
SpecialUploadStashTooLargeException
Returns
bool

Definition at line 302 of file SpecialUploadStash.php.

References $size, and outputFileHeaders().

Referenced by outputRemoteScaledThumb().

◆ outputFileHeaders()

static SpecialUploadStash::outputFileHeaders (   $contentType,
  $size 
)
staticprivate

Output headers for streaming.

Todo:
Unsure about encoding as binary; if we received from HTTP perhaps we should use that encoding, concatted with semicolon to mimeType as it usually is.

Side effect: preps PHP to write headers to STDOUT.

Parameters
string$contentTypeString suitable for content-type header
string$sizeLength in bytes

Definition at line 322 of file SpecialUploadStash.php.

Referenced by outputContents().

◆ outputLocalFile()

SpecialUploadStash::outputLocalFile ( File  $file)
private

Output HTTP response for file Side effect: writes HTTP response to STDOUT.

Parameters
File$fileFile object with a local path (e.g. UnregisteredLocalFile, LocalFile. Oddly these don't share an ancestor!)
Exceptions
SpecialUploadStashTooLargeException
Returns
bool

Definition at line 283 of file SpecialUploadStash.php.

References $file, array(), and MAX_SERVE_BYTES.

Referenced by outputLocallyScaledThumb(), and showUpload().

◆ outputLocallyScaledThumb()

SpecialUploadStash::outputLocallyScaledThumb (   $file,
  $params,
  $flags 
)
private

Scale a file (probably with a locally installed imagemagick, or similar) and output it to STDOUT.

Parameters
$fileFile
array$paramsScaling parameters ( e.g. array( width => '50' ) );
int$flagsScaling flags ( see File:: constants )
Exceptions
MWException|UploadStashFileNotFoundException
Returns
boolean success

Definition at line 186 of file SpecialUploadStash.php.

References $file, $flags, $params, false, outputLocalFile(), and File\RENDER_NOW.

Referenced by outputThumbFromStash().

◆ outputRemoteScaledThumb()

SpecialUploadStash::outputRemoteScaledThumb (   $file,
  $params,
  $flags 
)
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.

Parameters
File$file
array$paramsScaling parameters ( e.g. array( width => '50' ) );
int$flagsScaling flags ( see File:: constants )
Exceptions
MWException
Returns
boolean success

Definition at line 232 of file SpecialUploadStash.php.

References $file, $params, array(), MWHttpRequest\factory(), global, outputContents(), PROTO_CANONICAL, and wfExpandUrl().

Referenced by outputThumbFromStash().

◆ outputThumbFromStash()

SpecialUploadStash::outputThumbFromStash (   $file,
  $params 
)
private

Get a thumbnail for file, either generated locally or remotely, and stream it out.

Parameters
$file
$paramsarray
Returns
boolean success

Definition at line 161 of file SpecialUploadStash.php.

References $file, $flags, $params, global, outputLocallyScaledThumb(), and outputRemoteScaledThumb().

Referenced by showUpload().

◆ parseKey()

SpecialUploadStash::parseKey (   $key)
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

Parameters
string$key
Exceptions
UploadStashBadPathException
Returns
array

Definition at line 123 of file SpecialUploadStash.php.

References $file, $params, $type, and array().

Referenced by showUpload().

◆ 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.

Parameters
string$keythe key of a particular requested file
Exceptions
HttpError
Returns
bool

Definition at line 82 of file SpecialUploadStash.php.

References $e, $params, SpecialPage\getOutput(), outputLocalFile(), outputThumbFromStash(), and parseKey().

Referenced by execute().

◆ showUploads()

SpecialUploadStash::showUploads ( )
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.

Returns
bool

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().

◆ tryClearStashedUploads()

static SpecialUploadStash::tryClearStashedUploads (   $formData)
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.

Parameters
array$formData
Returns
Status

Definition at line 339 of file SpecialUploadStash.php.

References $stash, Status\newFatal(), Status\newGood(), RepoGroup\singleton(), true, and wfDebug().

Member Data Documentation

◆ $stash

SpecialUploadStash::$stash
private

Definition at line 37 of file SpecialUploadStash.php.

Referenced by tryClearStashedUploads().

◆ MAX_SERVE_BYTES

const SpecialUploadStash::MAX_SERVE_BYTES = 1048576

Definition at line 47 of file SpecialUploadStash.php.

Referenced by outputLocalFile().


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