public function __invoke($layout, $post, $amount = null) { $token = $this->filterString($post['everypayToken']); $this->setUpClient(); $params = ['token' => $token, 'amount' => $amount]; $response = Payment::create($params); header('Content-type: application/json'); return json_encode($response); }
public function __invoke($layout, $post, $amount = null) { $token = $this->filterString($post['everypayToken']); $this->setUpClient(); $params = array('token' => $token, 'create_customer' => '1', 'amount' => $amount, 'description' => 'Δοκιμαστική πληρωμή'); $response = Payment::create($params); if (isset($response->error)) { return $layout->render('customer/error', array('errorMessage' => $response->error->message)); } return $layout->render('customer/success', array('token' => $response->customer->token)); }
public function __invoke($layout, $post, $amount = null) { $token = $this->filterString($post['everypayToken']); $this->setUpClient(); $params = array('token' => $token, 'amount' => $amount); try { $response = Payment::create($params); } catch (\Exception $e) { return $layout->render('button/error', array('errorMessage' => $e->getMessage())); } if (isset($response->error)) { return $layout->render('button/error', array('errorMessage' => $response->error->message)); } return $layout->render('button/success', array('amount' => $response->amount)); }
public function __invoke($layout, $post, $amount = null) { if (isset($post['error_status'])) { return $layout->getView()->render('tds/error', array('errorMessage' => $post['error_message'])); } $token = $post['token']; $md = isset($post['md']) ? $post['md'] : null; $this->setUpClient(); $params = array('token' => $token, 'amount' => $amount, 'txn_type' => 'no-tds'); try { $response = Payment::create($params); } catch (CurlException $e) { return $layout->getView()->render('tds/error', array('errorMessage' => $e->getMessage())); } if (isset($response->error)) { return $layout->getView()->render('tds/error', array('errorMessage' => $response->error->message)); } return $layout->getView()->render('tds/redirect', array('url' => $this->getHost() . '/tds-secure/success')); # Dont render layout, only view. }
/** * Setup the smarty variables for the confirmation form. Also if the form * is submitted do the desired actions (close token, order etc.) * * @return array (if not redirected) */ public function paymentConfirmation() { global $cart; global $smarty; global $link; $this->_checkBeforeSend(); $token = (int) Tools::getValue('token'); $tokenRow = $this->_canUseToken($token); if (empty($token) || empty($tokenRow) || !$tokenRow) { $this->_redirectToCardForm(); } // check to see if some details on cart have changed in the meanwhile if ($this->_tokenDetailsHaveChanged($tokenRow)) { $updateAmountOnCart = $this->_updateDetailsOfToken($token); if ($updateAmountOnCart) { Tools::redirect(_MODULE_DIR_ . $this->name . '/controllers/front/confirm.php?msg=410&token=' . $token); } else { $this->_redirectToCardForm(); } } $customer = new Customer($cart->id_customer); $currency = new Currency($cart->id_currency); $params = array('amountInteger' => (int) Tools::ps_round($cart->getOrderTotal() * 100), 'amount' => (double) $cart->getOrderTotal(), 'EVERYPAY_FORM_ACTION' => _MODULE_DIR_ . $this->name . '/controllers/front/confirm.php?token=' . $token, 'cart' => $cart, 'customer' => $customer, 'tokenRow' => $tokenRow); //bypass the submit state if (1 || Tools::isSubmit('submitConfirm')) { //Set the API key try { Everypay::setApiKey($this->configuration['EVERYPAY_SECRET_KEY']); } catch (Exception $e) { $params['message'] = $e->getMessage(); $params['status'] = self::ERRORNEOUS; $this->_closeToken($params); Tools::redirect(__PS_BASE_URI__ . 'order.php?step=3'); } $evPayParams = array('token' => $tokenRow['crd_token'], 'currency' => strtoupper($currency->iso_code)); $shopname = Configuration::get('PS_SHOP_NAME'); if (!empty($tokenRow['save_customer']) && $this->configuration['EVERYPAY_CUSTOMER_MODE'] && !empty($tokenRow['crd_token'])) { $evCusParams = array_merge($evPayParams, array('full_name' => $customer->firstname . ' ' . $customer->lastname, 'description' => $shopname . ' - ' . $this->l('Customer') . '#' . $customer->id, 'email' => $customer->email)); try { $evCustomer = EverypayCustomer::create($evCusParams); $evPayParams['token'] = $evCustomer->token; } catch (Exception $e) { $params['message'] = $e->getMessage(); $params['status'] = self::ERRORNEOUS; $this->_closeToken($params); $this->_redirectToCardForm(); } } elseif (!empty($tokenRow['save_customer']) && !$this->configuration['EVERYPAY_CUSTOMER_MODE'] && !empty($tokenRow['crd_token'])) { $params['message'] = $this->l('The save card option got disabled during a payment proccess'); $params['status'] = self::ERRORNEOUS; $this->_closeToken($params); $this->_redirectToCardForm(); } elseif (!is_null($tokenRow['id_customer_token']) && !empty($tokenRow['cus_token']) && $this->configuration['EVERYPAY_CUSTOMER_MODE']) { $evPayParams['token'] = $tokenRow['cus_token']; } elseif (!is_null($tokenRow['id_customer_token']) && !empty($tokenRow['cus_token']) && !$this->configuration['EVERYPAY_CUSTOMER_MODE']) { $params['message'] = $this->l('The save card option got disabled during a payment proccess'); $params['status'] = self::ERRORNEOUS; $this->_closeToken($params); $this->_redirectToCardForm(); } try { $evPayParams = array_merge($evPayParams, array('payee_email' => $customer->email, 'amount' => $params['amountInteger'], 'description' => $shopname . ' - ' . $this->l('Cart') . '#' . $cart->id . ' - ' . Tools::displayPrice($cart->getOrderTotal()))); //var_dump($evPayParams); $evPayment = EverypayPayment::create($evPayParams); //error with the payment if (isset($evPayment->error)) { $params['message'] = $evPayment->error->message; $params['status'] = self::ERRORNEOUS; $this->_closeToken($params); $this->_redirectToCardForm(415); } } catch (Exception $e) { $params['message'] = $e->getMessage(); $params['status'] = self::ERRORNEOUS; $this->_closeToken($params); $this->_redirectToCardForm(415); } $mailVars = array(); $validateOrder = $this->validateOrder($params['cart']->id, Configuration::get('PS_OS_PAYMENT'), $params['amount'], $this->displayName, NULL, $mailVars, $params['cart']->id_currency, false, $params['customer']->secure_key); if ($validateOrder) { $params['id_order'] = $this->currentOrder; $params['status'] = self::SUCCESS; $params['pmt_token'] = $evPayment->token; $params['message'] = 'Success on ' . date('d/m/Y H:i:s'); if (!is_null($tokenRow['save_customer']) && $this->configuration['EVERYPAY_CUSTOMER_MODE']) { $id_customer_token = $this->_insertCardCustomer($evCustomer); if ($id_customer_token) { $params['id_customer_token'] = $id_customer_token; } } $_closeToken = $this->_closeToken($params); $redirect = array('id_cart=' . (int) $params['cart']->id, 'id_module=' . (int) $this->id, 'id_order=' . (int) $this->currentOrder, 'key=' . $params['customer']->secure_key); Tools::redirect(__PS_BASE_URI__ . 'order-confirmation.php?' . implode('&', $redirect)); } else { $this->_redirectToCardForm(); } } $smarty->assign($params); return $this->_fetchTemplate('views/templates/front/confirm.tpl'); }