MediaWiki REL1_38
SpecialUploadStash Class Reference

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

Inheritance diagram for SpecialUploadStash:
Collaboration diagram for SpecialUploadStash:

Public Member Functions

 __construct (RepoGroup $repoGroup, HttpRequestFactory $httpRequestFactory)
 
 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')
 
 isListed ()
 Whether this special page is listed in Special:SpecialPages.
 
- 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.
 
 getAuthority ()
 Shortcut to get the Authority executing this instance.
 
 getConfig ()
 Shortcut to get main config object.
 
 getContentLanguage ()
 Shortcut to get content language.
 
 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.
 
 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}}.
 
 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.
 
 setContentLanguage (Language $contentLanguage)
 Set content language.
 
 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.
 
 setSpecialPageFactory (SpecialPageFactory $specialPageFactory)
 
 userCanExecute (User $user)
 Checks if the given user (identified by an object) can execute this special page (as defined by $mRestriction).
 

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

HttpRequestFactory $httpRequestFactory
 
LocalRepo $localRepo
 
UploadStash null $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

- 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.
 
static newSearchPage (User $user)
 Get the users preferred search page.
 
- 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.
 
 getAuthManager ()
 
 getCacheTTL ()
 
 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.
 
 getSpecialPageFactory ()
 
 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, SearchEngineFactory $searchEngineFactory=null)
 Perform a regular substring search for prefixSearchSubpages.
 
 setAuthManager (AuthManager $authManager)
 Set the injected AuthManager from the special page constructor.
 
 setHeaders ()
 Sets headers - this should be called from the execute() method of all derived classes!
 
 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.
 
bool $mIncludable
 Whether the special page can be included in an article.
 
bool $mIncluding
 Whether or not this special page is being included from an article.
 
string $mName
 The canonical name of this special page Also used for the default.
 
string $mRestriction
 Minimum user level required to access this page, or "" for anyone.
 

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 39 of file SpecialUploadStash.php.

Constructor & Destructor Documentation

◆ __construct()

SpecialUploadStash::__construct ( RepoGroup  $repoGroup,
HttpRequestFactory  $httpRequestFactory 
)
Parameters
RepoGroup$repoGroup
HttpRequestFactory$httpRequestFactory

Definition at line 65 of file SpecialUploadStash.php.

References $httpRequestFactory, and RepoGroup\getLocalRepo().

Member Function Documentation

◆ doesWrites()

SpecialUploadStash::doesWrites ( )

Indicates whether this special page may perform database writes.

Stability: stable
to override
Returns
bool
Since
1.27

Reimplemented from SpecialPage.

Definition at line 74 of file SpecialUploadStash.php.

◆ execute()

SpecialUploadStash::execute (   $subPage)

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

Parameters
string | null$subPageSubpage, e.g. in https://example.com/wiki/Special:UploadStash/foo.jpg, the "foo.jpg" part

Reimplemented from SpecialPage.

Definition at line 84 of file SpecialUploadStash.php.

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

◆ outputContents()

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

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

Parameters
string$content
string$contentTypeMIME type
Exceptions
SpecialUploadStashTooLargeException

Definition at line 341 of file SpecialUploadStash.php.

References $content, SpecialPage\msg(), outputFileHeaders(), print, and wfResetOutputBuffers().

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, concatenated with semicolon to $contentType as it usually is. Side effect: preps PHP to write headers to STDOUT.
Parameters
string$contentTypeString suitable for content-type header
int$sizeLength in bytes

Definition at line 363 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

Definition at line 321 of file SpecialUploadStash.php.

References $file, and SpecialPage\msg().

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
File$file
array$paramsScaling parameters ( e.g. [ width => '50' ] );
int$flagsScaling flags ( see File:: constants )
Exceptions
MWException|UploadStashFileNotFoundException

Definition at line 202 of file SpecialUploadStash.php.

References $file, SpecialPage\msg(), and outputLocalFile().

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. [ width => '50' ] );
int$flagsScaling flags ( see File:: constants )
Exceptions
MWException

Definition at line 248 of file SpecialUploadStash.php.

References $file, SpecialPage\getConfig(), SpecialPage\msg(), 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$file
array$params

Definition at line 178 of file SpecialUploadStash.php.

References $file, 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 137 of file SpecialUploadStash.php.

References $file, $type, and SpecialPage\msg().

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 checking done in UploadStashLocalFile, so this is straightforward.

Parameters
string$keyThe key of a particular requested file
Exceptions
HttpError

Definition at line 105 of file SpecialUploadStash.php.

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

Definition at line 376 of file SpecialUploadStash.php.

References $file, SpecialPage\$linkRenderer, SpecialPage\getContext(), SpecialPage\getLinkRenderer(), SpecialPage\getOutput(), SpecialPage\getPageTitle(), MediaWiki\Linker\LinkRenderer\makeKnownLink(), SpecialPage\msg(), SpecialPage\outputHeader(), SpecialPage\setHeaders(), and wfDebug().

Referenced by execute().

Member Data Documentation

◆ $httpRequestFactory

HttpRequestFactory SpecialUploadStash::$httpRequestFactory
private

Definition at line 47 of file SpecialUploadStash.php.

Referenced by __construct().

◆ $localRepo

LocalRepo SpecialUploadStash::$localRepo
private

Definition at line 44 of file SpecialUploadStash.php.

◆ $stash

UploadStash null SpecialUploadStash::$stash
private

Definition at line 41 of file SpecialUploadStash.php.

◆ MAX_SERVE_BYTES

const SpecialUploadStash::MAX_SERVE_BYTES = 1048576
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 59 of file SpecialUploadStash.php.


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