713 lines
24 KiB
PHP
713 lines
24 KiB
PHP
|
<?php
|
||
|
/*
|
||
|
* 2007-2011 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-2011 PrestaShop SA
|
||
|
* @version Release: $Revision: 9296 $
|
||
|
* @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
|
||
|
* International Registered Trademark & Property of PrestaShop SA
|
||
|
*/
|
||
|
|
||
|
class LanguageCore extends ObjectModel
|
||
|
{
|
||
|
public $id;
|
||
|
|
||
|
/** @var string Name */
|
||
|
public $name;
|
||
|
|
||
|
/** @var string 2-letter iso code */
|
||
|
public $iso_code;
|
||
|
|
||
|
/** @var string 5-letter iso code */
|
||
|
public $language_code;
|
||
|
|
||
|
/** @var string date format http://http://php.net/manual/en/function.date.php with the date only */
|
||
|
public $date_format_lite = 'Y-m-d';
|
||
|
|
||
|
/** @var string date format http://http://php.net/manual/en/function.date.php with hours and minutes */
|
||
|
public $date_format_full = 'Y-m-d H:i:s';
|
||
|
|
||
|
/** @var bool true if this language is right to left language */
|
||
|
public $is_rtl = false;
|
||
|
|
||
|
/** @var boolean Status */
|
||
|
public $active = true;
|
||
|
|
||
|
protected $fieldsRequired = array('name', 'iso_code', 'date_format_lite', 'date_format_full');
|
||
|
protected $fieldsSize = array('name' => 32, 'iso_code' => 2, 'language_code' => 5, 'date_format_lite' => 32, 'date_format_full' => 32);
|
||
|
protected $fieldsValidate = array('name' => 'isGenericName', 'iso_code' => 'isLanguageIsoCode', 'language_code' => 'isLanguageCode',
|
||
|
'active' => 'isBool', 'is_rtl' => 'isBool', 'date_format_lite' => 'isPhpDateFormat', 'date_format_full' => 'isPhpDateFormat');
|
||
|
|
||
|
protected $table = 'lang';
|
||
|
protected $identifier = 'id_lang';
|
||
|
|
||
|
/** @var array Languages cache */
|
||
|
protected static $_checkedLangs;
|
||
|
protected static $_LANGUAGES;
|
||
|
protected static $countActiveLanguages;
|
||
|
|
||
|
protected $webserviceParameters = array(
|
||
|
'objectNodeName' => 'language',
|
||
|
'objectsNodeName' => 'languages',
|
||
|
);
|
||
|
|
||
|
protected $translationsFilesAndVars = array(
|
||
|
'fields' => '_FIELDS',
|
||
|
'errors' => '_ERRORS',
|
||
|
'admin' => '_LANGADM',
|
||
|
'pdf' => '_LANGPDF',
|
||
|
);
|
||
|
|
||
|
public function __construct($id = NULL, $id_lang = NULL)
|
||
|
{
|
||
|
parent::__construct($id);
|
||
|
}
|
||
|
|
||
|
public function getFields()
|
||
|
{
|
||
|
parent::validateFields();
|
||
|
$fields['name'] = pSQL($this->name);
|
||
|
$fields['iso_code'] = pSQL(strtolower($this->iso_code));
|
||
|
$fields['language_code'] = pSQL(strtolower($this->language_code));
|
||
|
$fields['is_rtl'] = (int)$this->is_rtl;
|
||
|
if (empty($fields['language_code']))
|
||
|
$fields['language_code'] = $fields['iso_code'];
|
||
|
$fields['date_format_lite'] = pSQL($this->date_format_lite);
|
||
|
$fields['date_format_full'] = pSQL($this->date_format_full);
|
||
|
$fields['active'] = (int)$this->active;
|
||
|
return $fields;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Generate traslations files
|
||
|
*
|
||
|
*/
|
||
|
private function _generateFiles($newIso = null)
|
||
|
{
|
||
|
$iso_code = $newIso?$newIso:$this->iso_code;
|
||
|
|
||
|
if (!file_exists(_PS_TRANSLATIONS_DIR_.$iso_code))
|
||
|
mkdir(_PS_TRANSLATIONS_DIR_.$iso_code);
|
||
|
foreach ($this->translationsFilesAndVars as $file => $var)
|
||
|
if (!file_exists(_PS_TRANSLATIONS_DIR_.$iso_code.'/'.$file.'.php'))
|
||
|
file_put_contents(_PS_TRANSLATIONS_DIR_.$iso_code.'/'.$file.'.php', '<?php
|
||
|
global $'.$var.';
|
||
|
$'.$var.' = array();
|
||
|
?>');
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Move translations files after editiing language iso code
|
||
|
*/
|
||
|
public function moveToIso($newIso)
|
||
|
{
|
||
|
if($newIso == $this->iso_code)
|
||
|
return true;
|
||
|
|
||
|
if (file_exists(_PS_TRANSLATIONS_DIR_.$this->iso_code))
|
||
|
rename(_PS_TRANSLATIONS_DIR_.$this->iso_code, _PS_TRANSLATIONS_DIR_.$newIso);
|
||
|
|
||
|
if (file_exists(_PS_MAIL_DIR_.$this->iso_code))
|
||
|
rename(_PS_MAIL_DIR_.$this->iso_code, _PS_MAIL_DIR_.$newIso);
|
||
|
|
||
|
$modulesList = Module::getModulesDirOnDisk();
|
||
|
foreach ($modulesList as $moduleDir)
|
||
|
{
|
||
|
if (file_exists(_PS_MODULE_DIR_.$moduleDir.'/mails/'.$this->iso_code))
|
||
|
rename(_PS_MODULE_DIR_.$moduleDir.'/mails/'.$this->iso_code, _PS_MODULE_DIR_.$moduleDir.'/mails/'.$newIso);
|
||
|
|
||
|
if (file_exists(_PS_MODULE_DIR_.$moduleDir.'/'.$this->iso_code.'.php'))
|
||
|
rename(_PS_MODULE_DIR_.$moduleDir.'/'.$this->iso_code.'.php', _PS_MODULE_DIR_.$moduleDir.'/'.$newIso.'.php');
|
||
|
}
|
||
|
|
||
|
foreach ($this->_getThemesList() as $theme => $data)
|
||
|
{
|
||
|
if (file_exists(_PS_ALL_THEMES_DIR_.$theme.'/lang/'.$this->iso_code.'.php'))
|
||
|
rename(_PS_ALL_THEMES_DIR_.$theme.'/lang/'.$this->iso_code.'.php', _PS_ALL_THEMES_DIR_.$theme.'/lang/'.$newIso.'.php');
|
||
|
|
||
|
if (file_exists(_PS_ALL_THEMES_DIR_.$theme.'/mails/'.$this->iso_code))
|
||
|
rename(_PS_ALL_THEMES_DIR_.$theme.'/mails/'.$this->iso_code, _PS_ALL_THEMES_DIR_.$theme.'/mails/'.$newIso);
|
||
|
|
||
|
foreach ($modulesList as $module)
|
||
|
if (file_exists(_PS_ALL_THEMES_DIR_.$theme.'/modules/'.$module.'/'.$this->iso_code.'.php'))
|
||
|
rename(_PS_ALL_THEMES_DIR_.$theme.'/modules/'.$module.'/'.$this->iso_code.'.php', _PS_ALL_THEMES_DIR_.$theme.'/modules/'.$module.'/'.$newIso.'.php');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Return an array with themes and thumbnails
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
private function _getThemesList()
|
||
|
{
|
||
|
$dir = opendir(_PS_ALL_THEMES_DIR_);
|
||
|
while ($folder = readdir($dir))
|
||
|
if ($folder != '.' AND $folder != '..' AND file_exists(_PS_ALL_THEMES_DIR_.'/'.$folder.'/preview.jpg'))
|
||
|
$themes[$folder]['name'] = $folder;
|
||
|
closedir($dir);
|
||
|
return isset($themes) ? $themes : array();
|
||
|
}
|
||
|
|
||
|
public function add($autodate = true, $nullValues = false)
|
||
|
{
|
||
|
if (!parent::add($autodate))
|
||
|
return false;
|
||
|
|
||
|
// create empty files if they not exists
|
||
|
$this->_generateFiles();
|
||
|
|
||
|
$resUpdateSQL = $this->loadUpdateSQL();
|
||
|
// If url_rewrite is not enabled, we don't need to regenerate .htaccess
|
||
|
if (!Configuration::get('PS_REWRITING_SETTINGS'))
|
||
|
return $resUpdateSQL;
|
||
|
|
||
|
return ($resUpdateSQL AND Tools::generateHtaccess(dirname(__FILE__).'/../.htaccess',
|
||
|
(int)(Configuration::get('PS_REWRITING_SETTINGS')),
|
||
|
(int)(Configuration::get('PS_HTACCESS_CACHE_CONTROL')),
|
||
|
Configuration::get('PS_HTACCESS_SPECIFIC'),
|
||
|
(int)Configuration::get('PS_HTACCESS_DISABLE_MULTIVIEWS')
|
||
|
));
|
||
|
}
|
||
|
|
||
|
public function toggleStatus()
|
||
|
{
|
||
|
if (!parent::toggleStatus())
|
||
|
return false;
|
||
|
|
||
|
// If url_rewrite is not enabled, we don't need to regenerate .htaccess
|
||
|
if (!Configuration::get('PS_REWRITING_SETTINGS'))
|
||
|
return true;
|
||
|
return (Tools::generateHtaccess(dirname(__FILE__).'/../.htaccess',
|
||
|
(int)(Configuration::get('PS_REWRITING_SETTINGS')),
|
||
|
(int)(Configuration::get('PS_HTACCESS_CACHE_CONTROL')),
|
||
|
Configuration::get('PS_HTACCESS_SPECIFIC'),
|
||
|
(int)Configuration::get('PS_HTACCESS_DISABLE_MULTIVIEWS')
|
||
|
));
|
||
|
}
|
||
|
|
||
|
public function checkFiles()
|
||
|
{
|
||
|
return self::checkFilesWithIsoCode($this->iso_code);
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* This functions checks if every files exists for the language $iso_code.
|
||
|
* Concerned files are theses located in translations/$iso_code/
|
||
|
* and translations/mails/$iso_code .
|
||
|
*
|
||
|
* @param mixed $iso_code
|
||
|
* @returntrue if all files exists
|
||
|
*/
|
||
|
public static function checkFilesWithIsoCode($iso_code)
|
||
|
{
|
||
|
if (isset(self::$_checkedLangs[$iso_code]) AND self::$_checkedLangs[$iso_code])
|
||
|
return true;
|
||
|
foreach (array_keys(self::getFilesList($iso_code, _THEME_NAME_, false, false, false, true)) as $key)
|
||
|
if (!file_exists($key))
|
||
|
return false;
|
||
|
self::$_checkedLangs[$iso_code] = true;
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
public static function getFilesList($iso_from, $theme_from, $iso_to = false, $theme_to = false, $select = false, $check = false, $modules = false)
|
||
|
{
|
||
|
if (empty($iso_from))
|
||
|
die(Tools::displayError());
|
||
|
|
||
|
$copy = ($iso_to AND $theme_to) ? true : false;
|
||
|
|
||
|
$lPath_from = _PS_TRANSLATIONS_DIR_.(string)$iso_from.'/';
|
||
|
$tPath_from = _PS_ROOT_DIR_.'/themes/'.(string)$theme_from.'/';
|
||
|
$mPath_from = _PS_MAIL_DIR_.(string)$iso_from.'/';
|
||
|
|
||
|
if ($copy)
|
||
|
{
|
||
|
$lPath_to = _PS_TRANSLATIONS_DIR_.(string)$iso_to.'/';
|
||
|
$tPath_to = _PS_ROOT_DIR_.'/themes/'.(string)$theme_to.'/';
|
||
|
$mPath_to = _PS_MAIL_DIR_.(string)$iso_to.'/';
|
||
|
}
|
||
|
|
||
|
$lFiles = array('admin'.'.php', 'errors'.'.php', 'fields'.'.php', 'pdf'.'.php');
|
||
|
$mFiles = array('account.html', 'account.txt', 'bankwire.html', 'bankwire.txt',
|
||
|
'cheque.html', 'cheque.txt', 'contact.html', 'contact.txt', 'contact_form.html',
|
||
|
'contact_form.txt', 'credit_slip.html', 'credit_slip.txt', 'download_product.html',
|
||
|
'download_product.txt', 'download-product.tpl', 'employee_password.html', 'employee_password.txt',
|
||
|
'forward_msg.html', 'forward_msg.txt', 'guest_to_customer.html', 'guest_to_customer.txt',
|
||
|
'in_transit.html', 'in_transit.txt', 'log_alert.html', 'log_alert.txt', 'newsletter.html', 'newsletter.txt',
|
||
|
'order_canceled.html', 'order_canceled.txt', 'order_conf.html', 'order_conf.txt',
|
||
|
'order_customer_comment.html', 'order_customer_comment.txt', 'order_merchant_comment.html',
|
||
|
'order_merchant_comment.txt', 'order_return_state.html', 'order_return_state.txt',
|
||
|
'outofstock.html', 'outofstock.txt', 'password.html', 'password.txt', 'password_query.html',
|
||
|
'password_query.txt', 'payment.html', 'payment.txt', 'payment_error.html', 'payment_error.txt',
|
||
|
'preparation.html', 'preparation.txt', 'refund.html', 'refund.txt', 'reply_msg.html',
|
||
|
'reply_msg.txt', 'shipped.html', 'shipped.txt', 'test.html', 'test.txt', 'voucher.html', 'voucher.txt');
|
||
|
|
||
|
$number = -1;
|
||
|
|
||
|
$files = array();
|
||
|
$files_tr = array();
|
||
|
$files_theme = array();
|
||
|
$files_mail = array();
|
||
|
$files_modules = array();
|
||
|
|
||
|
// When a copy is made from a theme in specific language
|
||
|
// to an other theme for the same language,
|
||
|
// it's avoid to copy Translations, Mails files
|
||
|
// and modules files which are not override by theme.
|
||
|
if (!$copy OR $iso_from != $iso_to)
|
||
|
{
|
||
|
// Translations files
|
||
|
if (!$check OR ($check AND (string)$iso_from != 'en'))
|
||
|
foreach ($lFiles as $file)
|
||
|
$files_tr[$lPath_from.$file] = ($copy ? $lPath_to.$file : ++$number);
|
||
|
if ($select == 'tr')
|
||
|
return $files_tr;
|
||
|
$files = array_merge($files, $files_tr);
|
||
|
|
||
|
// Mail files
|
||
|
if (!$check OR ($check AND (string)$iso_from != 'en'))
|
||
|
$files_mail[$mPath_from.'lang.php'] = ($copy ? $mPath_to.'lang.php' : ++$number);
|
||
|
foreach ($mFiles as $file)
|
||
|
$files_mail[$mPath_from.$file] = ($copy ? $mPath_to.$file : ++$number);
|
||
|
if ($select == 'mail')
|
||
|
return $files_mail;
|
||
|
$files = array_merge($files, $files_mail);
|
||
|
|
||
|
// Modules
|
||
|
if ($modules)
|
||
|
{
|
||
|
$modList = Module::getModulesDirOnDisk();
|
||
|
foreach ($modList as $mod)
|
||
|
{
|
||
|
$modDir = _PS_MODULE_DIR_.$mod;
|
||
|
// Lang file
|
||
|
if (file_exists($modDir.'/'.(string)$iso_from.'.php'))
|
||
|
$files_modules[$modDir.'/'.(string)$iso_from.'.php'] = ($copy ? $modDir.'/'.(string)$iso_to.'.php' : ++$number);
|
||
|
// Mails files
|
||
|
$modMailDirFrom = $modDir.'/mails/'.(string)$iso_from;
|
||
|
$modMailDirTo = $modDir.'/mails/'.(string)$iso_to;
|
||
|
if (file_exists($modMailDirFrom))
|
||
|
{
|
||
|
$dirFiles = scandir($modMailDirFrom);
|
||
|
foreach ($dirFiles as $file)
|
||
|
if (file_exists($modMailDirFrom.'/'.$file) AND $file != '.' AND $file != '..' AND $file != '.svn')
|
||
|
$files_modules[$modMailDirFrom.'/'.$file] = ($copy ? $modMailDirTo.'/'.$file : ++$number);
|
||
|
}
|
||
|
}
|
||
|
if ($select == 'modules')
|
||
|
return $files_modules;
|
||
|
$files = array_merge($files, $files_modules);
|
||
|
}
|
||
|
}
|
||
|
elseif ($select == 'mail' OR $select == 'tr')
|
||
|
{
|
||
|
return $files;
|
||
|
}
|
||
|
|
||
|
// Theme files
|
||
|
if (!$check OR ($check AND (string)$iso_from != 'en'))
|
||
|
{
|
||
|
$files_theme[$tPath_from.'lang/'.(string)$iso_from.'.php'] = ($copy ? $tPath_to.'lang/'.(string)$iso_to.'.php' : ++$number);
|
||
|
$module_theme_files = (file_exists($tPath_from.'modules/') ? scandir($tPath_from.'modules/') : array());
|
||
|
foreach ($module_theme_files as $module)
|
||
|
if ($module !== '.' AND $module != '..' AND $module !== '.svn' AND file_exists($tPath_from.'modules/'.$module.'/'.(string)$iso_from.'.php'))
|
||
|
$files_theme[$tPath_from.'modules/'.$module.'/'.(string)$iso_from.'.php'] = ($copy ? $tPath_to.'modules/'.$module.'/'.(string)$iso_to.'.php' : ++$number);
|
||
|
}
|
||
|
if ($select == 'theme')
|
||
|
return $files_theme;
|
||
|
$files = array_merge($files, $files_theme);
|
||
|
|
||
|
// Return
|
||
|
return $files;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* loadUpdateSQL will create default lang values when you create a new lang, based on default id lang
|
||
|
*
|
||
|
* @return boolean true if succeed
|
||
|
*/
|
||
|
public function loadUpdateSQL()
|
||
|
{
|
||
|
$tables = Db::getInstance()->ExecuteS('SHOW TABLES LIKE \''._DB_PREFIX_.'%_lang\' ');
|
||
|
$langTables = array();
|
||
|
|
||
|
foreach($tables as $table)
|
||
|
foreach($table as $t)
|
||
|
if ($t != _DB_PREFIX_.'configuration_lang')
|
||
|
$langTables[] = $t;
|
||
|
|
||
|
Db::getInstance()->Execute('SET @id_lang_default = (SELECT c.`value` FROM `'._DB_PREFIX_.'configuration` c WHERE c.`name` = \'PS_LANG_DEFAULT\' LIMIT 1)');
|
||
|
$return = true;
|
||
|
foreach($langTables as $name)
|
||
|
{
|
||
|
$fields = '';
|
||
|
$columns = Db::getInstance()->ExecuteS('SHOW COLUMNS FROM `'.$name.'`');
|
||
|
foreach($columns as $column)
|
||
|
$fields .= $column['Field'].', ';
|
||
|
$fields = rtrim($fields, ', ');
|
||
|
$identifier = 'id_'.str_replace('_lang', '', str_replace(_DB_PREFIX_, '', $name));
|
||
|
|
||
|
$sql = 'INSERT IGNORE INTO `'.$name.'` ('.$fields.') (SELECT ';
|
||
|
foreach($columns as $column) {
|
||
|
if ($identifier != $column['Field'] and $column['Field'] != 'id_lang')
|
||
|
$sql .= '(SELECT `'.$column['Field'].'` FROM `'.$name.'` tl WHERE tl.`id_lang` = @id_lang_default AND tl.`'.$identifier.'` = `'.str_replace('_lang', '', $name).'`.`'.$identifier.'`), ';
|
||
|
else
|
||
|
$sql.= '`'.$column['Field'].'`, ';
|
||
|
}
|
||
|
$sql = rtrim($sql, ', ');
|
||
|
$sql .= ' FROM `'._DB_PREFIX_.'lang` CROSS JOIN `'.str_replace('_lang', '', $name).'`) ;';
|
||
|
$return &= Db::getInstance()->Execute(pSQL($sql));
|
||
|
}
|
||
|
return $return;
|
||
|
}
|
||
|
|
||
|
public static function recurseDeleteDir($dir)
|
||
|
{
|
||
|
if (!is_dir($dir))
|
||
|
return false;
|
||
|
if ($handle = @opendir($dir))
|
||
|
{
|
||
|
while (false !== ($file = readdir($handle)))
|
||
|
if ($file != '.' && $file != '..')
|
||
|
{
|
||
|
if (is_dir($dir.'/'.$file))
|
||
|
self::recurseDeleteDir($dir.'/'.$file);
|
||
|
elseif (file_exists($dir.'/'.$file))
|
||
|
@unlink($dir.'/'.$file);
|
||
|
}
|
||
|
closedir($handle);
|
||
|
}
|
||
|
rmdir($dir);
|
||
|
}
|
||
|
|
||
|
public function delete()
|
||
|
{
|
||
|
if (empty($this->iso_code))
|
||
|
$this->iso_code = self::getIsoById($this->id);
|
||
|
|
||
|
// Database translations deletion
|
||
|
$result = Db::getInstance()->ExecuteS('SHOW TABLES FROM `'._DB_NAME_.'`');
|
||
|
foreach ($result AS $row)
|
||
|
if (preg_match('/_lang/', $row['Tables_in_'._DB_NAME_]))
|
||
|
if (!Db::getInstance()->Execute('DELETE FROM `'.$row['Tables_in_'._DB_NAME_].'` WHERE `id_lang` = '.(int)($this->id)))
|
||
|
return false;
|
||
|
|
||
|
// Delete tags
|
||
|
Db::getInstance()->Execute('DELETE FROM '._DB_PREFIX_.'tag WHERE id_lang = '.(int)($this->id));
|
||
|
|
||
|
// Delete search words
|
||
|
Db::getInstance()->Execute('DELETE FROM '._DB_PREFIX_.'search_word WHERE id_lang = '.(int)($this->id));
|
||
|
|
||
|
// Files deletion
|
||
|
foreach (self::getFilesList($this->iso_code, _THEME_NAME_, false, false, false, true, true) as $key => $file)
|
||
|
if (file_exists($key))
|
||
|
unlink($key);
|
||
|
$modList = scandir(_PS_MODULE_DIR_);
|
||
|
foreach ($modList as $mod)
|
||
|
{
|
||
|
self::recurseDeleteDir(_PS_MODULE_DIR_.$mod.'/mails/'.$this->iso_code);
|
||
|
$files = @scandir(_PS_MODULE_DIR_.$mod.'/mails/');
|
||
|
if (count($files) <= 2)
|
||
|
self::recurseDeleteDir(_PS_MODULE_DIR_.$mod.'/mails/');
|
||
|
|
||
|
if (file_exists(_PS_MODULE_DIR_.$mod.'/'.$this->iso_code.'.php'))
|
||
|
{
|
||
|
unlink(_PS_MODULE_DIR_.$mod.'/'.$this->iso_code.'.php');
|
||
|
$files = @scandir(_PS_MODULE_DIR_.$mod);
|
||
|
if (count($files) <= 2)
|
||
|
self::recurseDeleteDir(_PS_MODULE_DIR_.$mod);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if (file_exists(_PS_MAIL_DIR_.$this->iso_code))
|
||
|
self::recurseDeleteDir(_PS_MAIL_DIR_.$this->iso_code);
|
||
|
if (file_exists(_PS_TRANSLATIONS_DIR_.$this->iso_code))
|
||
|
self::recurseDeleteDir(_PS_TRANSLATIONS_DIR_.$this->iso_code);
|
||
|
if (!parent::delete())
|
||
|
return false;
|
||
|
|
||
|
// delete images
|
||
|
$files_copy = array('/en.jpg', '/en-default-thickbox.jpg', '/en-default-home.jpg', '/en-default-large.jpg', '/en-default-medium.jpg', '/en-default-small.jpg', '/en-default-large_scene.jpg');
|
||
|
$tos = array(_PS_CAT_IMG_DIR_, _PS_MANU_IMG_DIR_, _PS_PROD_IMG_DIR_, _PS_SUPP_IMG_DIR_);
|
||
|
foreach($tos AS $to)
|
||
|
foreach($files_copy AS $file)
|
||
|
{
|
||
|
$name = str_replace('/en', ''.$this->iso_code, $file);
|
||
|
|
||
|
if (file_exists($to.$name))
|
||
|
unlink($to.$name);
|
||
|
if (file_exists(dirname(__FILE__).'/../img/l/'.$this->id.'.jpg'))
|
||
|
unlink(dirname(__FILE__).'/../img/l/'.$this->id.'.jpg');
|
||
|
}
|
||
|
|
||
|
// If url_rewrite is not enabled, we don't need to regenerate .htaccess
|
||
|
if (!Configuration::get('PS_REWRITING_SETTINGS'))
|
||
|
return true;
|
||
|
|
||
|
return Tools::generateHtaccess(dirname(__FILE__).'/../.htaccess',
|
||
|
(int)(Configuration::get('PS_REWRITING_SETTINGS')),
|
||
|
(int)(Configuration::get('PS_HTACCESS_CACHE_CONTROL')),
|
||
|
Configuration::get('PS_HTACCESS_SPECIFIC'),
|
||
|
(int)Configuration::get('PS_HTACCESS_DISABLE_MULTIVIEWS')
|
||
|
);
|
||
|
}
|
||
|
|
||
|
|
||
|
public function deleteSelection($selection)
|
||
|
{
|
||
|
if (!is_array($selection) OR !Validate::isTableOrIdentifier($this->identifier) OR !Validate::isTableOrIdentifier($this->table))
|
||
|
die(Tools::displayError());
|
||
|
$result = true;
|
||
|
foreach ($selection AS $id)
|
||
|
{
|
||
|
$this->id = (int)($id);
|
||
|
$result = $result AND $this->delete();
|
||
|
}
|
||
|
|
||
|
// If url_rewrite is not enabled, we don't need to regenerate .htaccess
|
||
|
if (!Configuration::get('PS_REWRITING_SETTINGS'))
|
||
|
return true;
|
||
|
|
||
|
Tools::generateHtaccess(dirname(__FILE__).'/../.htaccess',
|
||
|
(int)(Configuration::get('PS_REWRITING_SETTINGS')),
|
||
|
(int)(Configuration::get('PS_HTACCESS_CACHE_CONTROL')),
|
||
|
Configuration::get('PS_HTACCESS_SPECIFIC'),
|
||
|
(int)Configuration::get('PS_HTACCESS_DISABLE_MULTIVIEWS')
|
||
|
);
|
||
|
|
||
|
return $result;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Return available languages
|
||
|
*
|
||
|
* @param boolean $active Select only active languages
|
||
|
* @return array Languages
|
||
|
*/
|
||
|
public static function getLanguages($active = true)
|
||
|
{
|
||
|
if (!self::$_LANGUAGES)
|
||
|
self::loadLanguages();
|
||
|
|
||
|
$languages = array();
|
||
|
foreach (self::$_LANGUAGES AS $language)
|
||
|
{
|
||
|
if ($active AND !$language['active'])
|
||
|
continue;
|
||
|
$languages[] = $language;
|
||
|
}
|
||
|
return $languages;
|
||
|
}
|
||
|
|
||
|
public static function getLanguage($id_lang)
|
||
|
{
|
||
|
if (!array_key_exists((int)($id_lang), self::$_LANGUAGES))
|
||
|
return false;
|
||
|
return self::$_LANGUAGES[(int)($id_lang)];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Return iso code from id
|
||
|
*
|
||
|
* @param integer $id_lang Language ID
|
||
|
* @return string Iso code
|
||
|
*/
|
||
|
public static function getIsoById($id_lang)
|
||
|
{
|
||
|
if (isset(self::$_LANGUAGES[(int)$id_lang]['iso_code']))
|
||
|
return self::$_LANGUAGES[(int)$id_lang]['iso_code'];
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Return id from iso code
|
||
|
*
|
||
|
* @param string $iso_code Iso code
|
||
|
* @return integer Language ID
|
||
|
*/
|
||
|
public static function getIdByIso($iso_code)
|
||
|
{
|
||
|
if (!Validate::isLanguageIsoCode($iso_code))
|
||
|
die(Tools::displayError('Fatal error: ISO code is not correct').' '.$iso_code);
|
||
|
|
||
|
return Db::getInstance()->getValue('SELECT `id_lang` FROM `'._DB_PREFIX_.'lang` WHERE `iso_code` = \''.pSQL(strtolower($iso_code)).'\'');
|
||
|
}
|
||
|
|
||
|
public static function getLanguageCodeByIso($iso_code)
|
||
|
{
|
||
|
if (!Validate::isLanguageIsoCode($iso_code))
|
||
|
die(Tools::displayError('Fatal error: ISO code is not correct').' '.$iso_code);
|
||
|
|
||
|
return Db::getInstance()->getValue('SELECT `language_code` FROM `'._DB_PREFIX_.'lang` WHERE `iso_code` = \''.pSQL(strtolower($iso_code)).'\'');
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Return array (id_lang, iso_code)
|
||
|
*
|
||
|
* @param string $iso_code Iso code
|
||
|
* @return array Language (id_lang, iso_code)
|
||
|
*/
|
||
|
public static function getIsoIds($active = true)
|
||
|
{
|
||
|
return Db::getInstance(_PS_USE_SQL_SLAVE_)->ExecuteS('SELECT `id_lang`, `iso_code` FROM `'._DB_PREFIX_.'lang` '.($active ? 'WHERE active = 1' : ''));
|
||
|
}
|
||
|
|
||
|
public static function copyLanguageData($from, $to)
|
||
|
{
|
||
|
$result = Db::getInstance()->ExecuteS('SHOW TABLES FROM `'._DB_NAME_.'`');
|
||
|
foreach ($result AS $row)
|
||
|
if (preg_match('/_lang/', $row['Tables_in_'._DB_NAME_]) AND $row['Tables_in_'._DB_NAME_] != _DB_PREFIX_.'lang')
|
||
|
{
|
||
|
$result2 = Db::getInstance()->ExecuteS('SELECT * FROM `'.$row['Tables_in_'._DB_NAME_].'` WHERE `id_lang` = '.(int)($from));
|
||
|
if (!sizeof($result2))
|
||
|
continue;
|
||
|
Db::getInstance()->Execute('DELETE FROM `'.$row['Tables_in_'._DB_NAME_].'` WHERE `id_lang` = '.(int)($to));
|
||
|
$query = 'INSERT INTO `'.$row['Tables_in_'._DB_NAME_].'` VALUES ';
|
||
|
foreach ($result2 AS $row2)
|
||
|
{
|
||
|
$query .= '(';
|
||
|
$row2['id_lang'] = $to;
|
||
|
foreach ($row2 AS $field)
|
||
|
$query .= '\''.pSQL($field, true).'\',';
|
||
|
$query = rtrim($query, ',').'),';
|
||
|
}
|
||
|
$query = rtrim($query, ',');
|
||
|
Db::getInstance()->Execute($query);
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Load all languages in memory for caching
|
||
|
*/
|
||
|
public static function loadLanguages()
|
||
|
{
|
||
|
self::$_LANGUAGES = array();
|
||
|
$result = Db::getInstance()->ExecuteS('SELECT * FROM `'._DB_PREFIX_.'lang`');
|
||
|
foreach ($result AS $row)
|
||
|
self::$_LANGUAGES[(int)$row['id_lang']] = $row;
|
||
|
}
|
||
|
|
||
|
public function update($nullValues = false)
|
||
|
{
|
||
|
|
||
|
|
||
|
if (!parent::update($nullValues))
|
||
|
return false;
|
||
|
|
||
|
// If url_rewrite is not enabled, we don't need to regenerate .htaccess
|
||
|
if (!Configuration::get('PS_REWRITING_SETTINGS'))
|
||
|
return true;
|
||
|
|
||
|
return Tools::generateHtaccess(dirname(__FILE__).'/../.htaccess',
|
||
|
(int)(Configuration::get('PS_REWRITING_SETTINGS')),
|
||
|
(int)(Configuration::get('PS_HTACCESS_CACHE_CONTROL')),
|
||
|
Configuration::get('PS_HTACCESS_SPECIFIC'),
|
||
|
(int)Configuration::get('PS_HTACCESS_DISABLE_MULTIVIEWS')
|
||
|
);
|
||
|
}
|
||
|
|
||
|
public static function checkAndAddLanguage($iso_code)
|
||
|
{
|
||
|
if (Language::getIdByIso($iso_code))
|
||
|
return true;
|
||
|
else
|
||
|
{
|
||
|
if (@fsockopen('www.prestashop.com', 80))
|
||
|
{
|
||
|
$lang = new Language();
|
||
|
$lang->iso_code = $iso_code;
|
||
|
$lang->active = true;
|
||
|
|
||
|
if ($lang_pack = Tools::jsonDecode(Tools::file_get_contents('http://www.prestashop.com/download/lang_packs/get_language_pack.php?version='._PS_VERSION_.'&iso_lang='.$iso_code)))
|
||
|
{
|
||
|
if (isset($lang_pack->name)
|
||
|
&& isset($lang_pack->version)
|
||
|
&& isset($lang_pack->iso_code))
|
||
|
$lang->name = $lang_pack->name;
|
||
|
}
|
||
|
if (!$lang->name OR !$lang->add())
|
||
|
return false;
|
||
|
$insert_id = (int)($lang->id);
|
||
|
|
||
|
if ($lang_pack)
|
||
|
{
|
||
|
$flag = Tools::file_get_contents('http://www.prestashop.com/download/lang_packs/flags/jpeg/'.$iso_code.'.jpg');
|
||
|
if ($flag != NULL && !preg_match('/<body>/', $flag))
|
||
|
{
|
||
|
$file = fopen(dirname(__FILE__).'/../img/l/'.$insert_id.'.jpg', 'w');
|
||
|
if ($file)
|
||
|
{
|
||
|
fwrite($file, $flag);
|
||
|
fclose($file);
|
||
|
}
|
||
|
else
|
||
|
self::_copyNoneFlag($insert_id);
|
||
|
}
|
||
|
else
|
||
|
self::_copyNoneFlag($insert_id);
|
||
|
}
|
||
|
else
|
||
|
self::_copyNoneFlag($insert_id);
|
||
|
|
||
|
$files_copy = array('/en.jpg', '/en-default-thickbox.jpg', '/en-default-home.jpg', '/en-default-large.jpg', '/en-default-medium.jpg', '/en-default-small.jpg', '/en-default-large_scene.jpg');
|
||
|
$tos = array(_PS_CAT_IMG_DIR_, _PS_MANU_IMG_DIR_, _PS_PROD_IMG_DIR_, _PS_SUPP_IMG_DIR_);
|
||
|
foreach($tos AS $to)
|
||
|
foreach($files_copy AS $file)
|
||
|
{
|
||
|
$name = str_replace('/en', '/'.$iso_code, $file);
|
||
|
copy(dirname(__FILE__).'/../img/l'.$file, $to.$name);
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
else
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
protected static function _copyNoneFlag($id)
|
||
|
{
|
||
|
return copy(dirname(__FILE__).'/../img/l/none.jpg', dirname(__FILE__).'/../img/l/'.$id.'.jpg');
|
||
|
}
|
||
|
|
||
|
private static $_cache_language_installation = null;
|
||
|
public static function isInstalled($iso_code)
|
||
|
{
|
||
|
if (self::$_cache_language_installation === null)
|
||
|
{
|
||
|
self::$_cache_language_installation = array();
|
||
|
$result = Db::getInstance()->ExecuteS('SELECT `id_lang`, `iso_code` FROM `'._DB_PREFIX_.'lang`');
|
||
|
foreach ($result as $row)
|
||
|
self::$_cache_language_installation[$row['iso_code']] = $row['id_lang'];
|
||
|
}
|
||
|
return (isset(self::$_cache_language_installation[$iso_code]) ? self::$_cache_language_installation[$iso_code] : false);
|
||
|
}
|
||
|
|
||
|
public static function countActiveLanguages()
|
||
|
{
|
||
|
if (!self::$countActiveLanguages)
|
||
|
self::$countActiveLanguages = Db::getInstance()->getValue('SELECT COUNT(*) FROM `'._DB_PREFIX_.'lang` WHERE `active` = 1');
|
||
|
return self::$countActiveLanguages;
|
||
|
}
|
||
|
}
|
||
|
|