From fe4b2ab2dc23406e07942683d04a66a720ef9c13 Mon Sep 17 00:00:00 2001 From: hickert Date: Wed, 7 Feb 2007 12:03:25 +0000 Subject: [PATCH] Some setup updates git-svn-id: https://oss.gonicus.de/repositories/gosa/trunk@5705 594d385d-05f5-0310-b6e9-bd551577e9d8 --- html/images/setup_step_back.png | Bin 0 -> 733 bytes html/images/setup_step_back_gray.png | Bin 0 -> 420 bytes html/images/setup_step_forward.png | Bin 0 -> 726 bytes html/images/setup_step_forward_gray.png | Bin 0 -> 426 bytes setup/class_setup.inc | 37 ++- setup/class_setupStep2.inc | 305 +++++++++++++----------- setup/setup_step2.tpl | 200 ++++++++++++---- 7 files changed, 356 insertions(+), 186 deletions(-) create mode 100644 html/images/setup_step_back.png create mode 100644 html/images/setup_step_back_gray.png create mode 100644 html/images/setup_step_forward.png create mode 100644 html/images/setup_step_forward_gray.png diff --git a/html/images/setup_step_back.png b/html/images/setup_step_back.png new file mode 100644 index 0000000000000000000000000000000000000000..52fa887f758c8aba8dbe68ef230c11ad2867cfff GIT binary patch literal 733 zcmV<30wVp1P)|Ek}WJYW#PzlJX z{{>W>7=H0NGkiN&4b}$`Kv-P>^;L?l6vI@Yfl@%WGDuiV$BV(dWIF>Zw*Xu%Kmaje z(+t$qA}R2DwyYq?HDJ?z$XX{cSd?yMU}9lo`1kuaTs=Slu^?*(Ih}=xVX`>?pB!f9 ze+<_jGBAj%JE&V{t(-4u>htLz&|820F>nBt-T>kF03Zw%kQe_{Cg?JvWpFaH=!m01{=nHX7tTKIsN5g>rz zVX$xEEVdUfzBBy!%gFHa7X!ohpZ^(t{Ql4I?=R46e}I1b2Z<#nCa`ls0rL-}4W@F)-F(Qv$jk^%2n=j&|GqtX z_W$vcS|Il%KmdVVgO;3`*ySUpn-<>vU$*?`e=g0uQ$R60Al3k4bttU~#Gv%S2oONn z3;+XWF{f&|=&S$PGz!lGx!SmrGC%;~Gyv=^QP)alm7LQ+rVffY#Jda)4Gjzc0fg58 zpi&l~-$Blmg9RE0y8uD;*5gN9v#y{9+4pS)i`QaFCH|J>#9Qj&yH<>BhY@?9Y=8SuIH zL-63@LK<>K)Xg~ED-qJu!KE{T_P80j--i-}?AhR4rr~Ps{_@xs(Qn-&MGkQ)e^b3p zTgQ#+*u<8OewDh{zT|N7ef4IkqpR(!T|2gosGKk$W$?D|yFyn-SD_G+OoZ~l(~eCg>5s|g+EnYso$2!~SZHlFQbOPEh7#eR>}>e?Y`luv2e*u>8C5qV z9RfJ__+E^Ba;>N9zX8t9U;gO&{+{sUUqGJfh9#I2iX#ANKiRwxBJBacF=@a8QM=gy O0000<|L@=b|9}1Z{a?<+ zS6#peAl3w84Iowwop|$p z(UPD4`8{_1W8l)94is|$Vt(X=1Q0+B*4EZo69}KI9)tJf_jhz6cm8Eyk?a8qS%Q)V zdP)QcAck+>zA<=udZOxP6K4?f-O3;pwCfZDi$pzCGZ(g`3=lwI0)z_+3K%psHKC~k zn3kE?KrC?}R>7tjW&l6{fe1#JAv_ zf@o<70wJg^a_Nfe&hO7p!+G2->U({@c)xf*-%)V-#Ak5TU6A=FRdu+(_B8)E!eO`} zsH@3cy8P&U?e+;3u}D38(0KUn!pc|$cooe^BXJp;T{kP0t<8yUdk~1W1&xE|^+Tmp zB9Y*WohN@b2;x#9pp?sG5{Zs0?!TOT25})*$o2L0^dyd?y8bfnD%BE&^QL7ozx|Lq za$xUmr>#%*4SXoGB9tKw3pW $value){ + if(preg_match("/^next_(x|y)/",$name)){ + $_POST['next'] = TRUE; + } + if(preg_match("/^last_(x|y)/",$name)){ + $_POST['last'] = TRUE; + } + } + /* Check if step was selected */ - if(isset($_GET['step']) || isset($_POST['next'])){ + if(isset($_GET['step']) || isset($_POST['next']) || isset($_POST['last'])){ if(isset($_GET['step'])){ $step = $_GET['step']; - }else{ + }elseif(isset($_POST['next'])){ $step = $this->i_current + 1; + }elseif(isset($_POST['last'])){ + $step = $this->i_current - 1; } if($this->selectable_step($step)){ @@ -124,9 +136,26 @@ class setup extends plugin /* Create header entry */ function get_header_html() { - $str =""; + $str =""; + $str.="
"; + $str.="
"; + $str.=" "; $str.= $this->o_steps[$this->i_current]->get_long_title(); - $str.=""; + $str.=" "; + $str.="
"; + $str.="
"; + if(isset($this->o_steps[$this->i_current -1]) && $this->o_steps[$this->i_current -1]->is_enabled()){ + $str.=" "; + }else{ + $str.=" "; + } + if(isset($this->o_steps[$this->i_current +1]) && $this->o_steps[$this->i_current +1]->is_enabled()){ + $str.=" "; + }else{ + $str.=" "; + } + $str.= "
"; + $str.= "
"; return ($str); } diff --git a/setup/class_setupStep2.inc b/setup/class_setupStep2.inc index b1cc05d2e..7c2d3536c 100644 --- a/setup/class_setupStep2.inc +++ b/setup/class_setupStep2.inc @@ -24,6 +24,8 @@ class setup_step_2 extends setup_step { var $basic_checks = array(); var $config_checks= array(); + var $is_writeable = array(); + function setup_step_2() { @@ -38,8 +40,9 @@ class setup_step_2 extends setup_step { $this->run_checks(); $smarty = get_smarty(); - $smarty->assign("basic" ,$this->basic_checks); - $smarty->assign("config",$this->config_checks); + $smarty->assign("basic" ,$this->basic_checks); + $smarty->assign("config" ,$this->config_checks); + $smarty->assign("is_writeable",$this->is_writeable); return($smarty->fetch(get_template_path("setup_step2.tpl",TRUE,dirname(__FILE__)))); } @@ -47,99 +50,109 @@ class setup_step_2 extends setup_step /* Execute all checks */ function run_checks() { - $i =0; $this->basic_checks = array(); $this->config_checks = array(); + $this->is_writeable = array(); /* PHP version check */ - $i ++; - $this->basic_checks[$i]['NAME'] = _("Checking PHP version"); - $this->basic_checks[$i]['DESC'] = sprintf(_("PHP must be of version %s or %s or above for some functions."),"4.3.10","5.2.0"); - $this->basic_checks[$i]['RESULT']= $this->check_php_version(); - $this->basic_checks[$i]['SOLUTION'] = _("GOsa requires functions that may not be available in older PHP versions, just update to a supported PHP version."); + $N = _("Checking PHP version"); + $D = sprintf(_("PHP must be of version %s or %s or above for some functions."),"4.3.10","5.2.0"); + $S = _("GOsa requires functions that may not be available in older PHP versions, just update to a supported PHP version."); + $R = $this->check_php_version(); + $M = TRUE; + $this->basic_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); /* Checking imap extension */ - $i ++; - $this->basic_checks[$i]['NAME'] = _("Checking for ldap module"); - $this->basic_checks[$i]['DESC'] = _("This is the main module used by GOsa and therefore really required."); - $this->basic_checks[$i]['RESULT']= is_callable("ldap_bind"); - $this->basic_checks[$i]['SOLUTION'] = _("The ldap module (PHP4-ldap/PHP5-ldap) is required to communicate with your ldap server."); + $N = _("Checking for ldap module"); + $D = _("This is the main module used by GOsa and therefore really required."); + $S = _("The ldap module (PHP4-ldap/PHP5-ldap) is required to communicate with your ldap server."); + $R = is_callable("ldap_bind"); + $M = TRUE; + $this->basic_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); /* Check for gettext support */ - $i ++; - $this->basic_checks[$i]['NAME'] = _("Checking for gettext support"); - $this->basic_checks[$i]['DESC'] = _("Gettext support is required for internationalized GOsa."); - $this->basic_checks[$i]['RESULT']= is_callable("bindtextdomain"); - $this->basic_checks[$i]['SOLUTION'] = _("This should be activated while compiling your PHP. (--with-gettext)"); - - /* iconv */ - $i ++; - $this->basic_checks[$i]['NAME'] = _("Checking for iconv support"); - $this->basic_checks[$i]['DESC'] = _("This module is used by GOsa to convert samba munged dial informations and is therefore required."); - $this->basic_checks[$i]['RESULT']= is_callable("iconv"); - $this->basic_checks[$i]['SOLUTION'] = _("his should be activated while compiling your PHP. (--with-iconv)"); - - /**/ - $i ++; - $this->basic_checks[$i]['NAME'] = _("Checking for mhash module"); - $this->basic_checks[$i]['DESC'] = _("To use SSHA encryption, you'll need this module. If you are just using crypt or md5 encryption, ignore this message. GOsa will run without it."); - $this->basic_checks[$i]['RESULT']= is_callable("mhash"); - $this->basic_checks[$i]['SOLUTION'] = _("The mhash module for PHP 4/5 is not available, please install it. (php4-mhash/php5-mhash)"); - - /**/ - $i ++; - $this->basic_checks[$i]['NAME'] = _("Checking for imap module"); - $this->basic_checks[$i]['DESC'] = _("The IMAP module is needed to communicate with the IMAP server. It gets status informations, creates and deletes mail users. "); - $this->basic_checks[$i]['RESULT']= is_callable("imap_open"); - $this->basic_checks[$i]['SOLUTION'] = _("This module is used to communicate with your mail server. Please install (PHP4-imap PHP5- imap)"); - - /**/ - $i ++; - $this->basic_checks[$i]['NAME'] = _("Checking for getacl in imap"); - $this->basic_checks[$i]['DESC'] = _("The getacl support is needed for shared folder permissions. The standard IMAP module is not capable of reading acl's. You need a recend PHP version for this feature."); - $this->basic_checks[$i]['RESULT']= is_callable("imap_getacl"); - $this->basic_checks[$i]['SOLUTION'] = _("This module is used to communicate with your mail server. Please install (PHP4-imap PHP5- imap)"); - - /**/ - $i ++; - $this->basic_checks[$i]['NAME'] = _("Checking for mysql module"); - $this->basic_checks[$i]['DESC'] = _("MySQL support is needed for reading GOfax reports from databases."); - $this->basic_checks[$i]['RESULT']= is_callable("mysql_query"); - $this->basic_checks[$i]['SOLUTION'] = _("This module is required to communicate with database servers, for example phone and fax addons. Please install (PHP4-mysql PHP5-mysql)"); - - /**/ - $i ++; - $this->basic_checks[$i]['NAME'] = _("Checking for kadm5 module"); - $this->basic_checks[$i]['DESC'] = _("Managing users in kerberos requires the kadm5 module which is downloadable via PEAR network."); - $this->basic_checks[$i]['RESULT']= is_callable("kadm5_init_with_password"); - $this->basic_checks[$i]['SOLUTION'] = _("This module is required to manage user in kerberos, it is downloadable via PEAR network"); - - /**/ - $i ++; - $this->basic_checks[$i]['NAME'] = _("Checking for snmp Module"); - $this->basic_checks[$i]['DESC'] = _("Simple Network Management Protocol (SNMP) is required for client monitoring."); - $this->basic_checks[$i]['RESULT']= is_callable("snmpget"); - $this->basic_checks[$i]['SOLUTION'] = _("This module is required for client monitoring. (PHP4-snmp/PHP5-snmp)"); + $N = _("Checking for gettext support"); + $D = _("Gettext support is required for internationalized GOsa."); + $S = _("This should be activated while compiling your PHP. (--with-gettext)"); + $R = is_callable("bindtextdomain"); + $M = TRUE; + $this->basic_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); + + /* Checing for iconv */ + $N = _("Checking for iconv support"); + $D = _("This module is used by GOsa to convert samba munged dial informations and is therefore required. "); + $S = _("his should be activated while compiling your PHP. (--with-iconv)"); + $R = is_callable("iconv"); + $M = TRUE; + $this->basic_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); + + /* Check for installed mhash module */ + $N = _("Checking for mhash module"); + $D = _("To use SSHA encryption, you'll need this module. GOsa will run without it."); + $S = _("The mhash module for PHP 4/5 is not available, please install it. (php4-mhash/php5-mhash)"); + $R = is_callable("mhash"); + $M = FALSE; + $this->basic_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); + + /* Is imap module available */ + $N = _("Checking for imap module"); + $D = _("The IMAP module is needed to communicate with the IMAP server. It gets status informations, creates and deletes mail users."); + $S = _("This module is used to communicate with your mail server. Please install (PHP4-imap PHP5-imap)"); + $R = is_callable("imap_open"); + $M = TRUE; + $this->basic_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); + + /* Check getacl in imap module */ + $N = _("Checking for getacl in imap"); + $D = _("The getacl support is needed for shared folder permissions. The standard IMAP module is not capable of reading acl's. You need a recend PHP version for this feature."); + $S = $D; + $R = is_callable("imap_getacl"); + $M = TRUE; + $this->basic_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); + + /* Mysql module loaded ? */ + $N = _("Checking for mysql module"); + $D = _("MySQL support is needed for reading GOfax reports from databases."); + $S = _("This module is required to communicate with database servers, for example used in phone and fax addons. Please install (PHP4-mysql PHP5-mysql)"); + $R = is_callable("mysql_query"); + $M = TRUE; + $this->basic_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); + + /* Checking for kadm5 module */ + $N = _("Checking for kadm5 module"); + $D = _("Managing users in kerberos requires the kadm5 module which is downloadable via PEAR network."); + $S = _("This module is required to manage user in kerberos, it is downloadable via PEAR network"); + $R = is_callable("kadm5_init_with_password"); + $M = FALSE; + $this->basic_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); + + /* Snmp module available ? */ + $N = _("Checking for snmp Module"); + $D = _("Simple Network Management Protocol (SNMP) is required for client monitoring."); + $S = _("This module is required for client monitoring. (PHP4-snmp/PHP5-snmp)"); + $R = is_callable("snmpget"); + $M = FALSE; + $this->basic_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); /* Checking for Cups module */ - $i ++; - $this->basic_checks[$i]['NAME'] = _("Checking for cups module"); - $this->basic_checks[$i]['DESC'] = _("In order to read available printers from IPP protocol instead of printcap files, you've to install the CUPS module."); - $this->basic_checks[$i]['RESULT']= is_callable("cups_get_dest_list"); - $this->basic_checks[$i]['SOLUTION'] = _("In order to read available printers from IPP protocol instead of printcap files, you've to install the CUPS module."); + $N = _("Checking for cups module"); + $D = _("In order to read available printers from IPP protocol instead of printcap files, you've to install the CUPS module."); + $S = $D; + $R = is_callable("cups_get_dest_list"); + $M = FALSE; + $this->basic_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); /* Checking for F ping utility */ - $i ++; $query= "LC_ALL=C LANG=C fping -v 2>&1"; $output= shell_exec ($query); - - $this->basic_checks[$i]['NAME'] = _("Checking for fping utility"); - $this->basic_checks[$i]['DESC'] = _("The fping utility is only used if you've got a thin client based terminal environment running."); - $this->basic_checks[$i]['RESULT']= preg_match("/^fping:/", $output); - $this->basic_checks[$i]['SOLUTION'] = _("The fping utility is only used in thin client based terminal environment."); + $N = _("Checking for fping utility"); + $D = _("The fping utility is only used if you've got a thin client based terminal environment running."); + $S = _("The fping utility is only used in thin client based terminal environment."); + $R = preg_match("/^fping:/", $output); + $M = FALSE; + $this->basic_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); /* Checking generate LM/NT password hashes */ - $i ++; $query= "mkntpwd 2>&1"; $output= shell_exec ($query); $have_mkntpwd= preg_match("/^Usage: mkntpwd /", $output); @@ -149,69 +162,93 @@ class setup_step_2 extends setup_step $have_mkntpwd |= ($ret == 0); } - $this->basic_checks[$i]['NAME'] = _("Password hashes"); - $this->basic_checks[$i]['DESC'] = _("In order to use SAMBA 2/3, you've to install some additional packages to generate password hashes."); - $this->basic_checks[$i]['RESULT']= $have_mkntpwd; - $this->basic_checks[$i]['SOLUTION'] = _("In order to use samba 2/3 you've to install some additional packages to generate password -hashes. (e.g. libmhash2)"); - + $N = _("Password hashes"); + $D = _("In order to use SAMBA 2/3, you've to install some additional packages to generate password hashes."); + $S = _("In order to use samba 2/3 you've to install some additional packages to generate password hashes. (e.g. libmhash2)"); + $R = $have_mkntpwd; + $M = TRUE; + $this->basic_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); /* PHP Configuration checks */ /* Register_globals off */ - $i = 0; - $this->config_checks[$i]['NAME'] = _("register_globals"." ".""._("Off").""); - $this->config_checks[$i]['DESC'] = _("register_globals is a PHP mechanism to register all global varibales to be accessible from scripts without changing the scope. This may be a security risk. GOsa will run in both modes."); - $this->config_checks[$i]['RESULT']= ini_get("register_globals") == 0; - - $i ++; - $this->config_checks[$i]['NAME'] = _("session.gc_maxlifetime"." "." >= 86400"); - $this->config_checks[$i]['DESC'] = _("PHP uses this value for the garbage collector to delete old sessions, setting this value to one day will prevent loosing session and cookie before they really timeout."); - $this->config_checks[$i]['RESULT']= ini_get("session.gc_maxlifetime") >= 86400; - - $i ++; + $N = _("register_globals"." ".""._("Off").""); + $D = _("register_globals is a PHP mechanism to register all global varibales to be accessible from scripts without changing the scope. This may be a security risk. GOsa will run in both modes."); + $S = _("Search for 'register_globals' in your php.ini and switch it to 'Off'."); + $R = ini_get("register_globals") == 0; + $M = FALSE; + $this->config_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); + + + /* session lifetime set to >=86400 seconds ? */ + $N = ("session.gc_maxlifetime"." "." >= 86400"); + $D = _("PHP uses this value for the garbage collector to delete old sessions.")." ". + _("Setting this value to one day will prevent loosing session and cookie before they really timeout."); + $S = _("Serach for 'session.gc_maxlifetime' in your php.ini and set it to 86400 or higher."); + $R = ini_get("session.gc_maxlifetime") >= 86400; + $M = FALSE; + $this->config_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); + + /* Session auto start must be turned off */ $session_auto_start = ini_get('session.auto_start'); - $this->config_checks[$i]['NAME'] = _("session.auto_start"." ".""._("Off").""); - $this->config_checks[$i]['DESC'] = _("In Order to use GOsa without any trouble, the session.auto_register option in your php.ini must be set to 'Off'."); - $this->config_checks[$i]['RESULT']= !$session_auto_start['local_value']; - - $i ++; - $this->config_checks[$i]['NAME'] = _("memory_limit")." "." >= 32"; - $this->config_checks[$i]['DESC'] = _("GOsa needs at least 32MB of memory, less will cause unpredictable errors! Increase it for larger setups."); - $this->config_checks[$i]['RESULT']= ini_get('memory_limit') >= 32 ; - - - $i ++; - $this->config_checks[$i]['NAME'] = _("implicit_flush")." ".""._("Off").""; - $this->config_checks[$i]['DESC'] = _("This option influences the Output handling. Turn this Option off, to increase performance."); - $this->config_checks[$i]['RESULT']= !ini_get('implicit_flush'); + $N = _("session.auto_start"." ".""._("Off").""); + $D = _("In Order to use GOsa without any trouble, the session.auto_register option in your php.ini must be set to 'Off'."); + $S = _("Serach for 'session.auto_start' in your php.ini and set it to 'Off'."); + $R = !$session_auto_start['local_value']; + $M = TRUE; + $this->config_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); + + /* Check if memory limit is set to 32 or > */ + $N = _("memory_limit")." "." >= 32"; + $D = _("GOsa needs at least 32MB of memory, less will cause unpredictable errors! Increase it for larger setups."); + $S = _("Search for 'memory_limit' in your php.ini and set it to '32M' or higher."); + $R = ini_get('memory_limit') >= 32 ; + $M = TRUE; + $this->config_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); + + /* Implicit Flush disabled can increase performance */ + $N = _("implicit_flush")." ".""._("Off").""; + $D = _("This option influences the Output handling. Turn this Option off, to increase performance."); + $S = _("Search for 'implicit_flush' in your php.ini and set it to 'Off'."); + $R = ini_get('implicit_flush'); + $M = FALSE; + $this->config_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); + + /* Check if execution time is set to 30 */ + $N = _("max_execution_time")." "." >= 30"; + $D = _("The Execution time should be at least 30 seconds, because some actions may consume more time."); + $S = _("Search for 'max_execution_time' in your php.ini and set it to '30' or higher."); + $R = ini_get("max_execution_time") >= 30 ; + $M = TRUE; + $this->config_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); + + /* Expose php should be set to off */ + $N = _("expose_php")." "._("Off").""; + $D = _("Increase the server security by setting expose_php to 'off'. PHP won't send any Information about the server you are running in this case."); + $S = _("Search for 'expose_php' in your php.ini and set if to 'Off'."); + $R = !ini_get("expose_php"); + $M = FALSE; + $this->config_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); + + /* Automatic quoting must be turned on */ + $N = _("magic_quotes_gpc")." "._("On").""; + $D = _("Increase your server security by setting magic_quotes_gpc to 'on'. PHP will escape all quotes in strings in this case."); + $S = _("Search for 'magic_quotes_gpc' in yout php.ini and set it to 'On'."); + $R = ini_get('magic_quotes_gpc'); + $M = TRUE; + $this->config_checks[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); + + + /* Automatic quoting must be turned on */ + $N = _("Configuration file writeable."); + $D = _("The Configuration file can't be written"); + $S = _("Grant write access on '/etc/gosa/gosa.conf' for the webserver or copy the generated gosa.conf on your own."); + $R = file_exists("/etc/gosa/gosa.conf") && is_writeable("/etc/gosa/gosa.conf"); + $M = TRUE; + $this->is_writeable[] = array("NAME" => $N , "DESC" => $D , "RESULT" => $R , "SOLUTION" => $S , "MUST" => $M ); - $i ++; - $this->config_checks[$i]['NAME'] = _("max_execution_time")." "." >= 30"; - $this->config_checks[$i]['DESC'] = _("The Execution time should be at least 30 seconds, because some actions may consume more time."); - $this->config_checks[$i]['RESULT']= ini_get("max_execution_time") >= 30 ; - - $i ++; - $this->config_checks[$i]['NAME'] = _("expose_php")." "._("Off").""; - $this->config_checks[$i]['DESC'] = _("Increase the server security by setting expose_php to 'off'. PHP won't send any Information about the server you are running in this case."); - $this->config_checks[$i]['RESULT']= !ini_get("expose_php"); - - - $i ++; - $this->config_checks[$i]['NAME'] = _("magic_quotes_gpc")." "._("On").""; - $this->config_checks[$i]['DESC'] = _("Increase your server security by setting magic_quotes_gpc to 'on'. PHP will escape all quotes in strings in this case."); - $this->config_checks[$i]['RESULT']= ini_get('magic_quotes_gpc'); - - - - - foreach($this->basic_checks as $key => $entry){ - if(!isset($entry['SOLUTION'])){ - $this->basic_checks[$key]['SOLUTION'] = ""; - } - } } diff --git a/setup/setup_step2.tpl b/setup/setup_step2.tpl index 4413065e7..30984f24d 100644 --- a/setup/setup_step2.tpl +++ b/setup/setup_step2.tpl @@ -1,73 +1,177 @@ +
+ +
-   -

{t}PHP module and extension checks{/t}

+ + +

{t}PHP module and extension checks{/t}

{foreach from=$basic item=val key=key} + + + {if $basic[$key].SOLUTION != "" && !$basic[$key].RESULT} + + +
+ {else} -
+ +
+ {/if} + +
{$basic[$key].NAME}
+
- {if $basic[$key].SOLUTION != "" && !$basic[$key].RESULT} -
+ {if $basic[$key].RESULT} + {t}Successfull{/t} + {else} + {if $basic[$key].MUST} + {t}Failed{/t} {else} -
+ {t}Failed{/t} {/if} - + {if $basic[$key].SOLUTION != ""} - {$basic[$key].NAME} + +
+ {if $basic[$key].MUST} +
+ {t}GOsa will NOT run without fixing this.{/t} + {else} +
+ {t}GOsa will run without fixing this.{/t} + {/if} +
+ {$basic[$key].SOLUTION} +
+
+ {/if} + {/if} +
- {if $basic[$key].SOLUTION != "" && !$basic[$key].RESULT} -
+ {/foreach} +
+
+ + + +
+ + +
+ + +

{t}PHP setup configuration{/t}

+ + {foreach from=$config item=val key=key} + + + {if $config[$key].SOLUTION != "" && !$config[$key].RESULT} + + +
+ {else} + + +
+ {/if} + + +
{$config[$key].NAME}
+
+ {if $config[$key].RESULT} + {t}Successfull{/t} + {else} + + {if $config[$key].MUST} + {t}Failed{/t} {else} -
 
+ {t}Failed{/t} {/if} - {if $basic[$key].SOLUTION != "" && !$basic[$key].RESULT} -
- {else} -
+ + {if $config[$key].SOLUTION != ""} + + +
+ {if $config[$key].MUST} +
+ {t}GOsa will NOT run without fixing this.{/t} + {else} +
+ {t}GOsa will run without fixing this.{/t} + {/if} +
+ {$config[$key].SOLUTION} +
+
{/if} - {if $basic[$key].RESULT} - {t}Success{/t} + {/if} +
+
+ {/foreach} + + + +

{t}Configuration file writeable{/t}

+ + {foreach from=$is_writeable item=val key=key} + + + {if $is_writeable[$key].SOLUTION != "" && !$is_writeable[$key].RESULT} + + +
+ {else} + + +
+ {/if} + + +
{$is_writeable[$key].NAME}
+
+ {if $is_writeable[$key].RESULT} + {t}Successfull{/t} {else} - {t}Failed{/t} - {if $basic[$key].SOLUTION != ""} -
+ + {if $is_writeable[$key].MUST} + {t}Failed{/t} + {else} + {t}Failed{/t} + {/if} + + {if $is_writeable[$key].SOLUTION != ""} + + +
+ {if $is_writeable[$key].MUST}
- {$basic[$key].SOLUTION} -
+ {t}GOsa will NOT run without fixing this.{/t} + {else} +
+ {t}GOsa will run without fixing this.{/t} + {/if} +
+ {$is_writeable[$key].SOLUTION}
+
{/if} - {/if}
-
+
{/foreach} + +
-
-   -

{t}PHP setup configuration{/t}

- {foreach from=$config item=val key=key} -
- {$config[$key].NAME} -
-
 
-
- {if $config[$key].RESULT} - {t}Success{/t} - {else} - {t}Failed{/t} - {/if} -
- {/foreach} -
-