Compare commits

..

12 Commits

Author SHA1 Message Date
Michael RICOIS
1d5578d66b Merge remote-tracking branch 'origin/ticket-14739-PackLogistic' 2018-03-27 10:20:34 +02:00
Michael RICOIS
922de8200a Fix quantity 2018-03-22 11:08:49 +01:00
Michael RICOIS
7699f86acd Save logisitic queue name in configuration 2018-03-21 10:32:59 +01:00
Michael RICOIS
76b26ac6b4 CS 2018-03-21 10:27:58 +01:00
Michael RICOIS
6b863fe940 Fix 2018-03-19 12:27:57 +01:00
Michael RICOIS
34e2bdc553 Merge remote-tracking branch 'origin/ticket/r16490-email_error' 2018-03-19 12:19:16 +01:00
Michael RICOIS
a4625499c0 Override email value 2018-03-15 11:21:41 +01:00
Michael RICOIS
eea2e769d1 Remove break point 2018-03-14 11:17:26 +01:00
Michael RICOIS
305234f74f CS 2018-03-12 12:58:54 +01:00
Michael RICOIS
1920a84634 Add rules 2018-03-12 11:52:00 +01:00
Michael RICOIS
d1d0642f91 Add a better way to correct email - to test 2018-03-09 17:54:36 +01:00
Michael RICOIS
197f4161d1 Add New Import 2018-02-26 11:46:03 +01:00
6 changed files with 536 additions and 148 deletions

View File

@ -79,7 +79,16 @@ class AdminImport extends AdminTab
public function __construct()
{
$this->entities = array_flip(array($this->l('Categories'), $this->l('Products'), $this->l('Combinations'), $this->l('Customers'), $this->l('Addresses'), $this->l('Manufacturers'), $this->l('Suppliers')));
$this->entities = array_flip(array(
$this->l('Categories'),
$this->l('Products'),
$this->l('Combinations'),
$this->l('Customers'),
$this->l('Addresses'),
$this->l('Manufacturers'),
$this->l('Suppliers'),
$this->l('Pack'),
));
switch ((int)(Tools::getValue('entity')))
{
@ -280,7 +289,19 @@ class AdminImport extends AdminTab
'meta_keywords' => array('label' => $this->l('Meta-keywords')),
'meta_description' => array('label' => $this->l('Meta-description')));
break;
case $this->entities[$this->l('Pack')]:
self::$required_fields = array('id_product_item', 'qty', 'id');
$this->available_fields = array(
'id_product_item' => array('label' => $this->l('ID Item')),
'qty' => array('label' => $this->l('Quantity Item')),
'id' => array('label' => $this->l('ID Pack')),
);
break;
}
parent::__construct();
}
@ -1292,6 +1313,51 @@ class AdminImport extends AdminTab
}
$this->closeCsvFile($handle);
}
public function packImport()
{
$this->receiveTab();
$handle = $this->openCsvFile();
self::setLocale();
for ($current_line = 0; $line = fgetcsv($handle, MAX_LINE_SIZE, Tools::getValue('separator')); $current_line++)
{
if (Tools::getValue('convert')) {
$line = $this->utf8_encode_array($line);
}
$info = self::getMaskedRow($line);
self::setDefaultValues($info);
// Is product a pack
if (array_key_exists('id', $info) && (int)($info['id']) && Pack::isPack((int)($info['id']))) {
$pack = new Pack((int)($info['id']));
}
else {
$pack = new Pack();
}
self::array_walk($info, array('AdminImport', 'fillInfo'), $pack);
if (($fieldError = $pack->validateFields(UNFRIENDLY_ERROR, true)) === true && is_numeric($info['qty']))
{
$res = false;
// Is product item in pack
if ($pack->isPacked($info['id_product_item'])) {
$res = $pack->updateItem($info['id'], $info['id_product_item'], $info['qty']);
}
// Insert
if (!$res) {
$res = $pack->addItem($info['id'], $info['id_product_item'], $info['qty']);
}
if (!$res) {
$this->_errors[] = mysql_error().' '.$info['id_product_item'].(isset($info['id']) ? ' (ID '.$info['id'].')' : '').' '.Tools::displayError('Cannot be saved');
}
}
else {
$this->_errors[] = ($fieldError !== true ? $fieldError : '').($langFieldError !== true ? $langFieldError : '');
}
}
$this->closeCsvFile($handle);
}
public function display()
{
@ -1824,6 +1890,9 @@ class AdminImport extends AdminTab
case $this->entities[$this->l('Suppliers')]:
$this->supplierImport();
break;
case $this->entities[$this->l('Pack')]:
$this->packImport();
break;
default:
$this->_errors[] = $this->l('no entity selected');
}

View File

@ -174,18 +174,30 @@ class PackCore extends Product
}
/**
* Add an item to the pack
*
* @param integer $id_product
* @param integer $id_item
* @param integer $qty
* @return boolean true if everything was fine
*/
* Add an item to the pack
* @param integer $id_product
* @param integer $id_item
* @param integer $qty
* @return boolean true if everything was fine
*/
public static function addItem($id_product, $id_item, $qty)
{
Db::getInstance()->Execute('UPDATE '._DB_PREFIX_.'product SET cache_is_pack = 1 WHERE id_product = '.(int)($id_product).' LIMIT 1');
return Db::getInstance()->AutoExecute(_DB_PREFIX_.'pack', array('id_product_pack' => (int)($id_product), 'id_product_item' => (int)($id_item), 'quantity' => (int)($qty)), 'INSERT');
}
/**
* Update item and his pack association
* @param integer $id_product
* @param integer $id_item
* @param integer $qty
* @return boolean true if everything was fine
*/
public static function updateItem($id_product, $id_item, $qty)
{
return Db::getInstance()->AutoExecute(_DB_PREFIX_.'pack', array('quantity' => (int)($qty)),
'UPDATE', 'id_product_pack='.(int)($id_product).' AND id_product_item='.(int)($id_item));
}
public static function duplicate($id_product_old, $id_product_new)
{

View File

@ -1,17 +1,12 @@
<?php
if (!defined('_PS_VERSION_')) {
if (!defined('_PS_VERSION_'))
exit;
}
require_once dirname(__FILE__).'/../privatesales/Sale.php';
class GoogleSitemap extends Module
{
class GoogleSitemap extends Module {
private $_html = '';
private $_postErrors = array();
public function __construct()
{
public function __construct() {
$this->name = 'googlesitemap';
$this->tab = 'seo';
$this->version = '1.2';
@ -23,18 +18,17 @@ class GoogleSitemap extends Module
$this->displayName = $this->l('Google sitemap with private sales support');
$this->description = $this->l('Generate your Google sitemap file');
if (!defined('GSITEMAP_FILE')) {
if(!defined('GSITEMAP_FILE')) {
define('GSITEMAP_FILE', dirname(__FILE__).'/../../sitemap.xml');
}
}
public function install()
{
if (!parent::install()) {
public function install() {
if(!parent::install()) {
return FALSE;
}
if (Module::isInstalled('privatesales')) {
if(Module::isInstalled('privatesales')) {
Db::getInstance()->Execute('
INSERT INTO `'._DB_PREFIX_.'privatesale_module`
VALUES (
@ -47,35 +41,31 @@ class GoogleSitemap extends Module
return TRUE;
}
public function uninstall()
{
public function uninstall() {
file_put_contents(GSITEMAP_FILE, '');
if (Module::isInstalled('privatesales')) {
if(Module::isInstalled('privatesales')) {
Db::getInstance()->Execute('DELETE FROM `'._DB_PREFIX_.'privatesale_module` WHERE `modulename` = "googlesitemap"');
}
return parent::uninstall();
}
private function _postValidation()
{
private function _postValidation() {
file_put_contents(GSITEMAP_FILE, '');
if (!($fp = fopen(GSITEMAP_FILE, 'w'))) {
if(!($fp = fopen(GSITEMAP_FILE, 'w'))) {
$this->_postErrors[] = $this->l('Cannot create').' '.realpath(dirname(__FILE__.'/../..')).'/'.$this->l('sitemap.xml file.');
} else {
fclose($fp);
}
}
public function generateSitemap()
{
public function generateSitemap() {
global $cookie;
$link = new Link();
$langs = Language::getLanguages();
$iso_code = Language::getIsoById((int) $cookie->id_lang);
$xmlString = <<<XML
<?xml version="1.0" encoding="UTF-8" ?>
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"
@ -85,7 +75,7 @@ XML;
$xml = new SimpleXMLElement($xmlString);
if (Configuration::get('PS_REWRITING_SETTINGS') && sizeof($langs) > 1) {
if(Configuration::get('PS_REWRITING_SETTINGS') && sizeof($langs) > 1) {
foreach($langs as $lang) {
$this->_addSitemapNode($xml, Tools::getShopDomain(true, true).__PS_BASE_URI__.$lang['iso_code'].'/', '1.00', 'daily', date('Y-m-d'));
}
@ -94,7 +84,7 @@ XML;
}
/* CMS Generator */
if (Configuration::get('GSITEMAP_ALL_CMS') || !Module::isInstalled('blockcms')) {
if(Configuration::get('GSITEMAP_ALL_CMS') || !Module::isInstalled('blockcms')) {
$sql_cms = '
SELECT DISTINCT '.(Configuration::get('PS_REWRITING_SETTINGS')? 'cl.id_cms, cl.link_rewrite, cl.id_lang': 'cl.id_cms').'
FROM `'._DB_PREFIX_.'cms_lang` cl
@ -118,25 +108,27 @@ XML;
$cmss = Db::getInstance(_PS_USE_SQL_SLAVE_)->ExecuteS($sql_cms);
foreach($cmss as $cms) {
$tmpLink = Configuration::get('PS_REWRITING_SETTINGS') ?
$link->getCMSLink((int)$cms['id_cms'], $cms['link_rewrite'], FALSE, (int)$cms['id_lang']) :
$link->getCMSLink((int)$cms['id_cms']);
$this->_addSitemapNode($xml, $tmpLink, '0.8', 'weekly');
$tmpLink = Configuration::get('PS_REWRITING_SETTINGS')? $link->getCMSLink((int)$cms['id_cms'], $cms['link_rewrite'], FALSE, (int) $cms['id_lang']): $link->getCMSLink((int)$cms['id_cms']);
$this->_addSitemapNode($xml, $tmpLink, '0.8', 'daily');
}
/* Categories Generator */
if (Module::isInstalled('privatesales')) {
$exclude_categories = array();
if(Module::isInstalled('privatesales')) {
include(dirname(__FILE__).'/../privatesales/Sale.php');
$has_trailers = file_exists(dirname(__FILE__).'/../privatesales/trailer.php');
$sales = Sale::getSales(true, null, null, 'all');
$sales = Sale::getSales(TRUE, NULL, NULL, 'not_ended');
foreach($sales as $sale) {
if ($has_trailers) {
$exclude_categories = array_merge($exclude_categories, Sale::getCategoriesFromCache($sale->id));
if($has_trailers) {
$trailers_i18n = array(
'fr' => 'bande-annonce',
'en' => 'trailer',
);
if (Configuration::get('PS_REWRITING_SETTINGS')) {
if (count($langs) > 1) {
if(Configuration::get('PS_REWRITING_SETTINGS')) {
if(count($langs) > 1) {
$this->_addSitemapNode($xml, Tools::getShopDomain(TRUE, TRUE).__PS_BASE_URI__.$iso_code.'/'.(isset($trailers_i18n[$iso_code])? $trailers_i18n[$iso_code]: $trailers_i18n['en']).'/'.$sale->id.'-'.Tools::str2url($sale->title[$cookie->id_lang]), '0.8', 'weekly');
} else {
$this->_addSitemapNode($xml, Tools::getShopDomain(TRUE, TRUE).__PS_BASE_URI__.(isset($trailers_i18n[$iso_code])? $trailers_i18n[$iso_code]: $trailers_i18n['en']).'/'.$sale->id.'-'.Tools::str2url($sale->title[$cookie->id_lang]), '0.8', 'weekly');
@ -146,58 +138,166 @@ XML;
}
}
}
}
// Liste des ventes actives
$sales = Sale::getSales(true, null, null, 'not_ended');
$products = array();
if (count($sales) > 0) {
foreach ($sales as $sale) {
$id_category = Db::getInstance(_PS_USE_SQL_SLAVE_)->getValue('
SELECT `id_category` FROM `'._DB_PREFIX_.'privatesale_category`
WHERE `id_sale`='.(int)$sale->id);
$category = new Category($id_category);
if (($priority = 0.9 - ($category->level_depth / 10)) < 0.1) {
$priority = 0.1;
$ordering = (int) Configuration::get('PRIVATESALES_FEATURED_ORDER');
if($ordering == 0) {
if(Module::isInstalled('privatesales_brands')) {
$sales = Sale::getSales(TRUE, (int) Configuration::get('PRIVATESALES_FEATURED_IGNORE') == 1? NULL: !((bool) Configuration::get('PRIVATESALES_GUESTLIST')), TRUE, (bool) Configuration::get('PRIVATESALES_FEATURED_CURRENT'), TRUE);
$brands = array();
foreach(Db::getInstance()->ExecuteS('
SELECT `id_brand`
FROM `'._DB_PREFIX_.'privatesale_brands`
WHERE `id_sale` IN ('.implode(', ', $sales).')
GROUP BY `id_brand`
') as $b) {
$brands[] = $b['id_brand'];
}
$manufacturers = Db::getInstance()->ExecuteS('
SELECT m.*, ml.`short_description`
FROM `'._DB_PREFIX_.'manufacturer` m
LEFT JOIN `'._DB_PREFIX_.'manufacturer_lang` ml
ON (
m.`id_manufacturer` = ml.`id_manufacturer`
AND ml.`id_lang` = '.(int) $cookie->id_lang.'
)
WHERE m.`active` = 1
AND m.`id_manufacturer` IN ('.implode(', ', $brands).')
ORDER BY m.`name` ASC
');
} else {
$manufacturers = Manufacturer::getManufacturers(TRUE, (int) $cookie->id_lang, TRUE, FALSE, FALSE, TRUE);
}
$tmpLink = Configuration::get('PS_REWRITING_SETTINGS') ?
$link->getCategoryLink((int)$category->id_category, $category->link_rewrite[1]) :
$link->getCategoryLink((int)$category->id_category);
$this->_addSitemapNode($xml, htmlspecialchars($tmpLink), $priority, 'daily', substr($category->date_upd, 0, 10));
$brands_i18n = array(
'fr' => 'marques',
'en' => 'brands',
);
foreach($manufacturers as $manufacturer) {
if(Configuration::get('PS_REWRITING_SETTINGS')) {
if(count($langs) > 1) {
$this->_addSitemapNode($xml, Tools::getShopDomain(true, true).__PS_BASE_URI__.$iso_code.'/'.(isset($brands_i18n[$iso_code])? $brands_i18n[$iso_code]: $brands_i18n['en']).'/'.$manufacturer['id_manufacturer'].'-'.Tools::str2url($manufacturer['name']), '0.8', 'weekly');
} else {
$this->_addSitemapNode($xml, Tools::getShopDomain(true, true).__PS_BASE_URI__.(isset($brands_i18n[$iso_code])? $brands_i18n[$iso_code]: $brands_i18n['en']).'/'.$manufacturer['id_manufacturer'].'-'.Tools::str2url($manufacturer['name']), '0.8', 'weekly');
}
} else {
$this->_addSitemapNode($xml, Tools::getShopDomain(true, true).__PS_BASE_URI__.'modules/privatesales/featured.php?id_brand='.$manufacturer['id_manufacturer'], '0.8', 'weekly');
}
}
}
}
if(Configuration::get('PS_REWRITING_SETTINGS')) {
$categories = Db::getInstance()->ExecuteS('
SELECT c.id_category, c.level_depth, link_rewrite, DATE_FORMAT(IF(date_upd,date_upd,date_add), \'%Y-%m-%d\') AS date_upd, cl.id_lang
FROM '._DB_PREFIX_.'category c
LEFT JOIN '._DB_PREFIX_.'category_lang cl
ON c.id_category = cl.id_category
LEFT JOIN '._DB_PREFIX_.'lang l
ON cl.id_lang = l.id_lang
WHERE l.`active` = 1
AND c.`active` = 1
AND c.id_category != 1
'.(count($exclude_categories) > 0? ' AND c.id_category NOT IN ('.implode(', ', $exclude_categories).')': '').'
ORDER BY cl.id_category, cl.id_lang ASC
');
} else {
$categories = Db::getInstance()->ExecuteS('
SELECT c.id_category, c.level_depth, DATE_FORMAT(IF(date_upd,date_upd,date_add), \'%Y-%m-%d\') AS date_upd
FROM '._DB_PREFIX_.'category c
'.(count($exclude_categories) > 0? ' AND c.id_category NOT IN ('.implode(', ', $exclude_categories).')': '').'
ORDER BY c.id_category ASC
');
}
foreach($categories as $category) {
if(($priority = 0.9 - ($category['level_depth'] / 10)) < 0.1) {
$priority = 0.1;
}
$tmpLink = Configuration::get('PS_REWRITING_SETTINGS')? $link->getCategoryLink((int)$category['id_category'], $category['link_rewrite'], (int)$category['id_lang']): $link->getCategoryLink((int)$category['id_category']);
$this->_addSitemapNode($xml, htmlspecialchars($tmpLink), $priority, 'weekly', substr($category['date_upd'], 0, 10));
}
$products = Db::getInstance(_PS_USE_SQL_SLAVE_)->ExecuteS('
SELECT p.id_product, pl.link_rewrite, DATE_FORMAT(IF(date_upd,date_upd,date_add), \'%Y-%m-%d\') date_upd, pl.id_lang, cl.`link_rewrite` category, ean13, i.id_image, il.legend legend_image, (
SELECT MIN(level_depth)
FROM '._DB_PREFIX_.'product p2
LEFT JOIN '._DB_PREFIX_.'category_product cp2
ON p2.id_product = cp2.id_product
LEFT JOIN '._DB_PREFIX_.'category c2
ON cp2.id_category = c2.id_category
WHERE p2.id_product = p.id_product AND p2.`active` = 1
AND c2.`active` = 1
) AS level_depth
FROM '._DB_PREFIX_.'product p
LEFT JOIN '._DB_PREFIX_.'product_lang pl
ON (p.id_product = pl.id_product)
LEFT JOIN `'._DB_PREFIX_.'category_lang` cl
ON (p.`id_category_default` = cl.`id_category` AND pl.`id_lang` = cl.`id_lang`)
LEFT JOIN '._DB_PREFIX_.'image i
ON p.id_product = i.id_product
LEFT JOIN `'._DB_PREFIX_.'image_lang` il
ON (i.`id_image` = il.`id_image`
AND pl.`id_lang` = il.`id_lang`)
LEFT JOIN '._DB_PREFIX_.'lang l
ON (pl.id_lang = l.id_lang)
WHERE l.`active` = 1
AND p.`active` = 1
'.(count($exclude_categories) > 0? ' AND p.id_category_default NOT IN ('.implode(', ', $exclude_categories).')': '').'
'.(Configuration::get('GSITEMAP_ALL_PRODUCTS') ? '' : 'HAVING level_depth IS NOT NULL').'
ORDER BY pl.id_product, pl.id_lang ASC
');
$tmp = NULL;
$res = NULL;
foreach($products as $product) {
if($tmp == $product['id_product']) {
$res[$tmp]['images'][] = array('id_image' => $product['id_image'], 'legend_image' => $product['legend_image']);
} else {
$tmp = $product['id_product'];
$res[$tmp] = $product;
unset($res[$tmp]['id_image'], $res[$tmp]['legend_image']);
$res[$tmp]['images'][] = array('id_image' => $product['id_image'], 'legend_image' => $product['legend_image']);
}
}
foreach($res as $product) {
if(($priority = 0.7 - ($product['level_depth'] / 10)) < 0.1) {
$priority = 0.1;
}
$tmpLink = $link->getProductLink((int) $product['id_product'], $product['link_rewrite'], $product['category'], $product['ean13'], (int) $product['id_lang']);
$sitemap = $this->_addSitemapNode($xml, htmlspecialchars($tmpLink), $priority, 'weekly', substr($product['date_upd'], 0, 10));
$sitemap = $this->_addSitemapNodeImage($sitemap, $product);
}
/* Add classic pages (contact, best sales, new products...) */
$pages = array(
'authentication' => true,
//'best-sales' => false,
'contact-form' => true,
//'discount' => false,
//'index' => true,
//'manufacturer' => false,
//'new-products' => false,
//'prices-drop' => false,
//'supplier' => false,
//'store' => false,
'authentication' => TRUE,
'best-sales' => FALSE,
'contact-form' => TRUE,
'discount' => FALSE,
'index' => FALSE,
'manufacturer' => FALSE,
'new-products' => FALSE,
'prices-drop' => FALSE,
'supplier' => FALSE,
'store' => FALSE,
);
// Don't show suppliers and manufacturers if they are disallowed
if (!Module::getInstanceByName('blockmanufacturer')->id && !Configuration::get('PS_DISPLAY_SUPPLIERS')) {
if(!Module::getInstanceByName('blockmanufacturer')->id && !Configuration::get('PS_DISPLAY_SUPPLIERS')) {
unset($pages['manufacturer']);
}
if (!Module::getInstanceByName('blocksupplier')->id && !Configuration::get('PS_DISPLAY_SUPPLIERS')) {
if(!Module::getInstanceByName('blocksupplier')->id && !Configuration::get('PS_DISPLAY_SUPPLIERS')) {
unset($pages['supplier']);
}
// Generate nodes for pages
if (Configuration::get('PS_REWRITING_SETTINGS')) {
if(Configuration::get('PS_REWRITING_SETTINGS')) {
foreach($pages as $page => $ssl) {
foreach($langs as $lang) {
$this->_addSitemapNode($xml, $link->getPageLink($page.'.php', $ssl, $lang['id_lang']), '0.5', 'monthly');
@ -208,7 +308,7 @@ XML;
$this->_addSitemapNode($xml, $link->getPageLink($page.'.php', $ssl), '0.5', 'monthly');
}
}
$xmlString = $xml->asXML();
$fp = fopen(GSITEMAP_FILE, 'w');
@ -217,8 +317,7 @@ XML;
}
private function _postProcess()
{
private function _postProcess() {
Configuration::updateValue('GSITEMAP_ALL_CMS', (int) Tools::getValue('GSITEMAP_ALL_CMS'));
Configuration::updateValue('GSITEMAP_ALL_PRODUCTS', (int) Tools::getValue('GSITEMAP_ALL_PRODUCTS'));
@ -230,31 +329,28 @@ XML;
$this->_html .= '</h3>';
}
private function getUrlWith($url, $key, $value)
{
if (empty($value)) {
private function getUrlWith($url, $key, $value) {
if(empty($value)) {
return $url;
}
if (strpos($url, '?') !== FALSE) {
if(strpos($url, '?') !== FALSE) {
return $url.'&'.$key.'='.$value;
}
return $url.'?'.$key.'='.$value;
}
private function _addSitemapNode($xml, $loc, $priority, $change_freq, $last_mod=NULL)
{
private function _addSitemapNode($xml, $loc, $priority, $change_freq, $last_mod=NULL) {
$sitemap = $xml->addChild('url');
$sitemap->addChild('loc', $loc);
$sitemap->addChild('priority', $priority);
if ($last_mod) {
if($last_mod) {
$sitemap->addChild('lastmod', $last_mod);
}
$sitemap->addChild('changefreq', $change_freq);
return $sitemap;
}
private function _addSitemapNodeImage($xml, $product)
{
private function _addSitemapNodeImage($xml, $product) {
foreach($product['images'] as $img) {
$link = new Link();
$image = $xml->addChild('image', NULL, 'http://www.google.com/schemas/sitemap-image/1.1');
@ -266,9 +362,8 @@ XML;
}
}
private function _displaySitemap()
{
if (file_exists(GSITEMAP_FILE) && filesize(GSITEMAP_FILE)) {
private function _displaySitemap() {
if(file_exists(GSITEMAP_FILE) && filesize(GSITEMAP_FILE)) {
$fp = fopen(GSITEMAP_FILE, 'r');
$fstat = fstat($fp);
fclose($fp);
@ -285,8 +380,7 @@ XML;
}
}
private function _displayForm()
{
private function _displayForm() {
$this->_html .=
'<form action="'.Tools::htmlentitiesUTF8($_SERVER['REQUEST_URI']).'" method="post">
<div style="margin:0 0 20px 0;">
@ -300,12 +394,11 @@ XML;
</form>';
}
public function getContent()
{
public function getContent() {
$this->_html .= '<h2>'.$this->l('Search Engine Optimization').'</h2>
'.$this->l('See').' <a href="https://www.google.com/webmasters/tools/docs/en/about.html" style="font-weight:bold;text-decoration:underline;" target="_blank">
'.$this->l('this page').'</a> '.$this->l('for more information').'<br /><br />';
if (Tools::isSubmit('btnSubmit')) {
if(Tools::isSubmit('btnSubmit')) {
$this->_postValidation();
if (!sizeof($this->_postErrors)) {
$this->_postProcess();

View File

@ -83,15 +83,115 @@ if($canSendInvitations) {
$friendsFirstName = Tools::getValue('friendsFirstName');
$mails_exists = array();
foreach ($friendsEmail AS $key => $friendEmail) {
$friendEmail = strval($friendEmail);
$friendEmail = trim($friendEmail);
/** @Override Antadis - mail fixing */
$friendEmail = str_replace(array('@hotmil.','@htmail.','@hotmal.','@hotml.','@hotmai.'),'@hotmail.',$friendEmail);
$friendEmail = str_replace(array('@gmal.','@gail.','@gml.','@gmai.','@gmil.'),'@gmail.',$friendEmail);
$friendEmail = str_replace('@gmailcom','@gmail.com',$friendEmail);
$friendEmail = str_replace('@hotmailcom','@hotmail.com',$friendEmail);
$friendEmail = str_replace('@hotmailfr','@hotmail.fr',$friendEmail);
/** @End Override Antadis - mail fixing */
$friendEmail = $emailOri = strtolower(trim(strval($friendEmail)));
// Prepare Check email
$domains = array(
/* Default domains included */
"aol.com", "att.net", "comcast.net", "facebook.com", "gmail.com", "gmx.com", "googlemail.com",
"google.com", "hotmail.com", "hotmail.co.uk", "mac.com", "me.com", "mail.com", "msn.com",
"live.com", "sbcglobal.net", "verizon.net", "yahoo.com", "yahoo.co.uk",
/* Other global domains */
"email.com", "fastmail.fm", "games.com" /* AOL */, "gmx.net", "hush.com", "hushmail.com", "icloud.com",
"iname.com", "inbox.com", "lavabit.com", "love.com" /* AOL */, "outlook.com", "pobox.com", "protonmail.com",
"rocketmail.com" /* Yahoo */, "safe-mail.net", "wow.com" /* AOL */, "ygm.com" /* AOL */,
"ymail.com" /* Yahoo */, "zoho.com", "yandex.com",
/* United States ISP domains */
"bellsouth.net", "charter.net", "cox.net", "earthlink.net", "juno.com",
/* British ISP domains */
"btinternet.com", "virginmedia.com", "blueyonder.co.uk", "freeserve.co.uk", "live.co.uk",
"ntlworld.com", "o2.co.uk", "orange.net", "sky.com", "talktalk.co.uk", "tiscali.co.uk",
"virgin.net", "wanadoo.co.uk", "bt.com",
/* Domains used in Asia */
"sina.com", "qq.com", "naver.com", "hanmail.net", "daum.net", "nate.com", "yahoo.co.jp", "yahoo.co.kr", "yahoo.co.id", "yahoo.co.in", "yahoo.com.sg", "yahoo.com.ph",
/* French ISP domains */
"hotmail.fr", "live.fr", "laposte.net", "yahoo.fr", "wanadoo.fr", "orange.fr", "gmx.fr", "sfr.fr", "neuf.fr", "free.fr",
/* German ISP domains */
"gmx.de", "hotmail.de", "live.de", "online.de", "t-online.de" /* T-Mobile */, "web.de", "yahoo.de",
/* Italian ISP domains */
"libero.it", "virgilio.it", "hotmail.it", "aol.it", "tiscali.it", "alice.it", "live.it", "yahoo.it", "email.it", "tin.it", "poste.it", "teletu.it",
/* Russian ISP domains */
"mail.ru", "rambler.ru", "yandex.ru", "ya.ru", "list.ru",
/* Belgian ISP domains */
"hotmail.be", "live.be", "skynet.be", "voo.be", "tvcablenet.be", "telenet.be",
/* Argentinian ISP domains */
"hotmail.com.ar", "live.com.ar", "yahoo.com.ar", "fibertel.com.ar", "speedy.com.ar", "arnet.com.ar",
/* Domains used in Mexico */
"yahoo.com.mx", "live.com.mx", "hotmail.es", "hotmail.com.mx", "prodigy.net.mx",
/* Domains used in Brazil */
"yahoo.com.br", "hotmail.com.br", "outlook.com.br", "uol.com.br", "bol.com.br", "terra.com.br", "ig.com.br", "itelefonica.com.br", "r7.com", "zipmail.com.br", "globo.com", "globomail.com", "oi.com.br"
);
// Real association
$replaceSLD = array(
'@hotmil.' => '@hotmail.',
'@htmail.' => '@hotmail.',
'@hotmal.' => '@hotmail.',
'@hotml.' => '@hotmail.',
'@hotmai.' => '@hotmail.',
'@gmal.' => '@gmail.',
'@gail.' => '@gmail.',
'@gml.' => '@gmail.',
'@gmai.' => '@gmail.',
'@gmil.' => '@gmail.',
);
$replaceGlobal = array(
'@gmailcom' => '@gmail.com',
'@hotmailcom' => '@hotmail.com',
'@hotmailfr' => '@hotmail.fr',
'@yahoocom' => '@yahoo.com',
'@yahoofr' => '@yahoo.fr',
);
// Real use case replacement
$friendEmail = strtr($friendEmail, $replaceGlobal);
// Check TLD
$atPos = strpos($friendEmail, '@');
$pointPos = strpos($friendEmail, '.', $atPos);
$tld = substr($friendEmail, $pointPos + 1);
$sld = substr($friendEmail, $atPos + 1, strlen($friendEmail) - ($atPos+1) - (strlen($tld)+1) );
if (empty($tld)) {
$errors[] = Tools::displayError('Invalid email');
$_POST['friendsEmail'] = '';
}
if (empty($errors)) {
// If you have a complete list of TLD, check it !
}
// Check SLD
if (empty($errors)) {
// Real use case replacement
$friendEmail = strtr($friendEmail, $replaceSLD);
// Levenhstein remplacement
if (count($domains) > 0 && $friendEmail == $emailOri) {
foreach ($domains as $d) {
$dpPos = strpos($d, '.');
$realDomain = substr($d, 0, $dpPos);
$lev = levenshtein($sld, $realDomain);
if ($lev == O) {
break;
}
elseif ($lev == 1 && $tld == substr($d, $dpPos+1)) {
$friendEmail = str_replace('@'.$sld.'.', '@'.$realDomain.'.', $friendEmail);
break;
}
}
}
}
if($askName) {
$friendLastName = strval($friendsLastName[$key]);
$friendFirstName = strval($friendsFirstName[$key]);

View File

@ -1,13 +1,14 @@
<?php
if(!defined('_PS_VERSION_')) {
if (!defined('_PS_VERSION_')) {
exit;
}
class Logistics extends Module {
class Logistics extends Module
{
public $_html = '';
public function __construct() {
public function __construct()
{
$this->name = 'logistics';
$this->tab = 'shipping_logistics';
$this->version = '2.0';
@ -20,7 +21,8 @@ class Logistics extends Module {
$this->description = $this->l('Allows to manage parcels');
}
public function install() {
public function install()
{
# Add admin tabs
$tabs_i18n = array(
'fr' => 'Gestion des envois',
@ -33,8 +35,8 @@ class Logistics extends Module {
$t->active = TRUE;
$t->module = 'logistics';
$t->class_name = 'AdminLogistics';
foreach(Language::getLanguages() as $lang) {
if(isset($tabs_i18n[$lang['iso_code']])) {
foreach (Language::getLanguages() as $lang) {
if (isset($tabs_i18n[$lang['iso_code']])) {
$t->name[$lang['id_lang']] = $tabs_i18n[$lang['iso_code']];
} else {
$t->name[$lang['id_lang']] = $tabs_i18n['en'];
@ -47,7 +49,8 @@ class Logistics extends Module {
&& $this->registerHook('updateCarrier');
}
private function installCarriers() {
private function installCarriers()
{
return
// La Poste
Db::getInstance()->Execute('
@ -150,7 +153,8 @@ class Logistics extends Module {
');
}
private function uninstallCarriers() {
private function uninstallCarriers()
{
/*Db::getInstance()->ExecuteS('DROP TABLE IF EXISTS `'._DB_PREFIX_.'lapostews`');
Db::getInstance()->ExecuteS('DROP TABLE IF EXISTS `'._DB_PREFIX_.'lapostews_pr`');
Db::getInstance()->ExecuteS('DROP TABLE IF EXISTS `'._DB_PREFIX_.'exapaqws`');
@ -161,14 +165,16 @@ class Logistics extends Module {
return TRUE;
}
public function uninstall() {
public function uninstall()
{
return $this->uninstallCarriers() && parent::uninstall();
}
public function getContent() {
public function getContent()
{
global $cookie;
if(Tools::isSubmit('submitUpdate')) {
if (Tools::isSubmit('submitUpdate')) {
/* La Poste */
Configuration::updateValue('LAPOSTEWS_CARRIERS', serialize(Tools::getValue('laposte_carriers', array())));
@ -326,13 +332,13 @@ class Logistics extends Module {
Configuration::updateValue('MONDIALRELAYWS_FTP_LOGIN', Tools::getValue('mondialrelay_ftp_login'));
Configuration::updateValue('MONDIALRELAYWS_FTP_PASSWORD', Tools::getValue('mondialrelay_ftp_password'));
// foreach(Tools::getValue('employee', array()) as $id_employee => $queue) {
// Configuration::updateValue('LOGISTICS_QUEUE_'.(int) $id_employee, $queue);
// }
// Set print queue - employe : name
foreach (Tools::getValue('employee', array()) as $id_employee => $queue) {
Configuration::updateValue('LOGISTICS_QUEUE_'.(int)$id_employee, $queue);
}
$lock = array();
foreach(explode(', ', Tools::getValue('lock_products')) as $item) {
foreach (explode(', ', Tools::getValue('lock_products')) as $item) {
$lock[] = (int) $item;
}
Configuration::updateValue('LOGISTICS_LOCK', serialize(implode(',', $lock)));
@ -459,7 +465,7 @@ class Logistics extends Module {
<label for="laposte_exp_country">'.$this->l('Country:').'</label>
<select name="laposte_exp_country">';
foreach(Country::getCountries((int) $cookie->id_lang) as $country) {
foreach (Country::getCountries((int) $cookie->id_lang) as $country) {
$this->_html .= '<option value="'.$country['id_country'].'"'.(Configuration::get('LAPOSTEWS_EXP_COUNTRY') == $country['id_country']? ' selected="selected"': '').'>'.$country['name'].'</option>';
}
@ -557,7 +563,7 @@ class Logistics extends Module {
';
$laposte_carriers = unserialize(Configuration::get('LAPOSTEWS_CARRIERS', serialize(array())));
foreach(Db::getInstance()->ExecuteS('
foreach (Db::getInstance()->ExecuteS('
SELECT c.*
FROM `'._DB_PREFIX_.'carrier` c
') as $carrier) {
@ -603,7 +609,7 @@ class Logistics extends Module {
<label for="exapaq_exp_country">'.$this->l('Country:').'</label>
<select name="exapaq_exp_country">';
foreach(Country::getCountries((int) $cookie->id_lang) as $country) {
foreach (Country::getCountries((int) $cookie->id_lang) as $country) {
$this->_html .= '<option value="'.$country['id_country'].'"'.(Configuration::get('EXAPAQWS_EXP_COUNTRY') == $country['id_country']? ' selected="selected"': '').'>'.$country['name'].'</option>';
}
@ -695,7 +701,7 @@ class Logistics extends Module {
';
$exapaq_carriers = unserialize(Configuration::get('EXAPAQWS_CARRIERS', serialize(array())));
foreach(Db::getInstance()->ExecuteS('
foreach (Db::getInstance()->ExecuteS('
SELECT c.*
FROM `'._DB_PREFIX_.'carrier` c
') as $carrier) {
@ -743,7 +749,7 @@ class Logistics extends Module {
<label for="mondialrelay_exp_country">'.$this->l('Country:').'</label>
<select name="mondialrelay_exp_country">';
foreach(Country::getCountries((int) $cookie->id_lang) as $country) {
foreach (Country::getCountries((int) $cookie->id_lang) as $country) {
$this->_html .= '<option value="'.$country['id_country'].'"'.(Configuration::get('MONDIALRELAY_EXP_COUNTRY') == $country['id_country']? ' selected="selected"': '').'>'.$country['name'].'</option>';
}
@ -804,7 +810,7 @@ class Logistics extends Module {
';
$mondialrelay_carriers = unserialize(Configuration::get('MONDIALRELAYWS_CARRIERS', serialize(array())));
foreach(Db::getInstance()->ExecuteS('
foreach (Db::getInstance()->ExecuteS('
SELECT c.*
FROM `'._DB_PREFIX_.'carrier` c
') as $carrier) {
@ -820,9 +826,9 @@ class Logistics extends Module {
<fieldset id="tab-4" style="line-height: 1.5em; display: none;">
';
foreach(Employee::getEmployees() as $employee) {
foreach (Employee::getEmployees() as $employee) {
$value = Configuration::get('LOGISTICS_QUEUE_'.(int) $employee['id_employee']);
// if($value === FALSE) {
// if ($value === FALSE) {
// $value = Configuration::get('LAPOSTEWS_EMPL_'.(int) $employee['id_employee']);
// }
@ -834,7 +840,7 @@ class Logistics extends Module {
}
$lock = Configuration::get('LOGISTICS_LOCK');
if($lock === FALSE || empty($lock)) {
if ($lock === false || empty($lock)) {
$lock = serialize(array());
}
@ -862,21 +868,21 @@ class Logistics extends Module {
$carriers = Configuration::get('LAPOSTEWS_CARRIERS');
if(in_array((int) $params['id_carrier'], $carriers)) {
if (in_array((int) $params['id_carrier'], $carriers)) {
$carriers[] = (int) $new_carrier_id;
Configuration::updateValue('LAPOSTEWS_CARRIERS', serialize($carriers));
}
$carriers = Configuration::get('EXAPAQWS_CARRIERS');
if(in_array((int) $params['id_carrier'], $carriers)) {
if (in_array((int) $params['id_carrier'], $carriers)) {
$carriers[] = (int) $new_carrier_id;
Configuration::updateValue('EXAPAQWS_CARRIERS', serialize($carriers));
}
$carriers = Configuration::get('MONDIALRELAYWS_CARRIERS');
if(in_array((int) $params['id_carrier'], $carriers)) {
if (in_array((int) $params['id_carrier'], $carriers)) {
$carriers[] = (int) $new_carrier_id;
Configuration::updateValue('MONDIALRELAYWS_CARRIERS', serialize($carriers));
}

View File

@ -114,15 +114,114 @@ class AuthController extends AuthControllerCore
if (Tools::getValue('guest_email') !== false) {
$email = Tools::getValue('guest_email');
}
$email = strtolower(trim($email));
$email = $emailOri = strtolower(trim($email));
/** @Override Antadis - mail fixing */
$email = str_replace(array('@hotmil.','@htmail.','@hotmal.','@hotml.','@hotmai.'),'@hotmail.', $email);
$email = str_replace(array('@gmal.','@gail.','@gml.','@gmai.','@gmil.'),'@gmail.', $email);
$email = str_replace('@gmailcom','@gmail.com', $email);
$email = str_replace('@hotmailcom','@hotmail.com', $email);
$email = str_replace('@hotmailfr','@hotmail.fr', $email);
/** @End Override Antadis - mail fixing */
// Prepare Check email
$domains = array(
/* Default domains included */
"aol.com", "att.net", "comcast.net", "facebook.com", "gmail.com", "gmx.com", "googlemail.com",
"google.com", "hotmail.com", "hotmail.co.uk", "mac.com", "me.com", "mail.com", "msn.com",
"live.com", "sbcglobal.net", "verizon.net", "yahoo.com", "yahoo.co.uk",
/* Other global domains */
"email.com", "fastmail.fm", "games.com" /* AOL */, "gmx.net", "hush.com", "hushmail.com", "icloud.com",
"iname.com", "inbox.com", "lavabit.com", "love.com" /* AOL */, "outlook.com", "pobox.com", "protonmail.com",
"rocketmail.com" /* Yahoo */, "safe-mail.net", "wow.com" /* AOL */, "ygm.com" /* AOL */,
"ymail.com" /* Yahoo */, "zoho.com", "yandex.com",
/* United States ISP domains */
"bellsouth.net", "charter.net", "cox.net", "earthlink.net", "juno.com",
/* British ISP domains */
"btinternet.com", "virginmedia.com", "blueyonder.co.uk", "freeserve.co.uk", "live.co.uk",
"ntlworld.com", "o2.co.uk", "orange.net", "sky.com", "talktalk.co.uk", "tiscali.co.uk",
"virgin.net", "wanadoo.co.uk", "bt.com",
/* Domains used in Asia */
"sina.com", "qq.com", "naver.com", "hanmail.net", "daum.net", "nate.com", "yahoo.co.jp", "yahoo.co.kr", "yahoo.co.id", "yahoo.co.in", "yahoo.com.sg", "yahoo.com.ph",
/* French ISP domains */
"hotmail.fr", "live.fr", "laposte.net", "yahoo.fr", "wanadoo.fr", "orange.fr", "gmx.fr", "sfr.fr", "neuf.fr", "free.fr",
/* German ISP domains */
"gmx.de", "hotmail.de", "live.de", "online.de", "t-online.de" /* T-Mobile */, "web.de", "yahoo.de",
/* Italian ISP domains */
"libero.it", "virgilio.it", "hotmail.it", "aol.it", "tiscali.it", "alice.it", "live.it", "yahoo.it", "email.it", "tin.it", "poste.it", "teletu.it",
/* Russian ISP domains */
"mail.ru", "rambler.ru", "yandex.ru", "ya.ru", "list.ru",
/* Belgian ISP domains */
"hotmail.be", "live.be", "skynet.be", "voo.be", "tvcablenet.be", "telenet.be",
/* Argentinian ISP domains */
"hotmail.com.ar", "live.com.ar", "yahoo.com.ar", "fibertel.com.ar", "speedy.com.ar", "arnet.com.ar",
/* Domains used in Mexico */
"yahoo.com.mx", "live.com.mx", "hotmail.es", "hotmail.com.mx", "prodigy.net.mx",
/* Domains used in Brazil */
"yahoo.com.br", "hotmail.com.br", "outlook.com.br", "uol.com.br", "bol.com.br", "terra.com.br", "ig.com.br", "itelefonica.com.br", "r7.com", "zipmail.com.br", "globo.com", "globomail.com", "oi.com.br"
);
// Real association
$replaceSLD = array(
'@hotmil.' => '@hotmail.',
'@htmail.' => '@hotmail.',
'@hotmal.' => '@hotmail.',
'@hotml.' => '@hotmail.',
'@hotmai.' => '@hotmail.',
'@gmal.' => '@gmail.',
'@gail.' => '@gmail.',
'@gml.' => '@gmail.',
'@gmai.' => '@gmail.',
'@gmil.' => '@gmail.',
);
$replaceGlobal = array(
'@gmailcom' => '@gmail.com',
'@hotmailcom' => '@hotmail.com',
'@hotmailfr' => '@hotmail.fr',
'@yahoocom' => '@yahoo.com',
'@yahoofr' => '@yahoo.fr',
);
// Real use case replacement
$email = strtr($email, $replaceGlobal);
// Check TLD
$atPos = strpos($email, '@');
$pointPos = strpos($email, '.', $atPos);
$tld = substr($email, $pointPos + 1);
$sld = substr($email, $atPos + 1, strlen($email) - ($atPos+1) - (strlen($tld)+1) );
if (empty($tld)) {
$this->errors[] = Tools::displayError('Invalid email');
$_POST['email'] = '';
}
if (empty($this->errors)) {
// If you have a complete list of TLD, check it !
}
// Check SLD
if (empty($this->errors)) {
// Real use case replacement
$email = strtr($email, $replaceSLD);
// Levenhstein remplacement
if (count($domains) > 0 && $email == $emailOri) {
foreach ($domains as $d) {
$dpPos = strpos($d, '.');
$realDomain = substr($d, 0, $dpPos);
$lev = levenshtein($sld, $realDomain);
if ($lev == O) {
break;
}
elseif ($lev == 1 && $tld == substr($d, $dpPos+1)) {
$email = str_replace('@'.$sld.'.', '@'.$realDomain.'.', $email);
break;
}
}
}
}
/* Preparing customer */
$customer = new Customer();
@ -140,14 +239,16 @@ class AuthController extends AuthControllerCore
$_POST['firstname'] = $firstnameAddress;
if (!sizeof($this->errors)) {
if(Customer::customerExists($email)) {
if (Customer::customerExists($email)) {
$this->errors[] = Tools::displayError('An account is already registered with this e-mail, please fill in the password or request a new one.');
}
if(Tools::isSubmit('newsletter')) {
if (Tools::isSubmit('newsletter')) {
$customer->ip_registration_newsletter = pSQL(Tools::getRemoteAddr());
$customer->newsletter_date_add = pSQL(date('Y-m-d H:i:s'));
}
$customer->email = $_POST['email'] = $email;
$customer->birthday = (empty($_POST['years'])? '': (int)($_POST['years']).'-'.(int)($_POST['months']).'-'.(int)($_POST['days']));
if (!sizeof($this->errors)) {
@ -158,13 +259,20 @@ class AuthController extends AuthControllerCore
} else {
$customer->is_guest = 0;
}
if (!$customer->add()) {
$this->errors[] = Tools::displayError('An error occurred while creating your account.');
} else {
if(!$customer->is_guest) {
if (!$customer->is_guest) {
if(!Mail::Send((int)(self::$cookie->id_lang), 'account', Mail::l('Welcome!'),
array('{firstname}' => $customer->firstname, '{lastname}' => $customer->lastname, '{email}' => $customer->email, '{passwd}' => Tools::getValue('passwd')), $customer->email, $customer->firstname.' '.$customer->lastname))
$this->errors[] = Tools::displayError('Cannot send email');
array(
'{firstname}' => $customer->firstname,
'{lastname}' => $customer->lastname,
'{email}' => $customer->email,
'{passwd}' => Tools::getValue('passwd')
), $customer->email, $customer->firstname.' '.$customer->lastname)) {
$this->errors[] = Tools::displayError('Cannot send email');
}
}
global $site_version_front;