aboutsummaryrefslogtreecommitdiffstats
path: root/public/catalog/controller/extension/payment/firstdata_remote.php
diff options
context:
space:
mode:
Diffstat (limited to 'public/catalog/controller/extension/payment/firstdata_remote.php')
-rw-r--r--public/catalog/controller/extension/payment/firstdata_remote.php138
1 files changed, 138 insertions, 0 deletions
diff --git a/public/catalog/controller/extension/payment/firstdata_remote.php b/public/catalog/controller/extension/payment/firstdata_remote.php
new file mode 100644
index 0000000..1ad6352
--- /dev/null
+++ b/public/catalog/controller/extension/payment/firstdata_remote.php
@@ -0,0 +1,138 @@
+<?php
+class ControllerExtensionPaymentFirstdataRemote extends Controller {
+ public function index() {
+ $this->load->language('extension/payment/firstdata_remote');
+ $this->load->model('extension/payment/firstdata_remote');
+
+ if ($this->config->get('firstdata_remote_card_storage') == 1 && $this->customer->isLogged()) {
+ $data['card_storage'] = 1;
+ $data['stored_cards'] = $this->model_extension_payment_firstdata_remote->getStoredCards();
+ } else {
+ $data['card_storage'] = 0;
+ $data['stored_cards'] = array();
+ }
+
+ $data['accepted_cards'] = $this->config->get('firstdata_remote_cards_accepted');
+
+ $data['months'] = array();
+
+ for ($i = 1; $i <= 12; $i++) {
+ $data['months'][] = array(
+ 'text' => strftime('%B', mktime(0, 0, 0, $i, 1, 2000)),
+ 'value' => sprintf('%02d', $i)
+ );
+ }
+
+ $today = getdate();
+
+ $data['year_expire'] = array();
+
+ for ($i = $today['year']; $i < $today['year'] + 11; $i++) {
+ $data['year_expire'][] = array(
+ 'text' => strftime('%Y', mktime(0, 0, 0, 1, 1, $i)),
+ 'value' => strftime('%y', mktime(0, 0, 0, 1, 1, $i))
+ );
+ }
+
+ return $this->load->view('extension/payment/firstdata_remote', $data);
+ }
+
+ public function send() {
+ $this->load->model('checkout/order');
+ $this->load->model('extension/payment/firstdata_remote');
+ $this->load->language('extension/payment/firstdata_remote');
+
+ $address_codes = array(
+ 'PPX' => $this->language->get('text_address_ppx'),
+ 'YYY' => $this->language->get('text_address_yyy'),
+ 'YNA' => $this->language->get('text_address_yna'),
+ 'NYZ' => $this->language->get('text_address_nyz'),
+ 'NNN' => $this->language->get('text_address_nnn'),
+ 'YPX' => $this->language->get('text_address_ypx'),
+ 'PYX' => $this->language->get('text_address_pyx'),
+ 'XXU' => $this->language->get('text_address_xxu')
+ );
+
+ $cvv_codes = array(
+ 'M' => $this->language->get('text_card_code_m'),
+ 'N' => $this->language->get('text_card_code_n'),
+ 'P' => $this->language->get('text_card_code_p'),
+ 'S' => $this->language->get('text_card_code_s'),
+ 'U' => $this->language->get('text_card_code_u'),
+ 'X' => $this->language->get('text_card_code_x'),
+ 'NONE' => $this->language->get('text_card_code_blank')
+ );
+
+ if (!isset($this->request->post['cc_choice']) || (isset($this->request->post['cc_choice']) && $this->request->post['cc_choice'] == 'new')) {
+ if ($this->request->post['cc_number'] == '') {
+ $json['error'] = $this->language->get('error_card_number');
+ }
+
+ if ($this->request->post['cc_name'] == '') {
+ $json['error'] = $this->language->get('error_card_name');
+ }
+ }
+
+ if (strlen($this->request->post['cc_cvv2']) != 3 && strlen($this->request->post['cc_cvv2']) != 4) {
+ $json['error'] = $this->language->get('error_card_cvv');
+ }
+
+ if (empty($json['error'])) {
+ $order_id = $this->session->data['order_id'];
+ $order_info = $this->model_checkout_order->getOrder($order_id);
+
+ $capture_result = $this->model_extension_payment_firstdata_remote->capturePayment($this->request->post, $order_id);
+
+ $message = '';
+
+ if (isset($capture_result['transaction_result']) && strtoupper($capture_result['transaction_result']) == 'APPROVED') {
+ $json['success'] = $this->url->link('checkout/success');
+
+ $message .= $this->language->get('text_result') . $capture_result['transaction_result'] . '<br />';
+ $message .= $this->language->get('text_avs') . $address_codes[$capture_result['avs']] . ' (' . $capture_result['avs'] . ')<br />';
+
+ if (!empty($capture_result['ccv'])) {
+ $message .= $this->language->get('text_card_code_verify') . $cvv_codes[$capture_result['ccv']] . ' (' . $capture_result['ccv'] . ')<br />';
+ }
+
+ $message .= $this->language->get('text_approval_code') . $capture_result['approval_code'] . '<br />';
+ $message .= $this->language->get('text_reference_number') . $capture_result['reference_number'] . '<br />';
+ $message .= $this->language->get('text_card_brand') . $capture_result['brand'] . '<br />';
+ $message .= $this->language->get('text_card_number_ref') . $capture_result['card_number_ref'] . '<br />';
+ $message .= $this->language->get('text_response_code') . $capture_result['response_code'] . '<br />';
+
+ $fd_order_id = $this->model_extension_payment_firstdata_remote->addOrder($order_info, $capture_result);
+
+ if ($this->config->get('firstdata_remote_auto_settle') == 1) {
+ $this->model_extension_payment_firstdata_remote->addTransaction($fd_order_id, 'payment', $order_info);
+
+ $this->model_checkout_order->addOrderHistory($order_id, $this->config->get('firstdata_remote_order_status_success_settled_id'), $message, false);
+ } else {
+ $this->model_extension_payment_firstdata_remote->addTransaction($fd_order_id, 'auth');
+
+ $this->model_checkout_order->addOrderHistory($order_id, $this->config->get('firstdata_remote_order_status_success_unsettled_id'), $message, false);
+ }
+ } else {
+ if (isset($capture_result['error']) && !empty($capture_result['error'])) {
+ $json['error'] = $capture_result['error'];
+ } else {
+ $json['error'] = $this->language->get('error_failed');
+ }
+
+ if (isset($capture_result['fault']) && !empty($capture_result['fault'])) {
+ $message .= $this->language->get('text_fault') . $capture_result['fault'] . '<br />';
+ }
+
+ $message .= $this->language->get('text_result') . $capture_result['transaction_result'] . '<br />';
+ $message .= $this->language->get('text_error') . $capture_result['error'] . '<br />';
+ $message .= $this->language->get('text_card_brand') . $capture_result['brand'] . '<br />';
+ $message .= $this->language->get('text_card_number_ref') . $capture_result['card_number_ref'] . '<br />';
+
+ $this->model_extension_payment_firstdata_remote->addHistory($order_id, $this->config->get('firstdata_remote_order_status_decline_id'), $message);
+ }
+ }
+
+ $this->response->addHeader('Content-Type: application/json');
+ $this->response->setOutput(json_encode($json));
+ }
+} \ No newline at end of file