private function getResponseData(TransactionInterface $transaction)
{
$cmd = sprintf('cd %s && %s pathfile=%s message=%s ', $this->getOption('base_folder'), $this->getOption('response_command'), $this->getOption('pathfile'), $this->encodeString($transaction->get('DATA')));
$this->logger->debug(sprintf('Response Command : %s', $cmd));
$process = new Process($cmd);
$process->run();
if (!$process->isSuccessful()) {
throw new \RuntimeException(sprintf('Error %d when executing Scellius command: "%s".', $process->getExitCode(), trim($process->getErrorOutput())));
}
//Sortie de la fonction : !code!error!v1!v2!v3!...!v29
// - code = 0 : la fonction retourne les données de la transaction dans les variables v1, v2, ...
// : Ces variables sont décrites dans le GUIDE DU PROGRAMMEUR
// - code = -1 : La fonction retourne un message d'erreur dans la variable error
$data = explode('!', $process->getOutput());
if (count($data) != 33) {
throw new \RuntimeException('Invalid data count');
}
return array('code' => $data[1], 'error' => $data[2], 'merchant_id' => $data[3], 'merchant_country' => $data[4], 'amount' => $data[5], 'transaction_id' => $data[6], 'payment_means' => $data[7], 'transmission_date' => $data[8], 'payment_time' => $data[9], 'payment_date' => $data[10], 'response_code' => $data[11], 'payment_certificate' => $data[12], 'authorisation_id' => $data[13], 'currency_code' => $data[14], 'card_number' => $data[15], 'cvv_flag' => $data[16], 'cvv_response_code' => $data[17], 'bank_response_code' => $data[18], 'complementary_code' => $data[19], 'complementary_info' => $data[20], 'return_context' => $data[21], 'caddie' => $data[22], 'receipt_complement' => $data[23], 'merchant_language' => $data[24], 'language' => $data[25], 'customer_id' => $data[26], 'order_id' => $data[27], 'customer_email' => $data[28], 'customer_ip_address' => $data[29], 'capture_day' => $data[30], 'capture_mode' => $data[31], 'data' => $data[32]);
}