load->language('extension/payment/globalpay');
$this->load->model('checkout/order');
$order_info = $this->model_checkout_order->getOrder($this->session->data['order_id']);
if ($this->config->get('payment_globalpay_live_demo') == 1) {
$data['action'] = $this->config->get('payment_globalpay_live_url');
} else {
$data['action'] = $this->config->get('payment_globalpay_demo_url');
}
if ($this->config->get('payment_globalpay_card_select') == 1) {
$card_types = array(
'visa' => $this->language->get('text_card_visa'),
'mc' => $this->language->get('text_card_mc'),
'amex' => $this->language->get('text_card_amex'),
'switch' => $this->language->get('text_card_switch'),
'laser' => $this->language->get('text_card_laser'),
'diners' => $this->language->get('text_card_diners'),
);
$data['cards'] = array();
$accounts = $this->config->get('payment_globalpay_account');
foreach ($accounts as $card => $account) {
if (isset($account['enabled']) && $account['enabled'] == 1) {
$data['cards'][] = array(
'type' => $card_types[$card],
'account' => (isset($account['default']) && $account['default'] == 1 ? $this->config->get('payment_globalpay_merchant_id') : $account['merchant_id']),
);
}
}
$data['card_select'] = true;
} else {
$data['card_select'] = false;
}
if ($this->config->get('payment_globalpay_auto_settle') == 0) {
$data['settle'] = 0;
} elseif ($this->config->get('payment_globalpay_auto_settle') == 1) {
$data['settle'] = 1;
} elseif ($this->config->get('payment_globalpay_auto_settle') == 2) {
$data['settle'] = 'MULTI';
}
$data['tss'] = (int)$this->config->get('payment_globalpay_tss_check');
$data['merchant_id'] = $this->config->get('payment_globalpay_merchant_id');
$data['timestamp'] = strftime("%Y%m%d%H%M%S");
$data['order_id'] = $this->session->data['order_id'] . 'T' . $data['timestamp'] . mt_rand(1, 999);
$data['amount'] = round($this->currency->format($order_info['total'], $order_info['currency_code'], $order_info['currency_value'], false)*100);
$data['currency'] = $order_info['currency_code'];
$tmp = $data['timestamp'] . '.' . $data['merchant_id'] . '.' . $data['order_id'] . '.' . $data['amount'] . '.' . $data['currency'];
$hash = sha1($tmp);
$tmp = $hash . '.' . $this->config->get('payment_globalpay_secret');
$data['hash'] = sha1($tmp);
$data['billing_code'] = filter_var(str_replace('-', '', $order_info['payment_postcode']), FILTER_SANITIZE_NUMBER_INT) . '|' . filter_var(str_replace('-', '', $order_info['payment_address_1']), FILTER_SANITIZE_NUMBER_INT);
$data['payment_country'] = $order_info['payment_iso_code_2'];
if ($this->cart->hasShipping()) {
$data['shipping_code'] = filter_var(str_replace('-', '', $order_info['shipping_postcode']), FILTER_SANITIZE_NUMBER_INT) . '|' . filter_var(str_replace('-', '', $order_info['shipping_address_1']), FILTER_SANITIZE_NUMBER_INT);
$data['shipping_country'] = $order_info['shipping_iso_code_2'];
} else {
$data['shipping_code'] = filter_var(str_replace('-', '', $order_info['payment_postcode']), FILTER_SANITIZE_NUMBER_INT) . '|' . filter_var(str_replace('-', '', $order_info['payment_address_1']), FILTER_SANITIZE_NUMBER_INT);
$data['shipping_country'] = $order_info['payment_iso_code_2'];
}
$data['response_url'] = HTTPS_SERVER . 'index.php?route=extension/payment/globalpay/notify';
return $this->load->view('extension/payment/globalpay', $data);
}
public function notify() {
$this->load->model('extension/payment/globalpay');
$this->model_extension_payment_globalpay->logger(print_r($this->request->post, 1));
$this->load->language('extension/payment/globalpay');
$hash = sha1($this->request->post['TIMESTAMP'] . '.' . $this->config->get('payment_globalpay_merchant_id') . '.' . $this->request->post['ORDER_ID'] . '.' . $this->request->post['RESULT'] . '.' . $this->request->post['MESSAGE'] . '.' . $this->request->post['PASREF'] . '.' . $this->request->post['AUTHCODE']);
$tmp = $hash . '.' . $this->config->get('payment_globalpay_secret');
$hash = sha1($tmp);
//Check to see if hashes match or not
if ($hash != $this->request->post['SHA1HASH']) {
$data['text_response'] = $this->language->get('text_hash_failed');
$data['text_link'] = sprintf($this->language->get('text_link'), $this->url->link('checkout/checkout', '', true));
} else {
$this->load->model('checkout/order');
$order_id_parts = explode('T', $this->request->post['ORDER_ID']);
$order_id = (int)$order_id_parts[0];
$order_info = $this->model_checkout_order->getOrder($order_id);
$auto_settle = (int)$this->config->get('payment_globalpay_auto_settle');
$tss = (int)$this->config->get('payment_globalpay_tss_check');
$message = '' . $this->language->get('text_result') . ': ' . $this->request->post['RESULT'];
$message .= '
' . $this->language->get('text_message') . ': ' . $this->request->post['MESSAGE'];
if (isset($this->request->post['ORDER_ID'])) {
$message .= '
' . $this->language->get('text_order_ref') . ': ' . $this->request->post['ORDER_ID'];
}
if (isset($this->request->post['CVNRESULT'])) {
$message .= '
' . $this->language->get('text_cvn_result') . ': ' . $this->request->post['CVNRESULT'];
}
if (isset($this->request->post['AVSPOSTCODERESULT'])) {
$message .= '
' . $this->language->get('text_avs_postcode') . ': ' . $this->request->post['AVSPOSTCODERESULT'];
}
if (isset($this->request->post['AVSADDRESSRESULT'])) {
$message .= '
' . $this->language->get('text_avs_address') . ': ' . $this->request->post['AVSADDRESSRESULT'];
}
//3D Secure message
if (isset($this->request->post['ECI']) && isset($this->request->post['CAVV']) && isset($this->request->post['XID'])) {
$eci = $this->request->post['ECI'];
if (($this->request->post['ECI'] == 6 || $this->request->post['ECI'] == 1) && empty($this->request->post['CAVV']) && empty($this->request->post['XID'])) {
$scenario_id = 1;
}
if (($this->request->post['ECI'] == 5 || $this->request->post['ECI'] == 0) && !empty($this->request->post['CAVV']) && !empty($this->request->post['XID'])) {
$scenario_id = 5;
}
if (($this->request->post['ECI'] == 6 || $this->request->post['ECI'] == 1) && !empty($this->request->post['CAVV']) && !empty($this->request->post['XID'])) {
$scenario_id = 6;
}
if (isset($scenario_id)) {
$scenario_message = $this->language->get('text_3d_s' . $scenario_id);
} else {
if (isset($this->request->post['CARDTYPE'])) {
if ($this->request->post['CARDTYPE'] == 'VISA') {
$eci = 7;
} else {
$eci = 2;
}
}
$scenario_message = $this->language->get('text_3d_liability');
}
$message .= '
' . $this->language->get('text_eci') . ': (' . $eci . ') ' . $scenario_message;
}
if ($tss == 1 && isset($this->request->post['TSS'])) {
$message .= '
' . $this->language->get('text_tss') . ': ' . $this->request->post['TSS'];
}
if (isset($this->request->post['TIMESTAMP'])) {
$message .= '
' . $this->language->get('text_timestamp') . ': ' . $this->request->post['TIMESTAMP'];
}
if (isset($this->request->post['CARDDIGITS'])) {
$message .= '
' . $this->language->get('text_card_digits') . ': ' . $this->request->post['CARDDIGITS'];
}
if (isset($this->request->post['CARDTYPE'])) {
$message .= '
' . $this->language->get('text_card_type') . ': ' . $this->request->post['CARDTYPE'];
}
if (isset($this->request->post['EXPDATE'])) {
$message .= '
' . $this->language->get('text_card_exp') . ': ' . $this->request->post['EXPDATE'];
}
if (isset($this->request->post['CARDNAME'])) {
$message .= '
' . $this->language->get('text_card_name') . ': ' . $this->request->post['CARDNAME'];
}
if (isset($this->request->post['DCCAUTHCARDHOLDERAMOUNT']) && isset($this->request->post['DCCAUTHRATE'])) {
$message .= '
DCCAUTHCARDHOLDERAMOUNT: ' . $this->request->post['DCCAUTHCARDHOLDERAMOUNT'];
$message .= '
DCCAUTHRATE: ' . $this->request->post['DCCAUTHRATE'];
$message .= '
DCCAUTHCARDHOLDERCURRENCY: ' . $this->request->post['DCCAUTHCARDHOLDERCURRENCY'];
$message .= '
DCCAUTHMERCHANTCURRENCY: ' . $this->request->post['DCCAUTHMERCHANTCURRENCY'];
$message .= '
DCCAUTHMERCHANTAMOUNT: ' . $this->request->post['DCCAUTHMERCHANTAMOUNT'];
$message .= '
DCCCCP: ' . $this->request->post['DCCCCP'];
$message .= '
DCCRATE: ' . $this->request->post['DCCRATE'];
$message .= '
DCCMARGINRATEPERCENTAGE: ' . $this->request->post['DCCMARGINRATEPERCENTAGE'];
$message .= '
DCCEXCHANGERATESOURCENAME: ' . $this->request->post['DCCEXCHANGERATESOURCENAME'];
$message .= '
DCCCOMMISSIONPERCENTAGE: ' . $this->request->post['DCCCOMMISSIONPERCENTAGE'];
$message .= '
DCCEXCHANGERATESOURCETIMESTAMP: ' . $this->request->post['DCCEXCHANGERATESOURCETIMESTAMP'];
$message .= '
DCCCHOICE: ' . $this->request->post['DCCCHOICE'];
}
if ($this->request->post['RESULT'] == "00") {
$globalpay_order_id = $this->model_extension_payment_globalpay->addOrder($order_info, $this->request->post['PASREF'], $this->request->post['AUTHCODE'], $this->request->post['ACCOUNT'], $this->request->post['ORDER_ID']);
if ($auto_settle == 1) {
$this->model_extension_payment_globalpay->addTransaction($globalpay_order_id, 'payment', $order_info);
$this->model_checkout_order->addOrderHistory($order_id, $this->config->get('globalpay_order_status_success_settled_id'), $message, false);
} else {
$this->model_extension_payment_globalpay->addTransaction($globalpay_order_id, 'auth', 0.00);
$this->model_checkout_order->addOrderHistory($order_id, $this->config->get('payment_globalpay_order_status_success_unsettled_id'), $message, false);
}
$data['text_response'] = $this->language->get('text_success');
$data['text_link'] = sprintf($this->language->get('text_link'), $this->url->link('checkout/success', '', true));
} elseif ($this->request->post['RESULT'] == "101") {
// Decline
$this->model_extension_payment_globalpay->addHistory($order_id, $this->config->get('payment_globalpay_order_status_decline_id'), $message);
$data['text_response'] = $this->language->get('text_decline');
$data['text_link'] = sprintf($this->language->get('text_link'), $this->url->link('checkout/checkout', '', true));
} elseif ($this->request->post['RESULT'] == "102") {
// Referal B
$this->model_extension_payment_globalpay->addHistory($order_id, $this->config->get('payment_globalpay_order_status_decline_pending_id'), $message);
$data['text_response'] = $this->language->get('text_decline');
$data['text_link'] = sprintf($this->language->get('text_link'), $this->url->link('checkout/checkout', '', true));
} elseif ($this->request->post['RESULT'] == "103") {
// Referal A
$this->model_extension_payment_globalpay->addHistory($order_id, $this->config->get('payment_globalpay_order_status_decline_stolen_id'), $message);
$data['text_response'] = $this->language->get('text_decline');
$data['text_link'] = sprintf($this->language->get('text_link'), $this->url->link('checkout/checkout', '', true));
} elseif ($this->request->post['RESULT'] == "200") {
// Error Connecting to Bank
$this->model_extension_payment_globalpay->addHistory($order_id, $this->config->get('payment_globalpay_order_status_decline_bank_id'), $message);
$data['text_response'] = $this->language->get('text_bank_error');
$data['text_link'] = sprintf($this->language->get('text_link'), $this->url->link('checkout/checkout', '', true));
} elseif ($this->request->post['RESULT'] == "204") {
// Error Connecting to Bank
$this->model_extension_payment_globalpay->addHistory($order_id, $this->config->get('payment_globalpay_order_status_decline_bank_id'), $message);
$data['text_response'] = $this->language->get('text_bank_error');
$data['text_link'] = sprintf($this->language->get('text_link'), $this->url->link('checkout/checkout', '', true));
} elseif ($this->request->post['RESULT'] == "205") {
// Comms Error
$this->model_extension_payment_globalpay->addHistory($order_id, $this->config->get('payment_globalpay_order_status_decline_bank_id'), $message);
$data['text_response'] = $this->language->get('text_bank_error');
$data['text_link'] = sprintf($this->language->get('text_link'), $this->url->link('checkout/checkout', '', true));
} else {
// Other error
$this->model_extension_payment_globalpay->addHistory($order_id, $this->config->get('payment_globalpay_order_status_decline_id'), $message);
$data['text_response'] = $this->language->get('text_generic_error');
$data['text_link'] = sprintf($this->language->get('text_link'), $this->url->link('checkout/checkout', '', true));
}
}
$this->response->setOutput($this->load->view('extension/payment/globalpay_response', $data));
}
}