aboutsummaryrefslogtreecommitdiffstats
path: root/public/admin/controller/extension/payment/firstdata.php
diff options
context:
space:
mode:
authorJesús <heckyel@hyperbola.info>2019-08-18 21:14:58 -0500
committerJesús <heckyel@hyperbola.info>2019-08-18 21:14:58 -0500
commit2eed7b082f83630301e51f57ca8394de228a8605 (patch)
tree1d19962d22d30f99317d9276e4bae7744fc93fc2 /public/admin/controller/extension/payment/firstdata.php
downloadlibrecart-2eed7b082f83630301e51f57ca8394de228a8605.tar.lz
librecart-2eed7b082f83630301e51f57ca8394de228a8605.tar.xz
librecart-2eed7b082f83630301e51f57ca8394de228a8605.zip
first commit
Diffstat (limited to 'public/admin/controller/extension/payment/firstdata.php')
-rw-r--r--public/admin/controller/extension/payment/firstdata.php352
1 files changed, 352 insertions, 0 deletions
diff --git a/public/admin/controller/extension/payment/firstdata.php b/public/admin/controller/extension/payment/firstdata.php
new file mode 100644
index 0000000..66f33f7
--- /dev/null
+++ b/public/admin/controller/extension/payment/firstdata.php
@@ -0,0 +1,352 @@
+<?php
+class ControllerExtensionPaymentFirstdata extends Controller {
+ private $error = array();
+
+ public function index() {
+ $this->load->language('extension/payment/firstdata');
+
+ $this->document->setTitle($this->language->get('heading_title'));
+
+ $this->load->model('setting/setting');
+
+ if (($this->request->server['REQUEST_METHOD'] == 'POST') && $this->validate()) {
+ $this->model_setting_setting->editSetting('payment_firstdata', $this->request->post);
+
+ $this->session->data['success'] = $this->language->get('text_success');
+
+ $this->response->redirect($this->url->link('marketplace/extension', 'user_token=' . $this->session->data['user_token'] . '&type=payment', true));
+ }
+
+ $data['notify_url'] = HTTPS_CATALOG . 'index.php?route=extension/payment/firstdata/notify';
+
+ $this->load->model('localisation/order_status');
+
+ $data['order_statuses'] = $this->model_localisation_order_status->getOrderStatuses();
+
+ $this->load->model('localisation/geo_zone');
+
+ $data['geo_zones'] = $this->model_localisation_geo_zone->getGeoZones();
+
+ if (isset($this->error['warning'])) {
+ $data['error_warning'] = $this->error['warning'];
+ } else {
+ $data['error_warning'] = '';
+ }
+
+ if (isset($this->error['error_merchant_id'])) {
+ $data['error_merchant_id'] = $this->error['error_merchant_id'];
+ } else {
+ $data['error_merchant_id'] = '';
+ }
+
+ if (isset($this->error['error_secret'])) {
+ $data['error_secret'] = $this->error['error_secret'];
+ } else {
+ $data['error_secret'] = '';
+ }
+
+ if (isset($this->error['error_live_url'])) {
+ $data['error_live_url'] = $this->error['error_live_url'];
+ } else {
+ $data['error_live_url'] = '';
+ }
+
+ if (isset($this->error['error_demo_url'])) {
+ $data['error_demo_url'] = $this->error['error_demo_url'];
+ } else {
+ $data['error_demo_url'] = '';
+ }
+
+ $data['breadcrumbs'] = array();
+
+ $data['breadcrumbs'][] = array(
+ 'text' => $this->language->get('text_home'),
+ 'href' => $this->url->link('common/dashboard', 'user_token=' . $this->session->data['user_token'], true)
+ );
+
+ $data['breadcrumbs'][] = array(
+ 'text' => $this->language->get('text_extension'),
+ 'href' => $this->url->link('marketplace/extension', 'user_token=' . $this->session->data['user_token'] . '&type=payment', true)
+ );
+
+ $data['breadcrumbs'][] = array(
+ 'text' => $this->language->get('heading_title'),
+ 'href' => $this->url->link('extension/payment/firstdata', 'user_token=' . $this->session->data['user_token'], true)
+ );
+
+ $data['action'] = $this->url->link('extension/payment/firstdata', 'user_token=' . $this->session->data['user_token'], true);
+
+ $data['cancel'] = $this->url->link('marketplace/extension', 'user_token=' . $this->session->data['user_token'] . '&type=payment', true);
+
+ if (isset($this->request->post['payment_firstdata_merchant_id'])) {
+ $data['payment_firstdata_merchant_id'] = $this->request->post['payment_firstdata_merchant_id'];
+ } else {
+ $data['payment_firstdata_merchant_id'] = $this->config->get('payment_firstdata_merchant_id');
+ }
+
+ if (isset($this->request->post['payment_firstdata_secret'])) {
+ $data['payment_firstdata_secret'] = $this->request->post['payment_firstdata_secret'];
+ } else {
+ $data['payment_firstdata_secret'] = $this->config->get('payment_firstdata_secret');
+ }
+
+ if (isset($this->request->post['payment_firstdata_live_demo'])) {
+ $data['payment_firstdata_live_demo'] = $this->request->post['payment_firstdata_live_demo'];
+ } else {
+ $data['payment_firstdata_live_demo'] = $this->config->get('payment_firstdata_live_demo');
+ }
+
+ if (isset($this->request->post['payment_firstdata_geo_zone_id'])) {
+ $data['payment_firstdata_geo_zone_id'] = $this->request->post['payment_firstdata_geo_zone_id'];
+ } else {
+ $data['payment_firstdata_geo_zone_id'] = $this->config->get('payment_firstdata_geo_zone_id');
+ }
+
+ if (isset($this->request->post['payment_firstdata_total'])) {
+ $data['payment_firstdata_total'] = $this->request->post['payment_firstdata_total'];
+ } else {
+ $data['payment_firstdata_total'] = $this->config->get('payment_firstdata_total');
+ }
+
+ if (isset($this->request->post['payment_firstdata_sort_order'])) {
+ $data['payment_firstdata_sort_order'] = $this->request->post['payment_firstdata_sort_order'];
+ } else {
+ $data['payment_firstdata_sort_order'] = $this->config->get('payment_firstdata_sort_order');
+ }
+
+ if (isset($this->request->post['payment_firstdata_status'])) {
+ $data['payment_firstdata_status'] = $this->request->post['payment_firstdata_status'];
+ } else {
+ $data['payment_firstdata_status'] = $this->config->get('payment_firstdata_status');
+ }
+
+ if (isset($this->request->post['payment_firstdata_debug'])) {
+ $data['payment_firstdata_debug'] = $this->request->post['payment_firstdata_debug'];
+ } else {
+ $data['payment_firstdata_debug'] = $this->config->get('payment_firstdata_debug');
+ }
+
+ if (isset($this->request->post['payment_firstdata_auto_settle'])) {
+ $data['payment_firstdata_auto_settle'] = $this->request->post['payment_firstdata_auto_settle'];
+ } elseif (!isset($this->request->post['payment_firstdata_auto_settle']) && $this->config->get('payment_firstdata_auto_settle') != '') {
+ $data['payment_firstdata_auto_settle'] = $this->config->get('payment_firstdata_auto_settle');
+ } else {
+ $data['payment_firstdata_auto_settle'] = 1;
+ }
+
+ if (isset($this->request->post['payment_firstdata_order_status_success_settled_id'])) {
+ $data['payment_firstdata_order_status_success_settled_id'] = $this->request->post['payment_firstdata_order_status_success_settled_id'];
+ } else {
+ $data['payment_firstdata_order_status_success_settled_id'] = $this->config->get('payment_firstdata_order_status_success_settled_id');
+ }
+
+ if (isset($this->request->post['payment_firstdata_order_status_success_unsettled_id'])) {
+ $data['payment_firstdata_order_status_success_unsettled_id'] = $this->request->post['payment_firstdata_order_status_success_unsettled_id'];
+ } else {
+ $data['payment_firstdata_order_status_success_unsettled_id'] = $this->config->get('payment_firstdata_order_status_success_unsettled_id');
+ }
+
+ if (isset($this->request->post['payment_firstdata_order_status_decline_id'])) {
+ $data['payment_firstdata_order_status_decline_id'] = $this->request->post['payment_firstdata_order_status_decline_id'];
+ } else {
+ $data['payment_firstdata_order_status_decline_id'] = $this->config->get('payment_firstdata_order_status_decline_id');
+ }
+
+ if (isset($this->request->post['payment_firstdata_order_status_void_id'])) {
+ $data['payment_firstdata_order_status_void_id'] = $this->request->post['payment_firstdata_order_status_void_id'];
+ } else {
+ $data['payment_firstdata_order_status_void_id'] = $this->config->get('payment_firstdata_order_status_void_id');
+ }
+
+ if (isset($this->request->post['payment_firstdata_live_url'])) {
+ $data['payment_firstdata_live_url'] = $this->request->post['payment_firstdata_live_url'];
+ } else {
+ $data['payment_firstdata_live_url'] = $this->config->get('payment_firstdata_live_url');
+ }
+
+ if (empty($data['payment_firstdata_live_url'])) {
+ $data['payment_firstdata_live_url'] = 'https://ipg-online.com/connect/gateway/processing';
+ }
+
+ if (isset($this->request->post['payment_firstdata_demo_url'])) {
+ $data['payment_firstdata_demo_url'] = $this->request->post['payment_firstdata_demo_url'];
+ } else {
+ $data['payment_firstdata_demo_url'] = $this->config->get('payment_firstdata_demo_url');
+ }
+
+ if (isset($this->request->post['payment_firstdata_card_storage'])) {
+ $data['payment_firstdata_card_storage'] = $this->request->post['payment_firstdata_card_storage'];
+ } else {
+ $data['payment_firstdata_card_storage'] = $this->config->get('payment_firstdata_card_storage');
+ }
+
+ if (empty($data['payment_firstdata_demo_url'])) {
+ $data['payment_firstdata_demo_url'] = 'https://test.ipg-online.com/connect/gateway/processing';
+ }
+
+ $data['header'] = $this->load->controller('common/header');
+ $data['column_left'] = $this->load->controller('common/column_left');
+ $data['footer'] = $this->load->controller('common/footer');
+
+ $this->response->setOutput($this->load->view('extension/payment/firstdata', $data));
+ }
+
+ public function install() {
+ $this->load->model('extension/payment/firstdata');
+ $this->model_extension_payment_firstdata->install();
+ }
+
+ public function uninstall() {
+ $this->load->model('extension/payment/firstdata');
+ $this->model_extension_payment_firstdata->uninstall();
+ }
+
+ public function order() {
+ if ($this->config->get('payment_firstdata_status')) {
+ $this->load->model('extension/payment/firstdata');
+
+ $firstdata_order = $this->model_extension_payment_firstdata->getOrder($this->request->get['order_id']);
+
+ if (!empty($firstdata_order)) {
+ $this->load->language('extension/payment/firstdata');
+
+ $firstdata_order['total_captured'] = $this->model_extension_payment_firstdata->getTotalCaptured($firstdata_order['firstdata_order_id']);
+ $firstdata_order['total_formatted'] = $this->currency->format($firstdata_order['total'], $firstdata_order['currency_code'], 1, true);
+ $firstdata_order['total_captured_formatted'] = $this->currency->format($firstdata_order['total_captured'], $firstdata_order['currency_code'], 1, true);
+
+ $data['firstdata_order'] = $firstdata_order;
+ $data['merchant_id'] = $this->config->get('payment_firstdata_merchant_id');
+ $data['currency'] = $this->model_extension_payment_firstdata->mapCurrency($firstdata_order['currency_code']);
+ $data['amount'] = number_format($firstdata_order['total'], 2);
+
+ $data['request_timestamp'] = date("Y:m:d-H:i:s");
+
+ $data['hash'] = sha1(bin2hex($data['merchant_id'] . $data['request_timestamp'] . $data['amount'] . $data['currency'] . $this->config->get('payment_firstdata_secret')));
+
+ $data['void_url'] = $this->url->link('extension/payment/firstdata/void', 'user_token=' . $this->session->data['user_token'], true);
+ $data['capture_url'] = $this->url->link('extension/payment/firstdata/capture', 'user_token=' . $this->session->data['user_token'], true);
+ $data['notify_url'] = HTTPS_CATALOG . 'index.php?route=extension/payment/firstdata/notify';
+
+ if ($this->config->get('payment_firstdata_live_demo') == 1) {
+ $data['action_url'] = $this->config->get('payment_firstdata_live_url');
+ } else {
+ $data['action_url'] = $this->config->get('payment_firstdata_demo_url');
+ }
+
+ if (isset($this->session->data['void_success'])) {
+ $data['void_success'] = $this->session->data['void_success'];
+
+ unset($this->session->data['void_success']);
+ } else {
+ $data['void_success'] = '';
+ }
+
+ if (isset($this->session->data['void_error'])) {
+ $data['void_error'] = $this->session->data['void_error'];
+
+ unset($this->session->data['void_error']);
+ } else {
+ $data['void_error'] = '';
+ }
+
+ if (isset($this->session->data['capture_success'])) {
+ $data['capture_success'] = $this->session->data['capture_success'];
+
+ unset($this->session->data['capture_success']);
+ } else {
+ $data['capture_success'] = '';
+ }
+
+ if (isset($this->session->data['capture_error'])) {
+ $data['capture_error'] = $this->session->data['capture_error'];
+
+ unset($this->session->data['capture_error']);
+ } else {
+ $data['capture_error'] = '';
+ }
+
+ $data['text_payment_info'] = $this->language->get('text_payment_info');
+ $data['text_order_ref'] = $this->language->get('text_order_ref');
+ $data['text_order_total'] = $this->language->get('text_order_total');
+ $data['text_total_captured'] = $this->language->get('text_total_captured');
+ $data['text_capture_status'] = $this->language->get('text_capture_status');
+ $data['text_void_status'] = $this->language->get('text_void_status');
+ $data['text_transactions'] = $this->language->get('text_transactions');
+ $data['text_yes'] = $this->language->get('text_yes');
+ $data['text_no'] = $this->language->get('text_no');
+ $data['text_column_amount'] = $this->language->get('text_column_amount');
+ $data['text_column_type'] = $this->language->get('text_column_type');
+ $data['text_column_date_added'] = $this->language->get('text_column_date_added');
+ $data['button_capture'] = $this->language->get('button_capture');
+ $data['button_void'] = $this->language->get('button_void');
+ $data['text_confirm_void'] = $this->language->get('text_confirm_void');
+ $data['text_confirm_capture'] = $this->language->get('text_confirm_capture');
+
+ $data['order_id'] = $this->request->get['order_id'];
+ $data['user_token'] = $this->request->get['user_token'];
+
+ return $this->load->view('extension/payment/firstdata_order', $data);
+ }
+ }
+ }
+
+ public function void() {
+ $this->load->language('extension/payment/firstdata');
+
+ if ($this->request->post['status'] == 'FAILED') {
+ if (isset($this->request->post['fail_reason'])) {
+ $this->session->data['void_error'] = $this->request->post['fail_reason'];
+ } else {
+ $this->session->data['void_error'] = $this->language->get('error_void_error');
+ }
+ }
+
+ if ($this->request->post['status'] == 'DECLINED') {
+ $this->session->data['void_success'] = $this->language->get('success_void');
+ }
+
+ $this->response->redirect($this->url->link('sale/order/info', 'order_id=' . $this->request->post['order_id'] . '&user_token=' . $this->session->data['user_token'], true));
+ }
+
+ public function capture() {
+ $this->load->language('extension/payment/firstdata');
+
+ if ($this->request->post['status'] == 'FAILED') {
+ if (isset($this->request->post['fail_reason'])) {
+ $this->session->data['capture_error'] = $this->request->post['fail_reason'];
+ } else {
+ $this->session->data['capture_error'] = $this->language->get('error_capture_error');
+ }
+ }
+
+ if ($this->request->post['status'] == 'APPROVED') {
+ $this->session->data['capture_success'] = $this->language->get('success_capture');
+ }
+
+ $this->response->redirect($this->url->link('sale/order/info', 'order_id=' . $this->request->post['order_id'] . '&user_token=' . $this->session->data['user_token'], true));
+ }
+
+ protected function validate() {
+ if (!$this->user->hasPermission('modify', 'extension/payment/firstdata')) {
+ $this->error['warning'] = $this->language->get('error_permission');
+ }
+
+ if (!$this->request->post['payment_firstdata_merchant_id']) {
+ $this->error['error_merchant_id'] = $this->language->get('error_merchant_id');
+ }
+
+ if (!$this->request->post['payment_firstdata_secret']) {
+ $this->error['error_secret'] = $this->language->get('error_secret');
+ }
+
+ if (!$this->request->post['payment_firstdata_live_url']) {
+ $this->error['error_live_url'] = $this->language->get('error_live_url');
+ }
+
+ if (!$this->request->post['payment_firstdata_demo_url']) {
+ $this->error['error_demo_url'] = $this->language->get('error_demo_url');
+ }
+
+ return !$this->error;
+ }
+} \ No newline at end of file