404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@18.218.220.243: ~ $
<?php
/**
 * Copyright 2017 Google Inc. All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

namespace Google\Cloud\Storage;

use Google\Cloud\Core\Upload\AbstractUploader;
use GuzzleHttp\Psr7\StreamDecoratorTrait;
use GuzzleHttp\Psr7\BufferStream;
use Psr\Http\Message\StreamInterface;

/**
 * A Stream implementation that uploads in chunks to a provided uploader when
 * we reach a certain chunkSize. Upon `close`, we will upload the remaining chunk.
 */
class WriteStream implements StreamInterface
{
    use StreamDecoratorTrait;

    private $uploader;
    private $stream;
    private $chunkSize = 262144;
    private $hasWritten = false;

    /**
     * Create a new WriteStream instance
     *
     * @param AbstractUploader $uploader The uploader to use.
     * @param array $options [optional] {
     *      Configuration options.
     *
     *      @type int $chunkSize The size of the buffer above which we attempt to
     *            upload data
     * }
     */
    public function __construct(AbstractUploader $uploader = null, $options = [])
    {
        if ($uploader) {
            $this->setUploader($uploader);
        }
        if (array_key_exists('chunkSize', $options)) {
            $this->chunkSize = $options['chunkSize'];
        }
        $this->stream = new BufferStream($this->chunkSize);
    }

    /**
     * Close the stream. Uploads any remaining data.
     */
    public function close()
    {
        if ($this->uploader && $this->hasWritten) {
            $this->uploader->upload();
            $this->uploader = null;
        }
    }

    /**
     * Write to the stream. If we pass the chunkable size, upload the available chunk.
     *
     * @param  string $data Data to write
     * @return int The number of bytes written
     * @throws \RuntimeException
     */
    public function write($data)
    {
        if (!isset($this->uploader)) {
            throw new \RuntimeException("No uploader set.");
        }

        // Ensure we have a resume uri here because we need to create the streaming
        // upload before we have data (size of 0).
        $this->uploader->getResumeUri();
        $this->hasWritten = true;

        if (!$this->stream->write($data)) {
            $this->uploader->upload($this->getChunkedWriteSize());
        }
        return strlen($data);
    }

    /**
     * Set the uploader for this class. You may need to set this after initialization
     * if the uploader depends on this stream.
     *
     * @param AbstractUploader $uploader The new uploader to use.
     */
    public function setUploader($uploader)
    {
        $this->uploader = $uploader;
    }

    private function getChunkedWriteSize()
    {
        return (int) floor($this->getSize() / $this->chunkSize) * $this->chunkSize;
    }
}

Filemanager

Name Type Size Permission Actions
Connection Folder 0755
Acl.php File 7.18 KB 0644
Bucket.php File 66.47 KB 0644
CreatedHmacKey.php File 1.88 KB 0644
EncryptionTrait.php File 5.23 KB 0644
HmacKey.php File 4.84 KB 0644
Lifecycle.php File 14.7 KB 0644
Notification.php File 5.62 KB 0644
ObjectIterator.php File 1.17 KB 0644
ObjectPageIterator.php File 1.85 KB 0644
ReadStream.php File 2.71 KB 0644
SigningHelper.php File 29.42 KB 0644
StorageClient.php File 23.54 KB 0644
StorageObject.php File 53.99 KB 0644
StreamWrapper.php File 24.72 KB 0644
WriteStream.php File 3.24 KB 0644