db->query("
CREATE TABLE IF NOT EXISTS `" . DB_PREFIX . "firstdata_order` (
`firstdata_order_id` INT(11) NOT NULL AUTO_INCREMENT,
`order_id` INT(11) NOT NULL,
`order_ref` CHAR(50) NOT NULL,
`order_ref_previous` CHAR(50) NOT NULL,
`pasref` VARCHAR(50) NOT NULL,
`pasref_previous` VARCHAR(50) NOT NULL,
`tdate` DATETIME NOT NULL,
`date_added` DATETIME NOT NULL,
`date_modified` DATETIME NOT NULL,
`capture_status` INT(1) DEFAULT NULL,
`void_status` INT(1) DEFAULT NULL,
`currency_code` CHAR(3) NOT NULL,
`authcode` VARCHAR(30) NOT NULL,
`account` VARCHAR(30) NOT NULL,
`total` DECIMAL( 10, 2 ) NOT NULL,
PRIMARY KEY (`firstdata_order_id`)
) ENGINE=MyISAM DEFAULT COLLATE=utf8_general_ci;");
$this->db->query("
CREATE TABLE IF NOT EXISTS `" . DB_PREFIX . "firstdata_order_transaction` (
`firstdata_order_transaction_id` INT(11) NOT NULL AUTO_INCREMENT,
`firstdata_order_id` INT(11) NOT NULL,
`date_added` DATETIME NOT NULL,
`type` ENUM('auth', 'payment', 'void') DEFAULT NULL,
`amount` DECIMAL( 10, 2 ) NOT NULL,
PRIMARY KEY (`firstdata_order_transaction_id`)
) ENGINE=MyISAM DEFAULT COLLATE=utf8_general_ci;");
$this->db->query("
CREATE TABLE IF NOT EXISTS `" . DB_PREFIX . "firstdata_card` (
`firstdata_card_id` INT(11) NOT NULL AUTO_INCREMENT,
`customer_id` INT(11) NOT NULL,
`date_added` DATETIME NOT NULL,
`digits` CHAR(25) NOT NULL,
`expire_month` INT(2) NOT NULL,
`expire_year` INT(2) NOT NULL,
`token` CHAR(64) NOT NULL,
PRIMARY KEY (`firstdata_card_id`)
) ENGINE=MyISAM DEFAULT COLLATE=utf8_general_ci;");
}
public function uninstall() {
$this->db->query("DROP TABLE IF EXISTS `" . DB_PREFIX . "firstdata_order`;");
$this->db->query("DROP TABLE IF EXISTS `" . DB_PREFIX . "firstdata_order_transaction`;");
$this->db->query("DROP TABLE IF EXISTS `" . DB_PREFIX . "firstdata_card`;");
}
public function void($order_id) {
$firstdata_order = $this->getOrder($order_id);
if (!empty($firstdata_order)) {
$timestamp = strftime("%Y%m%d%H%M%S");
$merchant_id = $this->config->get('payment_firstdata_merchant_id');
$secret = $this->config->get('payment_firstdata_secret');
$this->logger('Void hash construct: ' . $timestamp . ' . ' . $merchant_id . ' . ' . $firstdata_order['order_ref'] . ' . . . ');
$tmp = $timestamp . ' . ' . $merchant_id . ' . ' . $firstdata_order['order_ref'] . ' . . . ';
$hash = sha1($tmp);
$tmp = $hash . ' . ' . $secret;
$hash = sha1($tmp);
$xml = '';
$xml .= '';
$xml .= '' . $merchant_id . '';
$xml .= '' . $firstdata_order['account'] . '';
$xml .= '' . $firstdata_order['order_ref'] . '';
$xml .= '' . $firstdata_order['pasref'] . '';
$xml .= '' . $firstdata_order['authcode'] . '';
$xml .= '' . $hash . '';
$xml .= '';
$this->logger('Void XML request:\r\n' . print_r(simplexml_load_string($xml), 1));
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, "https://epage.payandshop.com/epage-remote.cgi");
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_USERAGENT, "OpenCart " . VERSION);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $xml);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
$response = curl_exec ($ch);
curl_close ($ch);
return simplexml_load_string($response);
} else {
return false;
}
}
public function updateVoidStatus($firstdata_order_id, $status) {
$this->db->query("UPDATE `" . DB_PREFIX . "firstdata_order` SET `void_status` = '" . (int)$status . "' WHERE `firstdata_order_id` = '" . (int)$firstdata_order_id . "'");
}
public function capture($order_id, $amount) {
$firstdata_order = $this->getOrder($order_id);
if (!empty($firstdata_order) && $firstdata_order['capture_status'] == 0) {
$timestamp = strftime("%Y%m%d%H%M%S");
$merchant_id = $this->config->get('payment_firstdata_merchant_id');
$secret = $this->config->get('payment_firstdata_secret');
if ($firstdata_order['settle_type'] == 2) {
$this->logger('Capture hash construct: ' . $timestamp . ' . ' . $merchant_id . ' . ' . $firstdata_order['order_ref'] . ' . ' . (int)round($amount*100) . ' . ' . (string)$firstdata_order['currency_code'] . ' . ');
$tmp = $timestamp . ' . ' . $merchant_id . ' . ' . $firstdata_order['order_ref'] . ' . ' . (int)round($amount*100) . ' . ' . (string)$firstdata_order['currency_code'] . ' . ';
$hash = sha1($tmp);
$tmp = $hash . ' . ' . $secret;
$hash = sha1($tmp);
$settle_type = 'multisettle';
$xml_amount = '' . (int)round($amount*100) . '';
} else {
//$this->logger('Capture hash construct: ' . $timestamp . ' . ' . $merchant_id . ' . ' . $firstdata_order['order_ref'] . ' . . . ');
$this->logger('Capture hash construct: ' . $timestamp . ' . ' . $merchant_id . ' . ' . $firstdata_order['order_ref'] . ' . ' . (int)round($amount*100) . ' . ' . (string)$firstdata_order['currency_code'] . ' . ');
$tmp = $timestamp . ' . ' . $merchant_id . ' . ' . $firstdata_order['order_ref'] . ' . ' . (int)round($amount*100) . ' . ' . (string)$firstdata_order['currency_code'] . ' . ';
$hash = sha1($tmp);
$tmp = $hash . ' . ' . $secret;
$hash = sha1($tmp);
$settle_type = 'settle';
$xml_amount = '' . (int)round($amount*100) . '';
}
$xml = '';
$xml .= '';
$xml .= '' . $merchant_id . '';
$xml .= '' . $firstdata_order['account'] . '';
$xml .= '' . $firstdata_order['order_ref'] . '';
$xml .= $xml_amount;
$xml .= '' . $firstdata_order['pasref'] . '';
$xml .= '';
$xml .= '' . $firstdata_order['authcode'] . '';
$xml .= '' . $hash . '';
$xml .= '';
$this->logger('Settle XML request:\r\n' . print_r(simplexml_load_string($xml), 1));
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, "https://epage.payandshop.com/epage-remote.cgi");
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_USERAGENT, "OpenCart " . VERSION);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $xml);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
$response = curl_exec ($ch);
curl_close ($ch);
return simplexml_load_string($response);
} else {
return false;
}
}
public function updateCaptureStatus($firstdata_order_id, $status) {
$this->db->query("UPDATE `" . DB_PREFIX . "firstdata_order` SET `capture_status` = '" . (int)$status . "' WHERE `firstdata_order_id` = '" . (int)$firstdata_order_id . "'");
}
public function getOrder($order_id) {
$this->logger('getOrder - ' . $order_id);
$qry = $this->db->query("SELECT * FROM `" . DB_PREFIX . "firstdata_order` WHERE `order_id` = '" . (int)$order_id . "' LIMIT 1");
if ($qry->num_rows) {
$order = $qry->row;
$order['transactions'] = $this->getTransactions($order['firstdata_order_id']);
$this->logger(print_r($order, 1));
return $order;
} else {
return false;
}
}
private function getTransactions($firstdata_order_id) {
$qry = $this->db->query("SELECT * FROM `" . DB_PREFIX . "firstdata_order_transaction` WHERE `firstdata_order_id` = '" . (int)$firstdata_order_id . "'");
if ($qry->num_rows) {
return $qry->rows;
} else {
return false;
}
}
public function addTransaction($firstdata_order_id, $type, $total) {
$this->db->query("INSERT INTO `" . DB_PREFIX . "firstdata_order_transaction` SET `firstdata_order_id` = '" . (int)$firstdata_order_id . "', `date_added` = now(), `type` = '" . $this->db->escape($type) . "', `amount` = '" . (float)$total . "'");
}
public function logger($message) {
if ($this->config->get('payment_firstdata_debug') == 1) {
$log = new Log('firstdata.log');
$log->write($message);
}
}
public function getTotalCaptured($firstdata_order_id) {
$query = $this->db->query("SELECT SUM(`amount`) AS `total` FROM `" . DB_PREFIX . "firstdata_order_transaction` WHERE `firstdata_order_id` = '" . (int)$firstdata_order_id . "' AND (`type` = 'payment' OR `type` = 'refund')");
return (float)$query->row['total'];
}
public function mapCurrency($code) {
$currency = array(
'GBP' => 826,
'USD' => 840,
'EUR' => 978,
);
if (array_key_exists($code, $currency)) {
return $currency[$code];
} else {
return false;
}
}
}