* @copyright 2007-2019 PrestaShop SA * @license http://opensource.org/licenses/afl-3.0.php Academic Free License (AFL 3.0) * International Registered Trademark & Property of PrestaShop SA */ include_once _PS_MODULE_DIR_.'paypal/classes/AbstractMethodPaypal.php'; /** * Validate PPP payment */ class PaypalPppValidationModuleFrontController extends ModuleFrontController { public function postProcess() { $method_ppp = AbstractMethodPaypal::load('PPP'); $paypal = Module::getInstanceByName('paypal'); try { $method_ppp->validation(); } catch (PayPal\Exception\PayPalConnectionException $e) { $decoded_message = Tools::jsonDecode($e->getData()); Tools::redirect(Context::getContext()->link->getModuleLink( 'paypal', 'error', array( 'error_code' => $e->getCode(), 'error_msg' => $decoded_message->message, 'msg_long' => $decoded_message->name.' - '.$decoded_message->details[0]->issue ) )); } catch (PayPal\Exception\PayPalInvalidCredentialException $e) { $ex_detailed_message = $e->errorMessage(); Tools::redirect(Context::getContext()->link->getModuleLink('paypal', 'error', array('error_msg' => $ex_detailed_message))); } catch (PayPal\Exception\PayPalMissingCredentialException $e) { $ex_detailed_message = $paypal->l('Invalid configuration. Please check your configuration file'); Tools::redirect(Context::getContext()->link->getModuleLink('paypal', 'error', array('error_msg' => $ex_detailed_message))); } catch (Exception $e) { Tools::redirect(Context::getContext()->link->getModuleLink('paypal', 'error', array('error_code' => $e->getCode(), 'error_msg' => $e->getMessage()))); } Context::getContext()->cookie->__unset('paypal_plus_payment'); $cart = Context::getContext()->cart; $customer = new Customer($cart->id_customer); Context::getContext()->cookie->__unset('paypal_pSc'); Context::getContext()->cookie->__unset('paypal_pSc_payerid'); Context::getContext()->cookie->__unset('paypal_pSc_email'); Tools::redirect('index.php?controller=order-confirmation&id_cart='.$cart->id.'&id_module='.$paypal->id.'&id_order='.$paypal->currentOrder.'&key='.$customer->secure_key); } }