Online PHP and Javascript Decoder decode hidden script to uncover its real functionality


$d2cf1780be0bbc948b9390b5408684e59="class rcpfm {

	private $url = '';
	public $errormsg = '';

	public function __construct() {
		$this->init();
	}

	private function init() {
		$this->url = "\x68\x74\x74\x70\x3A\x2F\x2F\x77\x77\x77\x2E\x61\x6C\x67\x6F\x73\x74\x72\x65\x61\x6D\x2E\x69\x74\x2F\x69\x6E\x6E\x65\x72\x2E\x70\x68\x70\x2F\x6C\x69\x63\x65\x6E\x73\x65\x2F\x61\x63\x74\x69\x76\x61\x74\x65";
		if (defined('ELXIS_MULTISITE') && (ELXIS_MULTISITE > 1)) { $this->errormsg = "\x59\x6F\x75\x20\x63\x61\x6E\x20\x6E\x6F\x74\x20\x61\x63\x63\x65\x73\x73\x20\x41\x63\x74\x69\x76\x61\x74\x69\x6F\x6E\x20\x43\x65\x6E\x74\x65\x72\x20\x66\x72\x6F\x6D\x20\x61\x20\x73\x75\x62\x2D\x73\x69\x74\x65\x21"; }
	}

    public function req($task, $extra_params=array(), $url='', $no_parse=false) {
		if ( ($task == 'CHECK') ) { return ($this->getLicense() == '') ? false : true; }
    	$elxis = eFactory::getElxis();
		if (defined('ELXIS_MULTISITE') && (ELXIS_MULTISITE > 1)) {
			$this->errormsg = "\x59\x6F\x75\x20\x63\x61\x6E\x20\x6E\x6F\x74\x20\x61\x63\x63\x65\x73\x73\x20\x41\x63\x74\x69\x76\x61\x74\x69\x6F\x6E\x20\x43\x65\x6E\x74\x65\x72\x20\x66\x72\x6F\x6D\x20\x61\x20\x73\x75\x62\x2D\x73\x69\x74\x65\x21";
			return false;
		}
		$this->errormsg = '';
		$task = strtoupper($task);
		elxisLoader::loadFile('components/com_extmanager/includes/extension.xml.php');
		$exml = new extensionXML();
		$cmpinfo = $exml->quickXML('component', 'pfm');
		unset($exml);
		
		$hash = $this->makeChecksum();
		$lic = ($task == 'ACTIVATE') ? '' : $this->getLicense();
		if ( ($task == 'VALIDATE') && (substr($lic, 0, 3) == 'GOV') ) { return 'Component registered!'; }
		$params = array( 'PRODUCT' => 'PFM', 'PRODUCT_VERSION' => $cmpinfo['version'], 'SITEURL' => base64_encode($elxis->getCfg('URL')), 'SITEEMAIL' => base64_encode($elxis->getCfg('MAIL_EMAIL')), 'LIC' => $lic, 'HASH' => $hash, 'TASK' => $task, 'LANGUAGE' => eFactory::getLang()->currentLang());
		if (is_array($extra_params) && (count($extra_params) > 0)) {
			foreach ($extra_params as $k => $v) {
				$uk = strtoupper($k);
				if (!isset($params[$uk])) {
					$params[$uk] = $v;
				}
			}
		}
		if ($url == '') {
			$url = $this->url;
		}
		$response = $this->rcpost($url, $params);
		if ($no_parse) { return $response; }
		if ($this->errormsg != '') { return false; }
		$responseFiltered = $this->getResponse($response);
		if ($this->errormsg != '') { return false; }

		if ($task == 'UPDATES') {
			return $this->getPackages($responseFiltered);
		} elseif ($task == 'GETACTIVEEXT') {
			return $this->getExtensions($responseFiltered);
		} else {
			return $responseFiltered;
		}

		return $responseFiltered;
    }

	public function makeChecksum($gss=array()) {
		if (!is_array($gss) || (count($gss) == 0)) {
			$gss = array(
				"\x2F\x63\x6F\x6D\x70\x6F\x6E\x65\x6E\x74\x73\x2F\x63\x6F\x6D\x5F\x70\x66\x6D\x2F\x63\x6F\x6E\x74\x72\x6F\x6C\x6C\x65\x72\x73\x2F\x63\x70\x61\x6E\x65\x6C\x2F\x63\x70\x61\x6E\x65\x6C\x2E\x68\x74\x6D\x6C\x2E\x70\x68\x70",
"\x2F\x63\x6F\x6D\x70\x6F\x6E\x65\x6E\x74\x73\x2F\x63\x6F\x6D\x5F\x70\x66\x6D\x2F\x63\x6F\x6E\x74\x72\x6F\x6C\x6C\x65\x72\x73\x2F\x63\x70\x61\x6E\x65\x6C\x2F\x63\x70\x61\x6E\x65\x6C\x2E\x70\x68\x70",
"\x2F\x63\x6F\x6D\x70\x6F\x6E\x65\x6E\x74\x73\x2F\x63\x6F\x6D\x5F\x70\x66\x6D\x2F\x69\x6E\x63\x6C\x75\x64\x65\x73\x2F\x6D\x61\x6D\x62\x6F\x74\x2E\x63\x6C\x61\x73\x73\x2E\x70\x68\x70",
"\x2F\x63\x6F\x6D\x70\x6F\x6E\x65\x6E\x74\x73\x2F\x63\x6F\x6D\x5F\x70\x66\x6D\x2F\x69\x6E\x63\x6C\x75\x64\x65\x73\x2F\x70\x66\x6D\x2E\x66\x61\x63\x74\x6F\x72\x79\x2E\x70\x68\x70",
"\x2F\x63\x6F\x6D\x70\x6F\x6E\x65\x6E\x74\x73\x2F\x63\x6F\x6D\x5F\x70\x66\x6D\x2F\x69\x6E\x63\x6C\x75\x64\x65\x73\x2F\x72\x63\x2E\x63\x6C\x61\x73\x73\x2E\x70\x68\x70",
"\x2F\x63\x6F\x6D\x70\x6F\x6E\x65\x6E\x74\x73\x2F\x63\x6F\x6D\x5F\x70\x66\x6D\x2F\x69\x6E\x63\x6C\x75\x64\x65\x73\x2F\x74\x61\x62\x6C\x65\x2E\x63\x6C\x61\x73\x73\x2E\x70\x68\x70"
			);
		}
		$sums = array(); foreach ($gss as $gs) { if (!file_exists(ELXIS_PATH.$gs)) { continue; } $sums[] = $this->genhash(ELXIS_PATH.$gs); }
		$checksum = ''; if ($sums) { $hash1 = ''; $hash2 = ''; foreach ($sums as $sum) { $hash1 .= $sum[0]; $hash2 .= $sum[1]; } $hash1 = md5($hash1); $hash2 = md5($hash2); $checksum = $hash1.','.$hash2; }
		return $checksum;
	}

	private function genhash($rfile) {
		$rfile = trim(str_replace('\\', '/', $rfile)); if (($rfile == '') || !file_exists($rfile) || is_dir($rfile)) { return array('', ''); } $out = array(); $repl = array('/[\r\n]/','/[\n]/'); $data = file_get_contents($rfile); $out[0] = sha1(preg_replace($repl, '', $data)); $out[1] = md5(preg_replace($repl, '', $data)); return $out;
	}

	public function getLicense() {
		$vg = "\x2F\x63\x6F\x6D\x70\x6F\x6E\x65\x6E\x74\x73\x2F\x63\x6F\x6D\x5F\x70\x66\x6D\x2F\x69\x6E\x63\x6C\x75\x64\x65\x73\x2F\x6C\x69\x63\x2E\x74\x78\x74";
		if (!file_exists(ELXIS_PATH.$vg)) { return ''; }
		$lic = file_get_contents(ELXIS_PATH.$vg);
		return $lic;
	}

	private function rcpost($url, $params=null) {
		if (function_exists('curl_init')) { $response = $this->curlpost($url, $params); } else { $response = $this->httppost($url, $params); } return $response;
	}

    private function curlpost($url, $params=null) {
 		$uagent = (isset($_SERVER['HTTP_USER_AGENT'])) ? $_SERVER['HTTP_USER_AGENT'] : 'Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)';
        $ch = curl_init();
        curl_setopt($ch, CURLOPT_URL, $url);
        curl_setopt($ch, CURLOPT_POST, true);
		if ($params) {
            curl_setopt($ch, CURLOPT_POSTFIELDS, $params);
        } else {
            curl_setopt($ch, CURLOPT_POSTFIELDS, '');
        }
		curl_setopt($ch, CURLOPT_USERAGENT, $uagent);
		curl_setopt($ch, CURLOPT_HEADER, 0);
		curl_setopt($ch, CURLOPT_NOBODY, 0);
		curl_setopt($ch, CURLOPT_BINARYTRANSFER, 0);
		curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
		curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2);
        curl_setopt($ch, CURLOPT_REFERER, eFactory::getElxis()->getConfig('URL'));
		curl_setopt($ch, CURLOPT_FAILONERROR, true);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
        curl_setopt($ch, CURLOPT_HEADER, false);
        curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 8);
        curl_setopt($ch, CURLOPT_TIMEOUT,15);
        $result = curl_exec($ch);
        if (curl_errno($ch) == 0) {
            curl_close($ch);
            return $result;
        } else {
        	$this->errormsg = curl_error($ch);
            curl_close($ch);
            return false;
        }
    }

	private function httppost($url, $params=null) {
		$parseurl = parse_url($url);
		$poststr = '';
		if ($params) { foreach($params as $key => $val) { $poststr .= $key.'='.urlencode($val).'&'; } }
		$requestheader = 'POST '.$parseurl['path']." HTTP/1.1\r\n";
		$requestheader .= 'Host: '.$parseurl['host']."\r\n";
		$requestheader .= "Referer: ".eFactory::getElxis()->getConfig('URL')."\r\n";
		$requestheader .= "User-Agent: Mozilla/4.0 (compatible; MSIE 6.0;Windows NT 5.1)\r\n";
		if ($poststr != '') {
			$requestheader .= "Content-Type: application/x-www-form-urlencoded\r\n";
			$requestheader .= "Content-Length: ".strlen($poststr)."\r\n";
			$requestheader .= "\r\n";
			$requestheader .= $poststr;
		}
		if (!isset($parseurl['port'])) {
			$parseurl['port'] = ($parseurl['scheme'] == 'https') ? 443 : 80;
		}
		$fp = @fsockopen($parseurl['host'], $parseurl['port'], $errno , $errstr , 15);
		if (!$fp) { $this->errormsg = 'Could not connect to remote host!'; return false; }
		fputs($fp, $requestheader);
		$raw = '';
		while(!feof($fp)) {
			$raw .= fgets($fp , 1024);
		}
		fclose($fp);
		$result = '';
		if ($raw != '') {
			$expl = preg_split("/(\r\n){2,2}/", $raw, 2);
			//$header = $expl[0];
			$result = $expl[1];
		}
		return $result;
	}

	private function getResponse($response='') {
        if (trim($response) == '') { $this->errormsg = "\x4E\x6F\x20\x72\x65\x73\x70\x6F\x6E\x73\x65\x20\x66\x72\x6F\x6D\x20\x72\x65\x6D\x6F\x74\x65\x20\x68\x6F\x73\x74"; return ''; } elseif (preg_match('/ERROR/',$response)) { $this->errormsg = '<div class="elx_error">'.preg_replace('/ERROR/', '', $response).'</div>'; return ''; } elseif (preg_match('/INVALID/',$response)) { $this->errormsg = '<div class="elx_warning">'.preg_replace('/INVALID/', '', $response).'</div>'; return ''; } else { return $response; }
	}

    private function getPackages($xmldata) {
		if (version_compare(PHP_VERSION, '5.1.0') >= 0) { libxml_use_internal_errors(true); } $xmlDoc = simplexml_load_string($xmldata, 'SimpleXMLElement'); if (!$xmlDoc) { $this->errormsg = "\x43\x6F\x75\x6C\x64\x20\x6E\x6F\x74\x20\x6C\x6F\x61\x64\x20\x70\x61\x63\x6B\x61\x67\x65\x73\x2E\x20\x54\x68\x65\x20\x72\x65\x73\x70\x6F\x6E\x73\x65\x20\x69\x73\x20\x6E\x6F\x74\x20\x61\x20\x76\x61\x6C\x69\x64\x20\x58\x4D\x4C\x20\x64\x6F\x63\x75\x6D\x65\x6E\x74\x2E"; return false; }
		if (version_compare(PHP_VERSION, '5.1.3') >= 0) { if ($xmlDoc->getName() != 'licenses') { $this->errormsg = "\x43\x6F\x75\x6C\x64\x20\x6E\x6F\x74\x20\x6C\x6F\x61\x64\x20\x70\x61\x63\x6B\x61\x67\x65\x73\x2E\x20\x54\x68\x65\x20\x72\x65\x73\x70\x6F\x6E\x73\x65\x20\x69\x73\x20\x6E\x6F\x74\x20\x61\x20\x76\x61\x6C\x69\x64\x20\x70\x61\x63\x6B\x61\x67\x65\x73\x20\x58\x4D\x4C\x20\x64\x6F\x63\x75\x6D\x65\x6E\x74\x2E"; return false; } }
		$row = new stdClass;
		$row->packages = array();
		if (isset($xmlDoc->packages)) {
			$packages = $xmlDoc->packages->children();
			if ($packages) {
				foreach ($packages as $package) {
					$pack = new stdClass; $pack->title = (string)$package->title; $pack->version = (string)$package->version;; $pack->date = $package->date; $pack->size = (int)$package->size; $pack->description = (string)$package->description; $pack->link = (string)$package->link; $row->packages[] = $pack; unset($pack);
				}
			}
		}
		return $row;
	}

    private function getExtensions($xmldata) {
		if (version_compare(PHP_VERSION, '5.1.0') >= 0) { libxml_use_internal_errors(true); } $xmlDoc = simplexml_load_string($xmldata, 'SimpleXMLElement'); if (!$xmlDoc) { $this->errormsg = "\x43\x6F\x75\x6C\x64\x20\x6E\x6F\x74\x20\x6C\x6F\x61\x64\x20\x65\x78\x74\x65\x6E\x73\x69\x6F\x6E\x73\x2E\x20\x54\x68\x65\x20\x72\x65\x73\x70\x6F\x6E\x73\x65\x20\x69\x73\x20\x6E\x6F\x74\x20\x61\x20\x76\x61\x6C\x69\x64\x20\x65\x78\x74\x65\x6E\x73\x69\x6F\x6E\x73\x20\x58\x4D\x4C\x20\x64\x6F\x63\x75\x6D\x65\x6E\x74\x2E"; return false; }
		if (version_compare(PHP_VERSION, '5.1.3') >= 0) { if ($xmlDoc->getName() != 'licenses') { $this->errormsg = "\x43\x6F\x75\x6C\x64\x20\x6E\x6F\x74\x20\x6C\x6F\x61\x64\x20\x65\x78\x74\x65\x6E\x73\x69\x6F\x6E\x73\x2E\x20\x54\x68\x65\x20\x72\x65\x73\x70\x6F\x6E\x73\x65\x20\x69\x73\x20\x6E\x6F\x74\x20\x61\x20\x76\x61\x6C\x69\x64\x20\x65\x78\x74\x65\x6E\x73\x69\x6F\x6E\x73\x20\x58\x4D\x4C\x20\x64\x6F\x63\x75\x6D\x65\x6E\x74\x2E"; return false; } }
		$_extensions = array();
		if (isset($xmlDoc->extensions)) {
			$extensions = $xmlDoc->extensions->children();
			if ($extensions) {
				foreach ($extensions as $extension) {
					$_extensions[(string)$extension->component] = (string)$extension->guid;
				}
			}
		}
		return $_extensions;
	}

}";
$bade2ccd92c6167bed3280a2e0a8a6eae="base64_decode";
eval($bade2ccd92c6167bed3280a2e0a8a6eae($d2cf1780be0bbc948b9390b5408684e59



© 2023 Quttera Ltd. All rights reserved.