PageRenderTime 57ms CodeModel.GetById 21ms RepoModel.GetById 0ms app.codeStats 0ms

/catalog/controller/payment/bluepay_redirect.php

https://gitlab.com/hazelnuts23/unitedfoodstuff
PHP | 147 lines | 114 code | 33 blank | 0 comment | 18 complexity | c0ccb4e5b5400de05fd223a90a9a4e24 MD5 | raw file
  1. <?php
  2. class ControllerPaymentBluePayRedirect extends Controller {
  3. public function index() {
  4. $this->load->language('payment/bluepay_redirect');
  5. $data['text_credit_card'] = $this->language->get('text_credit_card');
  6. $data['text_loading'] = $this->language->get('text_loading');
  7. $data['text_card_type'] = $this->language->get('text_card_type');
  8. $data['text_card_name'] = $this->language->get('text_card_name');
  9. $data['text_card_digits'] = $this->language->get('text_card_digits');
  10. $data['text_card_expiry'] = $this->language->get('text_card_expiry');
  11. $data['entry_card'] = $this->language->get('entry_card');
  12. $data['entry_card_existing'] = $this->language->get('entry_card_existing');
  13. $data['entry_card_new'] = $this->language->get('entry_card_new');
  14. $data['entry_card_save'] = $this->language->get('entry_card_save');
  15. $data['entry_cc_owner'] = $this->language->get('entry_cc_owner');
  16. $data['entry_cc_number'] = $this->language->get('entry_cc_number');
  17. $data['entry_cc_expire_date'] = $this->language->get('entry_cc_expire_date');
  18. $data['entry_cc_cvv2'] = $this->language->get('entry_cc_cvv2');
  19. $data['entry_cc_address'] = $this->language->get('entry_cc_address');
  20. $data['entry_cc_city'] = $this->language->get('entry_cc_city');
  21. $data['entry_cc_state'] = $this->language->get('entry_cc_state');
  22. $data['entry_cc_zipcode'] = $this->language->get('entry_cc_zipcode');
  23. $data['entry_cc_phone'] = $this->language->get('entry_cc_phone');
  24. $data['entry_cc_email'] = $this->language->get('entry_cc_email');
  25. $data['entry_cc_choice'] = $this->language->get('entry_cc_choice');
  26. $data['button_confirm'] = $this->language->get('button_confirm');
  27. $data['months'] = array();
  28. for ($i = 1; $i <= 12; $i++) {
  29. $data['months'][] = array(
  30. 'text' => strftime('%B', mktime(0, 0, 0, $i, 1, 2000)),
  31. 'value' => sprintf('%02d', $i)
  32. );
  33. }
  34. $today = getdate();
  35. $data['year_expire'] = array();
  36. for ($i = $today['year']; $i < $today['year'] + 11; $i++) {
  37. $data['year_expire'][] = array(
  38. 'text' => strftime('%Y', mktime(0, 0, 0, 1, 1, $i)),
  39. 'value' => strftime('%Y', mktime(0, 0, 0, 1, 1, $i))
  40. );
  41. }
  42. if ($this->config->get('bluepay_redirect_card') == '1') {
  43. $data['bluepay_redirect_card'] = true;
  44. } else {
  45. $data['bluepay_redirect_card'] = false;
  46. }
  47. $data['existing_cards'] = array();
  48. if ($this->customer->isLogged() && $data['bluepay_redirect_card']) {
  49. $this->load->model('payment/bluepay_redirect');
  50. $cards = $this->model_payment_bluepay_redirect->getCards($this->customer->getId());
  51. $data['existing_cards'] = $cards;
  52. }
  53. if (file_exists(DIR_TEMPLATE . $this->config->get('config_template') . '/template/payment/bluepay_redirect.tpl')) {
  54. return $this->load->view($this->config->get('config_template') . '/template/payment/bluepay_redirect.tpl', $data);
  55. } else {
  56. return $this->load->view('default/template/payment/bluepay_redirect.tpl', $data);
  57. }
  58. }
  59. public function send() {
  60. $this->load->language('payment/bluepay_redirect');
  61. $this->load->model('checkout/order');
  62. $this->load->model('payment/bluepay_redirect');
  63. $order_info = $this->model_checkout_order->getOrder($this->session->data['order_id']);
  64. $post_data = $this->request->post;
  65. $post_data['MERCHANT'] = $this->config->get('bluepay_redirect_account_id');
  66. $post_data["TRANSACTION_TYPE"] = $this->config->get('bluepay_redirect_transaction');
  67. $post_data["MODE"] = strtoupper($this->config->get('bluepay_redirect_test'));
  68. $post_data["AMOUNT"] = $this->currency->format($order_info['total'], $order_info['currency_code'], false, false);
  69. if (isset($this->request->post['RRNO'])) {
  70. $post_data["RRNO"] = $this->request->post['RRNO'];
  71. } else {
  72. $post_data["RRNO"] = '';
  73. }
  74. $post_data["NAME"] = substr($order_info['payment_firstname'], 0, 20) . ' ' . substr($order_info['payment_lastname'], 0, 20);
  75. $post_data["ADDR1"] = $post_data['BillingAddress1'] = substr($order_info['payment_address_1'], 0, 100);
  76. $post_data["CITY"] = $order_info['payment_city'];
  77. $post_data['STATE'] = $order_info['payment_zone_code'];
  78. $post_data["PHONE"] = substr($order_info['telephone'], 0, 20);
  79. $post_data["EMAIL"] = substr($order_info['email'], 0, 255);
  80. $post_data["ORDER_ID"] = $this->session->data['order_id'];
  81. $post_data['ZIPCODE'] = substr($order_info['payment_postcode'], 0, 10);
  82. $post_data['APPROVED_URL'] = $this->url->link('payment/bluepay_redirect/callback', '', 'SSL');
  83. $post_data['DECLINED_URL'] = $this->url->link('payment/bluepay_redirect/callback', '', 'SSL');
  84. $post_data['MISSING_URL'] = $this->url->link('payment/bluepay_redirect/callback', '', 'SSL');
  85. if (isset($this->request->server["REMOTE_ADDR"])) {
  86. $post_data["REMOTE_IP"] = $this->request->server["REMOTE_ADDR"];
  87. }
  88. $tamper_proof_data = $this->config->get('bluepay_redirect_secret_key') . $post_data['MERCHANT'] . $post_data["TRANSACTION_TYPE"] . $post_data['AMOUNT'] . $post_data["RRNO"] . $post_data["MODE"];
  89. $post_data["TAMPER_PROOF_SEAL"] = md5($tamper_proof_data);
  90. $response_data = $this->model_payment_bluepay_redirect->sendCurl("https://secure.bluepay.com/interfaces/bp10emu", $post_data);
  91. if ($response_data['Result'] == 'APPROVED') {
  92. $bluepay_redirect_order_id = $this->model_payment_bluepay_redirect->addOrder($order_info, $response_data);
  93. $this->model_payment_bluepay_redirect->addTransaction($bluepay_redirect_order_id, $this->config->get('bluepay_redirect_transaction'), $order_info);
  94. $this->model_checkout_order->addOrderHistory($this->session->data['order_id'], $this->config->get('bluepay_redirect_order_status_id'));
  95. $json['redirect'] = $this->url->link('checkout/success', '', 'SSL');
  96. } else {
  97. $json['error'] = $response_data['Result'] . ' : ' . $response_data['MESSAGE'];
  98. }
  99. if (isset($post_data['CreateToken']) && $response_data['Result'] == 'APPROVED') {
  100. $card_data['customer_id'] = $this->customer->getId();
  101. $card_data['Last4Digits'] = substr(str_replace(' ', '', $post_data['CC_NUM']), -4, 4);
  102. $card_data['ExpiryDate'] = $post_data['CC_EXPIRES_MONTH'] . '/' . substr($post_data['CC_EXPIRES_YEAR'], 2);
  103. $card_data['CardType'] = $response_data['CARD_TYPE'];
  104. $card_data['Token'] = $response_data['RRNO'];
  105. $this->model_payment_bluepay_redirect->addCard($card_data);
  106. }
  107. $this->response->addHeader('Content-Type: application/json');
  108. $this->response->setOutput(json_encode($json));
  109. }
  110. public function callback() {
  111. $this->response->addHeader('Content-Type: application/json');
  112. $this->response->setOutput(json_encode($this->request->get));
  113. }
  114. }