roykin/controllers/front/AddressController.php
Thibault UBUNTU 3d7f60a05e push site
2016-03-03 10:33:17 +01:00

371 lines
15 KiB
PHP
Executable File

<?php
/*
* 2007-2015 PrestaShop
*
* NOTICE OF LICENSE
*
* This source file is subject to the Open Software License (OSL 3.0)
* that is bundled with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* http://opensource.org/licenses/osl-3.0.php
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to license@prestashop.com so we can send you a copy immediately.
*
* DISCLAIMER
*
* Do not edit or add to this file if you wish to upgrade PrestaShop to newer
* versions in the future. If you wish to customize PrestaShop for your
* needs please refer to http://www.prestashop.com for more information.
*
* @author PrestaShop SA <contact@prestashop.com>
* @copyright 2007-2015 PrestaShop SA
* @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
* International Registered Trademark & Property of PrestaShop SA
*/
class AddressControllerCore extends FrontController
{
public $auth = true;
public $guestAllowed = true;
public $php_self = 'address';
public $authRedirection = 'addresses';
public $ssl = true;
/**
* @var Address Current address
*/
protected $_address;
protected $id_country;
/**
* Set default medias for this controller
*/
public function setMedia()
{
parent::setMedia();
$this->addJS(array(
_THEME_JS_DIR_.'tools/vatManagement.js',
_THEME_JS_DIR_.'tools/statesManagement.js',
_PS_JS_DIR_.'validate.js'
));
}
/**
* Initialize address controller
* @see FrontController::init()
*/
public function init()
{
parent::init();
// Get address ID
$id_address = 0;
if ($this->ajax && Tools::isSubmit('type')) {
if (Tools::getValue('type') == 'delivery' && isset($this->context->cart->id_address_delivery)) {
$id_address = (int)$this->context->cart->id_address_delivery;
} elseif (Tools::getValue('type') == 'invoice' && isset($this->context->cart->id_address_invoice)
&& $this->context->cart->id_address_invoice != $this->context->cart->id_address_delivery) {
$id_address = (int)$this->context->cart->id_address_invoice;
}
} else {
$id_address = (int)Tools::getValue('id_address', 0);
}
// Initialize address
if ($id_address) {
$this->_address = new Address($id_address);
if (Validate::isLoadedObject($this->_address) && Customer::customerHasAddress($this->context->customer->id, $id_address)) {
if (Tools::isSubmit('delete')) {
if ($this->_address->delete()) {
if ($this->context->cart->id_address_invoice == $this->_address->id) {
unset($this->context->cart->id_address_invoice);
}
if ($this->context->cart->id_address_delivery == $this->_address->id) {
unset($this->context->cart->id_address_delivery);
$this->context->cart->updateAddressId($this->_address->id, (int)Address::getFirstCustomerAddressId(Context::getContext()->customer->id));
}
Tools::redirect('index.php?controller=addresses');
}
$this->errors[] = Tools::displayError('This address cannot be deleted.');
}
} elseif ($this->ajax) {
exit;
} else {
Tools::redirect('index.php?controller=addresses');
}
}
}
/**
* Start forms process
* @see FrontController::postProcess()
*/
public function postProcess()
{
if (Tools::isSubmit('submitAddress')) {
$this->processSubmitAddress();
} elseif (!Validate::isLoadedObject($this->_address) && Validate::isLoadedObject($this->context->customer)) {
$_POST['firstname'] = $this->context->customer->firstname;
$_POST['lastname'] = $this->context->customer->lastname;
$_POST['company'] = $this->context->customer->company;
}
}
/**
* Process changes on an address
*/
protected function processSubmitAddress()
{
$address = new Address();
$this->errors = $address->validateController();
$address->id_customer = (int)$this->context->customer->id;
// Check page token
if ($this->context->customer->isLogged() && !$this->isTokenValid()) {
$this->errors[] = Tools::displayError('Invalid token.');
}
// Check phone
if (Configuration::get('PS_ONE_PHONE_AT_LEAST') && !Tools::getValue('phone') && !Tools::getValue('phone_mobile')) {
$this->errors[] = Tools::displayError('You must register at least one phone number.');
}
if ($address->id_country) {
// Check country
if (!($country = new Country($address->id_country)) || !Validate::isLoadedObject($country)) {
throw new PrestaShopException('Country cannot be loaded with address->id_country');
}
if ((int)$country->contains_states && !(int)$address->id_state) {
$this->errors[] = Tools::displayError('This country requires you to chose a State.');
}
if (!$country->active) {
$this->errors[] = Tools::displayError('This country is not active.');
}
$postcode = Tools::getValue('postcode');
/* Check zip code format */
if ($country->zip_code_format && !$country->checkZipCode($postcode)) {
$this->errors[] = sprintf(Tools::displayError('The Zip/Postal code you\'ve entered is invalid. It must follow this format: %s'), str_replace('C', $country->iso_code, str_replace('N', '0', str_replace('L', 'A', $country->zip_code_format))));
} elseif (empty($postcode) && $country->need_zip_code) {
$this->errors[] = Tools::displayError('A Zip/Postal code is required.');
} elseif ($postcode && !Validate::isPostCode($postcode)) {
$this->errors[] = Tools::displayError('The Zip/Postal code is invalid.');
}
// Check country DNI
if ($country->isNeedDni() && (!Tools::getValue('dni') || !Validate::isDniLite(Tools::getValue('dni')))) {
$this->errors[] = Tools::displayError('The identification number is incorrect or has already been used.');
} elseif (!$country->isNeedDni()) {
$address->dni = null;
}
}
// Check if the alias exists
if (!$this->context->customer->is_guest && !empty($_POST['alias']) && (int)$this->context->customer->id > 0) {
$id_address = Tools::getValue('id_address');
if (Configuration::get('PS_ORDER_PROCESS_TYPE') && (int)Tools::getValue('opc_id_address_'.Tools::getValue('type')) > 0) {
$id_address = Tools::getValue('opc_id_address_'.Tools::getValue('type'));
}
if (Address::aliasExist(Tools::getValue('alias'), (int)$id_address, (int)$this->context->customer->id)) {
$this->errors[] = sprintf(Tools::displayError('The alias "%s" has already been used. Please select another one.'), Tools::safeOutput(Tools::getValue('alias')));
}
}
// Check the requires fields which are settings in the BO
$this->errors = array_merge($this->errors, $address->validateFieldsRequiredDatabase());
// Don't continue this process if we have errors !
if ($this->errors && !$this->ajax) {
return;
}
// If we edit this address, delete old address and create a new one
if (Validate::isLoadedObject($this->_address)) {
if (Validate::isLoadedObject($country) && !$country->contains_states) {
$address->id_state = 0;
}
$address_old = $this->_address;
if (Customer::customerHasAddress($this->context->customer->id, (int)$address_old->id)) {
if ($address_old->isUsed()) {
$address_old->delete();
} else {
$address->id = (int)$address_old->id;
$address->date_add = $address_old->date_add;
}
}
}
if ($this->ajax && Configuration::get('PS_ORDER_PROCESS_TYPE')) {
$this->errors = array_unique(array_merge($this->errors, $address->validateController()));
if (count($this->errors)) {
$return = array(
'hasError' => (bool)$this->errors,
'errors' => $this->errors
);
$this->ajaxDie(Tools::jsonEncode($return));
}
}
// Save address
if ($result = $address->save()) {
// Update id address of the current cart if necessary
if (isset($address_old) && $address_old->isUsed()) {
$this->context->cart->updateAddressId($address_old->id, $address->id);
} else { // Update cart address
$this->context->cart->autosetProductAddress();
}
if ((bool)Tools::getValue('select_address', false) == true || (Tools::getValue('type') == 'invoice' && Configuration::get('PS_ORDER_PROCESS_TYPE'))) {
$this->context->cart->id_address_invoice = (int)$address->id;
} elseif (Configuration::get('PS_ORDER_PROCESS_TYPE')) {
$this->context->cart->id_address_invoice = (int)$this->context->cart->id_address_delivery;
}
$this->context->cart->update();
if ($this->ajax) {
$return = array(
'hasError' => (bool)$this->errors,
'errors' => $this->errors,
'id_address_delivery' => (int)$this->context->cart->id_address_delivery,
'id_address_invoice' => (int)$this->context->cart->id_address_invoice
);
$this->ajaxDie(Tools::jsonEncode($return));
}
// Redirect to old page or current page
if ($back = Tools::getValue('back')) {
if ($back == Tools::secureReferrer(Tools::getValue('back'))) {
Tools::redirect(html_entity_decode($back));
}
$mod = Tools::getValue('mod');
Tools::redirect('index.php?controller='.$back.($mod ? '&back='.$mod : ''));
} else {
Tools::redirect('index.php?controller=addresses');
}
}
$this->errors[] = Tools::displayError('An error occurred while updating your address.');
}
/**
* Assign template vars related to page content
* @see FrontController::initContent()
*/
public function initContent()
{
parent::initContent();
$this->assignCountries();
$this->assignVatNumber();
$this->assignAddressFormat();
// Assign common vars
$this->context->smarty->assign(array(
'address_validation' => Address::$definition['fields'],
'one_phone_at_least' => (int)Configuration::get('PS_ONE_PHONE_AT_LEAST'),
'onr_phone_at_least' => (int)Configuration::get('PS_ONE_PHONE_AT_LEAST'), //retro compat
'ajaxurl' => _MODULE_DIR_,
'errors' => $this->errors,
'token' => Tools::getToken(false),
'select_address' => (int)Tools::getValue('select_address'),
'address' => $this->_address,
'id_address' => (Validate::isLoadedObject($this->_address)) ? $this->_address->id : 0
));
if ($back = Tools::getValue('back')) {
$this->context->smarty->assign('back', Tools::safeOutput($back));
}
if ($mod = Tools::getValue('mod')) {
$this->context->smarty->assign('mod', Tools::safeOutput($mod));
}
if (isset($this->context->cookie->account_created)) {
$this->context->smarty->assign('account_created', 1);
unset($this->context->cookie->account_created);
}
$this->setTemplate(_PS_THEME_DIR_.'address.tpl');
}
/**
* Assign template vars related to countries display
*/
protected function assignCountries()
{
$this->id_country = (int)Tools::getCountry($this->_address);
// Generate countries list
if (Configuration::get('PS_RESTRICT_DELIVERED_COUNTRIES')) {
$countries = Carrier::getDeliveredCountries($this->context->language->id, true, true);
} else {
$countries = Country::getCountries($this->context->language->id, true);
}
// @todo use helper
$list = '';
foreach ($countries as $country) {
$selected = ((int)$country['id_country'] === $this->id_country) ? ' selected="selected"' : '';
$list .= '<option value="'.(int)$country['id_country'].'"'.$selected.'>'.htmlentities($country['name'], ENT_COMPAT, 'UTF-8').'</option>';
}
// Assign vars
$this->context->smarty->assign(array(
'countries_list' => $list,
'countries' => $countries,
'sl_country' => (int)$this->id_country,
));
}
/**
* Assign template vars related to address format
*/
protected function assignAddressFormat()
{
$id_country = is_null($this->_address)? (int)$this->id_country : (int)$this->_address->id_country;
$requireFormFieldsList = AddressFormat::getFieldsRequired();
$ordered_adr_fields = AddressFormat::getOrderedAddressFields($id_country, true, true);
$ordered_adr_fields = array_unique(array_merge($ordered_adr_fields, $requireFormFieldsList));
$this->context->smarty->assign(array(
'ordered_adr_fields' => $ordered_adr_fields,
'required_fields' => $requireFormFieldsList
));
}
/**
* Assign template vars related to vat number
* @todo move this in vatnumber module !
*/
protected function assignVatNumber()
{
$vat_number_exists = file_exists(_PS_MODULE_DIR_.'vatnumber/vatnumber.php');
$vat_number_management = Configuration::get('VATNUMBER_MANAGEMENT');
if ($vat_number_management && $vat_number_exists) {
include_once(_PS_MODULE_DIR_.'vatnumber/vatnumber.php');
}
if ($vat_number_management && $vat_number_exists && VatNumber::isApplicable((int)Tools::getCountry())) {
$vat_display = 2;
} elseif ($vat_number_management) {
$vat_display = 1;
} else {
$vat_display = 0;
}
$this->context->smarty->assign(array(
'vatnumber_ajax_call' => file_exists(_PS_MODULE_DIR_.'vatnumber/ajax.php'),
'vat_display' => $vat_display,
));
}
public function displayAjax()
{
if (count($this->errors)) {
$return = array(
'hasError' => !empty($this->errors),
'errors' => $this->errors
);
$this->ajaxDie(Tools::jsonEncode($return));
}
}
}