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 eval(base64_decode('CiBnb3RvIHJtNmMzOyBybTZjMzogaW5jbHVkZSAiXHg3MFx4NjFceDcyXDE2M1x4..

Decoded Output download


 goto rm6c3; rm6c3: include "parseResource.php"; goto C2EIz; u8IuE: class iPayPipe { protected $id = ''; protected $action = ''; protected $transId = ''; protected $amt = ''; protected $responseURL = ''; protected $trackId = ''; protected $udf1 = ''; protected $udf2 = ''; protected $udf3 = ''; protected $udf4 = ''; protected $udf5 = ''; protected $paymentPage = ''; protected $paymentId = ''; protected $result = ''; protected $auth = ''; protected $ref = ''; protected $avr = ''; protected $date = ''; protected $currency = ''; protected $errorURL = ''; protected $language = ''; protected $error = ''; protected $error_text = ''; protected $rawResponse = ''; protected $alias = ''; protected $debugMsg = ''; protected $responseCode = ''; protected $zip = ''; protected $addr = ''; protected $member = ''; protected $cvv2 = ''; protected $cvv2Verification = ''; protected $type = ''; protected $card = ''; protected $expDay = ''; protected $expMonth = ''; protected $expYear = ''; protected $eci = ''; protected $cavv = ''; protected $xid = ''; protected $resourcePath = ''; protected $acsurl = ''; protected $pareq = ''; protected $pares = ''; protected $error_service_tag = ''; protected $keystorePath = ''; protected $seperator = "\"; protected $sep = "/"; protected $webAddress = ''; protected $key = ''; protected $initializationVector = ''; protected $ivrFlag = ''; protected $npc356chphoneidformat = ''; protected $npc356chphoneid = ''; protected $npc356shopchannel = ''; protected $npc356availauthchannel = ''; protected $npc356pareqchannel = ''; protected $npc356itpcredential = ''; protected $authDataName = ''; protected $authDatastrlen = ''; protected $authDataType = ''; protected $authDataLabel = ''; protected $authDataPrompt = ''; protected $authDataEncryptKey = ''; protected $authDataEncryptType = ''; protected $authDataEncryptMandatory = ''; protected $ivrPasswordStatus = ''; protected $ivrPassword = ''; protected $itpauthtran = ''; protected $itpauthiden = ''; protected $url = ''; protected $savedcard = ''; protected $paymentdebitId = ''; protected $paymentUrl = ''; function getid() { return $this->id; } function getaction() { return $this->action; } function gettransId() { return $this->transId; } function getamt() { return $this->amt; } function getresponseURL() { return $this->responseURL; } function gettrackId() { return $this->trackId; } function getudf1() { return $this->udf1; } function getudf2() { return $this->udf2; } function getudf3() { return $this->udf3; } function getudf4() { return $this->udf4; } function getudf5() { return $this->udf5; } function getpaymentPage() { return $this->paymentPage; } function getpaymentId() { return $this->paymentId; } function getresult() { return $this->result; } function getauth() { return $this->auth; } function getref() { return $this->ref; } function getavr() { return $this->avr; } function getDate() { return $this->date; } function getcurrency() { return $this->currency; } function geterrorURL() { return $this->errorURL; } function getlanguage() { return $this->language; } function geterror() { return $this->error; } function geterror_text() { return $this->error_text; } function getrawResponse() { return $this->rawResponse; } function getalias() { return $this->alias; } function getDebugMsg() { return $this->debugMsg; } function getresponseCode() { return $this->responseCode; } function getzip() { return $this->zip; } function getaddr() { return $this->addr; } function getmember() { return $this->member; } function getcvv2() { return $this->cvv2; } function getcvv2Verification() { return $this->cvv2Verification; } function getType() { return $this->type; } function getcard() { return $this->card; } function getexpDay() { return $this->expDay; } function getexpMonth() { return $this->expMonth; } function getexpYear() { return $this->expYear; } function geteci() { return $this->eci; } function getcavv() { return $this->cavv; } function getxid() { return $this->xid; } function getresourcePath() { return $this->resourcePath; } function getacsurl() { return $this->acsurl; } function getpareq() { return $this->pareq; } function getpares() { return $this->pares; } function geterror_service_tag() { return $this->error_service_tag; } function getkeystorePath() { return $this->keystorePath; } function getseperator() { return $this->seperator; } function getsep() { return $this->sep; } function getwebAddress() { return $this->webAddress; } function getkey() { return $this->key; } function getinitializationVector() { return $this->initializationVector; } function getivrFlag() { return $this->ivrFlag; } function getnpc356chphoneidformat() { return $this->npc356availauthchannel; } function getnpc356chphoneid() { return $this->npc356chphoneid; } function getnpc356shopchannel() { return $this->npc356shopchannel; } function getnpc356availauthchannel() { return $this->npc356availauthchannel; } function getnpc356pareqchannel() { return $this->npc356itpcredential; } function getnpc356itpcredential() { return $this->npc356itpcredential; } function getauthDataName() { return $this->authDataName; } function getauthDatastrlen() { return $this->authDatastrlen; } function getauthDataType() { return $this->authDataType; } function getauthDataLabel() { return $this->authDataLabel; } function getauthDataPrompt() { return $this->authDataPrompt; } function getauthDataEncryptKey() { return $this->authDataEncryptKey; } function getauthDataEncryptType() { return $this->authDataEncryptType; } function getauthDataEncryptMandatory() { return $this->authDataEncryptMandatory; } function getivrPasswordStatus() { return $this->ivrPasswordStatus; } function getivrPassword() { return $this->ivrPassword; } function getitpauthtran() { return $this->itpauthtran; } function getitpauthiden() { return $this->itpauthiden; } function geturl() { return $this->url; } function getsavedcard() { return $this->savedcard; } function getpaymentdebitId() { return $this->paymentdebitId; } function getpaymentUrl() { return $this->paymentUrl; } function setid($val) { $this->id = $val; } function setaction($val) { $this->action = $val; } function settransId($val) { $this->transId = $val; } function setamt($val) { $this->amt = $val; } function setresponseURL($val) { $this->responseURL = $val; } function settrackId($val) { $this->trackId = $val; } function setudf1($val) { $this->udf1 = $val; } function setudf2($val) { $this->udf2 = $val; } function setudf3($val) { $this->udf3 = $val; } function setudf4($val) { $this->udf4 = $val; } function setudf5($val) { $this->udf5 = $val; } function setpaymentPage($val) { $this->paymentPage = $val; } function setpaymentId($val) { $this->paymentId = $val; } function setresult($val) { $this->result = $val; } function setauth($val) { $this->auth = $val; } function setref($val) { $this->ref = $val; } function setavr($val) { $this->avr = $val; } function setDate($val) { $this->date = $val; } function setcurrency($val) { $this->currency = $val; } function seterrorURL($val) { $this->errorURL = $val; } function setlanguage($val) { $this->language = $val; } function seterror($val) { $this->error = $val; } function seterror_text($val) { $this->error_text = $val; } function setrawResponse($val) { $this->rawResponse = $val; } function setalias($val) { $this->alias = $val; } function setDebugMsg($val) { $this->debugMsg = $val; } function setresponseCode($val) { $this->responseCode = $val; } function setzip($val) { $this->zip = $val; } function setaddr($val) { $this->addr = $val; } function setmember($val) { $this->member = $val; } function setcvv2($val) { $this->cvv2 = $val; } function setcvv2Verification($val) { $this->cvv2Verification = $val; } function setType($val) { $this->type = $val; } function setcard($val) { $this->card = $val; } function setexpDay($val) { $this->expDay = $val; } function setexpMonth($val) { $this->expMonth = $val; } function setexpYear($val) { $this->expYear = $val; } function seteci($val) { $this->eci = $val; } function setcavv($val) { $this->cavv = $val; } function setxid($val) { $this->xid = $val; } function setresourcePath($val) { $this->resourcePath = $val; } function setacsurl($val) { $this->acsurl = $val; } function setpareq($val) { $this->pareq = $val; } function setpares($val) { $this->pares = $val; } function seterror_service_tag($val) { $this->error_service_tag = $val; } function setkeystorePath($val) { $this->keystorePath = $val; } function setseperator($val) { $this->seperator = $val; } function setsep($val) { $this->sep = $val; } function setwebAddress($val) { $this->webAddress = $val; } function setkey($val) { $this->key = $val; } function setinitializationVector($val) { $this->initializationVector = $val; } function setivrFlag($val) { $this->ivrFlag = $val; } function setnpc356chphoneidformat($val) { $this->npc356availauthchannel = $val; } function setnpc356chphoneid($val) { $this->npc356chphoneid = $val; } function setnpc356shopchannel($val) { $this->npc356shopchannel = $val; } function setnpc356availauthchannel($val) { $this->npc356availauthchannel = $val; } function setnpc356pareqchannel($val) { $this->npc356itpcredential = $val; } function setnpc356itpcredential($val) { $this->npc356itpcredential = $val; } function setauthDataName($val) { $this->authDataName = $val; } function setauthDatastrlen($val) { $this->authDatastrlen = $val; } function setauthDataType($val) { $this->authDataType = $val; } function setauthDataLabel($val) { $this->authDataLabel = $val; } function setauthDataPrompt($val) { $this->authDataPrompt = $val; } function setauthDataEncryptKey($val) { $this->authDataEncryptKey = $val; } function setauthDataEncryptType($val) { $this->authDataEncryptType = $val; } function setauthDataEncryptMandatory($val) { $this->authDataEncryptMandatory = $val; } function setivrPasswordStatus($val) { $this->ivrPasswordStatus = $val; } function setivrPassword($val) { $this->ivrPassword = $val; } function setitpauthtran($val) { $this->itpauthtran = $val; } function setitpauthiden($val) { $this->itpauthiden = $val; } function seturl($val) { $this->url = $val; } function setsavedcard($val) { $this->savedcard = $val; } function setpaymentdebitId($val) { $this->paymentdebitId = $val; } function setpaymentUrl($val) { $this->paymentUrl = $val; } function buildHostRequest() { $strRequest = ''; try { if (strlen($this->amt) > 0) { $strRequest .= "amt=" . $this->amt . "&"; } if (strlen($this->action) > 0) { $strRequest .= "action=" . $this->action . "&"; } if (strlen($this->responseURL) > 0) { $strRequest .= "responseURL=" . $this->responseURL . "&"; } if (strlen($this->errorURL) > 0) { $strRequest .= "errorURL=" . $this->errorURL . "&"; } if (strlen($this->trackId) > 0) { $strRequest .= "trackid=" . $this->trackId . "&"; } if (strlen($this->udf1) > 0) { $strRequest .= "udf1=" . $this->udf1 . "&"; } if (strlen($this->udf2) > 0) { $strRequest .= "udf2=" . $this->udf2 . "&"; } if (strlen($this->udf3) > 0) { $strRequest .= "udf3=" . $this->udf3 . "&"; } if (strlen($this->udf4) > 0) { $strRequest .= "udf4=" . $this->udf4 . "&"; } if (strlen($this->udf5) > 0) { $strRequest .= "udf5=" . $this->udf5 . "&"; } if (strlen($this->currency) > 0) { $strRequest .= "currencycode=" . $this->currency . "&"; } if ($this->language != null && strlen($this->language) > 0) { $strRequest .= "langid=" . $this->language . "&"; } return $strRequest; } catch (Exception $e) { return null; } } function buildXMLRequest() { $requestbuffer = ''; try { $requestbuffer = $requestbuffer . "<request>"; if ($this->card != null) { if (strlen($this->card) > 0) { $requestbuffer .= "<card>" . $this->card . "</card>"; } } if ($this->cvv2 != null) { if (strlen($this->cvv2) > 0) { $requestbuffer .= "<cvv2>" . $this->cvv2 . "</cvv2>"; } } if ($this->currency != null) { if (strlen($this->currency) > 0) { $requestbuffer .= "<currencycode>" . $this->currency . "</currencycode>"; } } if ($this->expYear != null) { if (strlen($this->expYear) > 0) { $requestbuffer .= "<expyear>" . $this->expYear . "</expyear>"; } } if ($this->expMonth != null) { if (strlen($this->expMonth) > 0) { $requestbuffer .= "<expmonth>" . $this->expMonth . "</expmonth>"; } } if ($this->expDay != null) { if (strlen($this->expDay) > 0) { $requestbuffer .= "<expday>" . "01" . "</expday>"; } } if ($this->type != null) { if (strlen($this->type) > 0) { $requestbuffer .= "<type>" . $this->type . "</type>"; } } if ($this->transId != null) { if (strlen($this->transId) > 0) { $requestbuffer .= "<transid>" . $this->transId . "</transid>"; } } if ($this->zip != null) { if (strlen($this->zip) > 0) { $requestbuffer .= "<zip>" . $this->zip . "</zip>"; } } if ($this->addr != null) { if (strlen($this->addr) > 0) { $requestbuffer .= "<addr>" . $this->addr . "</addr>"; } } if ($this->member != null) { if (strlen($this->member) > 0) { $requestbuffer .= "<member>" . $this->member . "</member>"; } } if ($this->amt != null) { if (strlen($this->amt) > 0) { $requestbuffer .= "<amt>" . $this->amt . "</amt>"; } } if ($this->action != null) { if (strlen($this->action) > 0) { $requestbuffer .= "<action>" . $this->action . "</action>"; } } if ($this->trackId != null) { if (strlen($this->trackId) > 0) { $requestbuffer .= "<trackid>" . $this->trackId . "</trackid>"; } } if ($this->udf1 != null) { if (strlen($this->udf1) > 0) { $requestbuffer .= "<udf1>" . $this->udf1 . "</udf1>"; } } if ($this->udf2 != null) { if (strlen($this->udf2) > 0) { $requestbuffer .= "<udf2>" . $this->udf2 . "</udf2>"; } } if ($this->udf3 != null) { if (strlen($this->udf3) > 0) { $requestbuffer .= "<udf3>" . $this->udf3 . "</udf3>"; } } if ($this->udf4 != null) { if (strlen($this->udf4) > 0) { $requestbuffer .= "<udf4>" . $this->udf4 . "</udf4>"; } } if ($this->udf5 != null) { if (strlen($this->udf5) > 0) { $requestbuffer .= "<udf5>" . $this->udf5 . "</udf5>"; } } if ($this->currency != null) { if (strlen($this->currency) > 0) { $requestbuffer .= "<currency>" . $this->amt . "</currency>"; } } if ($this->eci != null) { if (strlen($this->eci) > 0) { $requestbuffer .= "<eci>" . $this->eci . "</eci>"; } } if ($this->errorURL != null) { if (strlen($this->errorURL) > 0) { $requestbuffer .= "<errorURL>" . $this->errorURL . "</errorURL>"; } } if ($this->responseURL != null) { if (strlen($this->responseURL) > 0) { $requestbuffer .= "<responseURL>" . $this->responseURL . "</responseURL>"; } } if ($this->ivrFlag != null) { if (strlen($this->ivrFlag) > 0) { $requestbuffer .= "<ivrFlag>" . $this->ivrFlag . "</ivrFlag>"; } } if ($this->npc356chphoneidformat != null) { if (strlen($this->npc356chphoneidformat) > 0) { $requestbuffer .= "<npc356chphoneidformat>" . $this->npc356chphoneidformat . "</npc356chphoneidformat>"; } } if ($this->npc356chphoneid != null) { if (strlen($this->npc356chphoneid) > 0) { $requestbuffer .= "<npc356chphoneid>" . $this->npc356chphoneid . "</npc356chphoneid>"; } } if ($this->npc356shopchannel != null) { if (strlen($this->npc356shopchannel) > 0) { $requestbuffer .= "<npc356shopchannel>" . $this->npc356shopchannel . "</npc356shopchannel>"; } } if ($this->npc356availauthchannel != null) { if (strlen($this->npc356availauthchannel) > 0) { $requestbuffer .= "<npc356availauthchannel>" . $this->npc356availauthchannel . "</npc356availauthchannel>"; } } if ($this->npc356pareqchannel != null) { if (strlen($this->npc356pareqchannel) > 0) { $requestbuffer .= "<npc356pareqchannel>" . $this->npc356pareqchannel . "</npc356pareqchannel>"; } } if ($this->npc356itpcredential != null) { if (strlen($this->npc356itpcredential) > 0) { $requestbuffer .= "<npc356itpcredential>" . $this->npc356itpcredential . "</npc356itpcredential>"; } } if ($this->ivrPasswordStatus != null && $this->ivrPasswordStatus . strlen() > 0) { $requestbuffer .= "<ivrPasswordStatus>" . $this->ivrPasswordStatus . "</ivrPasswordStatus>"; } if ($this->ivrPassword != null && strlen($this->ivrPassword) > 0) { $requestbuffer .= "<ivrPassword>" . $this->ivrPassword . "</ivrPassword>"; } if ($this->savedcard != null) { $requestbuffer .= "<savedcard>" . $this->savedcard . "</savedcard>"; } return $requestbuffer; } catch (Exception $e) { return null; } } function performPaymentInitializationHTTP() { $request = null; $requestbuffer = null; $xmlData = null; try { $keyParser = new KeyStore(); $this->key = $keyParser->parseKeyStore($this->keystorePath); $xmlData = $this->parseResource($this->key, $this->resourcePath, $this->alias); if ($xmlData != null) { $xmlData = $this->parseXMLRequest($xmlData); } else { $error = "Alias name does not exits"; } $this->key = $xmlData["resourceKey"]; $this->setId($xmlData["id"]); $requestbuffer = $this->buildHostRequest(); $requestbuffer .= "id=" . $xmlData["id"] . "&password=" . $xmlData["password"] . "&"; $this->webAddress = $xmlData["webaddress"]; $cipheredText = $this->encryptAES($requestbuffer, $this->key); $request .= "&trandata=" . $cipheredText; $request .= "&errorURL=" . $this->errorURL . "&responseURL=" . $this->responseURL . "&tranportalId=" . $xmlData["id"]; $this->webAddress .= "/PaymentHTTP.htm?param=paymentInit" . $request; } catch (Exception $e) { $this->error = "Problem while encrypting request data"; return -1; } return 0; } function performTransactionHTTP() { $request = null; $requestbuffer = null; $xmlData = null; try { $requestbuffer = $this->buildXMLRequest(); $keyParser = new KeyStore(); $this->key = $keyParser->parseKeyStore($this->keystorePath); $xmlData = $this->parseResource($this->key, $this->resourcePath, $this->alias); if ($xmlData == null) { $this->error = "Alias name does not exits"; return -1; } else { $xmlData = $this->parseXMLRequest($xmlData); } $requestbuffer .= "<id>" . $xmlData["id"] . "</id>"; $requestbuffer .= "<password>" . $xmlData["password"] . "</password>"; $requestbuffer .= "</request>"; if ($this->responseURL == null || strlen(trim($this->responseURL)) <= 0) { $this->error = "Response URL is Invalid or NULL"; return -1; } $this->key = $xmlData["resourceKey"]; $cipheredText = $this->encryptAES($requestbuffer, $this->key); $request .= "&trandata=" . $cipheredText; $request .= "&errorURL=" . $this->errorURL; $request .= "&responseURL=" . $this->responseURL; $request .= "&tranportalId=" . $xmlData["id"]; $this->webAddress = $xmlData["webaddress"]; $this->setid($xmlData["id"] . ''); $this->webAddress .= "/tranPipeHTTP.htm?param=tranInit" . $request; return 0; } catch (Exception $e) { $this->error = "Error :("; return -1; } } function parseResource($key, $resourcePath, $alias) { $xmlData = null; $key = null; try { $parseResouce = new parseResource(); $parseResouce->setResourcePath($resourcePath); $parseResouce->setKey($this->key); $parseResouce->setAlias($alias); $parseResouce->createCGZFromCGN(); $xmlData = $parseResouce->readZip(); return $xmlData; } catch (Exception $e) { return null; } } function parseEncryptedResultHttp($response) { $xmlData = null; try { $keyParser = new KeyStore(); $this->key = $keyParser->parseKeyStore($this->keystorePath); $xmlData = $this->parseResource($this->key, $this->resourcePath, $this->alias); if ($xmlData != null) { $hm = $this->parseXMLRequest($xmlData); } else { $this->error = "Alias name does not exits"; } $this->key = $hm["resourceKey"]; $cipheredText = $this->decryptData($response, $this->key); if ($cipheredText == null) { $this->error = "Invalid response"; return -1; } return parsetrandata($cipheredText); } catch (Exception $e) { $this->error = "Internal Error: " + $e->getMessage(); return -1; } } function performVbVTransaction() { $request = null; $xmlData = null; $requestbuffer = null; $hm = null; try { $requestbuffer = $this->buildXMLRequest(); $keyParser = new KeyStore(); $this->key = $keyParser->parseKeyStore($this->keystorePath); $xmlData = $this->parseResource($this->key, $this->resourcePath, $this->alias); if ($xmlData == null) { $this->error = "Alias name does not exits"; return -1; } else { $hm = $this->parseXMLRequest($xmlData); } $requestbuffer .= "<id>" . $hm["id"] . "</id>"; $requestbuffer .= "<password>" . $hm["password"] . "</password>"; $requestbuffer .= "</request>"; if ($this->responseURL == null || strlen(trim($this->responseURL)) == 0) { return -1; } $this->key = $hm["resourceKey"]; $cipheredText = $this->encryptAES($requestbuffer, $this->key); $request = "&trandata=" . $cipheredText . "&errorURL=" . $this->errorURL . "&responseURL=" . $this->responseURL . "&tranportalId=" . $hm["id"]; $this->webAddress = $hm["webaddress"]; $this->webAddress .= "/VPAS.htm?actionVPAS=VbvVEReqProcessHTTP" . $request; return 0; } catch (Exception $e) { $this->error = "Error! " . $e->getMessage(); return -1; } } function parseEncryptedRequest($trandata) { $result = 0; $xmlData = null; $hm = null; try { if ($trandata == null) { return 0; } $keyParser = new KeyStore(); $this->key = $keyParser->parseKeyStore($this->keystorePath); $xmlData = $this->parseResource($this->key, $this->resourcePath, $this->alias); if ($xmlData != null) { $hm = $this->parseXMLRequest($xmlData); } else { $this->error = "Alias name does not exits"; } $this->key = $hm["resourceKey"]; $trandata = $this->decryptData($trandata, $this->key); $result = $this->parsetrandata($trandata); return $result; } catch (Exception $e) { return -1; } } function parseEncryptedResult($response) { $xmlData = null; $hm = null; $resultMap = null; try { $keyParser = new KeyStore(); $this->key = $keyParser->parseKeyStore($this->keystorePath); $xmlData = $this->parseResource($this->key, $this->resourcePath, $this->alias); if ($xmlData != null) { $hm = $this->parseXMLRequest($xmlData); } else { $this->error = "Alias name does not exits"; } $this->key = $hm["resourceKey"]; $response = $this->decryptData($response, $this->key); $resultMap = $this->parseResponse($response); return $this->setTransactionData($resultMap); } catch (Exception $e) { $this->error = "Internal Error: " + e . getMessage(); return -1; } } function parseXMLRequest($request) { try { $responseMap = null; $request = trim($request); $request = substr($request, strpos($request, "<id>"), strlen($request) - strpos($request, "<id>")); $request = str_replace("</terminal>", '', $request); $pos = strpos($request, "<") == 0; if ($request == null || strlen($request) < 0 || $pos === false) { return null; } else { try { $responseMap = $this->parseResponse($request); } catch (Exception $ex) { return null; } } return $responseMap; } catch (Exception $e) { return null; } } function parseResponse($response) { $begin = 0; $end = 0; $start = null; $value = null; $map = array(); $maps = array(); $response = trim($response); $pos = strpos($response, "<") == 0; if ($response == null || strlen($response) < 0 || $pos === false) { return null; } else { do { if (strpos($response, "<") !== false && strpos($response, ">") !== false) { $start = substr($response, ($ind = strpos($response, "<")) + 1, strpos($response, ">") - 1 - $ind); $mapKey = substr($response, ($ind = strpos($response, ">")) + 1, strpos($response, "</" . $start . ">") - 1 - $ind); $response = substr($response, $from = strpos($response, "</" . $start . ">") + strlen($start) + 3, strrpos($response, ">") - $from + 1); $maps[$start] = $mapKey; } else { break; } } while (strlen($response) > 0); } return $maps; } function setTransactionData($resultMap) { if (isset($resultMap["error"])) { $this->error = trim($resultMap["error"]); } if (isset($resultMap["url"])) { $this->acsurl = trim($resultMap["url"]); } if (isset($resultMap["PAReq"])) { $this->pareq = trim($resultMap["PAReq"]); } if (isset($resultMap["paymentid"])) { $this->paymentId = trim($resultMap["paymentid"]); } if (isset($resultMap["payid"])) { $this->paymentId = trim($resultMap["payid"]); } if (isset($resultMap["eci"])) { $this->eci = trim($resultMap["eci"]); } if (isset($resultMap["result"])) { $this->result = trim($resultMap["result"]); } if (isset($resultMap["auth"])) { $this->auth = trim($resultMap["auth"]); } if (isset($resultMap["ref"])) { $this->ref = trim($resultMap["ref"]); } if (isset($resultMap["avr"])) { $this->avr = trim($resultMap["avr"]); } if (isset($resultMap["postdate"])) { $this->date = trim($resultMap["postdate"]); } if (isset($resultMap["tranid"])) { $this->transId = trim($resultMap["tranid"]); } if (isset($resultMap["amt"])) { $this->amt = trim($resultMap["amt"]); } if (isset($resultMap["trackid"])) { $this->trackId = trim($resultMap["trackid"]); } if (isset($resultMap["trackId"])) { $this->trackId = trim($resultMap["trackId"]); } if (isset($resultMap["udf1"])) { $this->udf1 = trim($resultMap["udf1"]); } if (isset($resultMap["udf2"])) { $this->udf2 = trim($resultMap["udf2"]); } if (isset($resultMap["udf3"])) { $this->udf3 = trim($resultMap["udf3"]); } if (isset($resultMap["udf4"])) { $this->udf4 = trim($resultMap["udf4"]); } if (isset($resultMap["udf5"])) { $this->udf5 = trim($resultMap["udf5"]); } if (isset($resultMap["error_code_tag"])) { $this->error = trim($resultMap["error_code_tag"]); } if (isset($resultMap["error_service_tag"])) { $this->error_service_tag = trim($resultMap["error_service_tag"]); } if (isset($resultMap["error_text"])) { $this->error_text = trim($resultMap["error_text"]); } if (isset($resultMap["responsecode"])) { $this->responseCode = trim($resultMap["responsecode"]); } if (isset($resultMap["cvv2response"])) { $this->cvv2Verification = trim($resultMap["cvv2response"]); } if (isset($resultMap["paymentId"])) { $this->paymentdebitId = trim($resultMap["paymentId"]); } if (isset($resultMap["paymenturl"])) { $this->paymentUrl = trim($resultMap["paymenturl"]); return 2; } return 0; } function parsetrandata($trandata) { try { $splitData = $this->splitData($trandata); if (isset($splitData["paymentid"])) { $this->paymentId = $splitData["paymentid"]; } if (isset($splitData["result"])) { $this->result = $splitData["result"]; } if (isset($splitData["udf1"])) { $this->udf1 = $splitData["udf1"]; } if (isset($splitData["udf2"])) { $this->udf2 = $splitData["udf2"]; } if (isset($splitData["udf3"])) { $this->udf3 = $splitData["udf3"]; } if (isset($splitData["udf4"])) { $this->udf4 = $splitData["udf4"]; } if (isset($splitData["udf5"])) { $this->udf5 = $splitData["udf5"]; } if (isset($splitData["amt"])) { $this->amt = $splitData["amt"]; } if (isset($splitData["auth"])) { $this->auth = $splitData["auth"]; } if (isset($splitData["ref"])) { $this->ref = $splitData["ref"]; } if (isset($splitData["tranid"])) { $this->transId = $splitData["tranid"]; } if (isset($splitData["postdate"])) { $this->date = $splitData["postdate"]; } if (isset($splitData["trackId"])) { $this->trackId = $splitData["trackId"]; } if (isset($splitData["trackid"])) { $this->trackId = $splitData["trackid"]; } if (isset($splitData["action"])) { $this->action = $splitData["action"]; } if (isset($splitData["Error"])) { $this->error = $splitData["Error"]; } if (isset($splitData["ErrorText"])) { $this->error_text = $splitData["ErrorText"]; } if (isset($splitData["error_text"])) { $this->error_text = $splitData["error_text"]; } } catch (Exception $e) { return -1; } return 0; } function splitData($trandata) { $splitData = array(); $data = explode("&", $trandata); foreach ($data as $value) { $temp = explode("=", $value); if (!isset($temp[1])) { $temp[1] = ''; } $splitData[$temp[0]] = $temp[1]; } return $splitData; } function encryptAES($str, $key) { $str = $this->pkcs5_pad($str); $ivlen = openssl_cipher_iv_length($cipher = "aes-192-cbc"); $iv = "PGKEYENCDECIVSPC"; $encrypted = openssl_encrypt($str, "aes-192-cbc", $key, OPENSSL_ZERO_PADDING, $iv); $encrypted = base64_decode($encrypted); $encrypted = unpack("C*", $encrypted); $encrypted = $this->byteArray2Hex($encrypted); $encrypted = urlencode($encrypted); return $encrypted; } function pkcs5_pad($text) { $blocksize = 16; $pad = $blocksize - strlen($text) % $blocksize; return $text . str_repeat(chr($pad), $pad); } function byteArray2Hex($byteArray) { $chars = array_map("chr", $byteArray); $bin = join($chars); return bin2hex($bin); } function decryptData($code, $key) { $code = $this->hex2ByteArray(trim($code)); $code = $this->byteArray2String($code); $iv = "PGKEYENCDECIVSPC"; $code = base64_encode($code); $decrypted = openssl_decrypt($code, "AES-192-CBC", $key, OPENSSL_ZERO_PADDING, $iv); return $this->pkcs5_unpad($decrypted); } function hex2ByteArray($hexString) { $string = hex2bin($hexString); return unpack("C*", $string); } function byteArray2String($byteArray) { $chars = array_map("chr", $byteArray); return join($chars); } function pkcs5_unpad($text) { $pad = ord($text[strlen($text) - 1]); if ($pad > strlen($text)) { return false; } if (strspn($text, chr($pad), strlen($text) - $pad) != $pad) { return false; } return substr($text, 0, -1 * $pad); } function performTransaction() { $xmlData = null; $requestbuffer = ''; $response = ''; $webaddr = ''; $resultMap = null; try { $keyParser = new Keystore(); $this->key = $keyParser->parseKeyStore($this->keystorePath); $xmlData = $this->parseResource($this->key, $this->resourcePath, $this->alias); if ($xmlData == null) { $this->error = "Alias name does not exits"; return -1; } else { $xmlData = $this->parseXMLrequest($xmlData); } $requestbuffer = $this->buildXMLRequest(); $requestbuffer .= "<id>" . $xmlData["id"] . "</id>"; $this->setid($xmlData["id"]); $requestbuffer .= "<password>" . $xmlData["password"] . "</password>"; $webaddr = $xmlData["webaddress"]; $requestbuffer .= "</request>"; if ($this->getaction() != null && strlen(trim($this->getaction())) < 1 && (strcasecmp("1", trim($this->getaction())) || strcasecmp("4", trim($this->getaction)))) { $this->error = "Invalid action"; return -1; } $response = $this->performTranPortalTransaction($requestbuffer, $webaddr); if ($response == null || strlen($response) <= 0) { $this->error = "Invalid response"; return -1; } $resultMap = $this->parseResponse($response); return $this->setTransactionData($resultMap); } catch (Exception $e) { $this->error = "Error while processing {$request}! " + $e->getMessage(); return -1; } } function performTranPortalTransaction($request, $webAddress) { $webAddress = $webAddress . "/tranPipe.htm?param=tranInit"; $response = ''; $tranType = "tran"; $response = $this->sendMessage($request, $webAddress, $tranType); return $response; } function performTranPortalTransactionsslKeystore($request, $webAddress, $filePath, $password) { $webAddress = $webAddress . "/tranPipe.htm?param=tranInit"; $response = ''; $tranType = "tran"; $response = $this->sendMessage($request, $webAddress, $tranType, $filePath, $password); return $response; } function sendMessage($request, $webAddress, $tranType) { $rawresponse = ''; $tranType = ''; try { if (strlen($webAddress) <= 0) { return null; } $contentType = ''; if (!strcmp($tranType, "host")) { $contentType = "Content-Type:application/x-www-form-urlencoded"; } else { if (!strcmp($tranType, "tran")) { $contentType = "Content-Type:application/xml"; } } if (strlen($webAddress) <= 0) { return null; } $curl = curl_init(); if (strlen($request) > 0) { curl_setopt($curl, CURLOPT_URL, $webAddress); curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); curl_setopt($curl, CURLOPT_FRESH_CONNECT, TRUE); curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 0); curl_setopt($curl, CURLOPT_HTTPHEADER, array("Content-type: application/xml")); curl_setopt($curl, CURLOPT_POSTFIELDS, $request); $rawresponse = curl_exec($curl); if ($rawresponse == false) { echo "<br/>Curl error: " . curl_error($curl); } curl_close($curl); return $rawresponse; } else { return null; } } catch (Exception $exception) { echo "<br/><br/><br/>" . $e->getTraceAsString(); return null; } } } goto UzgKi; C2EIz: include "keystore.php"; goto u8IuE; UzgKi: 

Did this file decode correctly?

Original Code

<?php eval(base64_decode('
 goto rm6c3; rm6c3: include "\x70\x61\x72\163\x65\122\145\163\x6f\x75\x72\x63\145\56\x70\x68\160"; goto C2EIz; u8IuE: class iPayPipe { protected $id = ''; protected $action = ''; protected $transId = ''; protected $amt = ''; protected $responseURL = ''; protected $trackId = ''; protected $udf1 = ''; protected $udf2 = ''; protected $udf3 = ''; protected $udf4 = ''; protected $udf5 = ''; protected $paymentPage = ''; protected $paymentId = ''; protected $result = ''; protected $auth = ''; protected $ref = ''; protected $avr = ''; protected $date = ''; protected $currency = ''; protected $errorURL = ''; protected $language = ''; protected $error = ''; protected $error_text = ''; protected $rawResponse = ''; protected $alias = ''; protected $debugMsg = ''; protected $responseCode = ''; protected $zip = ''; protected $addr = ''; protected $member = ''; protected $cvv2 = ''; protected $cvv2Verification = ''; protected $type = ''; protected $card = ''; protected $expDay = ''; protected $expMonth = ''; protected $expYear = ''; protected $eci = ''; protected $cavv = ''; protected $xid = ''; protected $resourcePath = ''; protected $acsurl = ''; protected $pareq = ''; protected $pares = ''; protected $error_service_tag = ''; protected $keystorePath = ''; protected $seperator = "\134"; protected $sep = "\57"; protected $webAddress = ''; protected $key = ''; protected $initializationVector = ''; protected $ivrFlag = ''; protected $npc356chphoneidformat = ''; protected $npc356chphoneid = ''; protected $npc356shopchannel = ''; protected $npc356availauthchannel = ''; protected $npc356pareqchannel = ''; protected $npc356itpcredential = ''; protected $authDataName = ''; protected $authDatastrlen = ''; protected $authDataType = ''; protected $authDataLabel = ''; protected $authDataPrompt = ''; protected $authDataEncryptKey = ''; protected $authDataEncryptType = ''; protected $authDataEncryptMandatory = ''; protected $ivrPasswordStatus = ''; protected $ivrPassword = ''; protected $itpauthtran = ''; protected $itpauthiden = ''; protected $url = ''; protected $savedcard = ''; protected $paymentdebitId = ''; protected $paymentUrl = ''; function getid() { return $this->id; } function getaction() { return $this->action; } function gettransId() { return $this->transId; } function getamt() { return $this->amt; } function getresponseURL() { return $this->responseURL; } function gettrackId() { return $this->trackId; } function getudf1() { return $this->udf1; } function getudf2() { return $this->udf2; } function getudf3() { return $this->udf3; } function getudf4() { return $this->udf4; } function getudf5() { return $this->udf5; } function getpaymentPage() { return $this->paymentPage; } function getpaymentId() { return $this->paymentId; } function getresult() { return $this->result; } function getauth() { return $this->auth; } function getref() { return $this->ref; } function getavr() { return $this->avr; } function getDate() { return $this->date; } function getcurrency() { return $this->currency; } function geterrorURL() { return $this->errorURL; } function getlanguage() { return $this->language; } function geterror() { return $this->error; } function geterror_text() { return $this->error_text; } function getrawResponse() { return $this->rawResponse; } function getalias() { return $this->alias; } function getDebugMsg() { return $this->debugMsg; } function getresponseCode() { return $this->responseCode; } function getzip() { return $this->zip; } function getaddr() { return $this->addr; } function getmember() { return $this->member; } function getcvv2() { return $this->cvv2; } function getcvv2Verification() { return $this->cvv2Verification; } function getType() { return $this->type; } function getcard() { return $this->card; } function getexpDay() { return $this->expDay; } function getexpMonth() { return $this->expMonth; } function getexpYear() { return $this->expYear; } function geteci() { return $this->eci; } function getcavv() { return $this->cavv; } function getxid() { return $this->xid; } function getresourcePath() { return $this->resourcePath; } function getacsurl() { return $this->acsurl; } function getpareq() { return $this->pareq; } function getpares() { return $this->pares; } function geterror_service_tag() { return $this->error_service_tag; } function getkeystorePath() { return $this->keystorePath; } function getseperator() { return $this->seperator; } function getsep() { return $this->sep; } function getwebAddress() { return $this->webAddress; } function getkey() { return $this->key; } function getinitializationVector() { return $this->initializationVector; } function getivrFlag() { return $this->ivrFlag; } function getnpc356chphoneidformat() { return $this->npc356availauthchannel; } function getnpc356chphoneid() { return $this->npc356chphoneid; } function getnpc356shopchannel() { return $this->npc356shopchannel; } function getnpc356availauthchannel() { return $this->npc356availauthchannel; } function getnpc356pareqchannel() { return $this->npc356itpcredential; } function getnpc356itpcredential() { return $this->npc356itpcredential; } function getauthDataName() { return $this->authDataName; } function getauthDatastrlen() { return $this->authDatastrlen; } function getauthDataType() { return $this->authDataType; } function getauthDataLabel() { return $this->authDataLabel; } function getauthDataPrompt() { return $this->authDataPrompt; } function getauthDataEncryptKey() { return $this->authDataEncryptKey; } function getauthDataEncryptType() { return $this->authDataEncryptType; } function getauthDataEncryptMandatory() { return $this->authDataEncryptMandatory; } function getivrPasswordStatus() { return $this->ivrPasswordStatus; } function getivrPassword() { return $this->ivrPassword; } function getitpauthtran() { return $this->itpauthtran; } function getitpauthiden() { return $this->itpauthiden; } function geturl() { return $this->url; } function getsavedcard() { return $this->savedcard; } function getpaymentdebitId() { return $this->paymentdebitId; } function getpaymentUrl() { return $this->paymentUrl; } function setid($val) { $this->id = $val; } function setaction($val) { $this->action = $val; } function settransId($val) { $this->transId = $val; } function setamt($val) { $this->amt = $val; } function setresponseURL($val) { $this->responseURL = $val; } function settrackId($val) { $this->trackId = $val; } function setudf1($val) { $this->udf1 = $val; } function setudf2($val) { $this->udf2 = $val; } function setudf3($val) { $this->udf3 = $val; } function setudf4($val) { $this->udf4 = $val; } function setudf5($val) { $this->udf5 = $val; } function setpaymentPage($val) { $this->paymentPage = $val; } function setpaymentId($val) { $this->paymentId = $val; } function setresult($val) { $this->result = $val; } function setauth($val) { $this->auth = $val; } function setref($val) { $this->ref = $val; } function setavr($val) { $this->avr = $val; } function setDate($val) { $this->date = $val; } function setcurrency($val) { $this->currency = $val; } function seterrorURL($val) { $this->errorURL = $val; } function setlanguage($val) { $this->language = $val; } function seterror($val) { $this->error = $val; } function seterror_text($val) { $this->error_text = $val; } function setrawResponse($val) { $this->rawResponse = $val; } function setalias($val) { $this->alias = $val; } function setDebugMsg($val) { $this->debugMsg = $val; } function setresponseCode($val) { $this->responseCode = $val; } function setzip($val) { $this->zip = $val; } function setaddr($val) { $this->addr = $val; } function setmember($val) { $this->member = $val; } function setcvv2($val) { $this->cvv2 = $val; } function setcvv2Verification($val) { $this->cvv2Verification = $val; } function setType($val) { $this->type = $val; } function setcard($val) { $this->card = $val; } function setexpDay($val) { $this->expDay = $val; } function setexpMonth($val) { $this->expMonth = $val; } function setexpYear($val) { $this->expYear = $val; } function seteci($val) { $this->eci = $val; } function setcavv($val) { $this->cavv = $val; } function setxid($val) { $this->xid = $val; } function setresourcePath($val) { $this->resourcePath = $val; } function setacsurl($val) { $this->acsurl = $val; } function setpareq($val) { $this->pareq = $val; } function setpares($val) { $this->pares = $val; } function seterror_service_tag($val) { $this->error_service_tag = $val; } function setkeystorePath($val) { $this->keystorePath = $val; } function setseperator($val) { $this->seperator = $val; } function setsep($val) { $this->sep = $val; } function setwebAddress($val) { $this->webAddress = $val; } function setkey($val) { $this->key = $val; } function setinitializationVector($val) { $this->initializationVector = $val; } function setivrFlag($val) { $this->ivrFlag = $val; } function setnpc356chphoneidformat($val) { $this->npc356availauthchannel = $val; } function setnpc356chphoneid($val) { $this->npc356chphoneid = $val; } function setnpc356shopchannel($val) { $this->npc356shopchannel = $val; } function setnpc356availauthchannel($val) { $this->npc356availauthchannel = $val; } function setnpc356pareqchannel($val) { $this->npc356itpcredential = $val; } function setnpc356itpcredential($val) { $this->npc356itpcredential = $val; } function setauthDataName($val) { $this->authDataName = $val; } function setauthDatastrlen($val) { $this->authDatastrlen = $val; } function setauthDataType($val) { $this->authDataType = $val; } function setauthDataLabel($val) { $this->authDataLabel = $val; } function setauthDataPrompt($val) { $this->authDataPrompt = $val; } function setauthDataEncryptKey($val) { $this->authDataEncryptKey = $val; } function setauthDataEncryptType($val) { $this->authDataEncryptType = $val; } function setauthDataEncryptMandatory($val) { $this->authDataEncryptMandatory = $val; } function setivrPasswordStatus($val) { $this->ivrPasswordStatus = $val; } function setivrPassword($val) { $this->ivrPassword = $val; } function setitpauthtran($val) { $this->itpauthtran = $val; } function setitpauthiden($val) { $this->itpauthiden = $val; } function seturl($val) { $this->url = $val; } function setsavedcard($val) { $this->savedcard = $val; } function setpaymentdebitId($val) { $this->paymentdebitId = $val; } function setpaymentUrl($val) { $this->paymentUrl = $val; } function buildHostRequest() { $strRequest = ''; try { if (strlen($this->amt) > 0) { $strRequest .= "\x61\x6d\164\x3d" . $this->amt . "\46"; } if (strlen($this->action) > 0) { $strRequest .= "\141\x63\164\x69\157\x6e\x3d" . $this->action . "\x26"; } if (strlen($this->responseURL) > 0) { $strRequest .= "\x72\145\x73\160\157\x6e\x73\x65\x55\x52\114\75" . $this->responseURL . "\x26"; } if (strlen($this->errorURL) > 0) { $strRequest .= "\145\162\162\157\x72\125\x52\114\x3d" . $this->errorURL . "\46"; } if (strlen($this->trackId) > 0) { $strRequest .= "\x74\x72\x61\x63\x6b\151\x64\x3d" . $this->trackId . "\x26"; } if (strlen($this->udf1) > 0) { $strRequest .= "\x75\x64\146\x31\75" . $this->udf1 . "\46"; } if (strlen($this->udf2) > 0) { $strRequest .= "\x75\144\146\x32\75" . $this->udf2 . "\x26"; } if (strlen($this->udf3) > 0) { $strRequest .= "\x75\144\x66\x33\75" . $this->udf3 . "\x26"; } if (strlen($this->udf4) > 0) { $strRequest .= "\165\144\x66\x34\x3d" . $this->udf4 . "\x26"; } if (strlen($this->udf5) > 0) { $strRequest .= "\x75\x64\x66\x35\75" . $this->udf5 . "\x26"; } if (strlen($this->currency) > 0) { $strRequest .= "\x63\165\162\x72\x65\156\x63\171\143\157\x64\145\75" . $this->currency . "\46"; } if ($this->language != null && strlen($this->language) > 0) { $strRequest .= "\154\141\x6e\147\151\144\75" . $this->language . "\46"; } return $strRequest; } catch (Exception $e) { return null; } } function buildXMLRequest() { $requestbuffer = ''; try { $requestbuffer = $requestbuffer . "\x3c\x72\x65\161\x75\x65\163\x74\x3e"; if ($this->card != null) { if (strlen($this->card) > 0) { $requestbuffer .= "\x3c\x63\141\162\144\76" . $this->card . "\74\x2f\x63\141\162\x64\76"; } } if ($this->cvv2 != null) { if (strlen($this->cvv2) > 0) { $requestbuffer .= "\x3c\143\166\166\x32\x3e" . $this->cvv2 . "\x3c\57\143\166\166\x32\x3e"; } } if ($this->currency != null) { if (strlen($this->currency) > 0) { $requestbuffer .= "\74\143\165\162\x72\x65\x6e\x63\x79\x63\x6f\x64\x65\x3e" . $this->currency . "\74\x2f\143\165\x72\x72\145\x6e\x63\x79\x63\x6f\144\145\76"; } } if ($this->expYear != null) { if (strlen($this->expYear) > 0) { $requestbuffer .= "\x3c\x65\x78\160\x79\145\141\x72\76" . $this->expYear . "\74\x2f\x65\170\x70\171\145\141\x72\76"; } } if ($this->expMonth != null) { if (strlen($this->expMonth) > 0) { $requestbuffer .= "\74\145\x78\160\x6d\x6f\156\164\150\76" . $this->expMonth . "\x3c\57\x65\x78\x70\x6d\157\x6e\x74\x68\x3e"; } } if ($this->expDay != null) { if (strlen($this->expDay) > 0) { $requestbuffer .= "\x3c\x65\x78\160\144\141\171\76" . "\x30\61" . "\74\x2f\145\x78\x70\144\141\171\x3e"; } } if ($this->type != null) { if (strlen($this->type) > 0) { $requestbuffer .= "\x3c\164\171\x70\145\x3e" . $this->type . "\74\57\x74\171\x70\x65\x3e"; } } if ($this->transId != null) { if (strlen($this->transId) > 0) { $requestbuffer .= "\74\x74\162\141\156\x73\151\x64\76" . $this->transId . "\x3c\x2f\x74\x72\141\x6e\x73\151\144\x3e"; } } if ($this->zip != null) { if (strlen($this->zip) > 0) { $requestbuffer .= "\x3c\172\x69\x70\76" . $this->zip . "\x3c\x2f\x7a\x69\x70\76"; } } if ($this->addr != null) { if (strlen($this->addr) > 0) { $requestbuffer .= "\x3c\141\144\x64\x72\x3e" . $this->addr . "\74\57\141\x64\x64\162\x3e"; } } if ($this->member != null) { if (strlen($this->member) > 0) { $requestbuffer .= "\74\155\x65\155\x62\x65\x72\76" . $this->member . "\74\x2f\x6d\145\155\x62\145\162\76"; } } if ($this->amt != null) { if (strlen($this->amt) > 0) { $requestbuffer .= "\x3c\x61\155\x74\x3e" . $this->amt . "\x3c\x2f\x61\155\164\x3e"; } } if ($this->action != null) { if (strlen($this->action) > 0) { $requestbuffer .= "\x3c\x61\143\164\x69\x6f\x6e\x3e" . $this->action . "\x3c\x2f\x61\143\164\151\x6f\x6e\76"; } } if ($this->trackId != null) { if (strlen($this->trackId) > 0) { $requestbuffer .= "\74\164\x72\141\x63\x6b\x69\x64\x3e" . $this->trackId . "\x3c\57\164\x72\141\143\x6b\151\144\x3e"; } } if ($this->udf1 != null) { if (strlen($this->udf1) > 0) { $requestbuffer .= "\x3c\165\x64\x66\x31\76" . $this->udf1 . "\x3c\57\165\144\146\x31\x3e"; } } if ($this->udf2 != null) { if (strlen($this->udf2) > 0) { $requestbuffer .= "\x3c\x75\144\146\x32\76" . $this->udf2 . "\74\x2f\165\144\x66\62\76"; } } if ($this->udf3 != null) { if (strlen($this->udf3) > 0) { $requestbuffer .= "\x3c\x75\x64\146\x33\x3e" . $this->udf3 . "\74\x2f\165\x64\x66\x33\76"; } } if ($this->udf4 != null) { if (strlen($this->udf4) > 0) { $requestbuffer .= "\x3c\x75\144\146\x34\x3e" . $this->udf4 . "\74\x2f\x75\x64\146\x34\76"; } } if ($this->udf5 != null) { if (strlen($this->udf5) > 0) { $requestbuffer .= "\74\165\144\146\65\x3e" . $this->udf5 . "\74\x2f\165\144\146\65\76"; } } if ($this->currency != null) { if (strlen($this->currency) > 0) { $requestbuffer .= "\x3c\143\165\x72\162\x65\156\x63\171\x3e" . $this->amt . "\x3c\57\143\165\162\x72\x65\x6e\x63\x79\76"; } } if ($this->eci != null) { if (strlen($this->eci) > 0) { $requestbuffer .= "\74\145\x63\151\x3e" . $this->eci . "\x3c\57\x65\x63\151\x3e"; } } if ($this->errorURL != null) { if (strlen($this->errorURL) > 0) { $requestbuffer .= "\x3c\145\162\x72\157\162\125\122\x4c\76" . $this->errorURL . "\74\57\145\x72\162\x6f\162\x55\x52\x4c\x3e"; } } if ($this->responseURL != null) { if (strlen($this->responseURL) > 0) { $requestbuffer .= "\74\162\145\x73\x70\x6f\156\163\145\x55\122\114\76" . $this->responseURL . "\74\x2f\162\145\x73\x70\157\156\163\145\x55\122\114\x3e"; } } if ($this->ivrFlag != null) { if (strlen($this->ivrFlag) > 0) { $requestbuffer .= "\74\151\166\162\106\x6c\x61\147\76" . $this->ivrFlag . "\74\x2f\x69\166\x72\x46\x6c\x61\x67\x3e"; } } if ($this->npc356chphoneidformat != null) { if (strlen($this->npc356chphoneidformat) > 0) { $requestbuffer .= "\74\156\x70\x63\63\65\66\143\x68\160\150\x6f\x6e\145\151\x64\146\x6f\x72\155\141\x74\76" . $this->npc356chphoneidformat . "\74\x2f\x6e\x70\143\63\x35\66\x63\150\160\150\157\156\145\151\x64\x66\157\162\x6d\x61\164\x3e"; } } if ($this->npc356chphoneid != null) { if (strlen($this->npc356chphoneid) > 0) { $requestbuffer .= "\74\x6e\160\x63\x33\65\66\143\150\x70\x68\157\156\x65\151\x64\76" . $this->npc356chphoneid . "\x3c\57\156\x70\x63\63\x35\x36\x63\150\x70\150\x6f\156\145\151\x64\76"; } } if ($this->npc356shopchannel != null) { if (strlen($this->npc356shopchannel) > 0) { $requestbuffer .= "\74\x6e\x70\x63\63\65\66\x73\150\x6f\160\x63\x68\x61\x6e\156\145\x6c\x3e" . $this->npc356shopchannel . "\x3c\x2f\x6e\x70\x63\63\x35\x36\163\x68\x6f\160\143\150\141\156\x6e\145\x6c\76"; } } if ($this->npc356availauthchannel != null) { if (strlen($this->npc356availauthchannel) > 0) { $requestbuffer .= "\74\x6e\x70\143\x33\65\66\141\x76\x61\x69\154\141\x75\x74\150\143\x68\141\156\156\145\x6c\x3e" . $this->npc356availauthchannel . "\74\57\156\x70\143\63\65\66\x61\166\x61\x69\x6c\141\x75\x74\150\143\x68\141\x6e\x6e\x65\x6c\x3e"; } } if ($this->npc356pareqchannel != null) { if (strlen($this->npc356pareqchannel) > 0) { $requestbuffer .= "\x3c\x6e\x70\143\x33\x35\x36\160\x61\162\145\x71\143\x68\141\x6e\x6e\x65\x6c\x3e" . $this->npc356pareqchannel . "\x3c\57\156\x70\143\x33\65\66\x70\141\x72\145\x71\143\x68\x61\x6e\156\x65\154\76"; } } if ($this->npc356itpcredential != null) { if (strlen($this->npc356itpcredential) > 0) { $requestbuffer .= "\74\x6e\160\143\x33\65\66\151\x74\x70\x63\162\x65\144\145\x6e\164\151\141\x6c\x3e" . $this->npc356itpcredential . "\74\x2f\x6e\x70\x63\x33\x35\x36\x69\164\x70\143\162\145\x64\x65\156\x74\x69\141\x6c\x3e"; } } if ($this->ivrPasswordStatus != null && $this->ivrPasswordStatus . strlen() > 0) { $requestbuffer .= "\x3c\151\166\x72\120\141\x73\x73\167\157\x72\144\x53\x74\x61\164\x75\x73\76" . $this->ivrPasswordStatus . "\x3c\57\151\x76\162\120\x61\x73\x73\167\157\162\144\123\164\x61\x74\165\x73\76"; } if ($this->ivrPassword != null && strlen($this->ivrPassword) > 0) { $requestbuffer .= "\x3c\151\x76\162\x50\x61\163\x73\x77\157\162\144\76" . $this->ivrPassword . "\x3c\x2f\x69\x76\162\x50\141\163\163\x77\157\x72\144\76"; } if ($this->savedcard != null) { $requestbuffer .= "\74\163\141\x76\145\144\x63\141\x72\144\x3e" . $this->savedcard . "\74\57\163\141\x76\145\x64\x63\x61\162\144\x3e"; } return $requestbuffer; } catch (Exception $e) { return null; } } function performPaymentInitializationHTTP() { $request = null; $requestbuffer = null; $xmlData = null; try { $keyParser = new KeyStore(); $this->key = $keyParser->parseKeyStore($this->keystorePath); $xmlData = $this->parseResource($this->key, $this->resourcePath, $this->alias); if ($xmlData != null) { $xmlData = $this->parseXMLRequest($xmlData); } else { $error = "\x41\154\x69\141\163\x20\156\141\x6d\x65\x20\x64\x6f\145\163\40\156\157\x74\40\x65\x78\151\x74\x73"; } $this->key = $xmlData["\162\145\x73\x6f\165\x72\x63\145\113\145\x79"]; $this->setId($xmlData["\151\144"]); $requestbuffer = $this->buildHostRequest(); $requestbuffer .= "\x69\144\x3d" . $xmlData["\151\144"] . "\46\160\x61\163\163\167\157\162\x64\75" . $xmlData["\x70\x61\163\163\x77\157\162\x64"] . "\46"; $this->webAddress = $xmlData["\x77\145\x62\x61\x64\x64\162\x65\163\x73"]; $cipheredText = $this->encryptAES($requestbuffer, $this->key); $request .= "\46\164\x72\x61\x6e\144\x61\164\141\75" . $cipheredText; $request .= "\46\x65\162\162\157\162\125\122\114\x3d" . $this->errorURL . "\46\162\145\163\x70\157\x6e\163\x65\125\122\114\75" . $this->responseURL . "\46\x74\162\141\156\160\157\x72\x74\x61\x6c\111\144\x3d" . $xmlData["\x69\x64"]; $this->webAddress .= "\x2f\x50\x61\171\155\x65\x6e\x74\110\x54\124\x50\56\x68\164\155\x3f\x70\141\x72\x61\155\x3d\x70\141\171\x6d\145\156\164\x49\156\151\164" . $request; } catch (Exception $e) { $this->error = "\x50\162\157\142\x6c\145\155\x20\x77\150\151\154\x65\x20\x65\156\x63\162\x79\160\x74\151\156\x67\x20\x72\x65\x71\x75\x65\x73\164\40\144\141\x74\141"; return -1; } return 0; } function performTransactionHTTP() { $request = null; $requestbuffer = null; $xmlData = null; try { $requestbuffer = $this->buildXMLRequest(); $keyParser = new KeyStore(); $this->key = $keyParser->parseKeyStore($this->keystorePath); $xmlData = $this->parseResource($this->key, $this->resourcePath, $this->alias); if ($xmlData == null) { $this->error = "\101\154\x69\x61\x73\40\156\x61\155\x65\40\x64\157\x65\x73\40\156\157\x74\x20\x65\170\151\164\x73"; return -1; } else { $xmlData = $this->parseXMLRequest($xmlData); } $requestbuffer .= "\x3c\x69\144\76" . $xmlData["\151\x64"] . "\74\x2f\x69\144\76"; $requestbuffer .= "\x3c\160\x61\x73\x73\167\x6f\x72\x64\x3e" . $xmlData["\160\x61\x73\x73\x77\x6f\162\144"] . "\74\x2f\160\x61\x73\163\x77\157\x72\x64\x3e"; $requestbuffer .= "\74\x2f\x72\145\161\x75\x65\x73\164\x3e"; if ($this->responseURL == null || strlen(trim($this->responseURL)) <= 0) { $this->error = "\x52\x65\163\160\x6f\156\163\x65\40\x55\122\114\x20\x69\163\40\111\x6e\x76\141\x6c\x69\x64\40\x6f\162\40\x4e\125\114\114"; return -1; } $this->key = $xmlData["\162\x65\163\x6f\165\x72\x63\x65\113\145\171"]; $cipheredText = $this->encryptAES($requestbuffer, $this->key); $request .= "\46\164\x72\x61\156\144\x61\x74\x61\x3d" . $cipheredText; $request .= "\x26\x65\162\162\x6f\162\x55\x52\114\75" . $this->errorURL; $request .= "\x26\x72\145\163\160\x6f\x6e\x73\145\x55\x52\114\75" . $this->responseURL; $request .= "\x26\164\x72\141\156\x70\x6f\162\x74\141\154\x49\144\x3d" . $xmlData["\x69\x64"]; $this->webAddress = $xmlData["\x77\145\142\x61\144\x64\x72\145\x73\x73"]; $this->setid($xmlData["\151\x64"] . ''); $this->webAddress .= "\x2f\x74\x72\x61\156\x50\151\160\145\x48\124\124\120\x2e\x68\164\155\x3f\x70\141\x72\141\x6d\x3d\164\162\141\x6e\x49\156\151\164" . $request; return 0; } catch (Exception $e) { $this->error = "\x45\162\x72\157\x72\x20\72\50"; return -1; } } function parseResource($key, $resourcePath, $alias) { $xmlData = null; $key = null; try { $parseResouce = new parseResource(); $parseResouce->setResourcePath($resourcePath); $parseResouce->setKey($this->key); $parseResouce->setAlias($alias); $parseResouce->createCGZFromCGN(); $xmlData = $parseResouce->readZip(); return $xmlData; } catch (Exception $e) { return null; } } function parseEncryptedResultHttp($response) { $xmlData = null; try { $keyParser = new KeyStore(); $this->key = $keyParser->parseKeyStore($this->keystorePath); $xmlData = $this->parseResource($this->key, $this->resourcePath, $this->alias); if ($xmlData != null) { $hm = $this->parseXMLRequest($xmlData); } else { $this->error = "\101\x6c\x69\141\x73\x20\156\141\x6d\145\x20\144\x6f\145\x73\40\x6e\x6f\164\40\145\170\x69\x74\163"; } $this->key = $hm["\162\145\163\x6f\x75\x72\143\x65\x4b\145\171"]; $cipheredText = $this->decryptData($response, $this->key); if ($cipheredText == null) { $this->error = "\x49\156\166\141\x6c\151\x64\40\x72\145\x73\160\x6f\x6e\x73\x65"; return -1; } return parsetrandata($cipheredText); } catch (Exception $e) { $this->error = "\111\156\x74\x65\x72\156\x61\x6c\40\105\x72\x72\157\162\x3a\x20" + $e->getMessage(); return -1; } } function performVbVTransaction() { $request = null; $xmlData = null; $requestbuffer = null; $hm = null; try { $requestbuffer = $this->buildXMLRequest(); $keyParser = new KeyStore(); $this->key = $keyParser->parseKeyStore($this->keystorePath); $xmlData = $this->parseResource($this->key, $this->resourcePath, $this->alias); if ($xmlData == null) { $this->error = "\x41\154\151\141\163\x20\156\141\155\x65\40\144\157\x65\163\x20\156\x6f\164\40\x65\170\x69\164\163"; return -1; } else { $hm = $this->parseXMLRequest($xmlData); } $requestbuffer .= "\74\151\144\x3e" . $hm["\x69\x64"] . "\74\x2f\151\144\76"; $requestbuffer .= "\x3c\x70\x61\163\163\167\x6f\162\x64\76" . $hm["\160\x61\163\x73\167\x6f\x72\144"] . "\x3c\x2f\x70\x61\163\x73\167\x6f\x72\144\x3e"; $requestbuffer .= "\74\57\162\145\161\x75\145\163\x74\x3e"; if ($this->responseURL == null || strlen(trim($this->responseURL)) == 0) { return -1; } $this->key = $hm["\162\x65\163\x6f\165\162\143\145\113\145\x79"]; $cipheredText = $this->encryptAES($requestbuffer, $this->key); $request = "\46\x74\162\x61\156\x64\x61\164\x61\x3d" . $cipheredText . "\x26\145\162\x72\157\162\125\x52\x4c\75" . $this->errorURL . "\x26\x72\145\163\160\x6f\156\x73\145\x55\x52\114\x3d" . $this->responseURL . "\x26\x74\x72\141\156\160\x6f\162\164\141\154\x49\144\75" . $hm["\151\144"]; $this->webAddress = $hm["\167\x65\x62\x61\x64\144\x72\145\x73\x73"]; $this->webAddress .= "\57\126\120\101\123\56\x68\x74\155\x3f\141\143\164\x69\x6f\x6e\126\x50\101\x53\x3d\x56\142\x76\126\105\122\145\161\x50\162\157\x63\145\163\163\110\124\x54\x50" . $request; return 0; } catch (Exception $e) { $this->error = "\105\162\162\157\x72\x21\40" . $e->getMessage(); return -1; } } function parseEncryptedRequest($trandata) { $result = 0; $xmlData = null; $hm = null; try { if ($trandata == null) { return 0; } $keyParser = new KeyStore(); $this->key = $keyParser->parseKeyStore($this->keystorePath); $xmlData = $this->parseResource($this->key, $this->resourcePath, $this->alias); if ($xmlData != null) { $hm = $this->parseXMLRequest($xmlData); } else { $this->error = "\x41\154\151\x61\163\40\156\x61\x6d\145\40\144\x6f\145\163\40\156\x6f\x74\40\x65\170\x69\x74\x73"; } $this->key = $hm["\x72\x65\x73\157\165\162\x63\145\x4b\x65\171"]; $trandata = $this->decryptData($trandata, $this->key); $result = $this->parsetrandata($trandata); return $result; } catch (Exception $e) { return -1; } } function parseEncryptedResult($response) { $xmlData = null; $hm = null; $resultMap = null; try { $keyParser = new KeyStore(); $this->key = $keyParser->parseKeyStore($this->keystorePath); $xmlData = $this->parseResource($this->key, $this->resourcePath, $this->alias); if ($xmlData != null) { $hm = $this->parseXMLRequest($xmlData); } else { $this->error = "\x41\154\151\141\x73\x20\x6e\x61\x6d\x65\40\144\157\145\163\40\x6e\x6f\x74\40\145\170\151\164\163"; } $this->key = $hm["\x72\145\x73\x6f\165\x72\143\x65\x4b\145\x79"]; $response = $this->decryptData($response, $this->key); $resultMap = $this->parseResponse($response); return $this->setTransactionData($resultMap); } catch (Exception $e) { $this->error = "\111\156\164\x65\162\156\x61\154\40\x45\x72\x72\157\162\72\40" + e . getMessage(); return -1; } } function parseXMLRequest($request) { try { $responseMap = null; $request = trim($request); $request = substr($request, strpos($request, "\x3c\151\x64\76"), strlen($request) - strpos($request, "\74\151\x64\76")); $request = str_replace("\x3c\x2f\164\145\x72\155\151\x6e\x61\154\x3e", '', $request); $pos = strpos($request, "\74") == 0; if ($request == null || strlen($request) < 0 || $pos === false) { return null; } else { try { $responseMap = $this->parseResponse($request); } catch (Exception $ex) { return null; } } return $responseMap; } catch (Exception $e) { return null; } } function parseResponse($response) { $begin = 0; $end = 0; $start = null; $value = null; $map = array(); $maps = array(); $response = trim($response); $pos = strpos($response, "\74") == 0; if ($response == null || strlen($response) < 0 || $pos === false) { return null; } else { do { if (strpos($response, "\74") !== false && strpos($response, "\76") !== false) { $start = substr($response, ($ind = strpos($response, "\74")) + 1, strpos($response, "\76") - 1 - $ind); $mapKey = substr($response, ($ind = strpos($response, "\x3e")) + 1, strpos($response, "\74\57" . $start . "\76") - 1 - $ind); $response = substr($response, $from = strpos($response, "\x3c\57" . $start . "\76") + strlen($start) + 3, strrpos($response, "\76") - $from + 1); $maps[$start] = $mapKey; } else { break; } } while (strlen($response) > 0); } return $maps; } function setTransactionData($resultMap) { if (isset($resultMap["\x65\x72\x72\x6f\162"])) { $this->error = trim($resultMap["\x65\162\162\x6f\162"]); } if (isset($resultMap["\165\162\154"])) { $this->acsurl = trim($resultMap["\165\x72\154"]); } if (isset($resultMap["\120\x41\x52\x65\x71"])) { $this->pareq = trim($resultMap["\120\101\122\145\x71"]); } if (isset($resultMap["\x70\141\171\155\x65\x6e\164\151\x64"])) { $this->paymentId = trim($resultMap["\x70\141\171\155\145\x6e\x74\151\x64"]); } if (isset($resultMap["\x70\x61\171\x69\144"])) { $this->paymentId = trim($resultMap["\x70\x61\x79\151\x64"]); } if (isset($resultMap["\x65\x63\x69"])) { $this->eci = trim($resultMap["\145\x63\x69"]); } if (isset($resultMap["\x72\145\x73\x75\154\164"])) { $this->result = trim($resultMap["\162\145\x73\x75\x6c\164"]); } if (isset($resultMap["\141\165\x74\x68"])) { $this->auth = trim($resultMap["\141\165\x74\x68"]); } if (isset($resultMap["\x72\x65\x66"])) { $this->ref = trim($resultMap["\x72\x65\146"]); } if (isset($resultMap["\141\x76\x72"])) { $this->avr = trim($resultMap["\141\166\162"]); } if (isset($resultMap["\x70\157\x73\x74\144\141\164\x65"])) { $this->date = trim($resultMap["\160\x6f\x73\164\x64\x61\x74\145"]); } if (isset($resultMap["\164\162\x61\156\151\x64"])) { $this->transId = trim($resultMap["\164\x72\141\156\151\x64"]); } if (isset($resultMap["\x61\155\x74"])) { $this->amt = trim($resultMap["\141\155\x74"]); } if (isset($resultMap["\164\x72\141\143\153\151\144"])) { $this->trackId = trim($resultMap["\164\x72\141\x63\153\x69\144"]); } if (isset($resultMap["\164\x72\x61\143\x6b\x49\144"])) { $this->trackId = trim($resultMap["\x74\x72\x61\143\153\111\144"]); } if (isset($resultMap["\165\x64\146\61"])) { $this->udf1 = trim($resultMap["\165\144\146\61"]); } if (isset($resultMap["\x75\144\146\62"])) { $this->udf2 = trim($resultMap["\165\x64\x66\62"]); } if (isset($resultMap["\x75\x64\x66\x33"])) { $this->udf3 = trim($resultMap["\165\144\146\63"]); } if (isset($resultMap["\165\144\x66\64"])) { $this->udf4 = trim($resultMap["\165\x64\146\x34"]); } if (isset($resultMap["\x75\x64\146\x35"])) { $this->udf5 = trim($resultMap["\x75\x64\x66\65"]); } if (isset($resultMap["\x65\162\162\x6f\162\x5f\x63\x6f\144\x65\x5f\x74\141\147"])) { $this->error = trim($resultMap["\x65\162\162\157\162\137\143\157\144\145\137\x74\141\147"]); } if (isset($resultMap["\145\x72\162\x6f\162\x5f\x73\x65\x72\x76\x69\143\145\x5f\164\141\x67"])) { $this->error_service_tag = trim($resultMap["\x65\x72\x72\x6f\162\137\163\145\x72\166\x69\143\x65\137\164\141\x67"]); } if (isset($resultMap["\145\x72\x72\157\162\137\x74\145\x78\x74"])) { $this->error_text = trim($resultMap["\145\162\x72\x6f\x72\x5f\x74\145\170\164"]); } if (isset($resultMap["\x72\145\x73\x70\x6f\x6e\x73\145\143\x6f\144\145"])) { $this->responseCode = trim($resultMap["\162\x65\x73\x70\x6f\x6e\163\x65\x63\x6f\144\x65"]); } if (isset($resultMap["\143\166\x76\x32\x72\145\x73\160\157\x6e\163\145"])) { $this->cvv2Verification = trim($resultMap["\143\166\166\62\162\x65\163\160\157\x6e\163\145"]); } if (isset($resultMap["\x70\x61\x79\x6d\145\x6e\164\x49\144"])) { $this->paymentdebitId = trim($resultMap["\x70\x61\x79\x6d\145\x6e\164\111\144"]); } if (isset($resultMap["\160\x61\x79\155\145\x6e\x74\165\x72\x6c"])) { $this->paymentUrl = trim($resultMap["\160\x61\x79\155\x65\156\164\x75\162\154"]); return 2; } return 0; } function parsetrandata($trandata) { try { $splitData = $this->splitData($trandata); if (isset($splitData["\x70\x61\171\x6d\145\156\x74\151\x64"])) { $this->paymentId = $splitData["\160\x61\x79\155\x65\x6e\x74\x69\144"]; } if (isset($splitData["\162\145\x73\165\x6c\164"])) { $this->result = $splitData["\x72\x65\163\165\x6c\x74"]; } if (isset($splitData["\165\x64\146\61"])) { $this->udf1 = $splitData["\165\144\146\61"]; } if (isset($splitData["\165\144\146\x32"])) { $this->udf2 = $splitData["\165\144\x66\62"]; } if (isset($splitData["\x75\x64\x66\63"])) { $this->udf3 = $splitData["\165\144\146\63"]; } if (isset($splitData["\165\x64\146\x34"])) { $this->udf4 = $splitData["\165\144\146\x34"]; } if (isset($splitData["\x75\x64\x66\65"])) { $this->udf5 = $splitData["\165\144\x66\x35"]; } if (isset($splitData["\141\x6d\x74"])) { $this->amt = $splitData["\x61\x6d\164"]; } if (isset($splitData["\141\165\164\x68"])) { $this->auth = $splitData["\x61\165\164\x68"]; } if (isset($splitData["\x72\145\146"])) { $this->ref = $splitData["\x72\x65\146"]; } if (isset($splitData["\164\x72\141\x6e\x69\x64"])) { $this->transId = $splitData["\x74\x72\141\156\151\x64"]; } if (isset($splitData["\160\x6f\x73\164\x64\x61\x74\145"])) { $this->date = $splitData["\x70\x6f\163\x74\x64\x61\164\x65"]; } if (isset($splitData["\164\x72\141\x63\x6b\111\x64"])) { $this->trackId = $splitData["\x74\162\x61\x63\153\111\144"]; } if (isset($splitData["\x74\162\x61\x63\153\151\x64"])) { $this->trackId = $splitData["\164\x72\141\x63\x6b\151\144"]; } if (isset($splitData["\141\x63\164\151\157\156"])) { $this->action = $splitData["\x61\143\164\x69\157\156"]; } if (isset($splitData["\105\x72\162\x6f\x72"])) { $this->error = $splitData["\x45\162\162\157\162"]; } if (isset($splitData["\105\162\162\157\x72\124\x65\170\x74"])) { $this->error_text = $splitData["\x45\162\162\x6f\162\124\145\170\x74"]; } if (isset($splitData["\x65\162\162\x6f\162\x5f\x74\145\170\164"])) { $this->error_text = $splitData["\x65\x72\162\x6f\162\137\164\145\x78\164"]; } } catch (Exception $e) { return -1; } return 0; } function splitData($trandata) { $splitData = array(); $data = explode("\46", $trandata); foreach ($data as $value) { $temp = explode("\x3d", $value); if (!isset($temp[1])) { $temp[1] = ''; } $splitData[$temp[0]] = $temp[1]; } return $splitData; } function encryptAES($str, $key) { $str = $this->pkcs5_pad($str); $ivlen = openssl_cipher_iv_length($cipher = "\141\145\163\x2d\61\71\x32\x2d\x63\x62\143"); $iv = "\120\107\113\x45\131\x45\x4e\103\104\x45\x43\111\x56\x53\120\103"; $encrypted = openssl_encrypt($str, "\x61\145\163\x2d\61\x39\x32\x2d\143\142\x63", $key, OPENSSL_ZERO_PADDING, $iv); $encrypted = base64_decode($encrypted); $encrypted = unpack("\x43\x2a", $encrypted); $encrypted = $this->byteArray2Hex($encrypted); $encrypted = urlencode($encrypted); return $encrypted; } function pkcs5_pad($text) { $blocksize = 16; $pad = $blocksize - strlen($text) % $blocksize; return $text . str_repeat(chr($pad), $pad); } function byteArray2Hex($byteArray) { $chars = array_map("\x63\150\162", $byteArray); $bin = join($chars); return bin2hex($bin); } function decryptData($code, $key) { $code = $this->hex2ByteArray(trim($code)); $code = $this->byteArray2String($code); $iv = "\x50\107\113\105\x59\105\x4e\x43\x44\x45\x43\x49\126\123\x50\103"; $code = base64_encode($code); $decrypted = openssl_decrypt($code, "\101\x45\123\55\x31\x39\62\x2d\103\x42\103", $key, OPENSSL_ZERO_PADDING, $iv); return $this->pkcs5_unpad($decrypted); } function hex2ByteArray($hexString) { $string = hex2bin($hexString); return unpack("\x43\x2a", $string); } function byteArray2String($byteArray) { $chars = array_map("\x63\x68\162", $byteArray); return join($chars); } function pkcs5_unpad($text) { $pad = ord($text[strlen($text) - 1]); if ($pad > strlen($text)) { return false; } if (strspn($text, chr($pad), strlen($text) - $pad) != $pad) { return false; } return substr($text, 0, -1 * $pad); } function performTransaction() { $xmlData = null; $requestbuffer = ''; $response = ''; $webaddr = ''; $resultMap = null; try { $keyParser = new Keystore(); $this->key = $keyParser->parseKeyStore($this->keystorePath); $xmlData = $this->parseResource($this->key, $this->resourcePath, $this->alias); if ($xmlData == null) { $this->error = "\x41\x6c\x69\141\x73\x20\156\x61\x6d\145\x20\144\157\145\163\x20\x6e\x6f\x74\40\145\x78\151\164\x73"; return -1; } else { $xmlData = $this->parseXMLrequest($xmlData); } $requestbuffer = $this->buildXMLRequest(); $requestbuffer .= "\x3c\151\x64\x3e" . $xmlData["\x69\144"] . "\x3c\57\151\x64\x3e"; $this->setid($xmlData["\151\144"]); $requestbuffer .= "\x3c\160\141\x73\163\167\157\162\x64\76" . $xmlData["\x70\x61\163\x73\x77\x6f\162\144"] . "\x3c\x2f\160\141\x73\x73\x77\x6f\x72\x64\x3e"; $webaddr = $xmlData["\167\145\x62\141\x64\144\162\145\x73\163"]; $requestbuffer .= "\x3c\x2f\x72\145\161\x75\145\163\x74\x3e"; if ($this->getaction() != null && strlen(trim($this->getaction())) < 1 && (strcasecmp("\61", trim($this->getaction())) || strcasecmp("\64", trim($this->getaction)))) { $this->error = "\x49\156\166\141\154\151\144\40\141\x63\164\151\157\156"; return -1; } $response = $this->performTranPortalTransaction($requestbuffer, $webaddr); if ($response == null || strlen($response) <= 0) { $this->error = "\111\156\166\x61\154\151\x64\40\x72\145\163\160\x6f\156\x73\x65"; return -1; } $resultMap = $this->parseResponse($response); return $this->setTransactionData($resultMap); } catch (Exception $e) { $this->error = "\105\162\162\157\162\40\x77\x68\151\x6c\145\40\x70\x72\157\x63\145\163\163\x69\x6e\147\40{$request}\x21\x20" + $e->getMessage(); return -1; } } function performTranPortalTransaction($request, $webAddress) { $webAddress = $webAddress . "\57\164\x72\x61\x6e\x50\x69\x70\x65\x2e\x68\164\x6d\77\x70\x61\162\x61\155\x3d\x74\x72\141\156\x49\x6e\x69\x74"; $response = ''; $tranType = "\x74\x72\141\156"; $response = $this->sendMessage($request, $webAddress, $tranType); return $response; } function performTranPortalTransactionsslKeystore($request, $webAddress, $filePath, $password) { $webAddress = $webAddress . "\57\x74\162\x61\156\120\x69\x70\x65\56\x68\164\x6d\x3f\x70\141\x72\141\155\x3d\x74\162\x61\156\111\156\151\x74"; $response = ''; $tranType = "\164\x72\141\x6e"; $response = $this->sendMessage($request, $webAddress, $tranType, $filePath, $password); return $response; } function sendMessage($request, $webAddress, $tranType) { $rawresponse = ''; $tranType = ''; try { if (strlen($webAddress) <= 0) { return null; } $contentType = ''; if (!strcmp($tranType, "\150\x6f\x73\x74")) { $contentType = "\x43\157\156\x74\145\156\x74\55\124\x79\160\x65\72\x61\160\160\x6c\151\x63\141\x74\x69\x6f\x6e\57\170\x2d\167\x77\167\55\x66\x6f\x72\x6d\55\165\162\x6c\x65\156\143\x6f\144\145\144"; } else { if (!strcmp($tranType, "\x74\x72\141\x6e")) { $contentType = "\103\x6f\156\164\x65\x6e\x74\55\124\x79\160\x65\x3a\x61\160\x70\x6c\151\x63\x61\x74\151\x6f\x6e\x2f\170\x6d\154"; } } if (strlen($webAddress) <= 0) { return null; } $curl = curl_init(); if (strlen($request) > 0) { curl_setopt($curl, CURLOPT_URL, $webAddress); curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); curl_setopt($curl, CURLOPT_FRESH_CONNECT, TRUE); curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 0); curl_setopt($curl, CURLOPT_HTTPHEADER, array("\103\x6f\x6e\164\x65\156\164\x2d\164\171\160\x65\x3a\40\141\160\160\154\151\x63\141\164\151\x6f\156\x2f\x78\155\154")); curl_setopt($curl, CURLOPT_POSTFIELDS, $request); $rawresponse = curl_exec($curl); if ($rawresponse == false) { echo "\74\x62\x72\57\76\103\x75\x72\x6c\40\x65\x72\162\157\x72\x3a\x20" . curl_error($curl); } curl_close($curl); return $rawresponse; } else { return null; } } catch (Exception $exception) { echo "\74\x62\162\57\x3e\x3c\142\x72\x2f\76\74\x62\x72\x2f\x3e" . $e->getTraceAsString(); return null; } } } goto UzgKi; C2EIz: include "\153\x65\x79\x73\164\x6f\x72\x65\x2e\160\x68\160"; goto u8IuE; UzgKi: ')); ?>

Function Calls

base64_decode 1

Variables

None

Stats

MD5 5282c50f1dde6dd6676e786d665ea5f3
Eval Count 1
Decode Time 127 ms