6fbeb519ca811a6f7f7314b445c8a1116db12587
[lhc/web/wiklou.git] / includes / upload / UploadFromStash.php
1 <?php
2 /**
3 * @file
4 * @ingroup upload
5 *
6 * Implements uploading from previously stored file.
7 *
8 * @author Bryan Tong Minh
9 */
10
11 class UploadFromStash extends UploadBase {
12 public static function isValidSessionKey( $key, $sessionData ) {
13 return !empty( $key ) &&
14 is_array( $sessionData ) &&
15 isset( $sessionData[$key] ) &&
16 isset( $sessionData[$key]['version'] ) &&
17 $sessionData[$key]['version'] == self::SESSION_VERSION;
18 }
19
20 public static function isValidRequest( $request ) {
21 $sessionData = $request->getSessionData( 'wsUploadData' );
22 return self::isValidSessionKey(
23 $request->getInt( 'wpSessionKey' ),
24 $sessionData
25 );
26 }
27 /*
28 * some $na vars for uploadBase method compatibility.
29 */
30 public function initialize( $name, $sessionData, $na, $na2=false ) {
31 /**
32 * Confirming a temporarily stashed upload.
33 * We don't want path names to be forged, so we keep
34 * them in the session on the server and just give
35 * an opaque key to the user agent.
36 */
37
38 parent::initialize( $name,
39 $this->getRealPath ( $sessionData['mTempPath'] ),
40 $sessionData['mFileSize'],
41 false
42 );
43
44 $this->mFileProps = $sessionData['mFileProps'];
45 }
46
47 public function initializeFromRequest( &$request ) {
48 $sessionKey = $request->getInt( 'wpSessionKey' );
49 $sessionData = $request->getSessionData('wsUploadData');
50
51 $desiredDestName = $request->getText( 'wpDestFile' );
52 if( !$desiredDestName )
53 $desiredDestName = $request->getText( 'wpUploadFile' );
54 return $this->initialize( $desiredDestName, $sessionData[$sessionKey], false );
55 }
56
57 /**
58 * File has been previously verified so no need to do so again.
59 */
60 protected function verifyFile() {
61 return true;
62 }
63
64 /**
65 * We're here from "ignore warnings anyway" so return just OK
66 */
67 public function checkWarnings() {
68 return array();
69 }
70
71 }