3 * This program is free software; you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License as published by
5 * the Free Software Foundation; either version 2 of the License, or
6 * (at your option) any later version.
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
13 * You should have received a copy of the GNU General Public License along
14 * with this program; if not, write to the Free Software Foundation, Inc.,
15 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16 * http://www.gnu.org/copyleft/gpl.html
19 * @ingroup FileBackend
20 * @author Aaron Schulz
24 * Create a file in the backend with the given content.
25 * Parameters for this operation are outlined in FileBackend::doOperations().
27 class CreateFileOp
extends FileOp
{
28 protected function allowedParams() {
31 [ 'overwrite', 'overwriteSame', 'headers' ],
36 protected function doPrecheck( array &$predicates ) {
37 $status = StatusValue
::newGood();
38 // Check if the source data is too big
39 if ( strlen( $this->getParam( 'content' ) ) > $this->backend
->maxFileSizeInternal() ) {
40 $status->fatal( 'backend-fail-maxsize',
41 $this->params
['dst'], $this->backend
->maxFileSizeInternal() );
42 $status->fatal( 'backend-fail-create', $this->params
['dst'] );
45 // Check if a file can be placed/changed at the destination
46 } elseif ( !$this->backend
->isPathUsableInternal( $this->params
['dst'] ) ) {
47 $status->fatal( 'backend-fail-usable', $this->params
['dst'] );
48 $status->fatal( 'backend-fail-create', $this->params
['dst'] );
52 // Check if destination file exists
53 $status->merge( $this->precheckDestExistence( $predicates ) );
54 $this->params
['dstExists'] = $this->destExists
; // see FileBackendStore::setFileCache()
55 if ( $status->isOK() ) {
56 // Update file existence predicates
57 $predicates['exists'][$this->params
['dst']] = true;
58 $predicates['sha1'][$this->params
['dst']] = $this->sourceSha1
;
61 return $status; // safe to call attempt()
64 protected function doAttempt() {
65 if ( !$this->overwriteSameCase
) {
66 // Create the file at the destination
67 return $this->backend
->createInternal( $this->setFlags( $this->params
) );
70 return StatusValue
::newGood();
73 protected function getSourceSha1Base36() {
74 return Wikimedia\base_convert
( sha1( $this->params
['content'] ), 16, 36, 31 );
77 public function storagePathsChanged() {
78 return [ $this->params
['dst'] ];