Файл: upload/catalog/controller/payment/sagepay_direct.php
Строк: 506
<?php
class ControllerPaymentSagepayDirect extends Controller {
public function index() {
$this->load->language('payment/sagepay_direct');
$data['text_credit_card'] = $this->language->get('text_credit_card');
$data['text_loading'] = $this->language->get('text_loading');
$data['text_card_type'] = $this->language->get('text_card_type');
$data['text_card_name'] = $this->language->get('text_card_name');
$data['text_card_digits'] = $this->language->get('text_card_digits');
$data['text_card_expiry'] = $this->language->get('text_card_expiry');
$data['entry_card'] = $this->language->get('entry_card');
$data['entry_card_existing'] = $this->language->get('entry_card_existing');
$data['entry_card_new'] = $this->language->get('entry_card_new');
$data['entry_card_save'] = $this->language->get('entry_card_save');
$data['entry_cc_owner'] = $this->language->get('entry_cc_owner');
$data['entry_cc_type'] = $this->language->get('entry_cc_type');
$data['entry_cc_number'] = $this->language->get('entry_cc_number');
$data['entry_cc_start_date'] = $this->language->get('entry_cc_start_date');
$data['entry_cc_expire_date'] = $this->language->get('entry_cc_expire_date');
$data['entry_cc_cvv2'] = $this->language->get('entry_cc_cvv2');
$data['entry_cc_issue'] = $this->language->get('entry_cc_issue');
$data['entry_cc_choice'] = $this->language->get('entry_cc_choice');
$data['help_start_date'] = $this->language->get('help_start_date');
$data['help_issue'] = $this->language->get('help_issue');
$data['button_confirm'] = $this->language->get('button_confirm');
$data['cards'] = array();
$data['cards'][] = array(
'text' => 'Visa',
'value' => 'VISA'
);
$data['cards'][] = array(
'text' => 'MasterCard',
'value' => 'MC'
);
$data['cards'][] = array(
'text' => 'Visa Delta/Debit',
'value' => 'DELTA'
);
$data['cards'][] = array(
'text' => 'Solo',
'value' => 'SOLO'
);
$data['cards'][] = array(
'text' => 'Maestro',
'value' => 'MAESTRO'
);
$data['cards'][] = array(
'text' => 'Visa Electron UK Debit',
'value' => 'UKE'
);
$data['cards'][] = array(
'text' => 'American Express',
'value' => 'AMEX'
);
$data['cards'][] = array(
'text' => 'Diners Club',
'value' => 'DC'
);
$data['cards'][] = array(
'text' => 'Japan Credit Bureau',
'value' => 'JCB'
);
$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_valid'] = array();
for ($i = $today['year'] - 10; $i < $today['year'] + 1; $i++) {
$data['year_valid'][] = array(
'text' => strftime('%Y', mktime(0, 0, 0, 1, 1, $i)),
'value' => strftime('%Y', mktime(0, 0, 0, 1, 1, $i))
);
}
$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))
);
}
if ($this->config->get('sagepay_direct_card') == '1') {
$data['sagepay_direct_card'] = true;
} else {
$data['sagepay_direct_card'] = false;
}
$data['existing_cards'] = array();
if ($this->customer->isLogged() && $data['sagepay_direct_card']) {
$this->load->model('payment/sagepay_direct');
$data['existing_cards'] = $this->model_payment_sagepay_direct->getCards($this->customer->getId());
}
if (file_exists(DIR_TEMPLATE . $this->config->get('config_template') . '/template/payment/sagepay_direct.tpl')) {
return $this->load->view($this->config->get('config_template') . '/template/payment/sagepay_direct.tpl', $data);
} else {
return $this->load->view('default/template/payment/sagepay_direct.tpl', $data);
}
}
public function send() {
$this->load->language('payment/sagepay_direct');
$this->load->model('checkout/order');
$this->load->model('payment/sagepay_direct');
$payment_data = array();
if ($this->config->get('sagepay_direct_test') == 'live') {
$url = 'https://live.sagepay.com/gateway/service/vspdirect-register.vsp';
$payment_data['VPSProtocol'] = '3.00';
} elseif ($this->config->get('sagepay_direct_test') == 'test') {
$url = 'https://test.sagepay.com/gateway/service/vspdirect-register.vsp';
$payment_data['VPSProtocol'] = '3.00';
} elseif ($this->config->get('sagepay_direct_test') == 'sim') {
$url = 'https://test.sagepay.com/Simulator/VSPDirectGateway.asp';
$payment_data['VPSProtocol'] = '2.23';
}
$order_info = $this->model_checkout_order->getOrder($this->session->data['order_id']);
$payment_data['ReferrerID'] = 'E511AF91-E4A0-42DE-80B0-09C981A3FB61';
$payment_data['Vendor'] = $this->config->get('sagepay_direct_vendor');
$payment_data['VendorTxCode'] = $this->session->data['order_id'] . 'SD' . strftime("%Y%m%d%H%M%S") . mt_rand(1, 999);
$payment_data['Amount'] = $this->currency->format($order_info['total'], $order_info['currency_code'], false, false);
$payment_data['Currency'] = $this->currency->getCode();
$payment_data['Description'] = substr($this->config->get('config_name'), 0, 100);
$payment_data['TxType'] = $this->config->get('sagepay_direct_transaction');
$payment_data['CV2'] = $this->request->post['cc_cvv2'];
if (isset($this->request->post['Token'])) {
$payment_data['Token'] = $this->request->post['Token'];
$payment_data['StoreToken'] = 1;
} else {
$payment_data['CardHolder'] = $this->request->post['cc_owner'];
$payment_data['CardNumber'] = $this->request->post['cc_number'];
$payment_data['ExpiryDate'] = $this->request->post['cc_expire_date_month'] . substr($this->request->post['cc_expire_date_year'], 2);
$payment_data['CardType'] = $this->request->post['cc_type'];
$payment_data['StartDate'] = $this->request->post['cc_start_date_month'] . substr($this->request->post['cc_start_date_year'], 2);
$payment_data['IssueNumber'] = $this->request->post['cc_issue'];
}
if (isset($this->request->post['CreateToken'])) {
$payment_data['CreateToken'] = $this->request->post['CreateToken'];
$payment_data['StoreToken'] = 1;
}
$payment_data['BillingSurname'] = substr($order_info['payment_lastname'], 0, 20);
$payment_data['BillingFirstnames'] = substr($order_info['payment_firstname'], 0, 20);
$payment_data['BillingAddress1'] = substr($order_info['payment_address_1'], 0, 100);
if ($order_info['payment_address_2']) {
$payment_data['BillingAddress2'] = $order_info['payment_address_2'];
}
$payment_data['BillingCity'] = substr($order_info['payment_city'], 0, 40);
$payment_data['BillingPostCode'] = substr($order_info['payment_postcode'], 0, 10);
$payment_data['BillingCountry'] = $order_info['payment_iso_code_2'];
if ($order_info['payment_iso_code_2'] == 'US') {
$payment_data['BillingState'] = $order_info['payment_zone_code'];
}
$payment_data['BillingPhone'] = substr($order_info['telephone'], 0, 20);
if ($this->cart->hasShipping()) {
$payment_data['DeliverySurname'] = substr($order_info['shipping_lastname'], 0, 20);
$payment_data['DeliveryFirstnames'] = substr($order_info['shipping_firstname'], 0, 20);
$payment_data['DeliveryAddress1'] = substr($order_info['shipping_address_1'], 0, 100);
if ($order_info['shipping_address_2']) {
$payment_data['DeliveryAddress2'] = $order_info['shipping_address_2'];
}
$payment_data['DeliveryCity'] = substr($order_info['shipping_city'], 0, 40);
$payment_data['DeliveryPostCode'] = substr($order_info['shipping_postcode'], 0, 10);
$payment_data['DeliveryCountry'] = $order_info['shipping_iso_code_2'];
if ($order_info['shipping_iso_code_2'] == 'US') {
$payment_data['DeliveryState'] = $order_info['shipping_zone_code'];
}
$payment_data['CustomerName'] = substr($order_info['firstname'] . ' ' . $order_info['lastname'], 0, 100);
$payment_data['DeliveryPhone'] = substr($order_info['telephone'], 0, 20);
} else {
$payment_data['DeliveryFirstnames'] = $order_info['payment_firstname'];
$payment_data['DeliverySurname'] = $order_info['payment_lastname'];
$payment_data['DeliveryAddress1'] = $order_info['payment_address_1'];
if ($order_info['payment_address_2']) {
$payment_data['DeliveryAddress2'] = $order_info['payment_address_2'];
}
$payment_data['DeliveryCity'] = $order_info['payment_city'];
$payment_data['DeliveryPostCode'] = $order_info['payment_postcode'];
$payment_data['DeliveryCountry'] = $order_info['payment_iso_code_2'];
if ($order_info['payment_iso_code_2'] == 'US') {
$payment_data['DeliveryState'] = $order_info['payment_zone_code'];
}
$payment_data['DeliveryPhone'] = $order_info['telephone'];
}
$payment_data['CustomerEMail'] = substr($order_info['email'], 0, 255);
$payment_data['Apply3DSecure'] = '0';
$payment_data['ClientIPAddress'] = $this->request->server['REMOTE_ADDR'];
$response_data = $this->model_payment_sagepay_direct->sendCurl($url, $payment_data);
$json = array();
if ($response_data['Status'] == '3DAUTH') {
$json['ACSURL'] = $response_data['ACSURL'];
$json['MD'] = $response_data['MD'];
$json['PaReq'] = $response_data['PAReq'];
$this->model_payment_sagepay_direct->addOrder($this->session->data['order_id'], $payment_data);
if (!empty($payment_data['CreateToken']) && $this->customer->isLogged()) {
$card_data = array();
$card_data['customer_id'] = $this->customer->getId();
$card_data['Last4Digits'] = substr(str_replace(' ', '', $payment_data['CardNumber']), -4, 4);
$card_data['ExpiryDate'] = $this->request->post['cc_expire_date_month'] . '/' . substr($this->request->post['cc_expire_date_year'], 2);
$card_data['CardType'] = $payment_data['CardType'];
$this->model_payment_sagepay_direct->addCard($this->session->data['order_id'], $card_data);
}
$json['TermUrl'] = $this->url->link('payment/sagepay_direct/callback', '', 'SSL');
} elseif ($response_data['Status'] == 'OK' || $response_data['Status'] == 'AUTHENTICATED' || $response_data['Status'] == 'REGISTERED') {
$message = '';
if (isset($response_data['TxAuthNo'])) {
$message .= 'TxAuthNo: ' . $response_data['TxAuthNo'] . "n";
}
if (isset($response_data['AVSCV2'])) {
$message .= 'AVSCV2: ' . $response_data['AVSCV2'] . "n";
}
if (isset($response_data['AddressResult'])) {
$message .= 'AddressResult: ' . $response_data['AddressResult'] . "n";
}
if (isset($response_data['PostCodeResult'])) {
$message .= 'PostCodeResult: ' . $response_data['PostCodeResult'] . "n";
}
if (isset($response_data['CV2Result'])) {
$message .= 'CV2Result: ' . $response_data['CV2Result'] . "n";
}
if (isset($response_data['3DSecureStatus'])) {
$message .= '3DSecureStatus: ' . $response_data['3DSecureStatus'] . "n";
}
if (isset($response_data['CAVV'])) {
$message .= 'CAVV: ' . $response_data['CAVV'] . "n";
}
$sagepay_direct_order_id = $this->model_payment_sagepay_direct->addFullOrder($order_info, $response_data, $payment_data);
$this->model_payment_sagepay_direct->addTransaction($sagepay_direct_order_id, $this->config->get('sagepay_direct_transaction'), $order_info);
$this->model_checkout_order->addOrderHistory($this->session->data['order_id'], $this->config->get('sagepay_direct_order_status_id'), $message, false);
if (!empty($response_data['Token']) && $this->customer->isLogged()) {
$card_data = array();
$card_data['customer_id'] = $this->customer->getId();
$card_data['Token'] = $response_data['Token'];
$card_data['Last4Digits'] = substr(str_replace(' ', '', $payment_data['CardNumber']), -4, 4);
$card_data['ExpiryDate'] = $this->request->post['cc_expire_date_month'] . '/' . substr($this->request->post['cc_expire_date_year'], 2);
$card_data['CardType'] = $payment_data['CardType'];
$this->model_payment_sagepay_direct->addFullCard($this->session->data['order_id'], $card_data);
}
if ($this->config->get('sagepay_direct_transaction') == 'PAYMENT') {
$recurring_products = $this->cart->getRecurringProducts();
//loop through any products that are recurring items
foreach ($recurring_products as $item) {
$this->model_payment_sagepay_direct->recurringPayment($item, $payment_data['VendorTxCode']);
}
}
$json['redirect'] = $this->url->link('checkout/success', '', 'SSL');
} else {
$json['error'] = $response_data['Status'] . ': ' . $response_data['StatusDetail'];
$this->model_payment_sagepay_direct->logger('Response data: ' . print_r($response_data['Status'] . ': ' . $response_data['StatusDetail'], 1));
}
$this->response->addHeader('Content-Type: application/json');
$this->response->setOutput(json_encode($json));
}
public function callback() {
$this->load->model('payment/sagepay_direct');
$this->load->language('payment/sagepay_direct');
$this->load->model('checkout/order');
if (isset($this->session->data['order_id'])) {
if ($this->config->get('sagepay_direct_test') == 'live') {
$url = 'https://live.sagepay.com/gateway/service/direct3dcallback.vsp';
} elseif ($this->config->get('sagepay_direct_test') == 'test') {
$url = 'https://test.sagepay.com/gateway/service/direct3dcallback.vsp';
} elseif ($this->config->get('sagepay_direct_test') == 'sim') {
$url = 'https://test.sagepay.com/Simulator/VSPDirectCallback.asp';
}
$response_data = $this->model_payment_sagepay_direct->sendCurl($url, $this->request->post);
if ($response_data['Status'] == 'OK' || $response_data['Status'] == 'AUTHENTICATED' || $response_data['Status'] == 'REGISTERED') {
$this->model_checkout_order->addOrderHistory($this->session->data['order_id'], $this->config->get('config_order_status_id'));
$message = '';
if (isset($response_data['TxAuthNo'])) {
$message .= 'TxAuthNo: ' . $response_data['TxAuthNo'] . "n";
}
if (isset($response_data['AVSCV2'])) {
$message .= 'AVSCV2: ' . $response_data['AVSCV2'] . "n";
}
if (isset($response_data['AddressResult'])) {
$message .= 'AddressResult: ' . $response_data['AddressResult'] . "n";
}
if (isset($response_data['PostCodeResult'])) {
$message .= 'PostCodeResult: ' . $response_data['PostCodeResult'] . "n";
}
if (isset($response_data['CV2Result'])) {
$message .= 'CV2Result: ' . $response_data['CV2Result'] . "n";
}
if (isset($response_data['3DSecureStatus'])) {
$message .= '3DSecureStatus: ' . $response_data['3DSecureStatus'] . "n";
}
if (isset($response_data['CAVV'])) {
$message .= 'CAVV: ' . $response_data['CAVV'] . "n";
}
$order_info = $this->model_checkout_order->getOrder($this->session->data['order_id']);
$this->model_payment_sagepay_direct->updateOrder($order_info, $response_data);
$sagepay_order_info = $this->model_payment_sagepay_direct->getOrder($this->session->data['order_id']);
$this->model_payment_sagepay_direct->logger('sagepay_direct_order_id: ' . print_r($sagepay_order_info['sagepay_direct_order_id'], 1));
$this->model_payment_sagepay_direct->logger('$order_info: ' . print_r($order_info, 1));
$this->model_payment_sagepay_direct->addTransaction($sagepay_order_info['sagepay_direct_order_id'], $this->config->get('sagepay_direct_transaction'), $order_info);
$this->model_checkout_order->addOrderHistory($this->session->data['order_id'], $this->config->get('sagepay_direct_order_status_id'), $message, false);
if (!empty($response_data['Token']) && $this->customer->isLogged()) {
$this->model_payment_sagepay_direct->updateCard($this->session->data['order_id'], $response_data['Token']);
} else {
$this->model_payment_sagepay_direct->deleteCard($this->session->data['order_id']);
}
if ($this->config->get('sagepay_direct_transaction') == 'PAYMENT') {
$recurring_products = $this->cart->getRecurringProducts();
//loop through any products that are recurring items
foreach ($recurring_products as $item) {
$this->model_payment_sagepay_direct->recurringPayment($item, $sagepay_order_info['VendorTxCode']);
}
}
$this->response->redirect($this->url->link('checkout/success', '', 'SSL'));
} else {
$this->session->data['error'] = $response_data['StatusDetail'];
$this->response->redirect($this->url->link('checkout/checkout', '', 'SSL'));
}
} else {
$this->response->redirect($this->url->link('account/login', '', 'SSL'));
}
}
public function cron() {
if ($this->request->get['token'] == $this->config->get('sagepay_direct_cron_job_token')) {
$this->load->model('payment/sagepay_direct');
$orders = $this->model_payment_sagepay_direct->cronPayment();
$this->model_payment_sagepay_direct->updateCronJobRunTime();
$this->model_payment_sagepay_direct->logger('Repeat Orders: ' . print_r($orders, 1));
}
}
}