Current Path : /home/sudancam/.trash/catalog.1/controller/checkout/ |
Current File : /home/sudancam/.trash/catalog.1/controller/checkout/payment_address.php |
<?php namespace Opencart\Catalog\Controller\Checkout; class PaymentAddress extends \Opencart\System\Engine\Controller { public function index(): string { $this->load->language('checkout/payment_address'); $data['error_upload_size'] = sprintf($this->language->get('error_upload_size'), $this->config->get('config_file_max_size')); $data['config_file_max_size'] = ((int)$this->config->get('config_file_max_size') * 1024 * 1024); $data['upload'] = $this->url->link('tool/upload', 'language=' . $this->config->get('config_language')); $data['language'] = $this->config->get('config_language'); $data['shipping_required'] = $this->cart->hasShipping(); // Set payment address $this->load->model('account/address'); if ($this->customer->isLogged() && !isset($this->session->data['payment_address'])) { $address_info = $this->model_account_address->getAddress($this->customer->getAddressId()); if ($address_info) { $this->session->data['payment_address'] = $address_info; } } if (isset($this->session->data['payment_address']['address_id'])) { $data['address_id'] = (int)$this->session->data['payment_address']['address_id']; } else { $data['address_id'] = 0; } $data['addresses'] = $this->model_account_address->getAddresses(); $this->load->model('localisation/country'); $data['countries'] = $this->model_localisation_country->getCountries(); // Custom Fields $data['custom_fields'] = []; $this->load->model('account/custom_field'); $custom_fields = $this->model_account_custom_field->getCustomFields($this->customer->getGroupId()); foreach ($custom_fields as $custom_field) { if ($custom_field['location'] == 'address') { $data['custom_fields'][] = $custom_field; } } return $this->load->view('checkout/payment_address', $data); } public function save(): void { $this->load->language('checkout/payment_address'); $json = []; // Validate cart has products and has stock. if ((!$this->cart->hasProducts() && empty($this->session->data['vouchers'])) || (!$this->cart->hasStock() && !$this->config->get('config_stock_checkout'))) { $json['redirect'] = $this->url->link('checkout/cart', 'language=' . $this->config->get('config_language'), true); } // Validate minimum quantity requirements. $products = $this->cart->getProducts(); foreach ($products as $product) { if (!$product['minimum']) { $json['redirect'] = $this->url->link('checkout/cart', 'language=' . $this->config->get('config_language'), true); break; } } // Validate if customer is logged in or customer session data is not set if (!$this->customer->isLogged() || !isset($this->session->data['customer'])) { $json['redirect'] = $this->url->link('account/login', 'language=' . $this->config->get('config_language'), true); } // Validate if payment address is set if required in settings if (!$this->config->get('config_checkout_address')) { $json['redirect'] = $this->url->link('checkout/cart', 'language=' . $this->config->get('config_language'), true); } if (!$json) { $keys = [ 'firstname', 'lastname', 'company', 'address_1', 'address_2', 'city', 'postcode', 'country_id', 'zone_id', 'custom_field' ]; foreach ($keys as $key) { if (!isset($this->request->post[$key])) { $this->request->post[$key] = ''; } } if ((utf8_strlen($this->request->post['firstname']) < 1) || (utf8_strlen($this->request->post['firstname']) > 32)) { $json['error']['payment_firstname'] = $this->language->get('error_firstname'); } if ((utf8_strlen($this->request->post['lastname']) < 1) || (utf8_strlen($this->request->post['lastname']) > 32)) { $json['error']['payment_lastname'] = $this->language->get('error_lastname'); } if ((utf8_strlen($this->request->post['address_1']) < 3) || (utf8_strlen($this->request->post['address_1']) > 128)) { $json['error']['payment_address_1'] = $this->language->get('error_address_1'); } if ((utf8_strlen($this->request->post['city']) < 2) || (utf8_strlen($this->request->post['city']) > 32)) { $json['error']['payment_city'] = $this->language->get('error_city'); } $this->load->model('localisation/country'); $country_info = $this->model_localisation_country->getCountry((int)$this->request->post['country_id']); if ($country_info && $country_info['postcode_required'] && (utf8_strlen($this->request->post['postcode']) < 2 || utf8_strlen($this->request->post['postcode']) > 10)) { $json['error']['payment_postcode'] = $this->language->get('error_postcode'); } if ($this->request->post['country_id'] == '') { $json['error']['payment_country'] = $this->language->get('error_country'); } if ($this->request->post['zone_id'] == '') { $json['error']['payment_zone'] = $this->language->get('error_zone'); } // Custom field validation $this->load->model('account/custom_field'); $custom_fields = $this->model_account_custom_field->getCustomFields($this->customer->getGroupId()); foreach ($custom_fields as $custom_field) { if ($custom_field['location'] == 'address') { if ($custom_field['required'] && empty($this->request->post['custom_field'][$custom_field['custom_field_id']])) { $json['error']['payment_custom_field_' . $custom_field['custom_field_id']] = sprintf($this->language->get('error_custom_field'), $custom_field['name']); } elseif (($custom_field['type'] == 'text') && !empty($custom_field['validation']) && !preg_match(html_entity_decode($custom_field['validation'], ENT_QUOTES, 'UTF-8'), $this->request->post['custom_field'][$custom_field['custom_field_id']])) { $json['error']['payment_custom_field_' . $custom_field['custom_field_id']] = sprintf($this->language->get('error_regex'), $custom_field['name']); } } } } if (!$json) { // If no default address add it $address_id = $this->customer->getAddressId(); if (!$address_id) { $this->request->post['default'] = 1; } $this->load->model('account/address'); $json['address_id'] = $this->model_account_address->addAddress($this->customer->getId(), $this->request->post); $json['addresses'] = $this->model_account_address->getAddresses(); if ($country_info) { $country = $country_info['name']; $iso_code_2 = $country_info['iso_code_2']; $iso_code_3 = $country_info['iso_code_3']; $address_format = $country_info['address_format']; } else { $country = ''; $iso_code_2 = ''; $iso_code_3 = ''; $address_format = ''; } $this->load->model('localisation/zone'); $zone_info = $this->model_localisation_zone->getZone($this->request->post['zone_id']); if ($zone_info) { $zone = $zone_info['name']; $zone_code = $zone_info['code']; } else { $zone = ''; $zone_code = ''; } $this->session->data['payment_address'] = [ 'address_id' => $json['address_id'], 'firstname' => $this->request->post['firstname'], 'lastname' => $this->request->post['lastname'], 'company' => $this->request->post['company'], 'address_1' => $this->request->post['address_1'], 'address_2' => $this->request->post['address_2'], 'city' => $this->request->post['city'], 'postcode' => $this->request->post['postcode'], 'zone_id' => $this->request->post['zone_id'], 'zone' => $zone, 'zone_code' => $zone_code, 'country_id' => $this->request->post['country_id'], 'country' => $country, 'iso_code_2' => $iso_code_2, 'iso_code_3' => $iso_code_3, 'address_format' => $address_format, 'custom_field' => isset($this->request->post['custom_field']) ? $this->request->post['custom_field'] : [] ]; $json['success'] = $this->language->get('text_success'); unset($this->session->data['payment_methods']); } $this->response->addHeader('Content-Type: application/json'); $this->response->setOutput(json_encode($json)); } public function address(): void { $this->load->language('checkout/payment_address'); $json = []; if (isset($this->request->get['address_id'])) { $address_id = (int)$this->request->get['address_id']; } else { $address_id = 0; } if (!isset($this->session->data['customer'])) { $json['redirect'] = $this->url->link('checkout/cart', 'language=' . $this->config->get('config_language'), true); } // Validate cart has products and has stock. if ((!$this->cart->hasProducts() && empty($this->session->data['vouchers'])) || (!$this->cart->hasStock() && !$this->config->get('config_stock_checkout'))) { $json['redirect'] = $this->url->link('checkout/cart', 'language=' . $this->config->get('config_language'), true); } // Validate minimum quantity requirements. $products = $this->cart->getProducts(); foreach ($products as $product) { if (!$product['minimum']) { $json['redirect'] = $this->url->link('checkout/cart', 'language=' . $this->config->get('config_language'), true); break; } } // Validate if customer is logged in or customer session data is not set if (!$this->customer->isLogged() || !isset($this->session->data['customer'])) { $json['redirect'] = $this->url->link('account/login', 'language=' . $this->config->get('config_language'), true); } // Validate if payment address is set if required in settings if (!$this->config->get('config_checkout_address')) { $json['redirect'] = $this->url->link('checkout/cart', 'language=' . $this->config->get('config_language'), true); } if (!$json) { $this->load->model('account/address'); $address_info = $this->model_account_address->getAddress($address_id); if (!$address_info) { $json['error'] = $this->language->get('error_address'); } } if (!$json) { $this->session->data['payment_address'] = $address_info; $json['success'] = $this->language->get('text_success'); unset($this->session->data['payment_methods']); } $this->response->addHeader('Content-Type: application/json'); $this->response->setOutput(json_encode($json)); } }