From 8e5ee31e565d18dedfa0c8ab2e4f4413cd4dad61 Mon Sep 17 00:00:00 2001 From: Ralf Becker Date: Tue, 1 Dec 2009 13:59:45 +0000 Subject: [PATCH] "supress warning \"session.save_path not writable by webserver\", if open_basedir is activ and path is NOT included --> spares users from false warning, that they can not login, because sessions not working" --- setup/check_install.php | 26 +++++++++++++++++++------- 1 file changed, 19 insertions(+), 7 deletions(-) diff --git a/setup/check_install.php b/setup/check_install.php index 660538f09b..2e738af206 100644 --- a/setup/check_install.php +++ b/setup/check_install.php @@ -206,14 +206,26 @@ $checks = array( 'error' => lang("The ctype extension is needed by HTMLpurifier to check content of FCKeditor agains Cross Site Skripting."), ), ); -if (extension_loaded('session') && ini_get('session.save_handler') == 'files' && ($session_path = session_save_path())) +if (extension_loaded('session') && ini_get('session.save_handler') == 'files' && ($session_path = realpath(session_save_path()))) { - $checks[realpath($session_path)] = array( - 'func' => 'permission_check', - 'is_writable' => true, - 'msg' => lang("Checking if php.ini setting session.save_path='%1' is writable by the webserver",session_save_path()), - 'error' => lang('You will NOT be able to log into eGroupWare using PHP sessions: "session could not be verified" !!!'), - ); + $sp_visible = true; + if (($open_basedir = ini_get('open_basedir')) && $open_basedir != 'none') + { + foreach(explode(PATH_SEPARATOR,$open_basedir) as $dir) + { + $dir = realpath($dir); + if (($sp_visible = substr($session_path,0,strlen($dir)) == $dir)) break; + } + } + if ($sp_visible) // only check if session_save_path is visible by webserver + { + $checks[$session_path] = array( + 'func' => 'permission_check', + 'is_writable' => true, + 'msg' => lang("Checking if php.ini setting session.save_path='%1' is writable by the webserver",session_save_path()), + 'error' => lang('You will NOT be able to log into eGroupWare using PHP sessions: "session could not be verified" !!!'), + ); + } } $setup_info = $GLOBALS['egw_setup']->detection->get_versions(); foreach($setup_info as $app => $app_data)