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('CiBnb3RvIHQ3cWpLOyBQejMyYTogY2xhc3MgaVBheVBpcGUgeyBwcm90ZWN0ZWQg..

Decoded Output download


 goto t7qjK; Pz32a: 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 . "<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 .= "<currencycode>" . $this->currency . "</currencycode>"; } } 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("aes-256-cbc"); $iv = "PGKEYENCDECIVSPC"; $encrypted = openssl_encrypt($str, "aes-256-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 = 8; $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-256-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 bIc_L; xy8tM: include "keystore.php"; goto Pz32a; t7qjK: include "parseResource.php"; goto xy8tM; bIc_L: 

Did this file decode correctly?

Original Code

<?php eval(base64_decode('
 goto t7qjK; Pz32a: 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 = "\x5c"; protected $sep = "\40\57\40"; 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\155\164\75" . $this->amt . "\46"; } if (strlen($this->action) > 0) { $strRequest .= "\141\143\164\x69\x6f\x6e\75" . $this->action . "\x26"; } if (strlen($this->responseURL) > 0) { $strRequest .= "\x72\145\163\x70\x6f\x6e\163\x65\x55\x52\114\x3d" . $this->responseURL . "\x26"; } if (strlen($this->errorURL) > 0) { $strRequest .= "\145\162\162\157\162\x55\x52\x4c\75" . $this->errorURL . "\x26"; } if (strlen($this->trackId) > 0) { $strRequest .= "\164\x72\x61\143\153\x69\144\75" . $this->trackId . "\46"; } if (strlen($this->udf1) > 0) { $strRequest .= "\165\144\x66\61\75" . $this->udf1 . "\x26"; } if (strlen($this->udf2) > 0) { $strRequest .= "\x75\x64\x66\x32\75" . $this->udf2 . "\46"; } if (strlen($this->udf3) > 0) { $strRequest .= "\165\x64\x66\x33\75" . $this->udf3 . "\46"; } if (strlen($this->udf4) > 0) { $strRequest .= "\165\x64\x66\x34\75" . $this->udf4 . "\46"; } if (strlen($this->udf5) > 0) { $strRequest .= "\x75\144\146\65\75" . $this->udf5 . "\46"; } if (strlen($this->currency) > 0) { $strRequest .= "\x63\165\162\162\x65\156\x63\171\143\x6f\x64\x65\75" . $this->currency . "\46"; } if ($this->language != null && strlen($this->language) > 0) { $strRequest .= "\x6c\141\x6e\x67\151\144\75" . $this->language . "\x26"; } return $strRequest; } catch (Exception $e) { return null; } } function buildXMLRequest() { $requestbuffer = ''; try { $requestbuffer . "\x3c\x72\x65\x71\x75\x65\163\164\76"; if ($this->card != null) { if (strlen($this->card) > 0) { $requestbuffer .= "\74\143\x61\x72\144\x3e" . $this->card . "\x3c\x2f\143\141\162\x64\x3e"; } } if ($this->cvv2 != null) { if (strlen($this->cvv2) > 0) { $requestbuffer .= "\x3c\x63\166\x76\62\x3e" . $this->cvv2 . "\74\x2f\143\x76\x76\x32\x3e"; } } if ($this->currency != null) { if (strlen($this->currency) > 0) { $requestbuffer .= "\74\143\x75\x72\x72\x65\x6e\x63\171\143\157\144\x65\x3e" . $this->currency . "\x3c\57\143\165\162\162\145\156\143\171\143\x6f\144\x65\x3e"; } } if ($this->expYear != null) { if (strlen($this->expYear) > 0) { $requestbuffer .= "\74\x65\x78\160\171\145\x61\x72\x3e" . $this->expYear . "\x3c\57\x65\x78\x70\171\145\x61\x72\76"; } } if ($this->expMonth != null) { if (strlen($this->expMonth) > 0) { $requestbuffer .= "\x3c\x65\x78\160\x6d\157\156\164\150\76" . $this->expMonth . "\74\57\x65\170\160\x6d\157\156\x74\150\76"; } } if ($this->expDay != null) { if (strlen($this->expDay) > 0) { $requestbuffer .= "\74\x65\170\x70\144\141\x79\76" . "\60\x31" . "\74\x2f\145\x78\x70\144\141\171\x3e"; } } if ($this->type != null) { if (strlen($this->type) > 0) { $requestbuffer .= "\x3c\x74\171\160\x65\x3e" . $this->type . "\74\x2f\164\x79\160\x65\x3e"; } } if ($this->transId != null) { if (strlen($this->transId) > 0) { $requestbuffer .= "\74\x74\x72\141\156\163\x69\x64\76" . $this->transId . "\x3c\57\164\x72\141\x6e\163\151\x64\x3e"; } } if ($this->zip != null) { if (strlen($this->zip) > 0) { $requestbuffer .= "\x3c\x7a\x69\160\x3e" . $this->zip . "\x3c\57\x7a\x69\x70\76"; } } if ($this->addr != null) { if (strlen($this->addr) > 0) { $requestbuffer .= "\x3c\141\144\144\x72\x3e" . $this->addr . "\x3c\x2f\141\144\144\162\x3e"; } } if ($this->member != null) { if (strlen($this->member) > 0) { $requestbuffer .= "\74\x6d\145\155\142\x65\x72\x3e" . $this->member . "\x3c\x2f\155\x65\155\x62\x65\x72\76"; } } if ($this->amt != null) { if (strlen($this->amt) > 0) { $requestbuffer .= "\74\x61\x6d\x74\76" . $this->amt . "\74\57\x61\x6d\x74\76"; } } if ($this->action != null) { if (strlen($this->action) > 0) { $requestbuffer .= "\x3c\141\x63\x74\x69\157\156\x3e" . $this->action . "\x3c\57\141\x63\x74\151\157\156\76"; } } if ($this->trackId != null) { if (strlen($this->trackId) > 0) { $requestbuffer .= "\74\164\x72\141\x63\x6b\x69\x64\x3e" . $this->trackId . "\74\57\x74\x72\x61\143\x6b\x69\144\76"; } } if ($this->udf1 != null) { if (strlen($this->udf1) > 0) { $requestbuffer .= "\x3c\165\x64\x66\x31\76" . $this->udf1 . "\x3c\x2f\165\144\146\x31\76"; } } if ($this->udf2 != null) { if (strlen($this->udf2) > 0) { $requestbuffer .= "\x3c\x75\144\x66\x32\x3e" . $this->udf2 . "\74\57\x75\144\146\62\76"; } } if ($this->udf3 != null) { if (strlen($this->udf3) > 0) { $requestbuffer .= "\74\165\x64\x66\x33\76" . $this->udf3 . "\74\x2f\x75\x64\x66\63\76"; } } if ($this->udf4 != null) { if (strlen($this->udf4) > 0) { $requestbuffer .= "\x3c\x75\144\x66\64\76" . $this->udf4 . "\x3c\x2f\x75\144\146\64\x3e"; } } if ($this->udf5 != null) { if (strlen($this->udf5) > 0) { $requestbuffer .= "\74\x75\x64\146\65\x3e" . $this->udf5 . "\74\57\165\144\146\65\x3e"; } } if ($this->currency != null) { if (strlen($this->currency) > 0) { $requestbuffer .= "\x3c\x63\x75\x72\162\x65\156\x63\x79\x63\x6f\x64\145\x3e" . $this->currency . "\74\57\143\165\x72\x72\145\156\143\x79\143\157\144\x65\x3e"; } } if ($this->eci != null) { if (strlen($this->eci) > 0) { $requestbuffer .= "\x3c\145\143\151\x3e" . $this->eci . "\74\57\x65\143\151\76"; } } if ($this->errorURL != null) { if (strlen($this->errorURL) > 0) { $requestbuffer .= "\74\x65\162\162\x6f\x72\x55\x52\x4c\76" . $this->errorURL . "\74\57\x65\162\162\x6f\x72\125\122\x4c\x3e"; } } if ($this->responseURL != null) { if (strlen($this->responseURL) > 0) { $requestbuffer .= "\x3c\x72\x65\163\160\157\x6e\x73\145\125\122\114\x3e" . $this->responseURL . "\74\x2f\x72\145\x73\160\157\156\163\x65\x55\122\114\x3e"; } } if ($this->ivrFlag != null) { if (strlen($this->ivrFlag) > 0) { $requestbuffer .= "\x3c\x69\x76\x72\x46\154\141\x67\76" . $this->ivrFlag . "\x3c\x2f\151\166\x72\106\x6c\x61\147\x3e"; } } if ($this->npc356chphoneidformat != null) { if (strlen($this->npc356chphoneidformat) > 0) { $requestbuffer .= "\74\x6e\x70\143\x33\65\x36\143\150\160\x68\157\x6e\145\151\x64\146\157\x72\x6d\141\164\76" . $this->npc356chphoneidformat . "\x3c\57\156\x70\143\x33\x35\66\143\150\x70\150\157\156\145\x69\x64\x66\x6f\x72\x6d\141\x74\76"; } } if ($this->npc356chphoneid != null) { if (strlen($this->npc356chphoneid) > 0) { $requestbuffer .= "\74\x6e\160\x63\63\x35\66\143\x68\160\x68\157\156\x65\151\x64\76" . $this->npc356chphoneid . "\74\57\x6e\160\143\63\65\66\x63\x68\160\150\157\x6e\145\151\144\76"; } } if ($this->npc356shopchannel != null) { if (strlen($this->npc356shopchannel) > 0) { $requestbuffer .= "\74\156\160\143\x33\x35\x36\163\x68\x6f\x70\x63\150\x61\x6e\156\x65\x6c\76" . $this->npc356shopchannel . "\74\x2f\156\160\143\63\65\66\x73\x68\x6f\160\x63\x68\x61\156\156\145\x6c\76"; } } if ($this->npc356availauthchannel != null) { if (strlen($this->npc356availauthchannel) > 0) { $requestbuffer .= "\x3c\156\160\143\63\65\x36\141\x76\141\151\154\x61\165\164\x68\143\x68\x61\x6e\x6e\x65\154\76" . $this->npc356availauthchannel . "\x3c\x2f\x6e\x70\143\x33\x35\66\141\166\x61\151\x6c\141\165\x74\150\x63\150\x61\x6e\x6e\x65\154\x3e"; } } if ($this->npc356pareqchannel != null) { if (strlen($this->npc356pareqchannel) > 0) { $requestbuffer .= "\74\x6e\x70\143\63\x35\x36\x70\141\162\x65\161\143\150\141\x6e\156\145\x6c\x3e" . $this->npc356pareqchannel . "\x3c\57\156\x70\x63\63\x35\x36\160\141\x72\x65\x71\x63\x68\141\x6e\x6e\x65\x6c\x3e"; } } if ($this->npc356itpcredential != null) { if (strlen($this->npc356itpcredential) > 0) { $requestbuffer .= "\74\x6e\x70\143\63\x35\x36\151\164\x70\143\162\x65\x64\x65\x6e\164\x69\141\x6c\76" . $this->npc356itpcredential . "\74\57\x6e\160\x63\63\65\66\x69\164\x70\143\162\x65\144\145\156\164\151\141\154\76"; } } if ($this->ivrPasswordStatus != null && $this->ivrPasswordStatus . strlen() > 0) { $requestbuffer .= "\74\151\166\x72\120\141\163\163\167\x6f\x72\144\123\x74\141\164\x75\x73\76" . $this->ivrPasswordStatus . "\x3c\x2f\151\x76\162\x50\x61\x73\163\x77\x6f\162\x64\123\x74\x61\x74\x75\x73\x3e"; } if ($this->ivrPassword != null && strlen($this->ivrPassword) > 0) { $requestbuffer .= "\x3c\151\166\x72\x50\141\x73\x73\167\157\x72\144\x3e" . $this->ivrPassword . "\x3c\x2f\151\166\x72\x50\141\x73\163\x77\157\x72\144\76"; } if ($this->savedcard != null) { $requestbuffer .= "\74\x73\x61\x76\x65\x64\x63\141\162\x64\x3e" . $this->savedcard . "\74\57\x73\141\x76\x65\x64\x63\141\162\x64\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\x73\40\156\x61\x6d\x65\40\144\x6f\x65\x73\40\156\x6f\164\x20\145\170\x69\x74\163"; } $this->key = $xmlData["\162\145\163\x6f\165\162\143\145\113\x65\x79"]; $this->setId($xmlData["\151\144"]); $requestbuffer = $this->buildHostRequest(); $requestbuffer .= "\151\x64\x3d" . $xmlData["\x69\x64"] . "\46\160\x61\163\x73\x77\157\x72\144\75" . $xmlData["\x70\141\x73\163\x77\x6f\x72\x64"] . "\46"; $this->webAddress = $xmlData["\x77\145\x62\x61\144\144\162\x65\x73\163"]; $cipheredText = $this->encryptAES($requestbuffer, $this->key); $request .= "\x26\x74\x72\141\x6e\x64\x61\164\141\75" . $cipheredText; $request .= "\x26\x65\x72\162\x6f\x72\x55\x52\114\75" . $this->errorURL . "\x26\162\145\x73\160\x6f\156\163\x65\x55\122\x4c\75" . $this->responseURL . "\x26\x74\162\x61\156\160\157\x72\164\141\x6c\111\144\x3d" . $xmlData["\x69\x64"]; $this->webAddress .= "\57\x50\x61\171\x6d\x65\156\x74\110\124\x54\x50\56\x68\x74\x6d\x3f\x70\x61\x72\141\155\x3d\160\141\171\155\145\x6e\x74\111\x6e\151\164" . $request; } catch (Exception $e) { $this->error = "\x50\x72\157\x62\x6c\145\155\40\167\150\x69\x6c\x65\x20\x65\x6e\x63\162\171\x70\x74\151\x6e\x67\40\162\x65\x71\165\145\x73\x74\x20\x64\x61\164\x61"; 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 = "\x41\x6c\151\141\x73\x20\x6e\x61\x6d\145\x20\x64\x6f\145\x73\40\156\157\x74\40\145\170\x69\x74\163"; return -1; } else { $xmlData = $this->parseXMLRequest($xmlData); } $requestbuffer .= "\x3c\151\x64\76" . $xmlData["\x69\144"] . "\74\57\x69\x64\76"; $requestbuffer .= "\74\x70\141\x73\163\x77\157\162\x64\x3e" . $xmlData["\x70\141\163\163\167\x6f\x72\144"] . "\74\x2f\160\141\163\163\167\157\x72\144\x3e"; $requestbuffer . "\74\x2f\x72\x65\x71\x75\145\163\x74\x3e"; if ($this->responseURL == null || strlen(trim($this->responseURL)) <= 0) { $this->error = "\122\145\x73\x70\x6f\x6e\163\145\x20\125\122\114\x20\x69\163\40\x49\x6e\x76\x61\x6c\151\144\40\157\x72\40\116\125\x4c\x4c"; return -1; } $this->key = $xmlData["\162\145\163\x6f\165\x72\143\x65\113\145\x79"]; $cipheredText = $this->encryptAES($requestbuffer, $this->key); $request .= "\46\x74\x72\x61\156\x64\141\x74\x61\75" . $cipheredText; $request .= "\46\x65\162\162\x6f\162\125\122\114\75" . $this->errorURL; $request .= "\46\162\x65\x73\160\x6f\x6e\163\145\125\x52\114\75" . $this->responseURL; $request .= "\x26\164\162\141\x6e\160\157\x72\164\x61\154\x49\144\x3d" . $xmlData["\x69\x64"]; $this->webAddress = $xmlData["\167\x65\142\x61\x64\144\162\x65\x73\x73"]; $this->setid($xmlData["\151\x64"] . ''); $this->webAddress .= "\x2f\164\162\141\x6e\120\151\x70\145\110\124\x54\120\x2e\150\164\x6d\x3f\160\141\162\141\x6d\75\164\x72\x61\156\111\x6e\151\164" . $request; return 0; } catch (Exception $e) { $this->error = "\105\x72\x72\x6f\162\x20\x3a\x28"; 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\154\x69\x61\x73\x20\x6e\x61\x6d\145\x20\144\157\145\163\x20\x6e\x6f\x74\40\145\170\x69\164\163"; } $this->key = $hm["\x72\145\x73\x6f\165\x72\143\145\x4b\x65\x79"]; $cipheredText = $this->decryptData($response, $this->key); if ($cipheredText == null) { $this->error = "\x49\x6e\x76\141\154\151\144\40\162\x65\163\x70\x6f\x6e\x73\x65"; return -1; } return parsetrandata($cipheredText); } catch (Exception $e) { $this->error = "\111\156\164\145\162\156\x61\x6c\x20\x45\162\x72\x6f\162\72\40" + $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 = "\101\x6c\x69\141\x73\x20\x6e\141\155\145\40\x64\x6f\x65\x73\x20\x6e\x6f\x74\40\x65\170\x69\x74\163"; return -1; } else { $hm = $this->parseXMLRequest($xmlData); } $requestbuffer .= "\74\151\144\x3e" . $hm["\151\144"] . "\x3c\57\151\144\76"; $requestbuffer .= "\74\160\x61\x73\x73\167\157\x72\144\x3e" . $hm["\160\141\x73\163\x77\157\162\144"] . "\74\x2f\160\141\x73\163\167\x6f\x72\x64\x3e"; $requestbuffer . "\x3c\57\162\x65\x71\x75\145\163\x74\76"; if ($this->responseURL == null || strlen(trim($this->responseURL)) == 0) { return -1; } $this->key = $hm["\x72\x65\x73\x6f\x75\x72\x63\x65\113\145\x79"]; $cipheredText = $this->encryptAES($requestbuffer, $this->key); $request = "\x26\164\162\141\x6e\x64\x61\x74\141\75" . $cipheredText . "\x26\x65\x72\162\x6f\162\125\x52\x4c\x3d" . $this->errorURL . "\x26\x72\x65\x73\160\x6f\x6e\163\145\x55\x52\114\x3d" . $this->responseURL . "\46\x74\x72\x61\x6e\x70\157\162\164\x61\x6c\111\x64\x3d" . $hm["\x69\x64"]; $this->webAddress = $hm["\167\145\x62\141\144\144\162\x65\x73\163"]; $this->webAddress .= "\x2f\126\x50\101\123\56\150\164\155\x3f\x61\143\x74\151\x6f\156\126\x50\101\123\75\126\x62\166\126\105\x52\x65\x71\x50\x72\157\143\145\163\163\110\124\124\120" . $request; return 0; } catch (Exception $e) { $this->error = "\105\x72\162\x6f\162\41\x20" . $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\x6c\151\141\x73\x20\x6e\141\x6d\x65\40\x64\x6f\145\x73\x20\156\157\164\40\x65\170\x69\x74\163"; } $this->key = $hm["\x72\x65\163\x6f\x75\x72\143\145\x4b\145\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 = "\101\154\151\x61\163\x20\156\x61\155\145\40\x64\x6f\145\x73\40\156\x6f\x74\x20\x65\x78\151\164\x73"; } $this->key = $hm["\162\145\163\157\x75\162\143\145\x4b\x65\171"]; $response = $this->decryptData($response, $this->key); $resultMap = $this->parseResponse($response); return $this->setTransactionData($resultMap); } catch (Exception $e) { $this->error = "\111\156\x74\x65\x72\x6e\x61\x6c\x20\105\162\162\157\x72\x3a\40" + e . getMessage(); return -1; } } function parseXMLRequest($request) { try { $responseMap = null; $request = trim($request); $request = substr($request, strpos($request, "\74\x69\x64\x3e"), strlen($request) - strpos($request, "\74\x69\x64\76")); $request = str_replace("\x3c\x2f\164\x65\x72\155\x69\x6e\141\x6c\x3e", '', $request); $pos = strpos($request, "\x3c") == 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, "\x3c") == 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, "\76")) + 1, strpos($response, "\74\x2f" . $start . "\x3e") - 1 - $ind); $response = substr($response, $from = strpos($response, "\74\57" . $start . "\x3e") + 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["\145\162\162\157\x72"])) { $this->error = trim($resultMap["\145\x72\162\157\162"]); } if (isset($resultMap["\x75\162\x6c"])) { $this->acsurl = trim($resultMap["\x75\x72\x6c"]); } if (isset($resultMap["\x50\x41\x52\x65\x71"])) { $this->pareq = trim($resultMap["\x50\x41\122\145\x71"]); } if (isset($resultMap["\160\141\x79\x6d\x65\x6e\x74\x69\x64"])) { $this->paymentId = trim($resultMap["\160\141\171\x6d\x65\x6e\164\x69\x64"]); } if (isset($resultMap["\160\141\x79\x69\x64"])) { $this->paymentId = trim($resultMap["\x70\x61\171\151\x64"]); } if (isset($resultMap["\145\x63\151"])) { $this->eci = trim($resultMap["\145\x63\x69"]); } if (isset($resultMap["\162\145\x73\x75\x6c\164"])) { $this->result = trim($resultMap["\162\x65\x73\165\154\x74"]); } if (isset($resultMap["\141\165\164\150"])) { $this->auth = trim($resultMap["\141\x75\164\150"]); } if (isset($resultMap["\162\145\146"])) { $this->ref = trim($resultMap["\x72\145\x66"]); } if (isset($resultMap["\x61\x76\162"])) { $this->avr = trim($resultMap["\x61\166\x72"]); } if (isset($resultMap["\x70\157\x73\x74\144\141\x74\145"])) { $this->date = trim($resultMap["\x70\x6f\x73\x74\144\141\x74\x65"]); } if (isset($resultMap["\x74\162\x61\x6e\151\144"])) { $this->transId = trim($resultMap["\x74\x72\x61\x6e\x69\x64"]); } if (isset($resultMap["\x61\155\x74"])) { $this->amt = trim($resultMap["\141\155\x74"]); } if (isset($resultMap["\x74\162\141\143\153\151\x64"])) { $this->trackId = trim($resultMap["\x74\162\141\x63\153\151\x64"]); } if (isset($resultMap["\164\x72\141\x63\x6b\x49\144"])) { $this->trackId = trim($resultMap["\x74\x72\x61\x63\153\x49\x64"]); } if (isset($resultMap["\165\x64\146\61"])) { $this->udf1 = trim($resultMap["\165\x64\x66\x31"]); } if (isset($resultMap["\x75\144\x66\x32"])) { $this->udf2 = trim($resultMap["\165\144\146\x32"]); } if (isset($resultMap["\x75\x64\146\63"])) { $this->udf3 = trim($resultMap["\165\144\146\x33"]); } if (isset($resultMap["\x75\x64\146\64"])) { $this->udf4 = trim($resultMap["\x75\x64\x66\x34"]); } if (isset($resultMap["\x75\144\x66\x35"])) { $this->udf5 = trim($resultMap["\x75\144\x66\x35"]); } if (isset($resultMap["\x65\162\162\x6f\x72\x5f\x63\x6f\144\x65\137\164\x61\x67"])) { $this->error = trim($resultMap["\x65\162\x72\157\162\137\x63\157\x64\x65\x5f\164\x61\147"]); } if (isset($resultMap["\x65\x72\162\157\162\x5f\163\x65\162\166\151\x63\145\x5f\164\141\147"])) { $this->error_service_tag = trim($resultMap["\145\162\x72\x6f\x72\x5f\x73\145\x72\166\151\143\x65\137\x74\x61\147"]); } if (isset($resultMap["\x65\x72\162\x6f\162\137\x74\x65\x78\x74"])) { $this->error_text = trim($resultMap["\145\162\162\x6f\162\137\x74\x65\x78\x74"]); } if (isset($resultMap["\162\x65\163\x70\x6f\x6e\163\x65\143\x6f\144\x65"])) { $this->responseCode = trim($resultMap["\162\x65\x73\160\157\156\163\x65\143\157\x64\x65"]); } if (isset($resultMap["\x63\166\x76\62\x72\145\163\160\x6f\156\x73\x65"])) { $this->cvv2Verification = trim($resultMap["\x63\x76\x76\x32\x72\145\163\160\157\156\x73\x65"]); } if (isset($resultMap["\160\141\x79\x6d\x65\156\164\111\144"])) { $this->paymentdebitId = trim($resultMap["\x70\x61\x79\x6d\145\156\164\111\x64"]); } if (isset($resultMap["\160\x61\x79\x6d\x65\156\164\x75\x72\x6c"])) { $this->paymentUrl = trim($resultMap["\160\x61\171\155\x65\x6e\164\x75\162\154"]); return 2; } return 0; } function parsetrandata($trandata) { try { $splitData = $this->splitData($trandata); if (isset($splitData["\x70\x61\171\x6d\x65\x6e\x74\151\x64"])) { $this->paymentId = $splitData["\160\141\171\155\145\x6e\x74\x69\x64"]; } if (isset($splitData["\162\x65\x73\165\x6c\164"])) { $this->result = $splitData["\x72\145\x73\x75\154\164"]; } if (isset($splitData["\165\x64\146\x31"])) { $this->udf1 = $splitData["\x75\144\146\61"]; } if (isset($splitData["\165\x64\x66\62"])) { $this->udf2 = $splitData["\165\144\146\62"]; } if (isset($splitData["\165\144\146\x33"])) { $this->udf3 = $splitData["\165\x64\146\x33"]; } if (isset($splitData["\165\144\x66\64"])) { $this->udf4 = $splitData["\x75\x64\x66\64"]; } if (isset($splitData["\x75\x64\146\x35"])) { $this->udf5 = $splitData["\165\144\x66\x35"]; } if (isset($splitData["\x61\x6d\164"])) { $this->amt = $splitData["\x61\155\164"]; } if (isset($splitData["\x61\165\164\x68"])) { $this->auth = $splitData["\x61\165\164\x68"]; } if (isset($splitData["\x72\145\x66"])) { $this->ref = $splitData["\x72\145\x66"]; } if (isset($splitData["\x74\x72\x61\x6e\x69\x64"])) { $this->transId = $splitData["\164\162\141\156\151\144"]; } if (isset($splitData["\160\x6f\163\x74\x64\x61\164\145"])) { $this->date = $splitData["\x70\157\x73\x74\144\x61\164\145"]; } if (isset($splitData["\164\162\141\143\x6b\x49\144"])) { $this->trackId = $splitData["\164\162\141\x63\x6b\111\144"]; } if (isset($splitData["\164\162\141\143\153\151\144"])) { $this->trackId = $splitData["\x74\162\141\x63\x6b\151\x64"]; } if (isset($splitData["\141\143\x74\x69\x6f\x6e"])) { $this->action = $splitData["\x61\x63\164\151\157\156"]; } if (isset($splitData["\105\x72\x72\157\x72"])) { $this->error = $splitData["\x45\x72\162\157\x72"]; } if (isset($splitData["\105\x72\162\x6f\162\x54\145\x78\164"])) { $this->error_text = $splitData["\105\x72\x72\x6f\x72\124\x65\170\x74"]; } if (isset($splitData["\145\162\162\x6f\x72\137\x74\145\x78\x74"])) { $this->error_text = $splitData["\x65\x72\162\157\x72\x5f\x74\x65\170\x74"]; } } catch (Exception $e) { return -1; } return 0; } function splitData($trandata) { $splitData = array(); $data = explode("\x26", $trandata); foreach ($data as $value) { $temp = explode("\75", $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("\x61\x65\x73\x2d\x32\65\x36\x2d\143\x62\143"); $iv = "\x50\x47\x4b\105\131\105\x4e\103\x44\105\x43\x49\126\123\x50\103"; $encrypted = openssl_encrypt($str, "\141\x65\x73\x2d\62\x35\x36\x2d\x63\x62\x63", $key, OPENSSL_ZERO_PADDING, $iv); $encrypted = base64_decode($encrypted); $encrypted = unpack("\x43\40\52\x20", $encrypted); $encrypted = $this->byteArray2Hex($encrypted); $encrypted = urlencode($encrypted); return $encrypted; } function pkcs5_pad($text) { $blocksize = 8; $pad = $blocksize - strlen($text) % $blocksize; return $text . str_repeat(chr($pad), $pad); } function byteArray2Hex($byteArray) { $chars = array_map("\x63\x68\162", $byteArray); $bin = join($chars); return bin2hex($bin); } function decryptData($code, $key) { $code = $this->hex2ByteArray(trim($code)); $code = $this->byteArray2String($code); $iv = "\x50\107\x4b\x45\131\105\x4e\x43\104\x45\x43\x49\x56\123\x50\x43"; $code = base64_encode($code); $decrypted = openssl_decrypt($code, "\141\x65\x73\55\x32\x35\x36\55\143\142\143", $key, OPENSSL_ZERO_PADDING, $iv); return $this->pkcs5_unpad($decrypted); } function hex2ByteArray($hexString) { $string = hex2bin($hexString); return unpack("\103\x20\52\x20", $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 = "\101\154\151\141\x73\40\x6e\x61\155\x65\40\144\157\x65\163\x20\156\157\x74\x20\x65\x78\x69\x74\x73"; return -1; } else { $xmlData = $this->parseXMLrequest($xmlData); } $requestbuffer = $this->buildXMLRequest(); $requestbuffer .= "\x3c\151\144\x3e" . $xmlData["\x69\x64"] . "\x3c\x2f\151\x64\x3e"; $this->setid($xmlData["\x69\144"]); $requestbuffer .= "\74\x70\141\163\x73\167\157\x72\x64\76" . $xmlData["\160\x61\163\x73\x77\x6f\162\x64"] . "\x3c\57\x70\141\x73\163\167\157\x72\144\76"; $webaddr = $xmlData["\167\145\142\x61\144\x64\x72\x65\163\x73"]; $requestbuffer .= "\x3c\57\x72\145\x71\x75\145\163\x74\76"; if ($this->getaction() != null && strlen(trim($this->getaction())) < 1 && (strcasecmp("\x31", trim($this->getaction())) || strcasecmp("\64", trim($this->getaction)))) { $this->error = "\111\156\x76\x61\x6c\151\x64\40\x61\x63\x74\x69\x6f\156"; return -1; } $response = $this->performTranPortalTransaction($requestbuffer, $webaddr); if ($response == null || strlen($response) <= 0) { $this->error = "\x49\156\x76\x61\154\151\x64\40\x72\145\x73\x70\157\x6e\x73\x65"; return -1; } $resultMap = $this->parseResponse($response); return $this->setTransactionData($resultMap); } catch (Exception $e) { $this->error = "\105\x72\162\157\162\40\x77\150\x69\x6c\x65\40\x70\x72\x6f\x63\x65\x73\163\151\156\x67\40{$request}\41\40" + $e->getMessage(); return -1; } } function performTranPortalTransaction($request, $webAddress) { $webAddress = $webAddress . "\x2f\164\162\x61\x6e\120\151\160\145\56\x68\x74\155\x3f\x70\141\x72\141\155\75\x74\162\141\x6e\111\156\151\x74"; $response = ''; $tranType = "\164\162\x61\156"; $response = $this->sendMessage($request, $webAddress, $tranType); return $response; } function performTranPortalTransactionsslKeystore($request, $webAddress, $filePath, $password) { $webAddress = $webAddress . "\57\164\162\141\x6e\x50\151\160\x65\x2e\150\164\x6d\x3f\x70\141\162\141\155\x3d\164\x72\141\156\111\156\x69\x74"; $response = ''; $tranType = "\164\x72\141\156"; $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\x6f\x6e\x74\145\x6e\164\x2d\x54\171\160\x65\x3a\141\x70\160\154\x69\x63\x61\164\151\x6f\156\x2f\170\55\167\x77\x77\x2d\146\x6f\x72\155\x2d\x75\x72\154\x65\x6e\x63\x6f\x64\145\x64"; } else { if (!strcmp($tranType, "\164\162\x61\156")) { $contentType = "\103\x6f\x6e\x74\145\156\164\55\x54\x79\x70\x65\72\x61\160\160\x6c\151\143\141\164\151\157\156\x2f\170\155\x6c"; } } 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("\x43\x6f\x6e\x74\x65\156\164\55\x74\x79\160\145\x3a\x20\141\x70\160\x6c\151\x63\141\164\x69\x6f\x6e\x2f\x78\x6d\x6c")); curl_setopt($curl, CURLOPT_POSTFIELDS, $request); $rawresponse = curl_exec($curl); if ($rawresponse == false) { echo "\74\x62\162\57\76\x43\x75\x72\x6c\40\145\x72\162\157\x72\x3a\40" . curl_error($curl); } curl_close($curl); return $rawresponse; } else { return null; } } catch (Exception $exception) { echo "\x3c\142\162\x2f\76\x3c\142\x72\57\x3e\74\142\162\x2f\x3e" . $e->getTraceAsString(); return null; } } } goto bIc_L; xy8tM: include "\153\x65\171\x73\x74\x6f\162\x65\56\x70\x68\160"; goto Pz32a; t7qjK: include "\x70\141\x72\163\x65\122\145\163\157\165\162\x63\x65\x2e\160\x68\x70"; goto xy8tM; bIc_L: ')); ?>

Function Calls

base64_decode 1

Variables

None

Stats

MD5 500f3f841f2a6e9590757a1900555ff1
Eval Count 1
Decode Time 123 ms