preProcess(); if (!$cookie->isLogged()) Tools::redirect('authentication.php'); // verif if there's at least one order with this delivery address $orders_with_delivery_address = Db::getInstance()->getValue(' SELECT COUNT(`id_order`) FROM `'._DB_PREFIX_.'orders` WHERE `id_address_delivery` = '.(int)$cart->id_address_delivery.' AND `id_customer` = '.(int)$cart->id_customer.' '); if ($orders_with_delivery_address == 0) { Tools::redirect('order.php?step=3&cgv=1&paybox_error=1'); } $id_paybox_card = Tools::getValue('id_paybox_card', false); if ($id_paybox_card) { $paybox_card = Db::getInstance()->getRow(' SELECT * FROM `ps_paybox_customer_agreement` WHERE `id_customer` = '.(int)$cart->id_customer.' AND `id_paybox_card` = '.(int)$id_paybox_card.' '); if(empty($paybox_card) || (int)$paybox_card['id_customer']!=(int)$cart->id_customer) { Tools::redirect('order.php?step=3&cgv=1&paybox_error=1'); } } else { Tools::redirect('order.php?step=3&cgv=1&paybox_error=1'); } include(dirname(__FILE__).'/../../header.php'); if(Configuration::get('PBX_DEMO_MODE') == 0) { $curl = curl_init('https://preprod-ppps.paybox.com/PPPS.php'); } else { //$curl = curl_init('https://ppps.paybox.com/PPPS.php'); } curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); curl_setopt($curl, CURLOPT_COOKIESESSION, true); $pbx_site = trim(Configuration::get('PBX_SITE')); $pbx_rang = trim(Configuration::get('PBX_RANG')); $pbx_id = trim(Configuration::get('PBX_ID')); $num_question = Configuration::get('NUM_QUESTION_PAYBOX') + 1; Configuration::updateValue('NUM_QUESTION_PAYBOX', $num_question); $montant = "".(Tools::convertPrice($cart->getOrderTotal(), null, false) * 100).""; $devise = 978; $numbers = urldecode($paybox_card['handle']); $dateval = $paybox_card['date']; $customer = new Customer((int)$cart->id_customer); $refabonne = $customer->email; $language = new Language((int)$cart->id_lang); switch ($language->iso_code) { case 'fr': $country = 'FRA'; break; case 'es': $country = 'ESP'; break; case 'de': $country = 'DEU'; break; case 'it': $country = 'ITA'; break; case 'nl': $country = 'NLD'; break; case 'sv': $country = 'SWE'; break; case 'en-us': default: $country = 'GBR'; break; } unset($language); $postfields = array( 'VERSION' => '00104', 'TYPE' => '00053', 'SITE' => $pbx_site, 'RANG' => $pbx_rang, 'CLE' => 'EFNLJKFB', 'NUMQUESTION' => $num_question, 'MONTANT' => str_pad($montant, 10, '0', STR_PAD_LEFT), 'DEVISE' => $devise, 'REFERENCE' => (int)$cart->id, 'REFABONNE' => $refabonne, 'PORTEUR' => $numbers, 'DATEVAL' => $dateval, 'ACTIVITE' => '027', 'PAYS' => $country, /*'CVV' => Configuration::get('PBX_DEMO_MODE') == 0 ?'000':$cvv,*/ 'DATEQ' => date('dmYHis') ); $trame = http_build_query($postfields, '', '&'); mail('marion@antadis.com', '[BBB] Envoi trame paiement direct', $trame); curl_setopt($curl, CURLOPT_POST, true); curl_setopt($curl, CURLOPT_HTTPHEADER, array('Content-Type: application/x-www-form-urlencoded')); curl_setopt($curl, CURLOPT_POSTFIELDS, $trame); $response = curl_exec($curl); curl_close($curl); $data = explode('&', $response); $num_trans = explode('NUMTRANS=', $data[0]); $num_appel = explode('NUMAPPEL=', $data[1]); $autorisation = explode('AUTORISATION=', $data[5]); $code_reponse = explode('CODEREPONSE=', $data[6]); $commentaire = explode('COMMENTAIRE=', $data[7]); mail('marion@antadis.com', '[BBB] Paiement direct reponse globale', $response); $error = ''; $paybox = new Paybox(); $test_mode = (int)Configuration::get('PBX_DEMO_MODE'); $values = array( 'm' => (int) $montant, 'r' => (int) $cart->id, 't' => (int) $num_appel[1], 'p' => $autorisation[1], 'c' => $paybox_card['payment_type'], 'a' => 'CARTE', 's' => (int) $num_trans[1], 'e' => $code_reponse[1], 'd' => $paybox_card['date'], ); // payment success if ((!isset($autorisation[1]) || empty($autorisation[1]))) { Logger::addLog('No autorisation number', 4); die('No autorisation number'); } // Wrong authorization number in live mode if ($autorisation[1] == 'XXXXXX' && $test_mode === 1) { $error .= '- error payment - wrong authorization number
'."\n"; } if ($id_order = (int)Order::getOrderByCartId($cart->id)) { $paybox->saveInformationPaiement($values); if (empty($error)) { $order = new Order($id_order); $order->valid = 1; $order->total_paid_real = $values['m'] / 100; $order->update(); if ($order->getCurrentState() != _PS_OS_PAYMENT_) { $products = $cart->getProducts(); foreach ($products as $product) { Product::updateQuantity($product); Hook::updateQuantity($product, $order); } } $history = new OrderHistory(); $history->id_order = $id_order; $history->changeIdOrderState((int)_PS_OS_PAYMENT_, $id_order); $history->addWithemail(true, array()); $order_message = ''; foreach ($values as $key => $value) { $order_message .= $key.': '.$value.'
'; } if (isset($order_message) && !empty($order_message)) { $msg = new Message(); $message = $order_message; if (Validate::isCleanHtml($order_message)) { $msg->message = $order_message; $msg->id_order = (int)$order->id; $msg->private = 1; $msg->add(); } } } die($error); } $total_paid = $values['m'] / 100; if ($test_mode === 0) { if (empty($error) && $code_reponse[1] == '00000') { $error = '***TEST*** : Validated Payment
'."\n"; $statut = _PS_OS_PAYMENT_; } else { $error = '***TEST*** : Invalid Payment
'."\n".$error; $statut = _PS_OS_ERROR_; } } elseif ($test_mode === 1) { if ($code_reponse[1] == '00000' && empty($error)){ $statut = _PS_OS_PAYMENT_; } else { $statut = _PS_OS_ERROR_; } } switch ($code_reponse[1]) { case '00001': $error .= 'Connection to the authorization center failed or an internal error occurred
'."\n"; break; case '00003': $error .= 'Paybox error
'."\n"; break; case '00004': $error .= 'Card number invalid or visual cryptogram invalid
'."\n"; break; case '00006': $error .= 'Access refused or site/rank/identifier incorrect
'."\n"; break; case '00008': $error .= 'Incorrect expiry date.
'."\n"; break; case '00009': $error .= 'Error when during subscriber creation
'."\n"; break; case '00010': $error .= 'Unknown currency
'."\n"; break; case '00011': $error .= 'Amount incorrect
'."\n"; break; case '00015': $error .= 'Payment already done
'."\n"; break; case '00016': $error .= 'Subscriber already exists
'."\n"; break; case '00021': $error .= 'Not authorized bin card
'."\n"; break; case '00029': $error .= 'Not the same card used for the first payment.
'."\n"; break; case '00030': $error .= 'Time-out > 15 mn before validation by the buyer when the buyer is on the page of payments of PAYBOX
'."\n"; break; case '00031': case '00032': $error .= 'Reserved
'."\n"; break; case '00033': $error .= 'Unauthorized country code of the IP address of the cardholder’s browser
'."\n"; break; case '00040': $error .= 'Operation without 3DSecure authentication, blocked by the fraud filter.
'."\n"; break; case '99999': $error .= 'Payment waiting confirmation from the issuer
'."\n"; break; case '00000': default: $error .= 'Successful operation
'."\n\n"; break; } $error .= 'PayBox version: '.$paybox->version."\n".'
POST '.print_r($postfields, true)."\n".'
GET '.print_r($data, true)."\n"; $paybox->validateOrder((int)$cart->id, $statut, $total_paid, $paybox->displayName, $error, array(), NULL, false, $customer->secure_key); // save info paiement BDD $paybox->saveInformationPaiement($values); if (version_compare(_PS_VERSION_, '1.5.0.0') >= '0') { $order_id = Order::getOrderByCartId((int)$cart->id); $order = new Order((int)$order_id); if ($order_state == _PS_OS_PAYMENT_) { $order->valid = 1; $order->save(); } $id_order_payment = Db::getInstance()->getValue('SELECT id_order_payment FROM `'._DB_PREFIX_.'order_payment` WHERE `order_reference` LIKE \'%'.pSQL($order->reference).'%\''); if ($id_order_payment == false) $order->addOrderPayment($total_paid, null, trim($values['t'])); else { $order_payment = new OrderPayment((int)$id_order_payment); $order_payment->transaction_id = trim($values['t']); $order_payment->save(); } } Tools::redirect('order-confirmation.php?id_cart='.$cart->id.'&id_module='.$paybox->id.'&key='.$customer->secure_key); include(dirname(__FILE__).'/../../footer.php');