%PDF- %PDF-
Direktori : /www/varak.net/shop.varak.net/modules/paypal/controllers/front/ |
Current File : /www/varak.net/shop.varak.net/modules/paypal/controllers/front/submitplus.php |
<?php /** * 2007-2016 PrestaShop * * NOTICE OF LICENSE * * This source file is subject to the Academic Free License (AFL 3.0) * that is bundled with this package in the file LICENSE.txt. * It is also available through the world-wide-web at this URL: * http://opensource.org/licenses/afl-3.0.php * If you did not receive a copy of the license and are unable to * obtain it through the world-wide-web, please send an email * to license@prestashop.com so we can send you a copy immediately. * * DISCLAIMER * * Do not edit or add to this file if you wish to upgrade PrestaShop to newer * versions in the future. If you wish to customize PrestaShop for your * needs please refer to http://www.prestashop.com for more information. * * @author PrestaShop SA <contact@prestashop.com> * @copyright 2007-2016 PrestaShop SA * @version Release: $Revision: 13573 $ * @license http://opensource.org/licenses/afl-3.0.php Academic Free License (AFL 3.0) * International Registered Trademark & Property of PrestaShop SA */ /** * @since 1.5.0 */ class PayPalSubmitplusModuleFrontController extends ModuleFrontController { public $display_column_left = false; public $display_column_right = false; public $ssl = true; /*public function init(){ $this->page_name = 'Confirm Payment'; }*/ public function __construct() { parent::__construct(); if (class_exists('Context')) { $this->context = Context::getContext(); } else { global $smarty, $cookie; $this->context = new StdClass(); $this->context->smarty = $smarty; $this->context->cookie = $cookie; } } public function initContent() { parent::initContent(); $paypal = new PayPal(); $this->id_module = (int) Tools::getValue('id_module'); $this->id_cart = Tools::getValue('id_cart'); $this->paymentId = Tools::getValue('paymentId'); $this->token = Tools::getValue('token'); if (!empty($this->id_cart) && !empty($this->paymentId) && !empty($this->token)) { $CallApiPaypalPlus = new CallApiPaypalPlus(); $payment = Tools::jsonDecode($CallApiPaypalPlus->lookUpPayment($this->paymentId)); if (isset($payment->state)) { $this->context->smarty->assign('state', $payment->state); $transaction = array( 'id_transaction' => $payment->id, 'payment_status' => $payment->state, 'currency' => $payment->transactions[0]->amount->currency, 'payment_date' => date("Y-m-d H:i:s"), 'total_paid' => $payment->transactions[0]->amount->total, 'id_invoice' => 0, 'shipping' => 0, ); switch ($payment->state) { case 'created': /* LookUp OK */ /* Affichage bouton confirmation */ $this->context->smarty->assign(array( 'PayerID' => $payment->payer->payer_info->payer_id, 'paymentId' => $this->paymentId, 'id_cart' => $this->id_cart, 'totalAmount' => Tools::displayPrice(Cart::getTotalCart($this->id_cart)), 'linkSubmitPlus' => $this->context->link->getModuleLink('paypal', 'submitplus'), )); break; case 'canceled': /* LookUp cancel */ $paypal->validateOrder( $this->id_cart, $this->getOrderStatus('order_canceled'), $payment->transactions[0]->amount->total, $payment->payer->payment_method, null, $transaction ); break; default: /* Erreur de payment */ $paypal->validateOrder( $this->id_cart, $this->getOrderStatus('payment_error'), $payment->transactions[0]->amount->total, $payment->payer->payment_method, null, $transaction ); break; } } else { $this->context->smarty->assign('state', 'failed'); } } else { $this->context->smarty->assign('state', 'failed'); } if (($this->context->customer->is_guest) || $this->context->customer->id == false) { /* If guest we clear the cookie for security reason */ $this->context->customer->mylogout(); } $this->module->assignCartSummary(); if ($this->context->getMobileDevice() == true) { $this->setTemplate('order-confirmation-plus-mobile.tpl'); } else { $this->setTemplate('order-confirmation-plus.tpl'); } } private function displayHook() { if (Validate::isUnsignedId($this->id_order) && Validate::isUnsignedId($this->id_module)) { $order = new Order((int) $this->id_order); $currency = new Currency((int) $order->id_currency); if (Validate::isLoadedObject($order)) { $params = array(); $params['objOrder'] = $order; $params['currencyObj'] = $currency; $params['currency'] = $currency->sign; $params['total_to_pay'] = $order->getOrdersTotalPaid(); return $params; } } return false; } public function displayAjax() { $ajax = Tools::getValue('ajax'); $return = array(); if (!$ajax) { $return['error'][] = $this->module->l('An error occured during the payment'); echo Tools::jsonEncode($return); die(); } $id_cart = Tools::getValue('id_cart'); $payerID = Tools::getValue('payerID'); $paymentId = Tools::getValue('paymentId'); $submit = Tools::getValue('submit'); if ( (!empty($id_cart) && $this->context->cart->id == $id_cart) && !empty($payerID) && !empty($paymentId) && !empty($submit) ) { $CallApiPaypalPlus = new CallApiPaypalPlus(); $payment = Tools::jsonDecode($CallApiPaypalPlus->executePayment($payerID, $paymentId)); if (isset($payment->state)) { $paypal = new PayPal(); $transaction = array( 'id_transaction' => $payment->transactions[0]->related_resources[0]->sale->id, 'payment_status' => $payment->state, 'total_paid' => $payment->transactions[0]->amount->total, 'id_invoice' => 0, 'shipping' => 0, 'currency' => $payment->transactions[0]->amount->currency, 'payment_date' => date("Y-m-d H:i:s"), ); if ($submit == 'confirmPayment') { if ($payment->state == 'approved') { $paypal->validateOrder( $this->id_cart, $this->getOrderStatus('payment'), $payment->transactions[0]->amount->total, $payment->payer->payment_method, null, $transaction ); $return['success'][] = $this->module->l('Your payment has been taken into account'); } else { $paypal->validateOrder( $this->id_cart, $this->getOrderStatus('payment_error'), $payment->transactions[0]->amount->total, $payment->payer->payment_method, null, $transaction ); $return['error'][] = $this->module->l('An error occured during the payment'); } } elseif ($submit == 'confirmCancel') { $paypal->validateOrder( $this->id_cart, $this->getOrderStatus('order_canceled'), $payment->transactions[0]->amount->total, $payment->payer->payment_method, null, $transaction ); $return['success'][] = $this->module->l('Your order has been canceled'); } else { $return['error'][] = $this->module->l('An error occured during the payment'); } } else { $return['error'][] = $this->module->l('An error occured during the payment'); } } else { $return['error'][] = $this->module->l('An error occured during the payment'); } echo Tools::jsonEncode($return); die(); } /** * Execute the hook displayPaymentReturn */ public function displayPaymentReturn() { $params = $this->displayHook(); if ($params && is_array($params)) { return Hook::exec('displayPaymentReturn', $params, (int) $this->id_module); } return false; } /** * Execute the hook displayOrderConfirmation */ public function displayOrderConfirmation() { $params = $this->displayHook(); if ($params && is_array($params)) { return Hook::exec('displayOrderConfirmation', $params); } return false; } public function getOrderStatus($template) { /* * payment * payment_error * order_canceled * refund */ return Db::getInstance()->getValue('SELECT id_order_state FROM '._DB_PREFIX_.'order_state_lang WHERE template = "'.pSQL($template).'" AND id_lang = "'.(int) $this->context->language->id.'"'); } }