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 if(!class_exists("testBase")) { class testBase { public $key = "1193C275..

Decoded Output download

<?php  
 
if(!class_exists("testBase")) { 
	class testBase { 
    	public $key = "1193C275A3B1881A"; 
    	private $product_id = "1"; 
    	private $product_base = "WordPress Plugin"; 
    	private $server_host = "http://s-o-c.pp.ua/wp-json/licensor/"; 
    	private $hasCheckUpdate=true; 
    	private $isEncryptUpdate=true; 
    	private $pluginFile; 
        private static $selfobj=null; 
        private $version=""; 
        private $isTheme=false; 
        private $emailAddress = ""; 
        private static $_onDeleteLicense=[]; 
		function __construct($plugin_base_file='') 
		{ 
			$this->pluginFile=$plugin_base_file; 
            $dir=dirname($plugin_base_file); 
            $dir=str_replace('\','/',$dir); 
            if(strpos($dir,'wp-content/themes')!==FALSE){ 
                $this->isTheme=true; 
            } 
			$this->version=$this->getCurrentVersion(); 
			if($this->hasCheckUpdate) { 
				if(function_exists("add_action")){ 
					add_action( 'admin_post_WordPress Plugin_fupc', function(){ 
						update_option('_site_transient_update_plugins',''); 
						update_option('_site_transient_update_themes',''); 
						set_site_transient('update_themes', null); 
                        delete_transient($this->product_base."_up"); 
						wp_redirect(  admin_url( 'plugins.php' ) ); 
						exit; 
					}); 
					add_action( 'init', [$this,"initActionHandler"]); 
 
				} 
				if(function_exists("add_filter")) { 
					if($this->isTheme){ 
						add_filter('pre_set_site_transient_update_themes', [$this, "PluginUpdate"]); 
						add_filter('themes_api', [$this, 'checkUpdateInfo'], 10, 3); 
						add_action('admin_menu',function(){ 
                            add_theme_page( 'Update Check', 'Update Check', 'edit_theme_options', 'update_check', [$this,"ThemeForceUpdate"] ); 
                        },999); 
					}else{ 
						add_filter('pre_set_site_transient_update_plugins', [$this, "PluginUpdate"]); 
						add_filter('plugins_api', [$this, 'checkUpdateInfo'], 10, 3); 
						add_filter( 'plugin_row_meta', function($links, $plugin_file ){ 
							if ( $plugin_file == plugin_basename( $this->pluginFile ) ) { 
								$links[] = " <a class='edit coption' href='" . esc_url( admin_url( 'admin-post.php' ) . '?action=WordPress Plugin_fupc' ) . "'>Update Check</a>"; 
							} 
							return $links; 
						}, 10, 2 ); 
						add_action( "in_plugin_update_message-".plugin_basename( $this->pluginFile ), [$this,'updateMessageCB'], 20, 2 ); 
					} 
 
					add_action( 'upgrader_process_complete', function($upgrader_object, $options){ 
                        update_option('_site_transient_update_plugins',''); 
                        update_option('_site_transient_update_themes',''); 
                        set_site_transient('update_themes', null); 
                    },10,2); 
				} 
 
 
			} 
		} 
		 public function ThemeForceUpdate(){ 
            $this->cleanUpdateInfo(); 
            $url= admin_url( 'themes.php' ); 
            echo '<h1>'.__("Update Checking..",$this->product_base).'</h1>'; 
            echo("<script>location.href = '".$url."'</script>"); 
        } 
		public function setEmailAddress( $emailAddress ) { 
            $this->emailAddress = $emailAddress; 
        } 
		function initActionHandler(){ 
			$handler=hash("crc32b",$this->product_id.$this->key.$this->getDomain())."_handle"; 
			if(isset($_GET['action']) && $_GET['action']==$handler){ 
				$this->handleServerRequest(); 
				exit; 
			} 
		} 
		function handleServerRequest(){ 
			$type=isset($_GET['type'])?strtolower($_GET['type']):""; 
			switch ($type) { 
				case "rl": //remove license 
					$this->cleanUpdateInfo(); 
					$this->removeOldWPResponse(); 
					$obj          = new stdClass(); 
					$obj->product = $this->product_id; 
					$obj->status  = true; 
					echo $this->encryptObj( $obj ); 
					 
					return; 
				case "rc": //remove license 
					$key  = $this->getKeyName(); 
					delete_option( $key ); 
					$obj          = new stdClass(); 
					$obj->product = $this->product_id; 
					$obj->status  = true; 
					echo $this->encryptObj( $obj ); 
					return; 
				case "dl": //delete plugins 
					$obj          = new stdClass(); 
					$obj->product = $this->product_id; 
					$obj->status  = false; 
					$this->removeOldWPResponse(); 
					require_once( ABSPATH . 'wp-admin/includes/file.php' ); 
					if ( $this->isTheme ) { 
						$res = delete_theme( $this->pluginFile ); 
						if ( ! is_wp_error( $res ) ) { 
							$obj->status = true; 
						} 
						echo $this->encryptObj( $obj ); 
					} else { 
					    deactivate_plugins( [ plugin_basename( $this->pluginFile ) ] ); 
						$res = delete_plugins( [ plugin_basename( $this->pluginFile ) ] ); 
						if ( ! is_wp_error( $res ) ) { 
							$obj->status = true; 
						} 
						echo $this->encryptObj( $obj ); 
					} 
					 
					return; 
				default: 
					return; 
			} 
		} 
		/** 
         * @param callable $func 
         */ 
        static function addOnDelete( $func){ 
            self::$_onDeleteLicense[]=$func; 
        } 
		function getCurrentVersion(){ 
			if( !function_exists('get_plugin_data') ){ 
				require_once( ABSPATH . 'wp-admin/includes/plugin.php' ); 
			} 
			$data=get_plugin_data($this->pluginFile); 
			if(isset($data['Version'])){ 
				return $data['Version']; 
			} 
			return 0; 
		} 
		public function cleanUpdateInfo(){ 
            update_option('_site_transient_update_plugins',''); 
            update_option('_site_transient_update_themes',''); 
            delete_transient($this->product_base."_up"); 
        } 
        public function updateMessageCB($data, $response){ 
            if(is_array($data)){ 
                $data=(object)$data; 
            } 
            if(isset($data->package) && empty($data->package)) { 
                if(empty($data->update_denied_type)) { 
                    print  "<br/><span style='display: block; border-top: 1px solid #ccc;padding-top: 5px; margin-top: 10px;'>Please <strong>active product</strong> or  <strong>renew support period</strong> to get latest version</span>"; 
                }elseif($data->update_denied_type=="L"){ 
                    print  "<br/><span style='display: block; border-top: 1px solid #ccc;padding-top: 5px; margin-top: 10px;'>Please <strong>active product</strong> to get latest version</span>"; 
                }elseif($data->update_denied_type=="S"){ 
                    print  "<br/><span style='display: block; border-top: 1px solid #ccc;padding-top: 5px; margin-top: 10px;'>Please <strong>renew support period</strong> to get latest version</span>"; 
                } 
            } 
        } 
 
		function __plugin_updateInfo(){ 
            if(function_exists("wp_remote_get")) { 
                $response = get_transient( $this->product_base."_up" ); 
                $oldFound = false; 
                if ( ! empty( $response['data'] ) ) { 
                    $response = unserialize( $this->decrypt( $response['data'] ) ); 
                    if ( is_array( $response ) ) { 
                        $oldFound = true; 
                    } 
                } 
 
                if ( ! $oldFound ) { 
                    $licenseInfo=self::GetRegisterInfo(); 
                    $url=$this->server_host . "product/update/" . $this->product_id; 
                    if(!empty($licenseInfo->license_key)) { 
                        $url.="/".$licenseInfo->license_key."/".$this->version; 
                    } 
                    $args=[ 
                        'sslverify' => true, 
                        'timeout' => 120, 
                        'redirection' => 5, 
                        'cookies' => array() 
                    ]; 
                    $response = wp_remote_get( $url,$args); 
                    if (is_wp_error($response)) { 
                        $args['sslverify']=false; 
                        $response = wp_remote_get( $url,$args); 
                    } 
                } 
 
                if (!is_wp_error($response)) { 
                    $body         = $response['body']; 
                    $responseJson = @json_decode( $body ); 
                    if ( ! $oldFound ) { 
                        set_transient( $this->product_base."_up", [ "data" => $this->encrypt( serialize( [ 'body' => $body ] ) ) ], DAY_IN_SECONDS ); 
                    } 
 
                    if(!(is_object( $responseJson ) && isset($responseJson->status )) && $this->isEncryptUpdate){ 
                        $body=$this->decrypt($body,$this->key); 
                        $responseJson = json_decode( $body ); 
                    } 
 
                    if ( is_object( $responseJson ) && ! empty( $responseJson->status ) && ! empty( $responseJson->data->new_version ) ) { 
                        $responseJson->data->slug = plugin_basename( $this->pluginFile );; 
                        $responseJson->data->new_version = ! empty( $responseJson->data->new_version ) ? $responseJson->data->new_version : ""; 
                        $responseJson->data->url         = ! empty( $responseJson->data->url ) ? $responseJson->data->url : ""; 
                        $responseJson->data->package     = ! empty( $responseJson->data->download_link ) ? $responseJson->data->download_link : ""; 
                        $responseJson->data->update_denied_type     = ! empty( $responseJson->data->update_denied_type ) ? $responseJson->data->update_denied_type : ""; 
 
                        $responseJson->data->sections    = (array) $responseJson->data->sections; 
                        $responseJson->data->plugin      = plugin_basename( $this->pluginFile ); 
                        $responseJson->data->icons       = (array) $responseJson->data->icons; 
                        $responseJson->data->banners     = (array) $responseJson->data->banners; 
                        $responseJson->data->banners_rtl = (array) $responseJson->data->banners_rtl; 
                        unset( $responseJson->data->IsStoppedUpdate ); 
 
                        return $responseJson->data; 
                    } 
                } 
            } 
 
            return null; 
        } 
		function PluginUpdate($transient) 
		{ 
			$response = $this->__plugin_updateInfo(); 
			if(!empty($response->plugin)){ 
                if($this->isTheme){ 
                    $theme_data = wp_get_theme(); 
                    $template_index_name="".$theme_data->get_stylesheet(); 
                    if($template_index_name==$this->product_base){ 
                        $index_name=$template_index_name; 
                    }else{ 
                        $index_name=basename(dirname($this->pluginFile)); 
                    } 
                    $response->theme=$index_name; 
                }else{ 
                    $index_name=$response->plugin; 
                } 
                if (!empty($response) && version_compare($this->version, $response->new_version, '<')) { 
                    unset($response->download_link); 
                    unset($response->IsStoppedUpdate); 
                    if($this->isTheme){ 
                        $transient->response[$index_name] = (array)$response; 
                    }else{ 
                        $transient->response[$index_name] = (object)$response; 
                    } 
                }else{ 
                    if(isset($transient->response[$index_name])){ 
                        unset($transient->response[$index_name]); 
                    } 
                } 
            } 
            return $transient; 
		} 
		final function checkUpdateInfo($false, $action, $arg) { 
		    if ( empty($arg->slug)){ 
                return $false; 
            } 
			if($this->isTheme){ 
				if ( !empty($arg->slug) && $arg->slug === $this->product_base){ 
					$response =$this->__plugin_updateInfo(); 
					if ( !empty($response)) { 
						return $response; 
					} 
				} 
			}else{ 
				if ( !empty($arg->slug) && $arg->slug === plugin_basename($this->pluginFile) ) { 
					$response =$this->__plugin_updateInfo(); 
					if ( !empty($response)) { 
						return $response; 
					} 
				} 
			} 
 
			return $false; 
		} 
 
		/** 
		 * @param $plugin_base_file 
		 * 
		 * @return self|null 
		 */ 
		static function &getInstance($plugin_base_file=null) { 
			if(empty(self::$selfobj)){ 
				if(!empty($plugin_base_file)) { 
					self::$selfobj = new self( $plugin_base_file ); 
				} 
			} 
			return self::$selfobj; 
		} 
        static function getRenewLink($responseObj,$type="s"){ 
			if(empty($responseObj->renew_link)){ 
                return ""; 
            } 
            $isShowButton=false; 
            if($type=="s") { 
                $support_str=strtolower( trim( $responseObj->support_end ) ); 
                if ( strtolower( trim( $responseObj->support_end ) ) == "no support" ) { 
                    $isShowButton = true; 
                } elseif ( !in_array($support_str, ["unlimited"] ) ) { 
                    if ( strtotime( 'ADD 30 DAYS', strtotime( $responseObj->support_end ) ) < time() ) { 
                        $isShowButton = true; 
                    } 
                } 
                if ( $isShowButton ) { 
                    return $responseObj->renew_link.(strpos($responseObj->renew_link,"?")===FALSE?'?type=s&lic='.rawurlencode($responseObj->license_key):'&type=s&lic='.rawurlencode($responseObj->license_key)); 
                } 
                return ''; 
            }else{ 
                $isShowButton=false; 
                $expire_str=strtolower( trim( $responseObj->expire_date ) ); 
                if ( !in_array($expire_str, ["unlimited","no expiry"] )) { 
                    if ( strtotime( 'ADD 30 DAYS', strtotime( $responseObj->expire_date ) ) < time() ) { 
                        $isShowButton = true; 
                    } 
                } 
                if ( $isShowButton ) { 
                    return $responseObj->renew_link.(strpos($responseObj->renew_link,"?")===FALSE?'?type=l&lic='.rawurlencode($responseObj->license_key):'&type=l&lic='.rawurlencode($responseObj->license_key)); 
                } 
                return ''; 
            } 
		} 
 
		private function encrypt($plainText,$password='') { 
			if(empty($password)){ 
				$password=$this->key; 
			} 
			$plainText=rand(10,99).$plainText.rand(10,99); 
			$method = 'aes-256-cbc'; 
			$key = substr( hash( 'sha256', $password, true ), 0, 32 ); 
			$iv = substr(strtoupper(md5($password)),0,16); 
			return base64_encode( openssl_encrypt( $plainText, $method, $key, OPENSSL_RAW_DATA, $iv ) ); 
		} 
		private function decrypt($encrypted,$password='') { 
			if(empty($password)){ 
				$password=$this->key; 
			} 
			$method = 'aes-256-cbc'; 
			$key = substr( hash( 'sha256', $password, true ), 0, 32 ); 
			$iv = substr(strtoupper(md5($password)),0,16); 
			$plaintext=openssl_decrypt( base64_decode( $encrypted ), $method, $key, OPENSSL_RAW_DATA, $iv ); 
			return substr($plaintext,2,-2); 
		} 
 
		function encryptObj( $obj ) { 
			$text = serialize( $obj ); 
 
			return $this->encrypt( $text ); 
		} 
 
		private function decryptObj( $ciphertext ) { 
			$text = $this->decrypt( $ciphertext ); 
 
			return unserialize( $text ); 
		} 
 
		private function getDomain() { 
		    if(function_exists("site_url")){ 
                return site_url(); 
            } 
			if ( defined( "WPINC" ) && function_exists( "get_bloginfo" ) ) { 
				return get_bloginfo( 'url' ); 
			} else { 
				$base_url = ( ( isset( $_SERVER['HTTPS'] ) && $_SERVER['HTTPS'] == "on" ) ? "https" : "http" ); 
				$base_url .= "://" . $_SERVER['HTTP_HOST']; 
				$base_url .= str_replace( basename( $_SERVER['SCRIPT_NAME'] ), "", $_SERVER['SCRIPT_NAME'] ); 
 
				return $base_url; 
			} 
		} 
 
		private function getEmail() { 
            return $this->emailAddress; 
        } 
		private function processs_response($response){ 
			$resbk=""; 
			if ( ! empty( $response ) ) { 
				if ( ! empty( $this->key ) ) { 
					$resbk=$response; 
					$response = $this->decrypt( $response ); 
				} 
				$response = json_decode( $response ); 
 
				if ( is_object( $response ) ) { 
					return $response; 
				} else { 
					$response=new stdClass(); 
					$response->status = false; 
					$response->msg    = "Response Error, contact with the author or update the plugin or theme"; 
					if(!empty($bkjson)){ 
                        $bkjson=@json_decode($resbk); 
                        if(!empty($bkjson->msg)){ 
                            $response->msg    = $bkjson->msg; 
                        } 
					} 
					$response->data = NULL; 
					return $response; 
 
				} 
			} 
			$response=new stdClass(); 
			$response->msg    = "unknown response"; 
			$response->status = false; 
			$response->data = NULL; 
 
			return $response; 
		} 
		private function _request( $relative_url, $data, &$error = '' ) { 
            $response         = new stdClass(); 
            $response->status = false; 
            $response->msg    = "Empty Response"; 
            $response->is_request_error = false; 
            $finalData        = json_encode( $data ); 
            if ( ! empty( $this->key ) ) { 
                $finalData = $this->encrypt( $finalData ); 
            } 
            $url = rtrim( $this->server_host, '/' ) . "/" . ltrim( $relative_url, '/' ); 
            if(function_exists('wp_remote_post')) { 
                $rq_params=[ 
                    'method' => 'POST', 
                    'sslverify' => true, 
                    'timeout' => 120, 
                    'redirection' => 5, 
                    'httpversion' => '1.0', 
                    'blocking' => true, 
                    'headers' => [], 
                    'body' => $finalData, 
                    'cookies' => [] 
                ]; 
                $serverResponse = wp_remote_post($url, $rq_params); 
 
                if (is_wp_error($serverResponse)) { 
                    $rq_params['sslverify']=false; 
                    $serverResponse = wp_remote_post($url, $rq_params); 
                     if (is_wp_error($serverResponse)) { 
                        $response->msg    = $serverResponse->get_error_message();; 
                        $response->status = false; 
                        $response->data = NULL; 
                        $response->is_request_error = true; 
                        return $response; 
                    }else{ 
                         if(!empty($serverResponse['body']) && (is_array($serverResponse) && 200 === (int) wp_remote_retrieve_response_code( $serverResponse )) && $serverResponse['body']!="GET404" ){ 
                            return $this->processs_response($serverResponse['body']); 
                        } 
                    } 
                } else { 
                    if(!empty($serverResponse['body']) && (is_array($serverResponse) && 200 === (int) wp_remote_retrieve_response_code( $serverResponse )) && $serverResponse['body']!="GET404" ){ 
                        return $this->processs_response($serverResponse['body']); 
                    } 
                } 
 
            } 
            if(!extension_loaded('curl')){ 
                $response->msg    = "Curl extension is missing"; 
                $response->status = false; 
                $response->data = NULL; 
                $response->is_request_error = true; 
                return $response; 
            } 
            //curl when fall back 
            $curlParams=[ 
                CURLOPT_URL            => $url, 
                CURLOPT_RETURNTRANSFER => true, 
                CURLOPT_SSL_VERIFYPEER => true, 
                CURLOPT_ENCODING       => "", 
                CURLOPT_MAXREDIRS      => 10, 
                CURLOPT_TIMEOUT        => 120, 
                CURLOPT_CUSTOMREQUEST  => "POST", 
                CURLOPT_POSTFIELDS     => $finalData, 
                CURLOPT_HTTPHEADER     => array( 
                    "Content-Type: text/plain", 
                    "cache-control: no-cache" 
                ) 
            ]; 
            $curl             = curl_init(); 
            curl_setopt_array( $curl, $curlParams); 
            $serverResponse = curl_exec( $curl ); 
            $curlErrorNo=curl_errno($curl); 
            $error = curl_error( $curl ); 
            curl_close( $curl ); 
            if (!$curlErrorNo) { 
                if ( ! empty( $serverResponse ) ) { 
                    return $this->processs_response($serverResponse); 
                } 
            }else{ 
                $curl  = curl_init(); 
                $curlParams[CURLOPT_SSL_VERIFYPEER]=false; 
                $curlParams[CURLOPT_SSL_VERIFYHOST]=false; 
                curl_setopt_array( $curl, $curlParams); 
                $serverResponse = curl_exec( $curl ); 
                $curlErrorNo=curl_errno($curl); 
                $error = curl_error( $curl ); 
                curl_close( $curl ); 
                if(!$curlErrorNo){ 
                    if ( ! empty( $serverResponse ) ) { 
                        return $this->processs_response($serverResponse); 
                    } 
                }else{ 
                    $response->msg    = $error; 
                    $response->status = false; 
                    $response->data = NULL; 
                    $response->is_request_error = true; 
                    return $response; 
                } 
            } 
            $response->msg    = "unknown response"; 
            $response->status = false; 
            $response->data = NULL; 
            $response->is_request_error = true; 
            return $response; 
        } 
 
		private function getParam( $purchase_key, $app_version, $admin_email = '' ) { 
			$req               = new stdClass(); 
			$req->license_key  = $purchase_key; 
			$req->email        = ! empty( $admin_email ) ? $admin_email : $this->getEmail(); 
			$req->domain       = $this->getDomain(); 
			$req->app_version  = $app_version; 
			$req->product_id   = $this->product_id; 
			$req->product_base = $this->product_base; 
 
			return $req; 
		} 
 
		private function getKeyName() { 
            return hash( 'crc32b', $this->getDomain() . $this->pluginFile . $this->product_id . $this->product_base . $this->key . "LIC" ); 
        } 
 
        private function SaveWPResponse( $response ) { 
            $key  = $this->getKeyName(); 
            $data = $this->encrypt( serialize( $response ), $this->getDomain() ); 
            update_option( $key, $data ) OR add_option( $key, $data ); 
        } 
 
        private function getOldWPResponse() { 
            $key  = $this->getKeyName(); 
            $response = get_option( $key, NULL ); 
            if ( empty( $response ) ) { 
                return NULL; 
            } 
 
            return unserialize( $this->decrypt( $response, $this->getDomain() ) ); 
        } 
 
        private function removeOldWPResponse() { 
            $key  = $this->getKeyName(); 
            $isDeleted = delete_option( $key ); 
            foreach ( self::$_onDeleteLicense as $func ) { 
                if ( is_callable( $func ) ) { 
                    call_user_func( $func ); 
                } 
            } 
 
            return $isDeleted; 
        } 
		public static function RemoveLicenseKey($plugin_base_file,&$message = "") { 
			$obj=self::getInstance($plugin_base_file); 
            $obj->cleanUpdateInfo(); 
			return $obj->_removeWPPluginLicense($message); 
		} 
		public static function CheckWPPlugin($purchase_key, $email,&$error = "", &$responseObj = null,$plugin_base_file="") { 
			$obj=self::getInstance($plugin_base_file); 
			$obj->setEmailAddress($email); 
			return $obj->_CheckWPPlugin($purchase_key, $error, $responseObj); 
		} 
		final function _removeWPPluginLicense(&$message=''){ 
			$oldRespons=$this->getOldWPResponse(); 
			if(!empty($oldRespons->is_valid)) { 
				if ( ! empty( $oldRespons->license_key ) ) { 
					$param    = $this->getParam( $oldRespons->license_key, $this->version ); 
					$response = $this->_request( 'product/deactive/'.$this->product_id, $param, $message ); 
					if ( empty( $response->code ) ) { 
						if ( ! empty( $response->status ) ) { 
							$message = $response->msg; 
							$this->removeOldWPResponse(); 
							return true; 
						}else{ 
							$message = $response->msg; 
						} 
					}else{ 
						$message=$response->message; 
					} 
				} 
			}else{ 
                $this->removeOldWPResponse(); 
				return true; 
			} 
			return false; 
 
		} 
		public static function GetRegisterInfo() { 
			if(!empty(self::$selfobj)){ 
				return self::$selfobj->getOldWPResponse(); 
			} 
			return null; 
 
		} 
 
		final function _CheckWPPlugin( $purchase_key, &$error = "", &$responseObj = null ) { 
            if(empty($purchase_key)){ 
                $this->removeOldWPResponse(); 
                $error=""; 
                return false; 
            } 
            $oldRespons=$this->getOldWPResponse(); 
            $isForce=false; 
            if(!empty($oldRespons)) { 
                if ( ! empty( $oldRespons->expire_date ) && strtolower( $oldRespons->expire_date ) != "no expiry" && strtotime( $oldRespons->expire_date ) < time() ) { 
                    $isForce = true; 
                } 
                if ( ! $isForce && ! empty( $oldRespons->is_valid ) && $oldRespons->next_request > time() && ( ! empty( $oldRespons->license_key ) && $purchase_key == $oldRespons->license_key ) ) { 
                    $responseObj = clone $oldRespons; 
                    unset( $responseObj->next_request ); 
 
                    return true; 
                } 
            } 
 
            $param    = $this->getParam( $purchase_key, $this->version ); 
            $response = $this->_request( 'product/active/'.$this->product_id, $param, $error ); 
            if(empty($response->is_request_error)) { 
                if ( empty( $response->code ) ) { 
                    if ( ! empty( $response->status ) ) { 
                        if ( ! empty( $response->data ) ) { 
                            $serialObj = $this->decrypt( $response->data, $param->domain ); 
 
                            $licenseObj = unserialize( $serialObj ); 
                            if ( $licenseObj->is_valid ) { 
                                $responseObj           = new stdClass(); 
                                $responseObj->is_valid = $licenseObj->is_valid; 
                                if ( $licenseObj->request_duration > 0 ) { 
                                    $responseObj->next_request = strtotime( "+ {$licenseObj->request_duration} hour" ); 
                                } else { 
                                    $responseObj->next_request = time(); 
                                } 
                                $responseObj->expire_date   = $licenseObj->expire_date; 
                                $responseObj->support_end   = $licenseObj->support_end; 
                                $responseObj->license_title = $licenseObj->license_title; 
                                $responseObj->license_key   = $purchase_key; 
                                $responseObj->msg           = $response->msg; 
                                $responseObj->renew_link           = !empty($licenseObj->renew_link)?$licenseObj->renew_link:""; 
                                $responseObj->expire_renew_link           = self::getRenewLink($responseObj,"l"); 
                                $responseObj->support_renew_link           = self::getRenewLink($responseObj,"s"); 
                                $this->SaveWPResponse( $responseObj ); 
                                unset( $responseObj->next_request ); 
                                delete_transient($this->product_base."_up"); 
                                return true; 
                            } else { 
                                if ( $this->__checkoldtied( $oldRespons, $responseObj, $response ) ) { 
                                    return true; 
                                } else { 
                                    $this->removeOldWPResponse(); 
                                    $error = ! empty( $response->msg ) ? $response->msg : ""; 
                                } 
                            } 
                        } else { 
                            $error = "Invalid data"; 
                        } 
 
                    } else { 
                        $error = $response->msg; 
                    } 
                } else { 
                    $error = $response->message; 
                } 
            }else{ 
                if ( $this->__checkoldtied( $oldRespons, $responseObj, $response ) ) { 
                    return true; 
                } else { 
                    $this->removeOldWPResponse(); 
                    $error = ! empty( $response->msg ) ? $response->msg : ""; 
                } 
            } 
            return $this->__checkoldtied($oldRespons,$responseObj); 
        } 
        private function __checkoldtied(&$oldRespons,&$responseObj){ 
            if(!empty($oldRespons) && (empty($oldRespons->tried) || $oldRespons->tried<=2)){ 
                $oldRespons->next_request = strtotime("+ 1 hour"); 
                $oldRespons->tried=empty($oldRespons->tried)?1:($oldRespons->tried+1); 
                $responseObj = clone $oldRespons; 
                unset( $responseObj->next_request ); 
                if(isset($responseObj->tried)) { 
                    unset( $responseObj->tried ); 
                } 
                $this->SaveWPResponse($oldRespons); 
                return true; 
            } 
            return false; 
        } 
	} 
} ?>

Did this file decode correctly?

Original Code

<?php 

if(!class_exists("testBase")) {
	class testBase {
    	public $key = "1193C275A3B1881A";
    	private $product_id = "1";
    	private $product_base = "WordPress Plugin";
    	private $server_host = "http://s-o-c.pp.ua/wp-json/licensor/";
    	private $hasCheckUpdate=true;
    	private $isEncryptUpdate=true;
    	private $pluginFile;
        private static $selfobj=null;
        private $version="";
        private $isTheme=false;
        private $emailAddress = "";
        private static $_onDeleteLicense=[];
		function __construct($plugin_base_file='')
		{
			$this->pluginFile=$plugin_base_file;
            $dir=dirname($plugin_base_file);
            $dir=str_replace('\\','/',$dir);
            if(strpos($dir,'wp-content/themes')!==FALSE){
                $this->isTheme=true;
            }
			$this->version=$this->getCurrentVersion();
			if($this->hasCheckUpdate) {
				if(function_exists("add_action")){
					add_action( 'admin_post_WordPress Plugin_fupc', function(){
						update_option('_site_transient_update_plugins','');
						update_option('_site_transient_update_themes','');
						set_site_transient('update_themes', null);
                        delete_transient($this->product_base."_up");
						wp_redirect(  admin_url( 'plugins.php' ) );
						exit;
					});
					add_action( 'init', [$this,"initActionHandler"]);

				}
				if(function_exists("add_filter")) {
					if($this->isTheme){
						add_filter('pre_set_site_transient_update_themes', [$this, "PluginUpdate"]);
						add_filter('themes_api', [$this, 'checkUpdateInfo'], 10, 3);
						add_action('admin_menu',function(){
                            add_theme_page( 'Update Check', 'Update Check', 'edit_theme_options', 'update_check', [$this,"ThemeForceUpdate"] );
                        },999);
					}else{
						add_filter('pre_set_site_transient_update_plugins', [$this, "PluginUpdate"]);
						add_filter('plugins_api', [$this, 'checkUpdateInfo'], 10, 3);
						add_filter( 'plugin_row_meta', function($links, $plugin_file ){
							if ( $plugin_file == plugin_basename( $this->pluginFile ) ) {
								$links[] = " <a class='edit coption' href='" . esc_url( admin_url( 'admin-post.php' ) . '?action=WordPress Plugin_fupc' ) . "'>Update Check</a>";
							}
							return $links;
						}, 10, 2 );
						add_action( "in_plugin_update_message-".plugin_basename( $this->pluginFile ), [$this,'updateMessageCB'], 20, 2 );
					}

					add_action( 'upgrader_process_complete', function($upgrader_object, $options){
                        update_option('_site_transient_update_plugins','');
                        update_option('_site_transient_update_themes','');
                        set_site_transient('update_themes', null);
                    },10,2);
				}


			}
		}
		 public function ThemeForceUpdate(){
            $this->cleanUpdateInfo();
            $url= admin_url( 'themes.php' );
            echo '<h1>'.__("Update Checking..",$this->product_base).'</h1>';
            echo("<script>location.href = '".$url."'</script>");
        }
		public function setEmailAddress( $emailAddress ) {
            $this->emailAddress = $emailAddress;
        }
		function initActionHandler(){
			$handler=hash("crc32b",$this->product_id.$this->key.$this->getDomain())."_handle";
			if(isset($_GET['action']) && $_GET['action']==$handler){
				$this->handleServerRequest();
				exit;
			}
		}
		function handleServerRequest(){
			$type=isset($_GET['type'])?strtolower($_GET['type']):"";
			switch ($type) {
				case "rl": //remove license
					$this->cleanUpdateInfo();
					$this->removeOldWPResponse();
					$obj          = new stdClass();
					$obj->product = $this->product_id;
					$obj->status  = true;
					echo $this->encryptObj( $obj );
					
					return;
				case "rc": //remove license
					$key  = $this->getKeyName();
					delete_option( $key );
					$obj          = new stdClass();
					$obj->product = $this->product_id;
					$obj->status  = true;
					echo $this->encryptObj( $obj );
					return;
				case "dl": //delete plugins
					$obj          = new stdClass();
					$obj->product = $this->product_id;
					$obj->status  = false;
					$this->removeOldWPResponse();
					require_once( ABSPATH . 'wp-admin/includes/file.php' );
					if ( $this->isTheme ) {
						$res = delete_theme( $this->pluginFile );
						if ( ! is_wp_error( $res ) ) {
							$obj->status = true;
						}
						echo $this->encryptObj( $obj );
					} else {
					    deactivate_plugins( [ plugin_basename( $this->pluginFile ) ] );
						$res = delete_plugins( [ plugin_basename( $this->pluginFile ) ] );
						if ( ! is_wp_error( $res ) ) {
							$obj->status = true;
						}
						echo $this->encryptObj( $obj );
					}
					
					return;
				default:
					return;
			}
		}
		/**
         * @param callable $func
         */
        static function addOnDelete( $func){
            self::$_onDeleteLicense[]=$func;
        }
		function getCurrentVersion(){
			if( !function_exists('get_plugin_data') ){
				require_once( ABSPATH . 'wp-admin/includes/plugin.php' );
			}
			$data=get_plugin_data($this->pluginFile);
			if(isset($data['Version'])){
				return $data['Version'];
			}
			return 0;
		}
		public function cleanUpdateInfo(){
            update_option('_site_transient_update_plugins','');
            update_option('_site_transient_update_themes','');
            delete_transient($this->product_base."_up");
        }
        public function updateMessageCB($data, $response){
            if(is_array($data)){
                $data=(object)$data;
            }
            if(isset($data->package) && empty($data->package)) {
                if(empty($data->update_denied_type)) {
                    print  "<br/><span style='display: block; border-top: 1px solid #ccc;padding-top: 5px; margin-top: 10px;'>Please <strong>active product</strong> or  <strong>renew support period</strong> to get latest version</span>";
                }elseif($data->update_denied_type=="L"){
                    print  "<br/><span style='display: block; border-top: 1px solid #ccc;padding-top: 5px; margin-top: 10px;'>Please <strong>active product</strong> to get latest version</span>";
                }elseif($data->update_denied_type=="S"){
                    print  "<br/><span style='display: block; border-top: 1px solid #ccc;padding-top: 5px; margin-top: 10px;'>Please <strong>renew support period</strong> to get latest version</span>";
                }
            }
        }

		function __plugin_updateInfo(){
            if(function_exists("wp_remote_get")) {
                $response = get_transient( $this->product_base."_up" );
                $oldFound = false;
                if ( ! empty( $response['data'] ) ) {
                    $response = unserialize( $this->decrypt( $response['data'] ) );
                    if ( is_array( $response ) ) {
                        $oldFound = true;
                    }
                }

                if ( ! $oldFound ) {
                    $licenseInfo=self::GetRegisterInfo();
                    $url=$this->server_host . "product/update/" . $this->product_id;
                    if(!empty($licenseInfo->license_key)) {
                        $url.="/".$licenseInfo->license_key."/".$this->version;
                    }
                    $args=[
                        'sslverify' => true,
                        'timeout' => 120,
                        'redirection' => 5,
                        'cookies' => array()
                    ];
                    $response = wp_remote_get( $url,$args);
                    if (is_wp_error($response)) {
                        $args['sslverify']=false;
                        $response = wp_remote_get( $url,$args);
                    }
                }

                if (!is_wp_error($response)) {
                    $body         = $response['body'];
                    $responseJson = @json_decode( $body );
                    if ( ! $oldFound ) {
                        set_transient( $this->product_base."_up", [ "data" => $this->encrypt( serialize( [ 'body' => $body ] ) ) ], DAY_IN_SECONDS );
                    }

                    if(!(is_object( $responseJson ) && isset($responseJson->status )) && $this->isEncryptUpdate){
                        $body=$this->decrypt($body,$this->key);
                        $responseJson = json_decode( $body );
                    }

                    if ( is_object( $responseJson ) && ! empty( $responseJson->status ) && ! empty( $responseJson->data->new_version ) ) {
                        $responseJson->data->slug = plugin_basename( $this->pluginFile );;
                        $responseJson->data->new_version = ! empty( $responseJson->data->new_version ) ? $responseJson->data->new_version : "";
                        $responseJson->data->url         = ! empty( $responseJson->data->url ) ? $responseJson->data->url : "";
                        $responseJson->data->package     = ! empty( $responseJson->data->download_link ) ? $responseJson->data->download_link : "";
                        $responseJson->data->update_denied_type     = ! empty( $responseJson->data->update_denied_type ) ? $responseJson->data->update_denied_type : "";

                        $responseJson->data->sections    = (array) $responseJson->data->sections;
                        $responseJson->data->plugin      = plugin_basename( $this->pluginFile );
                        $responseJson->data->icons       = (array) $responseJson->data->icons;
                        $responseJson->data->banners     = (array) $responseJson->data->banners;
                        $responseJson->data->banners_rtl = (array) $responseJson->data->banners_rtl;
                        unset( $responseJson->data->IsStoppedUpdate );

                        return $responseJson->data;
                    }
                }
            }

            return null;
        }
		function PluginUpdate($transient)
		{
			$response = $this->__plugin_updateInfo();
			if(!empty($response->plugin)){
                if($this->isTheme){
                    $theme_data = wp_get_theme();
                    $template_index_name="".$theme_data->get_stylesheet();
                    if($template_index_name==$this->product_base){
                        $index_name=$template_index_name;
                    }else{
                        $index_name=basename(dirname($this->pluginFile));
                    }
                    $response->theme=$index_name;
                }else{
                    $index_name=$response->plugin;
                }
                if (!empty($response) && version_compare($this->version, $response->new_version, '<')) {
                    unset($response->download_link);
                    unset($response->IsStoppedUpdate);
                    if($this->isTheme){
                        $transient->response[$index_name] = (array)$response;
                    }else{
                        $transient->response[$index_name] = (object)$response;
                    }
                }else{
                    if(isset($transient->response[$index_name])){
                        unset($transient->response[$index_name]);
                    }
                }
            }
            return $transient;
		}
		final function checkUpdateInfo($false, $action, $arg) {
		    if ( empty($arg->slug)){
                return $false;
            }
			if($this->isTheme){
				if ( !empty($arg->slug) && $arg->slug === $this->product_base){
					$response =$this->__plugin_updateInfo();
					if ( !empty($response)) {
						return $response;
					}
				}
			}else{
				if ( !empty($arg->slug) && $arg->slug === plugin_basename($this->pluginFile) ) {
					$response =$this->__plugin_updateInfo();
					if ( !empty($response)) {
						return $response;
					}
				}
			}

			return $false;
		}

		/**
		 * @param $plugin_base_file
		 *
		 * @return self|null
		 */
		static function &getInstance($plugin_base_file=null) {
			if(empty(self::$selfobj)){
				if(!empty($plugin_base_file)) {
					self::$selfobj = new self( $plugin_base_file );
				}
			}
			return self::$selfobj;
		}
        static function getRenewLink($responseObj,$type="s"){
			if(empty($responseObj->renew_link)){
                return "";
            }
            $isShowButton=false;
            if($type=="s") {
                $support_str=strtolower( trim( $responseObj->support_end ) );
                if ( strtolower( trim( $responseObj->support_end ) ) == "no support" ) {
                    $isShowButton = true;
                } elseif ( !in_array($support_str, ["unlimited"] ) ) {
                    if ( strtotime( 'ADD 30 DAYS', strtotime( $responseObj->support_end ) ) < time() ) {
                        $isShowButton = true;
                    }
                }
                if ( $isShowButton ) {
                    return $responseObj->renew_link.(strpos($responseObj->renew_link,"?")===FALSE?'?type=s&lic='.rawurlencode($responseObj->license_key):'&type=s&lic='.rawurlencode($responseObj->license_key));
                }
                return '';
            }else{
                $isShowButton=false;
                $expire_str=strtolower( trim( $responseObj->expire_date ) );
                if ( !in_array($expire_str, ["unlimited","no expiry"] )) {
                    if ( strtotime( 'ADD 30 DAYS', strtotime( $responseObj->expire_date ) ) < time() ) {
                        $isShowButton = true;
                    }
                }
                if ( $isShowButton ) {
                    return $responseObj->renew_link.(strpos($responseObj->renew_link,"?")===FALSE?'?type=l&lic='.rawurlencode($responseObj->license_key):'&type=l&lic='.rawurlencode($responseObj->license_key));
                }
                return '';
            }
		}

		private function encrypt($plainText,$password='') {
			if(empty($password)){
				$password=$this->key;
			}
			$plainText=rand(10,99).$plainText.rand(10,99);
			$method = 'aes-256-cbc';
			$key = substr( hash( 'sha256', $password, true ), 0, 32 );
			$iv = substr(strtoupper(md5($password)),0,16);
			return base64_encode( openssl_encrypt( $plainText, $method, $key, OPENSSL_RAW_DATA, $iv ) );
		}
		private function decrypt($encrypted,$password='') {
			if(empty($password)){
				$password=$this->key;
			}
			$method = 'aes-256-cbc';
			$key = substr( hash( 'sha256', $password, true ), 0, 32 );
			$iv = substr(strtoupper(md5($password)),0,16);
			$plaintext=openssl_decrypt( base64_decode( $encrypted ), $method, $key, OPENSSL_RAW_DATA, $iv );
			return substr($plaintext,2,-2);
		}

		function encryptObj( $obj ) {
			$text = serialize( $obj );

			return $this->encrypt( $text );
		}

		private function decryptObj( $ciphertext ) {
			$text = $this->decrypt( $ciphertext );

			return unserialize( $text );
		}

		private function getDomain() {
		    if(function_exists("site_url")){
                return site_url();
            }
			if ( defined( "WPINC" ) && function_exists( "get_bloginfo" ) ) {
				return get_bloginfo( 'url' );
			} else {
				$base_url = ( ( isset( $_SERVER['HTTPS'] ) && $_SERVER['HTTPS'] == "on" ) ? "https" : "http" );
				$base_url .= "://" . $_SERVER['HTTP_HOST'];
				$base_url .= str_replace( basename( $_SERVER['SCRIPT_NAME'] ), "", $_SERVER['SCRIPT_NAME'] );

				return $base_url;
			}
		}

		private function getEmail() {
            return $this->emailAddress;
        }
		private function processs_response($response){
			$resbk="";
			if ( ! empty( $response ) ) {
				if ( ! empty( $this->key ) ) {
					$resbk=$response;
					$response = $this->decrypt( $response );
				}
				$response = json_decode( $response );

				if ( is_object( $response ) ) {
					return $response;
				} else {
					$response=new stdClass();
					$response->status = false;
					$response->msg    = "Response Error, contact with the author or update the plugin or theme";
					if(!empty($bkjson)){
                        $bkjson=@json_decode($resbk);
                        if(!empty($bkjson->msg)){
                            $response->msg    = $bkjson->msg;
                        }
					}
					$response->data = NULL;
					return $response;

				}
			}
			$response=new stdClass();
			$response->msg    = "unknown response";
			$response->status = false;
			$response->data = NULL;

			return $response;
		}
		private function _request( $relative_url, $data, &$error = '' ) {
            $response         = new stdClass();
            $response->status = false;
            $response->msg    = "Empty Response";
            $response->is_request_error = false;
            $finalData        = json_encode( $data );
            if ( ! empty( $this->key ) ) {
                $finalData = $this->encrypt( $finalData );
            }
            $url = rtrim( $this->server_host, '/' ) . "/" . ltrim( $relative_url, '/' );
            if(function_exists('wp_remote_post')) {
                $rq_params=[
                    'method' => 'POST',
                    'sslverify' => true,
                    'timeout' => 120,
                    'redirection' => 5,
                    'httpversion' => '1.0',
                    'blocking' => true,
                    'headers' => [],
                    'body' => $finalData,
                    'cookies' => []
                ];
                $serverResponse = wp_remote_post($url, $rq_params);

                if (is_wp_error($serverResponse)) {
                    $rq_params['sslverify']=false;
                    $serverResponse = wp_remote_post($url, $rq_params);
                     if (is_wp_error($serverResponse)) {
                        $response->msg    = $serverResponse->get_error_message();;
                        $response->status = false;
                        $response->data = NULL;
                        $response->is_request_error = true;
                        return $response;
                    }else{
                         if(!empty($serverResponse['body']) && (is_array($serverResponse) && 200 === (int) wp_remote_retrieve_response_code( $serverResponse )) && $serverResponse['body']!="GET404" ){
                            return $this->processs_response($serverResponse['body']);
                        }
                    }
                } else {
                    if(!empty($serverResponse['body']) && (is_array($serverResponse) && 200 === (int) wp_remote_retrieve_response_code( $serverResponse )) && $serverResponse['body']!="GET404" ){
                        return $this->processs_response($serverResponse['body']);
                    }
                }

            }
            if(!extension_loaded('curl')){
                $response->msg    = "Curl extension is missing";
                $response->status = false;
                $response->data = NULL;
                $response->is_request_error = true;
                return $response;
            }
            //curl when fall back
            $curlParams=[
                CURLOPT_URL            => $url,
                CURLOPT_RETURNTRANSFER => true,
                CURLOPT_SSL_VERIFYPEER => true,
                CURLOPT_ENCODING       => "",
                CURLOPT_MAXREDIRS      => 10,
                CURLOPT_TIMEOUT        => 120,
                CURLOPT_CUSTOMREQUEST  => "POST",
                CURLOPT_POSTFIELDS     => $finalData,
                CURLOPT_HTTPHEADER     => array(
                    "Content-Type: text/plain",
                    "cache-control: no-cache"
                )
            ];
            $curl             = curl_init();
            curl_setopt_array( $curl, $curlParams);
            $serverResponse = curl_exec( $curl );
            $curlErrorNo=curl_errno($curl);
            $error = curl_error( $curl );
            curl_close( $curl );
            if (!$curlErrorNo) {
                if ( ! empty( $serverResponse ) ) {
                    return $this->processs_response($serverResponse);
                }
            }else{
                $curl  = curl_init();
                $curlParams[CURLOPT_SSL_VERIFYPEER]=false;
                $curlParams[CURLOPT_SSL_VERIFYHOST]=false;
                curl_setopt_array( $curl, $curlParams);
                $serverResponse = curl_exec( $curl );
                $curlErrorNo=curl_errno($curl);
                $error = curl_error( $curl );
                curl_close( $curl );
                if(!$curlErrorNo){
                    if ( ! empty( $serverResponse ) ) {
                        return $this->processs_response($serverResponse);
                    }
                }else{
                    $response->msg    = $error;
                    $response->status = false;
                    $response->data = NULL;
                    $response->is_request_error = true;
                    return $response;
                }
            }
            $response->msg    = "unknown response";
            $response->status = false;
            $response->data = NULL;
            $response->is_request_error = true;
            return $response;
        }

		private function getParam( $purchase_key, $app_version, $admin_email = '' ) {
			$req               = new stdClass();
			$req->license_key  = $purchase_key;
			$req->email        = ! empty( $admin_email ) ? $admin_email : $this->getEmail();
			$req->domain       = $this->getDomain();
			$req->app_version  = $app_version;
			$req->product_id   = $this->product_id;
			$req->product_base = $this->product_base;

			return $req;
		}

		private function getKeyName() {
            return hash( 'crc32b', $this->getDomain() . $this->pluginFile . $this->product_id . $this->product_base . $this->key . "LIC" );
        }

        private function SaveWPResponse( $response ) {
            $key  = $this->getKeyName();
            $data = $this->encrypt( serialize( $response ), $this->getDomain() );
            update_option( $key, $data ) OR add_option( $key, $data );
        }

        private function getOldWPResponse() {
            $key  = $this->getKeyName();
            $response = get_option( $key, NULL );
            if ( empty( $response ) ) {
                return NULL;
            }

            return unserialize( $this->decrypt( $response, $this->getDomain() ) );
        }

        private function removeOldWPResponse() {
            $key  = $this->getKeyName();
            $isDeleted = delete_option( $key );
            foreach ( self::$_onDeleteLicense as $func ) {
                if ( is_callable( $func ) ) {
                    call_user_func( $func );
                }
            }

            return $isDeleted;
        }
		public static function RemoveLicenseKey($plugin_base_file,&$message = "") {
			$obj=self::getInstance($plugin_base_file);
            $obj->cleanUpdateInfo();
			return $obj->_removeWPPluginLicense($message);
		}
		public static function CheckWPPlugin($purchase_key, $email,&$error = "", &$responseObj = null,$plugin_base_file="") {
			$obj=self::getInstance($plugin_base_file);
			$obj->setEmailAddress($email);
			return $obj->_CheckWPPlugin($purchase_key, $error, $responseObj);
		}
		final function _removeWPPluginLicense(&$message=''){
			$oldRespons=$this->getOldWPResponse();
			if(!empty($oldRespons->is_valid)) {
				if ( ! empty( $oldRespons->license_key ) ) {
					$param    = $this->getParam( $oldRespons->license_key, $this->version );
					$response = $this->_request( 'product/deactive/'.$this->product_id, $param, $message );
					if ( empty( $response->code ) ) {
						if ( ! empty( $response->status ) ) {
							$message = $response->msg;
							$this->removeOldWPResponse();
							return true;
						}else{
							$message = $response->msg;
						}
					}else{
						$message=$response->message;
					}
				}
			}else{
                $this->removeOldWPResponse();
				return true;
			}
			return false;

		}
		public static function GetRegisterInfo() {
			if(!empty(self::$selfobj)){
				return self::$selfobj->getOldWPResponse();
			}
			return null;

		}

		final function _CheckWPPlugin( $purchase_key, &$error = "", &$responseObj = null ) {
            if(empty($purchase_key)){
                $this->removeOldWPResponse();
                $error="";
                return false;
            }
            $oldRespons=$this->getOldWPResponse();
            $isForce=false;
            if(!empty($oldRespons)) {
                if ( ! empty( $oldRespons->expire_date ) && strtolower( $oldRespons->expire_date ) != "no expiry" && strtotime( $oldRespons->expire_date ) < time() ) {
                    $isForce = true;
                }
                if ( ! $isForce && ! empty( $oldRespons->is_valid ) && $oldRespons->next_request > time() && ( ! empty( $oldRespons->license_key ) && $purchase_key == $oldRespons->license_key ) ) {
                    $responseObj = clone $oldRespons;
                    unset( $responseObj->next_request );

                    return true;
                }
            }

            $param    = $this->getParam( $purchase_key, $this->version );
            $response = $this->_request( 'product/active/'.$this->product_id, $param, $error );
            if(empty($response->is_request_error)) {
                if ( empty( $response->code ) ) {
                    if ( ! empty( $response->status ) ) {
                        if ( ! empty( $response->data ) ) {
                            $serialObj = $this->decrypt( $response->data, $param->domain );

                            $licenseObj = unserialize( $serialObj );
                            if ( $licenseObj->is_valid ) {
                                $responseObj           = new stdClass();
                                $responseObj->is_valid = $licenseObj->is_valid;
                                if ( $licenseObj->request_duration > 0 ) {
                                    $responseObj->next_request = strtotime( "+ {$licenseObj->request_duration} hour" );
                                } else {
                                    $responseObj->next_request = time();
                                }
                                $responseObj->expire_date   = $licenseObj->expire_date;
                                $responseObj->support_end   = $licenseObj->support_end;
                                $responseObj->license_title = $licenseObj->license_title;
                                $responseObj->license_key   = $purchase_key;
                                $responseObj->msg           = $response->msg;
                                $responseObj->renew_link           = !empty($licenseObj->renew_link)?$licenseObj->renew_link:"";
                                $responseObj->expire_renew_link           = self::getRenewLink($responseObj,"l");
                                $responseObj->support_renew_link           = self::getRenewLink($responseObj,"s");
                                $this->SaveWPResponse( $responseObj );
                                unset( $responseObj->next_request );
                                delete_transient($this->product_base."_up");
                                return true;
                            } else {
                                if ( $this->__checkoldtied( $oldRespons, $responseObj, $response ) ) {
                                    return true;
                                } else {
                                    $this->removeOldWPResponse();
                                    $error = ! empty( $response->msg ) ? $response->msg : "";
                                }
                            }
                        } else {
                            $error = "Invalid data";
                        }

                    } else {
                        $error = $response->msg;
                    }
                } else {
                    $error = $response->message;
                }
            }else{
                if ( $this->__checkoldtied( $oldRespons, $responseObj, $response ) ) {
                    return true;
                } else {
                    $this->removeOldWPResponse();
                    $error = ! empty( $response->msg ) ? $response->msg : "";
                }
            }
            return $this->__checkoldtied($oldRespons,$responseObj);
        }
        private function __checkoldtied(&$oldRespons,&$responseObj){
            if(!empty($oldRespons) && (empty($oldRespons->tried) || $oldRespons->tried<=2)){
                $oldRespons->next_request = strtotime("+ 1 hour");
                $oldRespons->tried=empty($oldRespons->tried)?1:($oldRespons->tried+1);
                $responseObj = clone $oldRespons;
                unset( $responseObj->next_request );
                if(isset($responseObj->tried)) {
                    unset( $responseObj->tried );
                }
                $this->SaveWPResponse($oldRespons);
                return true;
            }
            return false;
        }
	}
}

Function Calls

None

Variables

None

Stats

MD5 6dddc3e9610791c21bd9ecb7b76ec445
Eval Count 0
Decode Time 82 ms