!C99Shell v. 2.5 [PHP 8 Update] [24.05.2025]!

Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 

uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 

uid=33(www-data) gid=33(www-data) groups=33(www-data) 

Safe-mode: OFF (not secure)

/uploads/script/vendor/composer/composer/src/Composer/Downloader/   drwxr-xr-x
Free 13.37 GB of 57.97 GB (23.07%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     DownloadManager.php (15.23 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

/*
 * This file is part of Composer.
 *
 * (c) Nils Adermann <naderman@naderman.de>
 *     Jordi Boggiano <j.boggiano@seld.be>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace Composer\Downloader;

use 
Composer\Package\PackageInterface;
use 
Composer\IO\IOInterface;
use 
Composer\Util\Filesystem;
use 
Composer\Exception\IrrecoverableDownloadException;
use 
React\Promise\PromiseInterface;

/**
 * Downloaders manager.
 *
 * @author Konstantin Kudryashov <ever.zet@gmail.com>
 */
class DownloadManager
{
    
/** @var IOInterface */
    
private $io;
    
/** @var bool */
    
private $preferDist false;
    
/** @var bool */
    
private $preferSource;
    
/** @var array<string, string> */
    
private $packagePreferences = array();
    
/** @var Filesystem */
    
private $filesystem;
    
/** @var array<string, DownloaderInterface> */
    
private $downloaders = array();

    
/**
     * Initializes download manager.
     *
     * @param IOInterface     $io           The Input Output Interface
     * @param bool            $preferSource prefer downloading from source
     * @param Filesystem|null $filesystem   custom Filesystem object
     */
    
public function __construct(IOInterface $io$preferSource falseFilesystem $filesystem null)
    {
        
$this->io $io;
        
$this->preferSource $preferSource;
        
$this->filesystem $filesystem ?: new Filesystem();
    }

    
/**
     * Makes downloader prefer source installation over the dist.
     *
     * @param  bool            $preferSource prefer downloading from source
     * @return DownloadManager
     */
    
public function setPreferSource($preferSource)
    {
        
$this->preferSource $preferSource;

        return 
$this;
    }

    
/**
     * Makes downloader prefer dist installation over the source.
     *
     * @param  bool            $preferDist prefer downloading from dist
     * @return DownloadManager
     */
    
public function setPreferDist($preferDist)
    {
        
$this->preferDist $preferDist;

        return 
$this;
    }

    
/**
     * Sets fine tuned preference settings for package level source/dist selection.
     *
     * @param  array           $preferences array of preferences by package patterns
     * @return DownloadManager
     */
    
public function setPreferences(array $preferences)
    {
        
$this->packagePreferences $preferences;

        return 
$this;
    }

    
/**
     * Sets installer downloader for a specific installation type.
     *
     * @param  string              $type       installation type
     * @param  DownloaderInterface $downloader downloader instance
     * @return DownloadManager
     */
    
public function setDownloader($typeDownloaderInterface $downloader)
    {
        
$type strtolower($type);
        
$this->downloaders[$type] = $downloader;

        return 
$this;
    }

    
/**
     * Returns downloader for a specific installation type.
     *
     * @param  string                    $type installation type
     * @throws \InvalidArgumentException if downloader for provided type is not registered
     * @return DownloaderInterface
     */
    
public function getDownloader($type)
    {
        
$type strtolower($type);
        if (!isset(
$this->downloaders[$type])) {
            throw new 
\InvalidArgumentException(sprintf('Unknown downloader type: %s. Available types: %s.'$typeimplode(', 'array_keys($this->downloaders))));
        }

        return 
$this->downloaders[$type];
    }

    
/**
     * Returns downloader for already installed package.
     *
     * @param  PackageInterface          $package package instance
     * @throws \InvalidArgumentException if package has no installation source specified
     * @throws \LogicException           if specific downloader used to load package with
     *                                           wrong type
     * @return DownloaderInterface|null
     */
    
public function getDownloaderForPackage(PackageInterface $package)
    {
        
$installationSource $package->getInstallationSource();

        if (
'metapackage' === $package->getType()) {
            return;
        }

        if (
'dist' === $installationSource) {
            
$downloader $this->getDownloader($package->getDistType());
        } elseif (
'source' === $installationSource) {
            
$downloader $this->getDownloader($package->getSourceType());
        } else {
            throw new 
\InvalidArgumentException(
                
'Package '.$package.' does not have an installation source set'
            
);
        }

        if (
$installationSource !== $downloader->getInstallationSource()) {
            throw new 
\LogicException(sprintf(
                
'Downloader "%s" is a %s type downloader and can not be used to download %s for package %s',
                
get_class($downloader),
                
$downloader->getInstallationSource(),
                
$installationSource,
                
$package
            
));
        }

        return 
$downloader;
    }

    public function 
getDownloaderType(DownloaderInterface $downloader)
    {
        return 
array_search($downloader$this->downloaders);
    }

    
/**
     * Downloads package into target dir.
     *
     * @param PackageInterface      $package     package instance
     * @param string                $targetDir   target dir
     * @param PackageInterface|null $prevPackage previous package instance in case of updates
     *
     * @throws \InvalidArgumentException if package have no urls to download from
     * @throws \RuntimeException
     * @return PromiseInterface
     */
    
public function download(PackageInterface $package$targetDirPackageInterface $prevPackage null)
    {
        
$targetDir $this->normalizeTargetDir($targetDir);
        
$this->filesystem->ensureDirectoryExists(dirname($targetDir));

        
$sources $this->getAvailableSources($package$prevPackage);

        
$io $this->io;
        
$self $this;

        
$download = function ($retry false) use (&$sources$io$package$self$targetDir, &$download$prevPackage) {
            
$source array_shift($sources);
            if (
$retry) {
                
$io->writeError('    <warning>Now trying to download from ' $source '</warning>');
            }
            
$package->setInstallationSource($source);

            
$downloader $self->getDownloaderForPackage($package);
            if (!
$downloader) {
                return 
\React\Promise\resolve();
            }

            
$handleError = function ($e) use ($sources$source$package$io$download) {
                if (
$e instanceof \RuntimeException && !$e instanceof IrrecoverableDownloadException) {
                    if (!
$sources) {
                        throw 
$e;
                    }

                    
$io->writeError(
                        
'    <warning>Failed to download '.
                        
$package->getPrettyName().
                        
' from ' $source ': '.
                        
$e->getMessage().'</warning>'
                    
);

                    return 
$download(true);
                }

                throw 
$e;
            };

            try {
                
$result $downloader->download($package$targetDir$prevPackage);
            } catch (
\Exception $e) {
                return 
$handleError($e);
            }
            if (!
$result instanceof PromiseInterface) {
                return 
\React\Promise\resolve($result);
            }

            
$res $result->then(function ($res) {
                return 
$res;
            }, 
$handleError);

            return 
$res;
        };

        return 
$download();
    }

    
/**
     * Prepares an operation execution
     *
     * @param string                $type        one of install/update/uninstall
     * @param PackageInterface      $package     package instance
     * @param string                $targetDir   target dir
     * @param PackageInterface|null $prevPackage previous package instance in case of updates
     *
     * @return PromiseInterface|null
     */
    
public function prepare($typePackageInterface $package$targetDirPackageInterface $prevPackage null)
    {
        
$targetDir $this->normalizeTargetDir($targetDir);
        
$downloader $this->getDownloaderForPackage($package);
        if (
$downloader) {
            return 
$downloader->prepare($type$package$targetDir$prevPackage);
        }
    }

    
/**
     * Installs package into target dir.
     *
     * @param PackageInterface $package   package instance
     * @param string           $targetDir target dir
     *
     * @throws \InvalidArgumentException if package have no urls to download from
     * @throws \RuntimeException
     * @return PromiseInterface|null
     */
    
public function install(PackageInterface $package$targetDir)
    {
        
$targetDir $this->normalizeTargetDir($targetDir);
        
$downloader $this->getDownloaderForPackage($package);
        if (
$downloader) {
            return 
$downloader->install($package$targetDir);
        }
    }

    
/**
     * Updates package from initial to target version.
     *
     * @param PackageInterface $initial   initial package version
     * @param PackageInterface $target    target package version
     * @param string           $targetDir target dir
     *
     * @throws \InvalidArgumentException if initial package is not installed
     * @return PromiseInterface|null
     */
    
public function update(PackageInterface $initialPackageInterface $target$targetDir)
    {
        
$targetDir $this->normalizeTargetDir($targetDir);
        
$downloader $this->getDownloaderForPackage($target);
        
$initialDownloader $this->getDownloaderForPackage($initial);

        
// no downloaders present means update from metapackage to metapackage, nothing to do
        
if (!$initialDownloader && !$downloader) {
            return;
        }

        
// if we have a downloader present before, but not after, the package became a metapackage and its files should be removed
        
if (!$downloader) {
            return 
$initialDownloader->remove($initial$targetDir);
        }

        
$initialType $this->getDownloaderType($initialDownloader);
        
$targetType $this->getDownloaderType($downloader);
        if (
$initialType === $targetType) {
            try {
                return 
$downloader->update($initial$target$targetDir);
            } catch (
\RuntimeException $e) {
                if (!
$this->io->isInteractive()) {
                    throw 
$e;
                }
                
$this->io->writeError('<error>    Update failed ('.$e->getMessage().')</error>');
                if (!
$this->io->askConfirmation('    Would you like to try reinstalling the package instead [<comment>yes</comment>]? ')) {
                    throw 
$e;
                }
            }
        }

        
// if downloader type changed, or update failed and user asks for reinstall,
        // we wipe the dir and do a new install instead of updating it
        
$promise $initialDownloader->remove($initial$targetDir);
        if (
$promise) {
            
$self $this;

            return 
$promise->then(function ($res) use ($self$target$targetDir) {
                return 
$self->install($target$targetDir);
            });
        }

        return 
$this->install($target$targetDir);
    }

    
/**
     * Removes package from target dir.
     *
     * @param PackageInterface $package   package instance
     * @param string           $targetDir target dir
     *
     * @return PromiseInterface|null
     */
    
public function remove(PackageInterface $package$targetDir)
    {
        
$targetDir $this->normalizeTargetDir($targetDir);
        
$downloader $this->getDownloaderForPackage($package);
        if (
$downloader) {
            return 
$downloader->remove($package$targetDir);
        }
    }

    
/**
     * Cleans up a failed operation
     *
     * @param string                $type        one of install/update/uninstall
     * @param PackageInterface      $package     package instance
     * @param string                $targetDir   target dir
     * @param PackageInterface|null $prevPackage previous package instance in case of updates
     *
     * @return PromiseInterface|null
     */
    
public function cleanup($typePackageInterface $package$targetDirPackageInterface $prevPackage null)
    {
        
$targetDir $this->normalizeTargetDir($targetDir);
        
$downloader $this->getDownloaderForPackage($package);
        if (
$downloader) {
            return 
$downloader->cleanup($type$package$targetDir$prevPackage);
        }
    }

    
/**
     * Determines the install preference of a package
     *
     * @param PackageInterface $package package instance
     *
     * @return string
     */
    
protected function resolvePackageInstallPreference(PackageInterface $package)
    {
        foreach (
$this->packagePreferences as $pattern => $preference) {
            
$pattern '{^'.str_replace('\\*''.*'preg_quote($pattern)).'$}i';
            if (
preg_match($pattern$package->getName())) {
                if (
'dist' === $preference || (!$package->isDev() && 'auto' === $preference)) {
                    return 
'dist';
                }

                return 
'source';
            }
        }

        return 
$package->isDev() ? 'source' 'dist';
    }

    
/**
     * @return string[]
     */
    
private function getAvailableSources(PackageInterface $packagePackageInterface $prevPackage null)
    {
        
$sourceType $package->getSourceType();
        
$distType $package->getDistType();

        
// add source before dist by default
        
$sources = array();
        if (
$sourceType) {
            
$sources[] = 'source';
        }
        if (
$distType) {
            
$sources[] = 'dist';
        }

        if (empty(
$sources)) {
            throw new 
\InvalidArgumentException('Package '.$package.' must have a source or dist specified');
        }

        if (
            
$prevPackage
            
// if we are updating, we want to keep the same source as the previously installed package (if available in the new one)
            
&& in_array($prevPackage->getInstallationSource(), $sourcestrue)
            
// unless the previous package was stable dist (by default) and the new package is dev, then we allow the new default to take over
            
&& !(!$prevPackage->isDev() && $prevPackage->getInstallationSource() === 'dist' && $package->isDev())
        ) {
            
$prevSource $prevPackage->getInstallationSource();
            
usort($sources, function ($a$b) use ($prevSource) {
                return 
$a === $prevSource ? -1;
            });

            return 
$sources;
        }

        
// reverse sources in case dist is the preferred source for this package
        
if (!$this->preferSource && ($this->preferDist || 'dist' === $this->resolvePackageInstallPreference($package))) {
            
$sources array_reverse($sources);
        }

        return 
$sources;
    }

    
/**
     * Downloaders expect a /path/to/dir without trailing slash
     *
     * If any Installer provides a path with a trailing slash, this can cause bugs so make sure we remove them
     *
     * @return string
     */
    
private function normalizeTargetDir($dir)
    {
        if (
$dir === '\\' || $dir === '/') {
            return 
$dir;
        }

        return 
rtrim($dir'\\/');
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0058 ]--