AuthManager phpdoc cleanup
[mediawiki.git] / includes / jobqueue / jobs / AssembleUploadChunksJob.php
blob060cabb6272f04ffacfd247db47ba567ef917cb2
1 <?php
2 /**
3 * Assemble the segments of a chunked upload.
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License along
16 * with this program; if not, write to the Free Software Foundation, Inc.,
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 * http://www.gnu.org/copyleft/gpl.html
20 * @file
21 * @ingroup Upload
24 /**
25 * Assemble the segments of a chunked upload.
27 * @ingroup Upload
29 class AssembleUploadChunksJob extends Job {
30 public function __construct( Title $title, array $params ) {
31 parent::__construct( 'AssembleUploadChunks', $title, $params );
32 $this->removeDuplicates = true;
35 public function run() {
36 $scope = RequestContext::importScopedSession( $this->params['session'] );
37 $this->addTeardownCallback( function () use ( &$scope ) {
38 ScopedCallback::consume( $scope ); // T126450
39 } );
41 $context = RequestContext::getMain();
42 $user = $context->getUser();
43 try {
44 if ( !$user->isLoggedIn() ) {
45 $this->setLastError( "Could not load the author user from session." );
47 return false;
50 UploadBase::setSessionStatus(
51 $user,
52 $this->params['filekey'],
53 [ 'result' => 'Poll', 'stage' => 'assembling', 'status' => Status::newGood() ]
56 $upload = new UploadFromChunks( $user );
57 $upload->continueChunks(
58 $this->params['filename'],
59 $this->params['filekey'],
60 new WebRequestUpload( $context->getRequest(), 'null' )
63 // Combine all of the chunks into a local file and upload that to a new stash file
64 $status = $upload->concatenateChunks();
65 if ( !$status->isGood() ) {
66 UploadBase::setSessionStatus(
67 $user,
68 $this->params['filekey'],
69 [ 'result' => 'Failure', 'stage' => 'assembling', 'status' => $status ]
71 $this->setLastError( $status->getWikiText( false, false, 'en' ) );
73 return false;
76 // We can only get warnings like 'duplicate' after concatenating the chunks
77 $status = Status::newGood();
78 $status->value = [ 'warnings' => $upload->checkWarnings() ];
80 // We have a new filekey for the fully concatenated file
81 $newFileKey = $upload->getStashFile()->getFileKey();
83 // Remove the old stash file row and first chunk file
84 $upload->stash->removeFileNoAuth( $this->params['filekey'] );
86 // Build the image info array while we have the local reference handy
87 $apiMain = new ApiMain(); // dummy object (XXX)
88 $imageInfo = $upload->getImageInfo( $apiMain->getResult() );
90 // Cleanup any temporary local file
91 $upload->cleanupTempFile();
93 // Cache the info so the user doesn't have to wait forever to get the final info
94 UploadBase::setSessionStatus(
95 $user,
96 $this->params['filekey'],
98 'result' => 'Success',
99 'stage' => 'assembling',
100 'filekey' => $newFileKey,
101 'imageinfo' => $imageInfo,
102 'status' => $status
105 } catch ( Exception $e ) {
106 UploadBase::setSessionStatus(
107 $user,
108 $this->params['filekey'],
110 'result' => 'Failure',
111 'stage' => 'assembling',
112 'status' => Status::newFatal( 'api-error-stashfailed' )
115 $this->setLastError( get_class( $e ) . ": " . $e->getMessage() );
116 // To be extra robust.
117 MWExceptionHandler::rollbackMasterChangesAndLog( $e );
119 return false;
122 return true;
125 public function getDeduplicationInfo() {
126 $info = parent::getDeduplicationInfo();
127 if ( is_array( $info['params'] ) ) {
128 $info['params'] = [ 'filekey' => $info['params']['filekey'] ];
131 return $info;
134 public function allowRetries() {
135 return false;