mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-21 05:19:07 +01:00
fixed problem pointed out by Nahuel Grisolia <ngrisolia@cybsec.com>
This commit is contained in:
parent
dcc2ad7ea1
commit
f8ae0c1064
@ -310,7 +310,7 @@ else
|
||||
$remember_time,'/'); // make the cookie valid for the whole site (incl. sitemgr) and not only the eGW install-dir
|
||||
}
|
||||
|
||||
if ($_POST['lang'] && preg_match('/^[a-z]{2}(-[a-z]{2}){0,1}$/',$_POST['lang']) &&
|
||||
if ($_POST['lang'] && preg_match('/^[a-z]{2}(-[a-z]{2})?$/',$_POST['lang']) &&
|
||||
$_POST['lang'] != $GLOBALS['egw_info']['user']['preferences']['common']['lang'])
|
||||
{
|
||||
$GLOBALS['egw']->preferences->add('common','lang',$_POST['lang'],'session');
|
||||
@ -369,7 +369,7 @@ else
|
||||
$GLOBALS['egw_info']['user']['preferences'] = $prefs->read_repository();
|
||||
}
|
||||
}
|
||||
if ($_GET['lang'])
|
||||
if ($_GET['lang'] && preg_match('/^[a-z]{2}(-[a-z]{2})?$/',$_GET['lang']))
|
||||
{
|
||||
$GLOBALS['egw_info']['user']['preferences']['common']['lang'] = $_GET['lang'];
|
||||
}
|
||||
|
@ -203,9 +203,11 @@ abstract class egw_framework
|
||||
*/
|
||||
protected function _get_header()
|
||||
{
|
||||
// get used language code
|
||||
$lang_code = $GLOBALS['egw_info']['user']['preferences']['common']['lang'];
|
||||
|
||||
// get used language code (with a little xss check, if someone tries to sneak something in)
|
||||
if (preg_match('/^[a-z]{2}(-[a-z]{2})?$/',$GLOBALS['egw_info']['user']['preferences']['common']['lang']))
|
||||
{
|
||||
$lang_code = $GLOBALS['egw_info']['user']['preferences']['common']['lang'];
|
||||
}
|
||||
//pngfix defaults to yes
|
||||
if(!$GLOBALS['egw_info']['user']['preferences']['common']['disable_pngfix'])
|
||||
{
|
||||
@ -251,9 +253,7 @@ abstract class egw_framework
|
||||
}
|
||||
|
||||
return $this->_get_css()+array(
|
||||
#'img_icon' => EGW_IMAGES_DIR . '/favicon.ico',
|
||||
'img_icon' => $var['favicon_file'],
|
||||
#'img_shortcut' => EGW_IMAGES_DIR . '/favicon.ico',
|
||||
'img_shortcut' => $var['favicon_file'],
|
||||
'pngfix' => $pngfix,
|
||||
'slider_effects' => $slider_effects,
|
||||
|
@ -768,7 +768,7 @@ if ($run_by_webserver)
|
||||
));
|
||||
$ConfigDomain = get_var('ConfigDomain',Array('POST','COOKIE'));
|
||||
if (@$_GET['intro']) {
|
||||
if($ConfigLang = get_var('ConfigLang',array('POST','COOKIE')))
|
||||
if(($ConfigLang = setup::get_lang()))
|
||||
{
|
||||
$GLOBALS['egw_setup']->set_cookie('ConfigLang',$ConfigLang,(int) (time()+(1200*9)),'/');
|
||||
}
|
||||
|
@ -197,6 +197,21 @@ class setup
|
||||
}
|
||||
setcookie($cookiename,$cookievalue,$cookietime,'/',$this->cookie_domain);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get configuration language from $_POST or $_COOKIE and validate it
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
static function get_lang()
|
||||
{
|
||||
$ConfigLang = get_var('ConfigLang', array('POST','COOKIE'));
|
||||
if (preg_match('/^[a-z]{2}(-[a-z]{2})?$',$ConfigLang))
|
||||
{
|
||||
return $ConfigLang;
|
||||
}
|
||||
return 'en';
|
||||
}
|
||||
|
||||
/**
|
||||
* authenticate the setup user
|
||||
@ -207,7 +222,8 @@ class setup
|
||||
{
|
||||
#phpinfo();
|
||||
$FormLogout = get_var('FormLogout', array('GET','POST'));
|
||||
$ConfigLang = get_var('ConfigLang', array('POST','COOKIE'));
|
||||
$ConfigLang = self::get_lang();
|
||||
if (!preg_match('/^['))
|
||||
if(!$FormLogout)
|
||||
{
|
||||
$ConfigLogin = get_var('ConfigLogin', array('POST'));
|
||||
|
@ -169,7 +169,7 @@
|
||||
$manual_remote_egw_url = 'http://manual.egroupware.org/egroupware';
|
||||
$url_parts = explode('/',$_SERVER['PHP_SELF']);
|
||||
$script = array_pop($url_parts);
|
||||
$lang = get_var('ConfigLang',Array('POST','COOKIE'));
|
||||
$lang = setup::get_lang();
|
||||
$url = $manual_remote_egw_url.'/manual/index.php?referer='.urlencode($manual_remote_egw_url.'/setup/'.$script).
|
||||
($lang ? '&lang='.urlencode($lang) : '');
|
||||
$GLOBALS['setup_tpl']->set_var('manual','<a href="'.$url.'" target="manual" onclick="'.
|
||||
|
@ -188,7 +188,7 @@ class setup_process
|
||||
$langs = false;
|
||||
if ($method == 'new')
|
||||
{
|
||||
$langs[] = ($own_lang = get_var('ConfigLang',Array('POST','COOKIE')));
|
||||
$langs[] = ($own_lang = setup::get_lang());
|
||||
if ($own_lang != 'en') $langs[] = 'en';
|
||||
}
|
||||
$this->translation->drop_add_all_langs($langs);
|
||||
|
@ -32,7 +32,7 @@ class setup_translation
|
||||
*/
|
||||
function __construct()
|
||||
{
|
||||
$ConfigLang = get_var('ConfigLang',Array('POST','COOKIE'));
|
||||
$ConfigLang = setup::get_lang();
|
||||
|
||||
if(!$ConfigLang)
|
||||
{
|
||||
|
@ -108,7 +108,7 @@ function lang_select($onChange=False,$ConfigLang='')
|
||||
{
|
||||
if (!$ConfigLang)
|
||||
{
|
||||
$ConfigLang = get_var('ConfigLang',Array('POST','COOKIE'));
|
||||
$ConfigLang = setup::get_lang();
|
||||
}
|
||||
$select = '<select name="ConfigLang"'.($onChange ? ' onchange="this.form.submit();"' : '').'>' . "\n";
|
||||
$languages = get_langs();
|
||||
|
Loading…
Reference in New Issue
Block a user