!C99Shell v. 1.0 pre-release build #13!

Software: Apache. PHP/5.5.15 

uname -a: Windows NT SVR-DMZ 6.1 build 7600 (Windows Server 2008 R2 Enterprise Edition) i586 

SYSTEM 

Safe-mode: OFF (not secure)

C:\cumbre\cumbreclima\wp-content\plugins\w3-total-cache\lib\SNS\services\MessageValidator\   drwxrwxrwx
Free 4.09 GB of 39.52 GB (10.35%)
Detected drives: [ a ] [ c ] [ d ] [ e ] [ f ]
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     MessageValidator.php (3.44 KB)      -rw-rw-rw-
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/**
 * Copyright 2010-2013 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License").
 * You may not use this file except in compliance with the License.
 * A copy of the License is located at
 *
 * http://aws.amazon.com/apache2.0
 *
 * or in the "license" file accompanying this file. This file is distributed
 * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
 * express or implied. See the License for the specific language governing
 * permissions and limitations under the License.
 */
w3_require_once(W3TC_LIB_DIR '/SNS/services/MessageValidator/sns-exceptions.php');

/**
 * This class uses openssl to verify SNS messages to ensure that they were sent by AWS.
 */
class MessageValidator {

    
/**
     * Constructs the Message Validator object and ensures that openssl is installed
     *
     * @throws Exception If openssl is not installed
     */
    
public function __construct()
    {
        if (!
extension_loaded('openssl')) {
            throw new 
Exception('The openssl extension is required to use the SNS Message '
                
'Validator. Please install this extension in order to use this feature.');
        }
    }

    
/**
     * Validates a message from SNS to ensure that it was delivered by AWS
     *
     * @param Message $message The message to validate
     *
     * @throws CannotGetPublicKeyFromCertificateException If the certificate cannot be retrieved
     * @throws CertificateFromUnrecognizedSourceException If the certificate's source cannot be verified
     * @throws InvalidMessageSignatureException           If the message's signature is invalid
     */
    
public function validate($message) {
        
// Get the cert's URL and ensure it is from AWS
        
$certUrl $message->get('SigningCertURL');
        
$host parse_url($certUrlPHP_URL_HOST);
        if (
'.amazonaws.com' != substr($host, -14)) {
            throw new 
CertificateFromUnrecognizedSourceException($host ' did not match .amazonaws.com');
        }


        
// Get the cert itself and extract the public key
        
$response wp_remote_get($certUrl);
        if (
is_wp_error($response))
            throw new 
CannotGetPublicKeyFromCertificateException('Could not retrieve certificate from ' $certUrl);

        
$certificate wp_remote_retrieve_body($response);
        
$publicKey openssl_get_publickey($certificate);
        if (!
$publicKey) {
            throw new 
CannotGetPublicKeyFromCertificateException('Could not extract public key from ' $certUrl);
        }

        
// Verify the signature of the message
        
$stringToSign $message->getStringToSign();
        
$incomingSignature base64_decode($message->get('Signature'));
        if (!
openssl_verify($stringToSign$incomingSignature$publicKeyOPENSSL_ALGO_SHA1)) {
            throw new 
InvalidMessageSignatureException('The message did not match the signature ' "\n" $stringToSign);
        }
    }

    
/**
     * Determines if a message is valid and that is was delivered by AWS. This method does not throw exceptions and
     * returns a simple boolean value.
     *
     * @param Message $message The message to validate
     * @return bool
     */
    
public function isValid($message)
    {
        try {
            
$this->validate($message);
            return 
true;
        } catch (
SnsMessageValidatorException $e) {
            
$error $e->getMessage();
            return 
false;
        }
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

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

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

--[ c99shell v. 1.0 pre-release build #13 powered by Captain Crunch Security Team | http://ccteam.ru | Generation time: 0.0312 ]--