hedera-web/rest/tpv/confirm-soap.php

98 lines
2.1 KiB
PHP

<?php
require_once ('vn/web/http-request.php');
require_once ('vn/web/util.php');
/**
* Gets transaction confirmation from SOAP service.
**/
class TpvConfirmSoap extends Vn\Web\HttpRequest
{
function run ()
{
global $tpvConfirmSoap;
$tpvConfirmSoap = $this;
ini_set ('soap.wsdl_cache_enabled', FALSE);
$server = new SoapServer (__DIR__ .'/soap.wsdl');
$server->addFunction ('procesaNotificacionSIS');
$server->handle ();
}
}
function procesaNotificacionSIS ($XML)
{
global $tpvConfirmSoap;
$db = $tpvConfirmSoap->getSysConn ();
$status = 'OK';
$requestString = $XML;
// Processes the request
try {
$xml = new SimpleXMLElement ($requestString);
$request = (array) $xml->{'Request'};
if (!(isset ($request['Ds_Amount'])
&& isset ($request['Ds_Order'])
&& isset ($request['Ds_MerchantCode'])
&& isset ($request['Ds_Currency'])
&& isset ($request['Ds_Response'])))
throw new Exception ('Missing required parameters');
// Checks the signature
$start = strpos ($requestString, '<Request');
$end = strrpos ($requestString, '</Request>');
$shaString = substr ($requestString, $start, $end - $start + 10);
$key = $db->getValue (
'SELECT secret_key FROM tpv_merchant WHERE id = #'
,[$request['Ds_MerchantCode']]
);
if (sha1 ($shaString.$key) != $xml->{'Signature'})
throw new Exception ('Invalid signature');
// Confirms the transaction
$tpvConfirmSoap->confirm ($request);
}
catch (Exception $e)
{
$status = 'KO';
}
// Generates the response
$responseString = file_get_contents (__DIR__ .'/soap-reply.xml');
$xml = new SimpleXMLElement ($responseString);
$response = $xml->{'Response'};
$response->{'Ds_Response_Merchant'} = $status;
$xml->{'Signature'} = sha1 ($response->asXML ().$key);
return $xml->asXML ();
/*
// Another way to generate the response
$xmlResponse =
'<Response Ds_Version="0.0">
<Ds_Response_Merchant>'. $status .'</Ds_Response_Merchant>
</Response>';
$xmlMessage =
'<Message>
'. $xmlResponse .'
<Signature>'. sha1 ($xmlResponse.$key) .'</Signature>
</Message>';
return $xmlMessage;
*/}
?>