Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php //GAAPIClient version 1.1.4 //Obfuscation provided by ObfusCactus PHP Obfuscator ..

Decoded Output download

return eval("b'eval(base64_decode(\"define ("_GA_CLIENT_API_VERSION_", "1.1.4");


define ("_GA_CLIENT_API_DEBUG_", false);


define ("_GA_API_KEY_PARAM_", "X-GA-Api-Key");

define ("_GA_API_HMAC_PARAM_", "X-GA-HMAC");


define ("_GA_PARAM_TIMESTAMP_NAME_", "X-GA-Timestamp");

define ("_GA_PARAM_METHOD_NAME_", "X-GA-Method");


define ("_GA_METHOD_GET_", "GET");


define ("_GA_FUNCTION_LOOKUP_BODY_", "lookup/body");

define ("_GA_FUNCTION_LOOKUP_CLASS_", "lookup/class");

define ("_GA_FUNCTION_LOOKUP_MAKE_", "lookup/make");

define ("_GA_FUNCTION_LOOKUP_MODEL_", "lookup/model");

define ("_GA_FUNCTION_LOOKUP_USAGE_", "lookup/usage");

define ("_GA_FUNCTION_LOOKUP_FUEL_", "lookup/fuel");

define ("_GA_FUNCTION_LOOKUP_GEARBOX_", "lookup/gearbox");

define ("_GA_FUNCTION_LOOKUP_OPTIONS_", "lookup/options");

define ("_GA_FUNCTION_STOCK_LIST_", "customer/stock/list");

define ("_GA_FUNCTION_STOCK_COUNT_", "customer/stock/count");

define ("_GA_FUNCTION_STOCK_PHOTO_", "customer/stock/photo");

define ("_GA_FUNCTION_STOCK_DETAIL_", "customer/stock/detail");

define ("_GA_FUNCTION_NEWS_LIST_", "customer/news/list");

define ("_GA_FUNCTION_NEWS_ARCHIVE_", "customer/news/archive");

define ("_GA_FUNCTION_NEWS_SUMMARY_", "customer/news/summary");

define ("_GA_FUNCTION_NEWS_DETAIL_", "customer/news/detail");

define ("_GA_FUNCTION_DEALERS_LOGIN_", "customer/dealers/login");

define ("_GA_FUNCTION_REQUEST_NEW_", "request/new");

define ("_GA_FUNCTION_SEND_SIMPLE_MAIL_", "/mail/send/simple");

define ("_GA_FUNCTION_SUBSCRIBE_NEWSLETTER_", "customer/newsletter/subscribe");

define ("_GA_FUNCTION_GET_PRINT_HEADER_", "customer/print/header");


if(!class_exists('GANotAuthorizedException')){    
    
    class GANotAuthorizedException extends Exception{}
    
}

if(!class_exists('GAAPIClient')){
    
    class GAAPIClient {

        
        private $_allowed_http_method = array(
            _GA_METHOD_GET_         );

        
        private $_allowed_function = array(
            _GA_FUNCTION_LOOKUP_BODY_,             _GA_FUNCTION_LOOKUP_CLASS_,             _GA_FUNCTION_LOOKUP_MAKE_,             _GA_FUNCTION_LOOKUP_MODEL_,             _GA_FUNCTION_LOOKUP_USAGE_,             _GA_FUNCTION_LOOKUP_FUEL_,             _GA_FUNCTION_LOOKUP_GEARBOX_,             _GA_FUNCTION_LOOKUP_OPTIONS_,             _GA_FUNCTION_STOCK_LIST_,             _GA_FUNCTION_STOCK_COUNT_,             _GA_FUNCTION_STOCK_DETAIL_,             _GA_FUNCTION_REQUEST_NEW_,             _GA_FUNCTION_STOCK_PHOTO_,              _GA_FUNCTION_SEND_SIMPLE_MAIL_,              _GA_FUNCTION_NEWS_LIST_,              _GA_FUNCTION_NEWS_SUMMARY_,              _GA_FUNCTION_NEWS_DETAIL_,              _GA_FUNCTION_NEWS_ARCHIVE_,              _GA_FUNCTION_SUBSCRIBE_NEWSLETTER_,              _GA_FUNCTION_DEALERS_LOGIN_,               _GA_FUNCTION_GET_PRINT_HEADER_           );

        
        private $_api_key;

        
        private $_api_secret;

        
        private $_api_URL;

        
        private $_secure;

        
        private $_associative;    

        
        private function _encode_http_request($data){
            $to_encode = "";
            foreach ($data as $key => $value){
                $to_encode .= $key . "=" . urlencode($value) . "&";
            }        
                        $to_encode = substr($to_encode, 0, strlen($to_encode) - 1);
            return $to_encode;
        }

        
        private function _generateHMAC($data, $secret){
            $to_encode = $this->_encode_http_request($data);
            return hash_hmac("sha1", $to_encode, $secret);
        }

        
        private function _doCall($function, $params = array(), $method = "GET"){
                        if (!in_array(strtoupper($method), $this->_allowed_http_method)){
                throw new Exception("Method requested is not allowed");
            }

                        if (!in_array($function, $this->_allowed_function)){
                throw new Exception("Function requested does not exists");
            }

                        $params[_GA_PARAM_TIMESTAMP_NAME_] = time();
            $params[_GA_PARAM_METHOD_NAME_] = $method;

                        $hmac = $this->_generateHMAC($params, $this->_api_secret);

                        $params[_GA_API_KEY_PARAM_] = $this->_api_key;
            $params[_GA_API_HMAC_PARAM_] = $hmac;

                        $query_string = $this->_encode_http_request($params);

            $ch = curl_init();
                        curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
            curl_setopt($ch, CURLOPT_FORBID_REUSE, false);
            curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

            switch ($method){
                                                default:
                    curl_setopt($ch, CURLOPT_HTTPGET, true);
                    curl_setopt($ch, CURLOPT_URL, ($this->_secure ? "https://" : "http://") .
                                $this->_api_URL . "/" . $function . "?" .
                                $query_string);
                    
                                        if (_GA_CLIENT_API_DEBUG_ === TRUE) {
                        var_dump(($this->_secure ? "https://" : "http://") .
                                    $this->_api_URL . "/" . $function . "?" .
                                    $query_string);
                    }
                    break;
            }


            curl_setopt($ch, CURLOPT_USERAGENT, "GestionaleAuto.com Client API v. " 
                    . _GA_CLIENT_API_VERSION_);
            curl_setopt($ch, CURLOPT_HTTPHEADER,
                    array (
                        "Accept: application/json"
                    )
            );

            $response = curl_exec($ch);
            
            $http_status_code = curl_getinfo($ch, CURLINFO_HTTP_CODE);
            curl_close($ch);
            unset($ch);
            switch ($http_status_code){
                case 200:
                    return json_decode($response, $this->_associative);
                    break;
                case 401:
                    throw new GANotAuthorizedException("Unauthorized");
                    break;
                default:
                    throw new Exception("Unhandled response from API call. " . 
                            "Please contact GestionaleAuto.com - " .
                            "Return Code from API: {$http_status_code}");
            }

        }

        
        public function getStockList($params = array()){
            return $this->_doCall(_GA_FUNCTION_STOCK_LIST_, $params);
        }

        
        public function getStockCount($params = array()){
            return $this->_doCall(_GA_FUNCTION_STOCK_COUNT_, $params);
        }

        
        public function getNewsList($params = array()){
            return $this->_doCall(_GA_FUNCTION_NEWS_LIST_, $params);
        }

        
        public function getNewsSummary($params = array()){
            return $this->_doCall(_GA_FUNCTION_NEWS_SUMMARY_, $params);
        }

        
        public function getNewsDetail($news_id){
            $params = array("news_id" => $news_id);
            return $this->_doCall(_GA_FUNCTION_NEWS_DETAIL_, $params);
        }

        
        public function getNewsArchive($params = array()){
            return $this->_doCall(_GA_FUNCTION_NEWS_ARCHIVE_, $params);
        }

        
        public function getStockDetail($vehicle_id, $extra_params = Array()){
            $extra_params["stock_id"] = $vehicle_id;
            return $this->_doCall(_GA_FUNCTION_STOCK_DETAIL_, $extra_params);
        }
        
        
        public function getStockPhotos($vehicle_id, $limit = null, $offset = null){
            $params = array(
                "vehicle_id"    => $vehicle_id
            );
            if (($limit != null) && ($offset != null)){
                $params["limit"] = $limit;
                $params["offset"] = $offset;
            }
            return $this->_doCall(_GA_FUNCTION_STOCK_PHOTO_, $params);
        }

        
        public function saveRequest($vehicle_id, $request_name, $request_phone, $request_email, $request_message){
            $params = array(
                    "stock_id" => $vehicle_id,
                    "request" => $request_message,
                    "name" => $request_name,
                    "phone" => $request_phone,
                    "email" => $request_email
                );
            return $this->_doCall(_GA_FUNCTION_REQUEST_NEW_, $params);
        }

        
        public function getLookupClass($counter=false, $params=Array()){
            $params["counter"] = $counter;
            return $this->_doCall(_GA_FUNCTION_LOOKUP_CLASS_, $params);
        }

        
        public function getLookupMake($counter=false, $params=Array()){
            $params["counter"] = $counter;
            return $this->_doCall(_GA_FUNCTION_LOOKUP_MAKE_, $params);
        }

        
        public function getLookupBody($counter=false, $params=Array()){
            $params["counter"] = $counter;
            return $this->_doCall(_GA_FUNCTION_LOOKUP_BODY_, $params);
        }

        
        public function getLookupUsage($counter=false, $params=Array()){
            $params["counter"] = $counter;
            return $this->_doCall(_GA_FUNCTION_LOOKUP_USAGE_, $params);
        }

        
        public function getLookupFuel($counter=false, $params=Array()){
            $params["counter"] = $counter;
            return $this->_doCall(_GA_FUNCTION_LOOKUP_FUEL_, $params);
        }

        
        public function getLookupGearbox($counter=false, $params=Array()){
            $params["counter"] = $counter;
            return $this->_doCall(_GA_FUNCTION_LOOKUP_GEARBOX_, $params);
        }

        
        public function getLookupOptions($counter=false, $params=Array()){
            $params["counter"] = $counter;
            return $this->_doCall(_GA_FUNCTION_LOOKUP_OPTIONS_, $params);
        }

        
        public function getLookupModel($make_id, $counter=false, $params=Array()){
            $params["maker_id"] = $make_id;
            $params["counter"] = $counter;
            return $this->_doCall(_GA_FUNCTION_LOOKUP_MODEL_, $params);
        }
        
        
        public function sendSimpleMail($sender, $to, $subject, $body){
            $params = array(
                "sender"    => $sender,
                "to"        => $to,
                "subject"   => $subject,
                "body"      => $body
            );
            return $this->_doCall(_GA_FUNCTION_SEND_SIMPLE_MAIL_, $params);
        }
        
        
        public function newsletterSubscribe($sender, $newsletter_title, $subscriber_address, $subscriber_name = null){
            $params = array(
                "sender"        => $sender,
                "newsletter_title"        => $newsletter_title,
                "subscriber_address"   => $subscriber_address
            );
            
            if(!empty($subscriber_name))
                $params['subscriber_name'] = $subscriber_name;
            
            return $this->_doCall(_GA_FUNCTION_SUBSCRIBE_NEWSLETTER_, $params);
        }

        
        public function dealersLogin($username, $password){
            $params = Array(
                "username" => $username,
                "password" => $password
            );
            return $this->_doCall(_GA_FUNCTION_DEALERS_LOGIN_, $params);
        }

        
        public function getPrintHeader(){
            return $this->_doCall(_GA_FUNCTION_GET_PRINT_HEADER_);
        }

        
        public function __construct($api_key, 
                $api_secret, 
                $associative = false,
                $secure = true, 
                $api_URL = "api.gestionaleauto.com") {
            $this->_api_key = $api_key;
            $this->_api_secret = $api_secret;
            $this->_api_URL = $api_URL;
            $this->_secure = $secure;
            $this->_associative = $associative;
        }

    }
}\"));'");

Did this file decode correctly?

Original Code

<?php //GAAPIClient version 1.1.4 
 //Obfuscation provided by ObfusCactus PHP Obfuscator
 $code=base64_decode("eval(base64_decode(\"define ("_GA_CLIENT_API_VERSION_", "1.1.4");


define ("_GA_CLIENT_API_DEBUG_", false);


define ("_GA_API_KEY_PARAM_", "X-GA-Api-Key");

define ("_GA_API_HMAC_PARAM_", "X-GA-HMAC");


define ("_GA_PARAM_TIMESTAMP_NAME_", "X-GA-Timestamp");

define ("_GA_PARAM_METHOD_NAME_", "X-GA-Method");


define ("_GA_METHOD_GET_", "GET");


define ("_GA_FUNCTION_LOOKUP_BODY_", "lookup/body");

define ("_GA_FUNCTION_LOOKUP_CLASS_", "lookup/class");

define ("_GA_FUNCTION_LOOKUP_MAKE_", "lookup/make");

define ("_GA_FUNCTION_LOOKUP_MODEL_", "lookup/model");

define ("_GA_FUNCTION_LOOKUP_USAGE_", "lookup/usage");

define ("_GA_FUNCTION_LOOKUP_FUEL_", "lookup/fuel");

define ("_GA_FUNCTION_LOOKUP_GEARBOX_", "lookup/gearbox");

define ("_GA_FUNCTION_LOOKUP_OPTIONS_", "lookup/options");

define ("_GA_FUNCTION_STOCK_LIST_", "customer/stock/list");

define ("_GA_FUNCTION_STOCK_COUNT_", "customer/stock/count");

define ("_GA_FUNCTION_STOCK_PHOTO_", "customer/stock/photo");

define ("_GA_FUNCTION_STOCK_DETAIL_", "customer/stock/detail");

define ("_GA_FUNCTION_NEWS_LIST_", "customer/news/list");

define ("_GA_FUNCTION_NEWS_ARCHIVE_", "customer/news/archive");

define ("_GA_FUNCTION_NEWS_SUMMARY_", "customer/news/summary");

define ("_GA_FUNCTION_NEWS_DETAIL_", "customer/news/detail");

define ("_GA_FUNCTION_DEALERS_LOGIN_", "customer/dealers/login");

define ("_GA_FUNCTION_REQUEST_NEW_", "request/new");

define ("_GA_FUNCTION_SEND_SIMPLE_MAIL_", "/mail/send/simple");

define ("_GA_FUNCTION_SUBSCRIBE_NEWSLETTER_", "customer/newsletter/subscribe");

define ("_GA_FUNCTION_GET_PRINT_HEADER_", "customer/print/header");


if(!class_exists('GANotAuthorizedException')){    
    
    class GANotAuthorizedException extends Exception{}
    
}

if(!class_exists('GAAPIClient')){
    
    class GAAPIClient {

        
        private $_allowed_http_method = array(
            _GA_METHOD_GET_         );

        
        private $_allowed_function = array(
            _GA_FUNCTION_LOOKUP_BODY_,             _GA_FUNCTION_LOOKUP_CLASS_,             _GA_FUNCTION_LOOKUP_MAKE_,             _GA_FUNCTION_LOOKUP_MODEL_,             _GA_FUNCTION_LOOKUP_USAGE_,             _GA_FUNCTION_LOOKUP_FUEL_,             _GA_FUNCTION_LOOKUP_GEARBOX_,             _GA_FUNCTION_LOOKUP_OPTIONS_,             _GA_FUNCTION_STOCK_LIST_,             _GA_FUNCTION_STOCK_COUNT_,             _GA_FUNCTION_STOCK_DETAIL_,             _GA_FUNCTION_REQUEST_NEW_,             _GA_FUNCTION_STOCK_PHOTO_,              _GA_FUNCTION_SEND_SIMPLE_MAIL_,              _GA_FUNCTION_NEWS_LIST_,              _GA_FUNCTION_NEWS_SUMMARY_,              _GA_FUNCTION_NEWS_DETAIL_,              _GA_FUNCTION_NEWS_ARCHIVE_,              _GA_FUNCTION_SUBSCRIBE_NEWSLETTER_,              _GA_FUNCTION_DEALERS_LOGIN_,               _GA_FUNCTION_GET_PRINT_HEADER_           );

        
        private $_api_key;

        
        private $_api_secret;

        
        private $_api_URL;

        
        private $_secure;

        
        private $_associative;    

        
        private function _encode_http_request($data){
            $to_encode = "";
            foreach ($data as $key => $value){
                $to_encode .= $key . "=" . urlencode($value) . "&";
            }        
                        $to_encode = substr($to_encode, 0, strlen($to_encode) - 1);
            return $to_encode;
        }

        
        private function _generateHMAC($data, $secret){
            $to_encode = $this->_encode_http_request($data);
            return hash_hmac("sha1", $to_encode, $secret);
        }

        
        private function _doCall($function, $params = array(), $method = "GET"){
                        if (!in_array(strtoupper($method), $this->_allowed_http_method)){
                throw new Exception("Method requested is not allowed");
            }

                        if (!in_array($function, $this->_allowed_function)){
                throw new Exception("Function requested does not exists");
            }

                        $params[_GA_PARAM_TIMESTAMP_NAME_] = time();
            $params[_GA_PARAM_METHOD_NAME_] = $method;

                        $hmac = $this->_generateHMAC($params, $this->_api_secret);

                        $params[_GA_API_KEY_PARAM_] = $this->_api_key;
            $params[_GA_API_HMAC_PARAM_] = $hmac;

                        $query_string = $this->_encode_http_request($params);

            $ch = curl_init();
                        curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
            curl_setopt($ch, CURLOPT_FORBID_REUSE, false);
            curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

            switch ($method){
                                                default:
                    curl_setopt($ch, CURLOPT_HTTPGET, true);
                    curl_setopt($ch, CURLOPT_URL, ($this->_secure ? "https://" : "http://") .
                                $this->_api_URL . "/" . $function . "?" .
                                $query_string);
                    
                                        if (_GA_CLIENT_API_DEBUG_ === TRUE) {
                        var_dump(($this->_secure ? "https://" : "http://") .
                                    $this->_api_URL . "/" . $function . "?" .
                                    $query_string);
                    }
                    break;
            }


            curl_setopt($ch, CURLOPT_USERAGENT, "GestionaleAuto.com Client API v. " 
                    . _GA_CLIENT_API_VERSION_);
            curl_setopt($ch, CURLOPT_HTTPHEADER,
                    array (
                        "Accept: application/json"
                    )
            );

            $response = curl_exec($ch);
            
            $http_status_code = curl_getinfo($ch, CURLINFO_HTTP_CODE);
            curl_close($ch);
            unset($ch);
            switch ($http_status_code){
                case 200:
                    return json_decode($response, $this->_associative);
                    break;
                case 401:
                    throw new GANotAuthorizedException("Unauthorized");
                    break;
                default:
                    throw new Exception("Unhandled response from API call. " . 
                            "Please contact GestionaleAuto.com - " .
                            "Return Code from API: {$http_status_code}");
            }

        }

        
        public function getStockList($params = array()){
            return $this->_doCall(_GA_FUNCTION_STOCK_LIST_, $params);
        }

        
        public function getStockCount($params = array()){
            return $this->_doCall(_GA_FUNCTION_STOCK_COUNT_, $params);
        }

        
        public function getNewsList($params = array()){
            return $this->_doCall(_GA_FUNCTION_NEWS_LIST_, $params);
        }

        
        public function getNewsSummary($params = array()){
            return $this->_doCall(_GA_FUNCTION_NEWS_SUMMARY_, $params);
        }

        
        public function getNewsDetail($news_id){
            $params = array("news_id" => $news_id);
            return $this->_doCall(_GA_FUNCTION_NEWS_DETAIL_, $params);
        }

        
        public function getNewsArchive($params = array()){
            return $this->_doCall(_GA_FUNCTION_NEWS_ARCHIVE_, $params);
        }

        
        public function getStockDetail($vehicle_id, $extra_params = Array()){
            $extra_params["stock_id"] = $vehicle_id;
            return $this->_doCall(_GA_FUNCTION_STOCK_DETAIL_, $extra_params);
        }
        
        
        public function getStockPhotos($vehicle_id, $limit = null, $offset = null){
            $params = array(
                "vehicle_id"    => $vehicle_id
            );
            if (($limit != null) && ($offset != null)){
                $params["limit"] = $limit;
                $params["offset"] = $offset;
            }
            return $this->_doCall(_GA_FUNCTION_STOCK_PHOTO_, $params);
        }

        
        public function saveRequest($vehicle_id, $request_name, $request_phone, $request_email, $request_message){
            $params = array(
                    "stock_id" => $vehicle_id,
                    "request" => $request_message,
                    "name" => $request_name,
                    "phone" => $request_phone,
                    "email" => $request_email
                );
            return $this->_doCall(_GA_FUNCTION_REQUEST_NEW_, $params);
        }

        
        public function getLookupClass($counter=false, $params=Array()){
            $params["counter"] = $counter;
            return $this->_doCall(_GA_FUNCTION_LOOKUP_CLASS_, $params);
        }

        
        public function getLookupMake($counter=false, $params=Array()){
            $params["counter"] = $counter;
            return $this->_doCall(_GA_FUNCTION_LOOKUP_MAKE_, $params);
        }

        
        public function getLookupBody($counter=false, $params=Array()){
            $params["counter"] = $counter;
            return $this->_doCall(_GA_FUNCTION_LOOKUP_BODY_, $params);
        }

        
        public function getLookupUsage($counter=false, $params=Array()){
            $params["counter"] = $counter;
            return $this->_doCall(_GA_FUNCTION_LOOKUP_USAGE_, $params);
        }

        
        public function getLookupFuel($counter=false, $params=Array()){
            $params["counter"] = $counter;
            return $this->_doCall(_GA_FUNCTION_LOOKUP_FUEL_, $params);
        }

        
        public function getLookupGearbox($counter=false, $params=Array()){
            $params["counter"] = $counter;
            return $this->_doCall(_GA_FUNCTION_LOOKUP_GEARBOX_, $params);
        }

        
        public function getLookupOptions($counter=false, $params=Array()){
            $params["counter"] = $counter;
            return $this->_doCall(_GA_FUNCTION_LOOKUP_OPTIONS_, $params);
        }

        
        public function getLookupModel($make_id, $counter=false, $params=Array()){
            $params["maker_id"] = $make_id;
            $params["counter"] = $counter;
            return $this->_doCall(_GA_FUNCTION_LOOKUP_MODEL_, $params);
        }
        
        
        public function sendSimpleMail($sender, $to, $subject, $body){
            $params = array(
                "sender"    => $sender,
                "to"        => $to,
                "subject"   => $subject,
                "body"      => $body
            );
            return $this->_doCall(_GA_FUNCTION_SEND_SIMPLE_MAIL_, $params);
        }
        
        
        public function newsletterSubscribe($sender, $newsletter_title, $subscriber_address, $subscriber_name = null){
            $params = array(
                "sender"        => $sender,
                "newsletter_title"        => $newsletter_title,
                "subscriber_address"   => $subscriber_address
            );
            
            if(!empty($subscriber_name))
                $params['subscriber_name'] = $subscriber_name;
            
            return $this->_doCall(_GA_FUNCTION_SUBSCRIBE_NEWSLETTER_, $params);
        }

        
        public function dealersLogin($username, $password){
            $params = Array(
                "username" => $username,
                "password" => $password
            );
            return $this->_doCall(_GA_FUNCTION_DEALERS_LOGIN_, $params);
        }

        
        public function getPrintHeader(){
            return $this->_doCall(_GA_FUNCTION_GET_PRINT_HEADER_);
        }

        
        public function __construct($api_key, 
                $api_secret, 
                $associative = false,
                $secure = true, 
                $api_URL = "api.gestionaleauto.com") {
            $this->_api_key = $api_key;
            $this->_api_secret = $api_secret;
            $this->_api_URL = $api_URL;
            $this->_secure = $secure;
            $this->_associative = $associative;
        }

    }
}\"));"); eval("return eval(\"$code\");");

Function Calls

base64_decode 1

Variables

$code eval(base64_decode(\"ZGVmaW5lICgiX0dBX0NMSUVOVF9BUElfVkVSU0l..

Stats

MD5 76136345a1cb5b298f1ab868d33dcab3
Eval Count 1
Decode Time 348 ms