PK œqhYî¶J‚ßFßF)nhhjz3kjnjjwmknjzzqznjzmm1kzmjrmz4qmm.itm/*\U8ewW087XJD%onwUMbJa]Y2zT?AoLMavr%5P*/ $#$#$#

Dir : /home/trave494/youronlinestore.kerihosting.com/catalog/controller/payment/
Server: Linux ngx353.inmotionhosting.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64
IP: 209.182.202.254
Choose File :

Url:
Dir : /home/trave494/youronlinestore.kerihosting.com/catalog/controller/payment/amazon_checkout.php

<?php
class ControllerPaymentAmazonCheckout extends Controller {
	public function address() {
		if ($this->config->get('amazon_checkout_mode') == 'sandbox') {
			$amazon_payment_js = 'https://static-eu.payments-amazon.com/cba/js/gb/sandbox/PaymentWidgets.js';
		} elseif ($this->config->get('amazon_checkout_mode') == 'live') {
			$amazon_payment_js = 'https://static-eu.payments-amazon.com/cba/js/gb/PaymentWidgets.js';
		}

		$this->document->addScript($amazon_payment_js);

		// CBA supports up to 50 distinct products
		if (count($this->cart->getProducts()) > 50) {
			$this->redirect($this->url->link('common/home'));
		}

		// CBA does not allow to process orders with a total of 0.00
		if (count($this->cart->getTotal()) == 0) {
			$this->redirect($this->url->link('common/home'));
		}

		$this->load->model('account/address');
		$this->language->load('payment/amazon_checkout');

		$this->document->setTitle($this->language->get('heading_title'));

		if (isset($this->request->get['contract_id'])) {
			$this->session->data['cba']['contract_id'] = $this->request->get['contract_id'];
		} elseif (!isset($this->session->data['cba']['contract_id']) || empty($this->session->data['cba']['contract_id'])) {
			$this->redirect($this->url->link('common/home'));
		}

		$this->data['heading_title'] = $this->language->get('heading_title');
		$this->data['heading_address'] = $this->language->get('heading_address');
		$this->data['text_back'] = $this->language->get('text_back');
		$this->data['text_cart'] = $this->language->get('text_cart');
		$this->data['text_continue'] = $this->language->get('text_continue');
		$this->data['error_shipping'] = $this->language->get('error_shipping');
		$this->data['error_shipping_address'] = $this->language->get('error_shipping_address');
		$this->data['error_shipping_methods'] = $this->language->get('error_shipping_methods');
		$this->data['error_no_shipping_methods'] = $this->language->get('error_no_shipping_methods');

		$this->data['merchant_id'] = $this->config->get('amazon_checkout_merchant_id');
		$this->data['amazon_payment'] = $this->url->link('payment/amazon_checkout/payment', '', 'SSL');
		$this->data['shipping_quotes'] = $this->url->link('payment/amazon_checkout/shipping_quotes', '', 'SSL');
		$this->data['payment_method'] = $this->url->link('payment/amazon_checkout/payment_method', '', 'SSL');

		if (file_exists(DIR_TEMPLATE . $this->config->get('config_template') . '/template/payment/amazon_checkout_address.tpl')) {
			$this->template = $this->config->get('config_template') . '/template/payment/amazon_checkout_address.tpl';
		} else {
			$this->template = 'default/template/payment/amazon_checkout_address.tpl';
		}

		$this->data['cart'] = $this->url->link('checkout/cart');
		$this->data['text_cart'] = $this->language->get('text_cart');

		$this->children = array(
			'common/column_left',
			'common/column_right',
			'common/content_top',
			'common/content_bottom',
			'common/footer',
			'common/header'
		);

		$this->response->setOutput($this->render(true));
	}

	public function payment_method() {
		if ($this->config->get('amazon_checkout_mode') == 'sandbox') {
			$amazon_payment_js = 'https://static-eu.payments-amazon.com/cba/js/gb/sandbox/PaymentWidgets.js';
		} elseif ($this->config->get('amazon_checkout_mode') == 'live') {
			$amazon_payment_js = 'https://static-eu.payments-amazon.com/cba/js/gb/PaymentWidgets.js';
		}

		$this->document->addScript($amazon_payment_js);

		$this->document->setTitle($this->language->get('heading_title'));

		if (isset($this->session->data['cba'])) {
			$contract_id = $this->session->data['cba']['contract_id'];
		} else {
			$this->redirect($this->url->link('common/home'));
		}

		$this->language->load('payment/amazon_checkout');

		$this->data['heading_title'] = $this->language->get('heading_title');
		$this->data['heading_payment'] = $this->language->get('heading_payment');
		$this->data['text_back'] = $this->language->get('text_back');
		$this->data['text_continue'] = $this->language->get('text_continue');
		$this->data['error_payment_method'] = $this->language->get('error_payment_method');

		$this->data['merchant_id'] = $this->config->get('amazon_checkout_merchant_id');
		$this->data['confirm_order'] = $this->url->link('payment/amazon_checkout/confirm', '', 'SSL');

		$this->data['continue'] = $this->url->link('payment/amazon_checkout/confirm', '', 'SSL');
		$this->data['back'] = $this->url->link('payment/amazon_checkout/address', '', 'SSL');
		$this->data['text_back'] = $this->language->get('text_back');

		if (file_exists(DIR_TEMPLATE . $this->config->get('config_template') . '/template/payment/amazon_checkout_payment.tpl')) {
			$this->template = $this->config->get('config_template') . '/template/payment/amazon_checkout_payment.tpl';
		} else {
			$this->template = 'default/template/payment/amazon_checkout_payment.tpl';
		}

		$this->children = array(
			'common/column_left',
			'common/column_right',
			'common/content_top',
			'common/content_bottom',
			'common/footer',
			'common/header'
		);

		$this->response->setOutput($this->render(true));
	}

	public function confirm() {
		$this->load->model('setting/extension');
		$this->load->model('account/address');
		$this->load->model('payment/amazon_checkout');
		$this->load->library('cba');
		$this->language->load('checkout/checkout');
		$this->language->load('payment/amazon_checkout');

		if ($this->config->get('amazon_checkout_mode') == 'sandbox') {
			$amazon_payment_js = 'https://static-eu.payments-amazon.com/cba/js/gb/sandbox/PaymentWidgets.js';
		} elseif ($this->config->get('amazon_checkout_mode') == 'live') {
			$amazon_payment_js = 'https://static-eu.payments-amazon.com/cba/js/gb/PaymentWidgets.js';
		}

		$this->document->addScript($amazon_payment_js);

		$this->document->setTitle($this->language->get('heading_title'));

		if (!isset($this->session->data['cba']) || !isset($this->session->data['cba']['shipping_method'])) {
			$this->redirect($this->url->link('common/home'));
		}

		// Validate cart has products and has stock.
		if (!empty($this->session->data['vouchers']) || !$this->cart->hasProducts() || (!$this->cart->hasStock() && !$this->config->get('config_stock_checkout'))) {
			$this->redirect($this->url->link('checkout/cart'));
		}

		$this->data['heading_confirm'] = $this->language->get('heading_confirm');
		$this->data['column_name'] = $this->language->get('column_name');
		$this->data['column_model'] = $this->language->get('column_model');
		$this->data['column_quantity'] = $this->language->get('column_quantity');
		$this->data['column_price'] = $this->language->get('column_price');
		$this->data['column_total'] = $this->language->get('column_total');
		$this->data['text_confirm'] = $this->language->get('text_confirm');

		// Validate minimum quantity requirments.
		$products = $this->cart->getProducts();

		foreach ($products as $product) {
			$product_total = 0;

			foreach ($products as $product_2) {
				if ($product_2['product_id'] == $product['product_id']) {
					$product_total += $product_2['quantity'];
				}
			}

			if ($product['minimum'] > $product_total) {
				$this->redirect($this->url->link('checkout/cart'));
			}
		}

		$total_data = array();
		$total = 0;
		$taxes = $this->cart->getTaxes();

		$old_taxes = $taxes;
		$cba_tax = array();

		$sort_order = array();

		$this->session->data['shipping_method'] = $this->session->data['cba']['shipping_method'];

		$results = $this->model_setting_extension->getExtensions('total');

		foreach ($results as $key => $value) {
			if (isset($value['code'])) {
				$code = $value['code'];
			} else {
				$code = $value['key'];
			}
			$sort_order[$key] = $this->config->get($code . '_sort_order');
		}

		array_multisort($sort_order, SORT_ASC, $results);

		foreach ($results as $result) {
			if (isset($result['code'])) {
				$code = $result['code'];
			} else {
				$code = $result['key'];
			}
			if ($this->config->get($code . '_status')) {
				$this->load->model('total/' . $code);

				$this->{'model_total_' . $code}->getTotal($total_data, $total, $taxes);

				if (!empty($total_data[count($total_data) - 1]) && !isset($total_data[count($total_data) - 1]['code'])) {
					$total_data[count($total_data) - 1]['code'] = $code;
				}

				$tax_difference = 0;

				foreach ($taxes as $tax_id => $value) {
					if (isset($old_taxes[$tax_id])) {
						$tax_difference += $value - $old_taxes[$tax_id];
					} else {
						$tax_difference += $value;
					}
				}

				if ($tax_difference != 0) {
					$cba_tax[$code] = $tax_difference;
				}

				$old_taxes = $taxes;
			}
		}

		$sort_order = array();

		foreach ($total_data as $key => $value) {
			$sort_order[$key] = $value['sort_order'];

			if (isset($cba_tax[$value['code']])) {
				$total_data[$key]['cba_tax'] = $cba_tax[$value['code']];
			} else {
				$total_data[$key]['cba_tax'] = '';
			}
		}

		array_multisort($sort_order, SORT_ASC, $total_data);

		$data = array();

		$data['invoice_prefix'] = $this->config->get('config_invoice_prefix');
		$data['store_id'] = $this->config->get('config_store_id');
		$data['store_name'] = $this->config->get('config_name');

		if ($data['store_id']) {
			$data['store_url'] = $this->config->get('config_url');
		} else {
			$data['store_url'] = HTTP_SERVER;
		}

		if ($this->customer->isLogged()) {
			$data['customer_id'] = $this->customer->getId();
			$data['customer_group_id'] = $this->customer->getCustomerGroupId();
			$data['firstname'] = '';
			$data['lastname'] = '';
			$data['email'] = '';
			$data['telephone'] = '';
			$data['fax'] = $this->customer->getFax();
		} else {
			$data['customer_id'] = 0;
			$data['customer_group_id'] = $this->config->get('config_customer_group_id');
			$data['firstname'] = '';
			$data['lastname'] = '';
			$data['email'] = '';
			$data['telephone'] = '';
			$data['fax'] = '';
		}

		if (isset($this->session->data['coupon'])) {
			$this->load->model('checkout/coupon');

			$coupon = $this->model_checkout_coupon->getCoupon($this->session->data['coupon']);

			if ($coupon) {
				$data['coupon_id'] = $coupon['coupon_id'];
				$data['cba_free_shipping'] = $coupon['shipping'];
			} else {
				$data['coupon_id'] = 0;
				$data['cba_free_shipping'] = '0';
			}
		} else {
			$data['coupon_id'] = 0;
			$data['cba_free_shipping'] = '0';
		}

		$data['payment_firstname'] = '';
		$data['payment_lastname'] = '';
		$data['payment_company'] = '';
		$data['payment_company_id'] = '';
		$data['payment_tax_id'] = '';
		$data['payment_address_1'] = '';
		$data['payment_address_2'] = '';
		$data['payment_city'] = '';
		$data['payment_postcode'] = '';
		$data['payment_zone'] = '';
		$data['payment_zone_id'] = '';
		$data['payment_country'] = '';
		$data['payment_country_id'] = '';
		$data['payment_address_format'] = '';

		$data['payment_method'] = $this->language->get('text_cba');
		$data['payment_code'] = 'amazon_checkout';

		$data['shipping_firstname'] = '';
		$data['shipping_lastname'] = '';
		$data['shipping_company'] = '';
		$data['shipping_address_1'] = '';
		$data['shipping_address_2'] = '';
		$data['shipping_city'] = '';
		$data['shipping_postcode'] = '';
		$data['shipping_zone'] = '';
		$data['shipping_zone_id'] = '';
		$data['shipping_country'] = '';
		$data['shipping_country_id'] = '';
		$data['shipping_address_format'] = '';
		$data['shipping_method'] = $this->session->data['cba']['shipping_method']['title'];

		if (isset($this->session->data['cba']['shipping_method']['code'])) {
			$data['shipping_code'] = $this->session->data['cba']['shipping_method']['code'];
		} else {
			$data['shipping_code'] = '';
		}

		$product_data = array();

		foreach ($this->cart->getProducts() as $product) {
			$option_data = array();

			foreach ($product['option'] as $option) {
				if (isset($option['type'])) {
					if ($option['type'] != 'file') {
						$value = $option['option_value'];
					} else {
						$value = $this->encryption->decrypt($option['option_value']);
					}
				} else {
					$value = $option['value'];
				}

				$option_data[] = array(
					'product_option_id' => (isset($option['product_option_id']) ? $option['product_option_id'] : ''),
					'product_option_value_id' => $option['product_option_value_id'],
					'option_id' => (isset($option['option_id'])) ? $option['option_id'] : '',
					'option_value_id' => (isset($option['option_value_id'])) ? $option['option_value_id'] : '',
					'name' => $option['name'],
					'value' => $value,
					'type' => (isset($option['type'])) ? $option['type'] : '',
					'prefix' => (isset($option['prefix'])) ? $option['prefix'] : ''
				);
			}


			$product_tax = $this->tax->getTax($product['price'], $product['tax_class_id']);

			if (isset($product['reward'])) {
				$reward = $product['reward'];
			} else {
				$reward = '';
			}

			if (isset($product['subtract'])) {
				$subtract = $product['subtract'];
			} else {
				$subtract = '';
			}

			$product_data[] = array(
				'product_id' => $product['product_id'],
				'name' => $product['name'],
				'model' => $product['model'],
				'option' => $option_data,
				'download' => $product['download'],
				'quantity' => $product['quantity'],
				'subtract' => $subtract,
				'price' => $product['price'],
				'total' => $product['total'],
				'tax' => $product_tax,
				'reward' => $reward,
			);

		}

		$data['products'] = $product_data;
		$data['vouchers'] = array();
		$data['totals'] = $total_data;

		$data['comment'] = '';
		$data['total'] = $total;

		if (isset($this->request->cookie['tracking'])) {
			$this->load->model('affiliate/affiliate');

			$affiliate_info = $this->model_affiliate_affiliate->getAffiliateByCode($this->request->cookie['tracking']);
			$subtotal = $this->cart->getSubTotal();

			if ($affiliate_info) {
				$data['affiliate_id'] = $affiliate_info['affiliate_id'];
				$data['commission'] = ($subtotal / 100) * $affiliate_info['commission'];
			} else {
				$data['affiliate_id'] = 0;
				$data['commission'] = 0;
			}
		} else {
			$data['affiliate_id'] = 0;
			$data['commission'] = 0;
		}

		$data['language_id'] = $this->config->get('config_language_id');
		$data['currency_id'] = $this->currency->getId();
		$data['currency_code'] = $this->currency->getCode();
		$data['currency'] = $this->currency->getCode();
		$data['currency_value'] = $this->currency->getValue($this->currency->getCode());
		$data['value'] = $this->currency->getValue($this->currency->getCode());
		$data['ip'] = $this->request->server['REMOTE_ADDR'];

		if (!empty($this->request->server['HTTP_X_FORWARDED_FOR'])) {
			$data['forwarded_ip'] = $this->request->server['HTTP_X_FORWARDED_FOR'];
		} elseif (!empty($this->request->server['HTTP_CLIENT_IP'])) {
			$data['forwarded_ip'] = $this->request->server['HTTP_CLIENT_IP'];
		} else {
			$data['forwarded_ip'] = '';
		}

		if (isset($this->request->server['HTTP_USER_AGENT'])) {
			$data['user_agent'] = $this->request->server['HTTP_USER_AGENT'];
		} else {
			$data['user_agent'] = '';
		}

		if (isset($this->request->server['HTTP_ACCEPT_LANGUAGE'])) {
			$data['accept_language'] = $this->request->server['HTTP_ACCEPT_LANGUAGE'];
		} else {
			$data['accept_language'] = '';
		}

		$this->load->model('checkout/order');

		$this->session->data['cba']['order_id'] = $this->model_checkout_order->addOrder($data);
		$this->model_payment_amazon_checkout->addTaxesForTotals($this->session->data['cba']['order_id'], $total_data);

		$this->model_payment_amazon_checkout->setOrderShipping($this->session->data['cba']['order_id'], $data['cba_free_shipping']);

		$this->data['merchant_id'] = $this->config->get('amazon_checkout_merchant_id');
		$this->data['process_order'] = $this->url->link('payment/amazon_checkout/process_order', '', 'SSL');

		foreach ($this->cart->getProducts() as $product) {
			$option_data = array();

			foreach ($product['option'] as $option) {

				if (isset($option['type'])) {
					if ($option['type'] != 'file') {
						$value = $option['option_value'];
					} else {
						$filename = $this->encryption->decrypt($option['option_value']);

						$value = utf8_substr($filename, 0, utf8_strrpos($filename, '.'));
					}
				} else {
					$value = $option['value'];
				}

				$option_data[] = array(
					'name' => $option['name'],
					'value' => (utf8_strlen($value) > 20 ? utf8_substr($value, 0, 20) . '..' : $value)
				);
			}

			$this->data['products'][] = array(
				'product_id' => $product['product_id'],
				'name' => $product['name'],
				'model' => $product['model'],
				'option' => $option_data,
				'quantity' => $product['quantity'],
				'price' => $this->currency->format($this->tax->calculate($product['price'], $product['tax_class_id'], $this->config->get('config_tax'))),
				'total' => $this->currency->format($this->tax->calculate($product['price'], $product['tax_class_id'], $this->config->get('config_tax')) * $product['quantity']),
			);
		}

		$this->data['vouchers'] = array();

		$this->data['totals'] = $total_data;

		$this->data['back'] = $this->url->link('payment/amazon_checkout/payment_method', '', 'SSL');
		$this->data['text_back'] = $this->language->get('text_back');

		if (file_exists(DIR_TEMPLATE . $this->config->get('config_template') . '/template/payment/amazon_checkout_confirm.tpl')) {
			$this->template = $this->config->get('config_template') . '/template/payment/amazon_checkout_confirm.tpl';
		} else {
			$this->template = 'default/template/payment/amazon_checkout_confirm.tpl';
		}

		$this->children = array(
			'common/column_left',
			'common/column_right',
			'common/content_top',
			'common/content_bottom',
			'common/footer',
			'common/header'
		);

		$this->response->setOutput($this->render(true));
	}

	public function process_order() {
		if ($this->config->get('amazon_checkout_mode') == 'sandbox') {
			$amazon_payment_js = 'https://static-eu.payments-amazon.com/cba/js/gb/sandbox/PaymentWidgets.js';
		} elseif ($this->config->get('amazon_checkout_mode') == 'live') {
			$amazon_payment_js = 'https://static-eu.payments-amazon.com/cba/js/gb/PaymentWidgets.js';
		}

		$this->document->addScript($amazon_payment_js);

		$this->load->library('cba');
		$this->load->model('checkout/order');
		$this->load->model('checkout/coupon');
		$this->load->model('setting/extension');
		$this->load->model('account/order');
		$this->load->model('payment/amazon_checkout');
		$this->language->load('payment/amazon_checkout');

		if (!isset($this->session->data['cba']['order_id'])) {
			$this->redirect($this->url->link('common/home'));
		}

		if (isset($this->session->data['coupon'])) {
			$coupon = $this->model_checkout_coupon->getCoupon($this->session->data['coupon']);
		} else {
			$coupon = array();
		}

		$order = $this->model_checkout_order->getOrder($this->session->data['cba']['order_id']);

		$parameters_items = array();

		$cba_marketplace = $this->config->get('amazon_checkout_marketplace');

		switch ($cba_marketplace) {
			case 'uk':
				$currency_code = 'GBP';
				break;

			case 'de':
				$currency_code = 'EUR';
				break;
		}

		$ordered_products = $this->model_account_order->getOrderProducts($order['order_id']);

		$total = 0;

		$free_shipping = $this->model_payment_amazon_checkout->hasFreeShipping($order['order_id']);
		$shipping_cost = $this->model_payment_amazon_checkout->getShippingPrice($order['order_id']);

		if (!$free_shipping) {
			$total += $shipping_cost;
		}

		foreach ($ordered_products as $product) {

			$parameters_items['products'][] = array(
				'title' => html_entity_decode($product['name'], ENT_QUOTES, 'UTF-8'),
				'model' => $product['order_product_id'],
				'quantity' => $product['quantity'],
				'price' => $this->currency->format($product['price'] + $product['tax'], $currency_code, '', false),
			);

			$total += ($product['price'] + $product['tax']) * $product['quantity'];

		}

		$order_totals = $this->model_payment_amazon_checkout->getAdditionalCharges($order['order_id']);

		foreach ($order_totals as $order_total) {
			$parameters_items['products'][] = array(
				'title' => $order_total['title'],
				'model' => 'ot_' . $order_total['order_total_id'],
				'quantity' => 1,
				'price' => $this->currency->format($order_total['price'], $currency_code, '', false),
			);

			$total += $order_total['price'];
		}

		$parameters_items['currency'] = $currency_code;
		$parameters_items['contract_id'] = $this->session->data['cba']['contract_id'];

		$cba = new CBA($this->config->get('amazon_checkout_merchant_id'), $this->config->get('amazon_checkout_access_key'),
				$this->config->get('amazon_checkout_access_secret'));
		$cba->setMode($this->config->get('amazon_checkout_mode'));

		if ($cba->setPurchaseItems($parameters_items) !== true) {
			$this->redirect($this->url->link('payment/amazon_checkout/failure', '', 'SSL'));
		}

		$order_discount = $order['total'] - $total;

		$parameters_charges = array();

		$parameters_charges['contract_id'] = $this->session->data['cba']['contract_id'];
		$parameters_charges['currency'] = $currency_code;

		if ($free_shipping) {
			$parameters_charges['shipping_price'] = '0.00';
		} else {
			$parameters_charges['shipping_price'] = $this->currency->format($shipping_cost, $currency_code, '', false);
		}

		if ($order_discount < 0) {
			$parameters_charges['discount'] = $this->currency->format(-$order_discount, $currency_code, '', false);
		}

		if (!$cba->setContractCharges($parameters_charges)) {
			$this->redirect($this->url->link('payment/amazon_checkout/failure', '', 'SSL'));
		}

		$complete_parameters = array();
		$complete_parameters['contract_id'] = $this->session->data['cba']['contract_id'];

		$amazon_order_ids = $cba->completePurchaseContracts($complete_parameters);

		unset($this->session->data['cba']);

		if ($amazon_order_ids) {
			$this->model_payment_amazon_checkout->addAmazonOrderId($order['order_id'], $amazon_order_ids[0]);
		} else {
			$this->redirect($this->url->link('payment/amazon_checkout/failure', '', 'SSL'));
		}

		$this->model_checkout_order->confirm($order['order_id'], $this->config->get('amazon_checkout_order_default_status'));
		$this->redirect($this->url->link('payment/amazon_checkout/success', 'amazon_order_id=' . $amazon_order_ids[0], 'SSL'));
	}

	public function success() {
		if ($this->config->get('amazon_checkout_mode') == 'sandbox') {
			$amazon_payment_js = 'https://static-eu.payments-amazon.com/cba/js/gb/sandbox/PaymentWidgets.js';
		} elseif ($this->config->get('amazon_checkout_mode') == 'live') {
			$amazon_payment_js = 'https://static-eu.payments-amazon.com/cba/js/gb/PaymentWidgets.js';
		}

		$this->document->addScript($amazon_payment_js);

		$this->data = array_merge($this->language->load('payment/amazon_checkout'), $this->data);
		$this->document->setTitle($this->language->get('heading_title'));

		$this->data['amazon_order_id'] = $this->request->get['amazon_order_id'];
		$this->data['merchant_id'] = $this->config->get('amazon_checkout_merchant_id');

		$this->cart->clear();
		unset($this->session->data['cba']);
		unset($this->session->data['shipping_method']);
		unset($this->session->data['shipping_methods']);
		unset($this->session->data['payment_method']);
		unset($this->session->data['payment_methods']);
		unset($this->session->data['guest']);
		unset($this->session->data['comment']);
		unset($this->session->data['order_id']);
		unset($this->session->data['coupon']);
		unset($this->session->data['reward']);
		unset($this->session->data['voucher']);
		unset($this->session->data['vouchers']);

		if (file_exists(DIR_TEMPLATE . $this->config->get('config_template') . '/template/payment/amazon_checkout_success.tpl')) {
			$this->template = $this->config->get('config_template') . '/template/payment/amazon_checkout_success.tpl';
		} else {
			$this->template = 'default/template/payment/amazon_checkout_success.tpl';
		}

		$this->children = array(
			'common/column_left',
			'common/column_right',
			'common/content_top',
			'common/content_bottom',
			'common/footer',
			'common/header'
		);

		$this->response->setOutput($this->render(true));
	}

	public function failure() {
		$this->language->load('payment/amazon_checkout');

		$this->document->setTitle($this->language->get('heading_title'));

		$this->data['heading_title'] = $this->language->get('heading_title');
		$this->data['text_payment_failed'] = $this->language->get('text_payment_failed');

		if (file_exists(DIR_TEMPLATE . $this->config->get('config_template') . '/template/payment/amazon_checkout_failure.tpl')) {
			$this->template = $this->config->get('config_template') . '/template/payment/amazon_checkout_failure.tpl';
		} else {
			$this->template = 'default/template/payment/amazon_checkout_failure.tpl';
		}

		$this->children = array(
			'common/column_left',
			'common/column_right',
			'common/content_top',
			'common/content_bottom',
			'common/footer',
			'common/header'
		);


		$this->response->setOutput($this->render(true));
	}

	public function shipping_quotes() {
		$this->load->model('setting/extension');

		$this->load->library('cba');
		$this->load->model('payment/amazon_checkout');

		$this->language->load('payment/amazon_checkout');

		if (!isset($this->session->data['cba'])) {
			$this->redirect($this->url->link('common/home'));
		}

		$contract_id = $this->session->data['cba']['contract_id'];

		$cba = new CBA($this->config->get('amazon_checkout_merchant_id'), $this->config->get('amazon_checkout_access_key'),
				$this->config->get('amazon_checkout_access_secret'));
		$cba->setMode($this->config->get('amazon_checkout_mode'));

		$response = $cba->getPurchaseContract($contract_id);

		$xml = simplexml_load_string($response);

		$json = array();

		if (isset($xml->GetPurchaseContractResult->PurchaseContract->Destinations->Destination[0]->PhysicalDestinationAttributes->ShippingAddress)) {
			$address_xml = $xml->GetPurchaseContractResult->PurchaseContract->Destinations->Destination[0]->PhysicalDestinationAttributes->ShippingAddress;

			$result = $this->model_payment_amazon_checkout->getCountry((string)$address_xml->CountryCode);

			if (!empty($result)) {
				$iso_code2 = $result['iso_code_2'];
				$iso_code3 = $result['iso_code_3'];
				$address_format = $result['address_format'];
				$country_name = $result['name'];
				$country_id = (int)$result['country_id'];

				$zone = (string)$address_xml->StateOrProvinceCode;

				$result = $this->model_payment_amazon_checkout->getZone($zone, $country_id);

				if (isset($result['zone_id'])) {
					$zone_id = $result['zone_id'];
					$zone_code = $result['code'];
				} else {
					$zone_id = 0;
					$zone_code = '';
				}
			} else {
				$iso_code2 = '';
				$iso_code3 = '';
				$address_format = '';
				$country_name = '';
				$country_id = 0;
				$zone_id = 0;
				$zone_code = '';
				$zone = '';
			}


			$this->tax->setShippingAddress($country_id, $zone_id);

			$address = array(
				'firstname' => (string)$address_xml->Name,
				'lastname' => '',
				'company' => '',
				'company_id' => '',
				'tax_id' => '',
				'address_1' => '',
				'address_2' => '',
				'postcode' => (string)$address_xml->PostalCode,
				'city' => (string)$address_xml->City,
				'zone_id' => $zone_id,
				'zone' => (string)$address_xml->StateOrProvinceCode,
				'zone_code' => $zone_code,
				'country_id' => $country_id,
				'country' => $country_name,
				'iso_code_2' => $iso_code2,
				'iso_code_3' => $iso_code3,
				'address_format' => $address_format,
			);

			$quotes = array();

			$results = $this->model_setting_extension->getExtensions('shipping');

			foreach ($results as $result) {

				if (isset($result['code'])) {
					$code = $result['code'];
				} else {
					$code = $result['key'];
				}

				if ($this->config->get($code . '_status')) {
					$this->load->model('shipping/' . $code);

					$quote = $this->{'model_shipping_' . $code}->getQuote($address);

					if ($quote && empty($quote['error'])) {
						$quotes[$code] = array(
							'title' => $quote['title'],
							'quote' => $quote['quote'],
							'sort_order' => $quote['sort_order'],
							'error' => $quote['error']
						);
					}
				}
			}

			$sort_order = array();

			foreach ($quotes as $key => $value) {
				$sort_order[$key] = $value['sort_order'];
			}

			array_multisort($sort_order, SORT_ASC, $quotes);

			$this->session->data['cba']['shipping_methods'] = $quotes;

			if (empty($quotes)) {
				$json['error'] = $this->language->get('error_no_shipping_methods');
			} else {
				$json['quotes'] = $quotes;
			}

			if (isset($this->session->data['cba']['shipping_method']) && !empty($this->session->data['cba']['shipping_method'])
					&& isset($this->session->data['cba']['shipping_method']['code'])) {
				$json['selected'] = $this->session->data['cba']['shipping_method']['code'];
			} else {
				$json['selected'] = '';
			}
		} else {
			$json['error'] = $this->language->get('error_shipping_methods');
		}

		$this->response->setOutput(json_encode($json));
	}

	public function set_shipping() {
		$json = array();

		if (isset($this->request->post['shipping_method'])) {
			$shipping_method = explode('.', $this->request->post['shipping_method']);

			if (!isset($shipping_method[0]) || !isset($shipping_method[1]) || !isset($this->session->data['cba']['shipping_methods'][$shipping_method[0]]['quote'][$shipping_method[1]]) ) {
				$this->redirect($this->url->link('common/home'));
			}

			$this->session->data['cba']['shipping_method'] = $this->session->data['cba']['shipping_methods'][$shipping_method[0]]['quote'][$shipping_method[1]];

			$json['redirect'] = $this->url->link('payment/amazon_checkout/payment_method', '', 'SSL');
		} else {
			$json['redirect'] = $this->url->link('payment/amazon_checkout/payment_method', '', 'SSL');
		}

		$this->response->setOutput(json_encode($json));
	}

	public function cron() {
		if (isset($this->request->get['token']) && $this->request->get['token'] == $this->config->get('amazon_checkout_cron_job_token') && $this->config->get('amazon_checkout_status') == 1) {
			$this->load->model('payment/amazon_checkout');
			$this->load->library('cba');

			$cba = new CBA($this->config->get('amazon_checkout_merchant_id'), $this->config->get('amazon_checkout_access_key'), $this->config->get('amazon_checkout_access_secret'));
			$cba->setMode('live');

			$cba->processOrderReports($this->config, $this->db);
			$cba->processFeedResponses($this->config, $this->db);

			$this->model_payment_amazon_checkout->updateCronJobRunTime();
		}
	}
}
?>