mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-09 15:38:27 +01:00
fixed modified translations were not automatic loaded after new login
This commit is contained in:
parent
bcc1393c49
commit
796663c2a6
@ -379,7 +379,7 @@ class config
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// some things need on client-side which are not direct configs
|
// some things need on client-side which are not direct configs
|
||||||
$client_config['phpgwapi']['lang_ctimes_md5'] = md5(json_encode(self::$configs['phpgwapi']['lang_ctimes']));
|
$client_config['phpgwapi']['max_lang_time'] = translation::max_lang_time();
|
||||||
|
|
||||||
return $client_config;
|
return $client_config;
|
||||||
}
|
}
|
||||||
|
@ -326,9 +326,9 @@ class translation
|
|||||||
//error_log(__METHOD__."('$app', '$lang') instance_specific=$instance_specific, load_app(_files)() returned ".(is_array($loaded)?'Array('.count($loaded).')':array2string($loaded)));
|
//error_log(__METHOD__."('$app', '$lang') instance_specific=$instance_specific, load_app(_files)() returned ".(is_array($loaded)?'Array('.count($loaded).')':array2string($loaded)));
|
||||||
if ($loaded || $instance_specific)
|
if ($loaded || $instance_specific)
|
||||||
{
|
{
|
||||||
$ok=egw_cache::setCache($instance_specific ? egw_cache::INSTANCE : egw_cache::TREE,
|
egw_cache::setCache($instance_specific ? egw_cache::INSTANCE : egw_cache::TREE,
|
||||||
__CLASS__, $app.':'.$l, $loaded);
|
__CLASS__, $app.':'.$l, $loaded);
|
||||||
//error_log(__METHOD__."('$app', '$lang') caching now ".(is_array($loaded)?'Array('.count($loaded).')':array2string($loaded))." egw_cache::setCache() returned ".array2string($ok));
|
//error_log(__METHOD__."('$app', '$lang') caching now ".(is_array($loaded)?'Array('.count($loaded).')':array2string($loaded)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ($loaded)
|
if ($loaded)
|
||||||
@ -397,11 +397,17 @@ class translation
|
|||||||
{
|
{
|
||||||
$file = self::get_lang_file($app, $lang);
|
$file = self::get_lang_file($app, $lang);
|
||||||
// check if file has changed compared to what's cached
|
// check if file has changed compared to what's cached
|
||||||
if (file_exists($file) && egw_cache::getTree(__CLASS__, $file) != filectime($file))
|
if (file_exists($file))
|
||||||
{
|
{
|
||||||
//error_log(__METHOD__."() $file modified");
|
$cached_time = egw_cache::getTree(__CLASS__, $file);
|
||||||
|
$file_time = filemtime($file);
|
||||||
|
if ($cached_time != $file_time)
|
||||||
|
{
|
||||||
|
//error_log(__METHOD__."() $file MODIFIED ($cached_time != $file_time)");
|
||||||
self::invalidate_lang_file($app, $lang);
|
self::invalidate_lang_file($app, $lang);
|
||||||
}
|
}
|
||||||
|
//else error_log(__METHOD__."() $file unchanged ($cached_time == $file_time)");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -416,6 +422,7 @@ class translation
|
|||||||
{
|
{
|
||||||
//error_log(__METHOD__."('$app', '$lang') invalidate translations $app:$lang");
|
//error_log(__METHOD__."('$app', '$lang') invalidate translations $app:$lang");
|
||||||
egw_cache::unsetTree(__CLASS__, $app.':'.$lang);
|
egw_cache::unsetTree(__CLASS__, $app.':'.$lang);
|
||||||
|
egw_cache::unsetTree(__CLASS__, self::get_lang_file($app, $lang));
|
||||||
|
|
||||||
foreach(self::$load_via as $load => $via)
|
foreach(self::$load_via as $load => $via)
|
||||||
{
|
{
|
||||||
@ -424,6 +431,7 @@ class translation
|
|||||||
{
|
{
|
||||||
//error_log(__METHOD__."('$app', '$lang') additional invalidate translations $load:$lang");
|
//error_log(__METHOD__."('$app', '$lang') additional invalidate translations $load:$lang");
|
||||||
egw_cache::unsetTree(__CLASS__, $load.':'.$lang);
|
egw_cache::unsetTree(__CLASS__, $load.':'.$lang);
|
||||||
|
egw_cache::unsetTree(__CLASS__, self::get_lang_file($load, $lang));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -431,7 +439,7 @@ class translation
|
|||||||
/**
|
/**
|
||||||
* Get a state / etag for a given app's translations
|
* Get a state / etag for a given app's translations
|
||||||
*
|
*
|
||||||
* We currently only use a single state for all none-instance-specific apps depending on lang_ctimes.
|
* We currently only use a single state for all none-instance-specific apps depending on self::max_lang_time().
|
||||||
*
|
*
|
||||||
* @param string $_app
|
* @param string $_app
|
||||||
* @param string $_lang
|
* @param string $_lang
|
||||||
@ -441,7 +449,12 @@ class translation
|
|||||||
{
|
{
|
||||||
if (!in_array($_app, translation::$instance_specific_translations))
|
if (!in_array($_app, translation::$instance_specific_translations))
|
||||||
{
|
{
|
||||||
$etag = md5(json_encode($GLOBALS['egw_info']['server']['lang_ctimes']));
|
// check if cache is NOT invalided by checking if we have a modification time for concerned lang-file
|
||||||
|
$time = egw_cache::getTree(__CLASS__, $file=self::get_lang_file($_app, $_lang));
|
||||||
|
// if we dont have one, cache has been invalidated and we need to load translations
|
||||||
|
if (!isset($time)) self::add_app($_app, $_lang);
|
||||||
|
|
||||||
|
$etag = self::max_lang_time();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -451,6 +464,28 @@ class translation
|
|||||||
return $etag;
|
return $etag;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get or set maximum / latest modification-time for files of not instance-specific translations
|
||||||
|
*
|
||||||
|
* @param type $time
|
||||||
|
* @return type
|
||||||
|
*/
|
||||||
|
static function max_lang_time($time=null)
|
||||||
|
{
|
||||||
|
static $max_lang_time = null;
|
||||||
|
|
||||||
|
if (!isset($max_lang_time) || isset($time))
|
||||||
|
{
|
||||||
|
$max_lang_time = egw_cache::getTree(__CLASS__, 'max_lang_time');
|
||||||
|
}
|
||||||
|
if (isset($time) && $time > $max_lang_time)
|
||||||
|
{
|
||||||
|
//error_log(__METHOD__."($time) updating previous max_lang_time=$max_lang_time to $time");
|
||||||
|
egw_cache::setTree(__CLASS__, 'max_lang_time', $max_lang_time=$time);
|
||||||
|
}
|
||||||
|
return $max_lang_time;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Loads translations for an application direct from the lang-file(s)
|
* Loads translations for an application direct from the lang-file(s)
|
||||||
*
|
*
|
||||||
@ -462,7 +497,7 @@ class translation
|
|||||||
*/
|
*/
|
||||||
static function &load_app_files($app,$lang)
|
static function &load_app_files($app,$lang)
|
||||||
{
|
{
|
||||||
$start = microtime(true);
|
//$start = microtime(true);
|
||||||
$load_app = isset(self::$load_via[$app]) ? self::$load_via[$app] : $app;
|
$load_app = isset(self::$load_via[$app]) ? self::$load_via[$app] : $app;
|
||||||
$loaded = array();
|
$loaded = array();
|
||||||
foreach($load_app == 'all-apps' ? scandir(EGW_SERVER_ROOT) : (array)$load_app as $app_dir)
|
foreach($load_app == 'all-apps' ? scandir(EGW_SERVER_ROOT) : (array)$load_app as $app_dir)
|
||||||
@ -475,15 +510,16 @@ class translation
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
// store ctime of file we parse
|
// store ctime of file we parse
|
||||||
egw_cache::setTree(__CLASS__, $file, filectime($file));
|
egw_cache::setTree(__CLASS__, $file, $time=filemtime($file));
|
||||||
|
self::max_lang_time($time);
|
||||||
|
|
||||||
$line_nr = 0;
|
$line_nr = 0;
|
||||||
//use fgets and split the line, as php5.3.3 with squeeze does not support splitting lines with fgetcsv while reading properly
|
//use fgets and split the line, as php5.3.3 with squeeze does not support splitting lines with fgetcsv while reading properly
|
||||||
//if the first letter after the delimiter is a german umlaut (UTF8 representation thereoff)
|
//if the first letter after the delimiter is a german umlaut (UTF8 representation thereoff)
|
||||||
//while(($line = fgetcsv($f, 1024, "\t")))
|
//while(($line = fgetcsv($f, 1024, "\t")))
|
||||||
while($line = fgets($f))
|
while(($read = fgets($f)))
|
||||||
{
|
{
|
||||||
$line = explode("\t", trim($line));
|
$line = explode("\t", trim($read));
|
||||||
++$line_nr;
|
++$line_nr;
|
||||||
if (count($line) != 4) continue;
|
if (count($line) != 4) continue;
|
||||||
list($l_id,$l_app,$l_lang,$l_translation) = $line;
|
list($l_id,$l_app,$l_lang,$l_translation) = $line;
|
||||||
@ -622,6 +658,7 @@ class translation
|
|||||||
*/
|
*/
|
||||||
static function get_lang_file($app,$lang)
|
static function get_lang_file($app,$lang)
|
||||||
{
|
{
|
||||||
|
if ($app == 'common') $app = 'phpgwapi';
|
||||||
return EGW_SERVER_ROOT.'/'.$app.'/'.self::LANG_DIR.'/'.self::LANGFILE_PREFIX.$lang.self::LANGFILE_EXTENSION;
|
return EGW_SERVER_ROOT.'/'.$app.'/'.self::LANG_DIR.'/'.self::LANGFILE_PREFIX.$lang.self::LANGFILE_EXTENSION;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -632,7 +669,7 @@ class translation
|
|||||||
*/
|
*/
|
||||||
static function get_installed_charsets()
|
static function get_installed_charsets()
|
||||||
{
|
{
|
||||||
static $charsets;
|
static $charsets=null;
|
||||||
|
|
||||||
if (!isset($charsets))
|
if (!isset($charsets))
|
||||||
{
|
{
|
||||||
@ -747,16 +784,16 @@ class translation
|
|||||||
// iconv can not convert from/to utf7-imap
|
// iconv can not convert from/to utf7-imap
|
||||||
if ($to == 'utf7-imap' && function_exists(imap_utf7_encode))
|
if ($to == 'utf7-imap' && function_exists(imap_utf7_encode))
|
||||||
{
|
{
|
||||||
$convertedData = iconv($from, 'iso-8859-1', $data);
|
$data_iso = iconv($from, 'iso-8859-1', $data);
|
||||||
$convertedData = imap_utf7_encode($convertedData);
|
$convertedData = imap_utf7_encode($data_iso);
|
||||||
|
|
||||||
return $convertedData;
|
return $convertedData;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($from == 'utf7-imap' && function_exists(imap_utf7_decode))
|
if ($from == 'utf7-imap' && function_exists(imap_utf7_decode))
|
||||||
{
|
{
|
||||||
$convertedData = imap_utf7_decode($data);
|
$data_iso = imap_utf7_decode($data);
|
||||||
$convertedData = iconv('iso-8859-1', $to, $convertedData);
|
$convertedData = iconv('iso-8859-1', $to, $data_iso);
|
||||||
|
|
||||||
return $convertedData;
|
return $convertedData;
|
||||||
}
|
}
|
||||||
@ -814,7 +851,7 @@ class translation
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
foreach((array)self::get_installed_langs() as $key => $name)
|
foreach(array_keys((array)self::get_installed_langs()) as $key)
|
||||||
{
|
{
|
||||||
egw_cache::unsetCache(egw_cache::INSTANCE,__CLASS__,$app.':'.$key);
|
egw_cache::unsetCache(egw_cache::INSTANCE,__CLASS__,$app.':'.$key);
|
||||||
}
|
}
|
||||||
@ -1021,8 +1058,6 @@ class translation
|
|||||||
//error_log(__METHOD__.' Using EndTag:'.$endtag);
|
//error_log(__METHOD__.' Using EndTag:'.$endtag);
|
||||||
}
|
}
|
||||||
// strip tags out of the message completely with their content
|
// strip tags out of the message completely with their content
|
||||||
$taglen=strlen($tag);
|
|
||||||
$endtaglen=strlen($endtag);
|
|
||||||
if ($_body) {
|
if ($_body) {
|
||||||
if ($singleton)
|
if ($singleton)
|
||||||
{
|
{
|
||||||
@ -1051,7 +1086,6 @@ class translation
|
|||||||
static function transform_mailto2text($matches)
|
static function transform_mailto2text($matches)
|
||||||
{
|
{
|
||||||
//error_log(__METHOD__.__LINE__.array2string($matches));
|
//error_log(__METHOD__.__LINE__.array2string($matches));
|
||||||
$linkTextislink = false;
|
|
||||||
// this is the actual url
|
// this is the actual url
|
||||||
$matches[2] = trim(strip_tags($matches[2]));
|
$matches[2] = trim(strip_tags($matches[2]));
|
||||||
$matches[3] = trim(strip_tags($matches[3]));
|
$matches[3] = trim(strip_tags($matches[3]));
|
||||||
|
@ -141,7 +141,7 @@ egw.extend('lang', egw.MODULE_GLOBAL, function() {
|
|||||||
jss.push(this.webserverUrl +
|
jss.push(this.webserverUrl +
|
||||||
'/phpgwapi/lang.php?app=' + _apps[i].app +
|
'/phpgwapi/lang.php?app=' + _apps[i].app +
|
||||||
'&lang=' + _apps[i].lang +
|
'&lang=' + _apps[i].lang +
|
||||||
'&etag=' + (_apps[i].etag || this.config('lang_ctimes_md5')));
|
'&etag=' + (_apps[i].etag || this.config('max_lang_time')));
|
||||||
}
|
}
|
||||||
apps.push(_apps[i].app);
|
apps.push(_apps[i].app);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user