X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=plugins%2Fadministrator%2Foptions.php;h=f9f06adda65a06addea32f87db61eb2681e39316;hb=66eee195afb7bff6d87637e50b1744183575c9ce;hp=f1b5f6eec5abe1a5acea3690412270bdc3905c16;hpb=a55bb20745b11201a20908015bc299857769734e;p=squirrelmail.git diff --git a/plugins/administrator/options.php b/plugins/administrator/options.php index f1b5f6ee..f9f06add 100644 --- a/plugins/administrator/options.php +++ b/plugins/administrator/options.php @@ -16,71 +16,133 @@ function parseConfig( $cfg_file ) { global $newcfg; $cfg = file( $cfg_file ); - $cm = FALSE; - $j = count( $cfg ); - - for ( $i=0; $i < $j; $i++ ) { - $l = ''; - $first_char = $cfg[$i]{0}; - do { - // Remove comments - $c = trim( $cfg[$i] ); - $c = preg_replace( '/\/\*.*\*\//', '', $c ); - $c = preg_replace( '/#.*$/', '', $c ); - $c = preg_replace( '/\/\/.*$/', '', $c ); - $c = trim( $c ); - $l .= $c; - $i++; - } while( $first_char == '$' && substr( $c, -1 ) <> ';' && $i < $j ); - $i--; - if ( $l <> '' ) { - if ( $cm ) { - if( substr( $l, -2 ) == '*/' ) { - $l = ''; - $cm = FALSE; - } else if( $k = strpos( $l, '*/' ) ) { - $l = substr( $l, $k ); - $cm = FALSE; + $mode = ''; + $l = count( $cfg ); + $modifier = FALSE; + + for ($i=0;$i<$l;$i++) { + $line = trim( $cfg[$i] ); + $s = strlen( $line ); + for ($j=0;$j<$s;$j++) { + switch ( $mode ) { + case '=': + if ( $line{$j} == '=' ) { + // Ok, we've got a right value, lets detect what type + $mode = 'D'; + } else if ( $line{$j} == ';' ) { + // hu! end of command + $key = $mode = ''; + } + break; + case 'K': + // Key detect + if( $line{$j} == ' ' ) { + $mode = '='; } else { - $l = ''; + $key .= $line{$j}; } - } else { - if( $l{0}.$l{1} == '/*' ) { - $l = ''; - $cm = TRUE; - } else if ( $k = strpos( $l, '/*' ) ) { - $l = substr( $l, 0, $k ); - $cm = TRUE; + break; + case ';': + // Skip until next ; + if ( $line{$j} == ';' ) { + $mode = ''; + } + break; + case 'S': + if ( $line{$j} == '\\' ) { + $value .= $line{$j}; + $modifier = TRUE; + } else if ( $line{$j} == $delimiter && $modifier === FALSE ) { + // End of string; + $newcfg[$key] = $value . $delimiter; + $key = $value = ''; + $mode = ';'; + } else { + $value .= $line{$j}; + $modifier = FALSE; + } + break; + case 'N': + if ( $line{$j} == ';' ) { + $newcfg{$key} = $value; + $key = $mode = ''; + } else { + $value .= $line{$j}; + } + break; + case 'C': + // Comments + if ( $s > $j + 1 && + $line{$j}.$line{$j+1} == '*/' ) { + $mode = ''; + $j++; + } + break; + case 'D': + // Delimiter detect + switch ( $line{$j} ) { + case '"': + case "'": + // Double quote string + $delimiter = $value = $line{$j}; + $mode = 'S'; + break; + case ' ': + // Nothing yet + break; + default: + if ( strtoupper( substr( $line, $j, 4 ) ) == 'TRUE' ) { + // Boolean TRUE + $newcfg{$key} = 'TRUE'; + $key = ''; + $mode = ';'; + } else if ( strtoupper( substr( $line, $j, 5 ) ) == 'FALSE' ) { + $newcfg{$key} = 'FALSE'; + $key = ''; + $mode = ';'; + } else { + // Number or function call + $mode = 'N'; + $value = $line{$j}; + } + } + break; + default: + if ( $line{$j} == '$' ) { + // We must detect $key name + $mode = 'K'; + $key = '$'; + } else if ( $s < $j + 2 ) { + } else if ( strtoupper( substr( $line, $j, 7 ) ) == 'GLOBAL ' ) { + // Skip untill next ; + $mode = ';'; + $j += 6; + } else if ( $line{$j}.$line{$j+1} == '/*' ) { + $mode = 'C'; + $j++; + } else if ( $line{$j} == '#' || $line{$j}.$line{$j+1} == '//' ) { + // Delete till the end of the line + $j = $s; } - } - - if ( $k = strpos( $l, '=' ) ) { - $key = trim( substr( $l, 0, $k - 1 ) ); - $val = str_replace( ';', '', trim( substr( $l, $k + 1 ) ) ); - $newcfg[$key] = $val; } } - } } + /* ---------------------- main -------------------------- */ + chdir('..'); require_once('../src/validate.php'); require_once('../functions/page_header.php'); require_once('../functions/imap.php'); require_once('../src/load_prefs.php'); require_once('../plugins/administrator/defines.php'); +require_once('../plugins/administrator/auth.php'); -$auth = FALSE; -if ( $adm_id = fileowner('../config/config.php') ) { - $adm = posix_getpwuid( $adm_id ); - if ( $username == $adm['name'] ) { - $auth = TRUE; - } -} +GLOBAL $data_dir, $username; -if ( !auth ) { +if ( !adm_check_user() ) { header("Location: ../../src/options.php") ; exit; } @@ -97,10 +159,34 @@ $cfgfile = '../config/config.php'; parseConfig( '../config/config_default.php' ); parseConfig( $cfgfile ); -echo "
" . +$colapse = array( 'Titles' => 'off', + 'Group1' => getPref($data_dir, $username, 'adm_Group1', 'off' ), + 'Group2' => getPref($data_dir, $username, 'adm_Group2', 'on' ), + 'Group3' => getPref($data_dir, $username, 'adm_Group3', 'on' ), + 'Group4' => getPref($data_dir, $username, 'adm_Group4', 'on' ), + 'Group5' => getPref($data_dir, $username, 'adm_Group5', 'on' ), + 'Group6' => getPref($data_dir, $username, 'adm_Group6', 'on' ), + 'Group7' => getPref($data_dir, $username, 'adm_Group7', 'on' ), + 'Group8' => getPref($data_dir, $username, 'adm_Group8', 'on' ) ); + +if ( isset( $switch ) ) { + + if ( $colapse[$switch] == 'on' ) { + $colapse[$switch] = 'off'; + } else { + $colapse[$switch] = 'on'; + } + setPref($data_dir, $username, "adm_$switch", $colapse[$switch] ); + +} + +echo "" . "
". "" , ""; + +$act_grp = 'Titles'; /* Active group */ + foreach ( $newcfg as $k => $v ) { $l = strtolower( $v ); $type = SMOPT_TYPE_UNDEFINED; @@ -113,7 +199,11 @@ foreach ( $newcfg as $k => $v ) { if ( isset( $defcfg[$k] ) ) { $name = $defcfg[$k]['name']; $type = $defcfg[$k]['type']; - $size = $defcfg[$k]['size']; + if ( isset( $defcfg[$k]['size'] ) ) { + $size = $defcfg[$k]['size']; + } else { + $size = 40; + } } else if ( $l == 'true' ) { $v = 'TRUE'; $type = SMOPT_TYPE_BOOLEAN; @@ -126,88 +216,265 @@ foreach ( $newcfg as $k => $v ) { $type = SMOPT_TYPE_STRING; } - switch ( $type ) { - case SMOPT_TYPE_TITLE: - echo ""; - break; - case SMOPT_TYPE_COMMENT: - $v = substr( $v, 1, strlen( $v ) - 2 ); - echo ""; + break; + case SMOPT_TYPE_TITLE: + if ( $colapse[$k] == 'on' ) { + $sw = '(+)'; + } else { + $sw = '(-)'; + } + echo ""; + $act_grp = $k; + break; + case SMOPT_TYPE_COMMENT: + $v = substr( $v, 1, strlen( $v ) - 2 ); + echo "\n"; + break; + case SMOPT_TYPE_INTEGER: + if ( isset( $HTTP_POST_VARS[$e] ) ) { + $v = intval( $HTTP_POST_VARS[$e] ); + $newcfg[$k] = $v; + } + echo "\n"; + break; + case SMOPT_TYPE_NUMLIST: + if ( isset( $HTTP_POST_VARS[$e] ) ) { + $v = $HTTP_POST_VARS[$e]; + $newcfg[$k] = $v; + } + echo "\n"; + break; + case SMOPT_TYPE_STRLIST: + if ( isset( $HTTP_POST_VARS[$e] ) ) { + $v = '"' . $HTTP_POST_VARS[$e] . '"'; + $newcfg[$k] = $v; + } + echo "\n"; + break; + + case SMOPT_TYPE_TEXTAREA: + if ( isset( $HTTP_POST_VARS[$e] ) ) { + $v = '"' . $HTTP_POST_VARS[$e] . '"'; + $newcfg[$k] = str_replace( "\n", '', $v ); + } + echo "\n"; + break; + case SMOPT_TYPE_STRING: + if ( isset( $HTTP_POST_VARS[$e] ) ) { + $v = '"' . $HTTP_POST_VARS[$e] . '"'; + $newcfg[$k] = $v; + } + if ( $v == '""' && isset( $defcfg[$k]['default'] ) ) { + $v = "'" . $defcfg[$k]['default'] . "'"; + $newcfg[$k] = $v; + } + echo "\n"; + break; + case SMOPT_TYPE_BOOLEAN: + if ( isset( $HTTP_POST_VARS[$e] ) ) { + $v = $HTTP_POST_VARS[$e]; + $newcfg[$k] = $v; + } else { + $v = strtoupper( $v ); + } + if ( $v == 'TRUE' ) { + $ct = ' checked'; + $cf = ''; + } else { + $ct = ''; + $cf = ' checked'; + } + echo "\n"; + break; + default: + echo "\n"; } - echo "'; + while ( isset( $newcfg["\$theme[$i]['NAME']"] ) ) { + $k1 = "\$theme[$i]['NAME']"; + $e1 = "theme_name_$i"; + if ( isset( $HTTP_POST_VARS[$e1] ) ) { + $v1 = '"' . $HTTP_POST_VARS[$e1] . '"'; + $newcfg[$k1] = $v1; + } else { + $v1 = $newcfg[$k1]; } - echo ''; - break; - case SMOPT_TYPE_STRLIST: - if ( isset( $HTTP_POST_VARS[$e] ) ) { - $v = '"' . $HTTP_POST_VARS[$e] . '"'; - $newcfg[$k] = $v; + $k2 = "\$theme[$i]['PATH']"; + $e2 = "theme_path_$i"; + if ( isset( $HTTP_POST_VARS[$e2] ) ) { + $v2 = '"' . $HTTP_POST_VARS[$e2] . '"'; + $newcfg[$k2] = $v2; + } else { + $v2 = $newcfg[$k2]; } - echo "'. + "". + "". + "\n"; + $i++; + + } +} + +/* Special Plugins Block */ +if ( $colapse['Group8'] == 'on' ) { + $sw = '(+)'; +} else { + $sw = '(-)'; +} +echo "'; + +if( $colapse['Group8'] == 'off' ) { + + $fd = opendir( '../plugins/' ); + $op_plugin = array(); + $p_count = 0; + while (false!==($file = readdir($fd))) { + if ($file != '.' && $file != '..' && $file != 'CVS' ) { + if ( filetype( $file ) == 'dir' ) { + $op_plugin[] = $file; + $p_count++; + } } - echo ''; - break; + } + closedir($fd); + asort( $op_plugin ); - case SMOPT_TYPE_STRING: - if ( isset( $HTTP_POST_VARS[$e] ) ) { - $v = '"' . $HTTP_POST_VARS[$e] . '"'; - $newcfg[$k] = $v; + /* Lets get the plugins that are active */ + $plugins = array(); + if ( isset( $HTTP_POST_VARS['plg'] ) ) { + foreach ( $op_plugin as $plg ) { + if ( isset( $HTTP_POST_VARS["plgs_$plg"] ) && + $HTTP_POST_VARS["plgs_$plg"] == 'on' ) { + $plugins[] = $plg; + } } - echo "" , @@ -216,13 +483,15 @@ echo "
" . _("Configuration Administrator") . "
$name
$name". - "$v"; - $newcfg[$k] = "'$v'"; - break; - case SMOPT_TYPE_INTEGER: - if ( isset( $HTTP_POST_VARS[$e] ) ) { - $v = intval( $HTTP_POST_VARS[$e] ); - $newcfg[$k] = $v; - } - echo "
$name". - ""; - break; - case SMOPT_TYPE_NUMLIST: - if ( isset( $HTTP_POST_VARS[$e] ) ) { - $v = $HTTP_POST_VARS[$e]; - $newcfg[$k] = $v; + if ( substr( $k, 0, 7 ) == '$theme[' ) { + $type = SMOPT_TYPE_THEME; + } else if ( substr( $k, 0, 9 ) == '$plugins[' ) { + $type = SMOPT_TYPE_PLUGINS; + } else if ( substr( $k, 0, 13 ) == '$ldap_server[' ) { + $type = SMOPT_TYPE_LDAP; + } + + if( $type == SMOPT_TYPE_TITLE || $colapse[$act_grp] == 'off' ) { + + switch ( $type ) { + case SMOPT_TYPE_LDAP: + case SMOPT_TYPE_PLUGINS: + case SMOPT_TYPE_THEME: + case SMOPT_TYPE_HIDDEN: + break; + case SMOPT_TYPE_EXTERNAL: + echo "
$name" . + $defcfg[$k]['value'] . + "
" . + "$sw " . + "$name
$name". + "$v"; + $newcfg[$k] = "'$v'"; + if ( isset( $defcfg[$k]['comment'] ) ) { + echo '   ' . $defcfg[$k]['comment']; + } + echo "
$name". + ""; + if ( isset( $defcfg[$k]['comment'] ) ) { + echo '   ' . $defcfg[$k]['comment']; + } + echo "
$name"; + echo "'; + if ( isset( $defcfg[$k]['comment'] ) ) { + echo '   ' . $defcfg[$k]['comment']; + } + echo "
$name". + "'; + if ( isset( $defcfg[$k]['comment'] ) ) { + echo '   ' . $defcfg[$k]['comment']; + } + echo "
$name". + ""; + if ( isset( $defcfg[$k]['comment'] ) ) { + echo '   ' . $defcfg[$k]['comment']; + } + echo "
$name". + ""; + if ( isset( $defcfg[$k]['comment'] ) ) { + echo '   ' . $defcfg[$k]['comment']; + } + echo "
$name" . + "" . _("Yes") . + "" . _("No"); + if ( isset( $defcfg[$k]['comment'] ) ) { + echo '   ' . $defcfg[$k]['comment']; + } + echo "
$name" . + "$v"; + if ( isset( $defcfg[$k]['comment'] ) ) { + echo '   ' . $defcfg[$k]['comment']; + } + echo "
$name"; - echo "
' . _("Theme Name") . + '' . _("Theme Path") . + '
$name". - "
$i.
" . + "$sw " . + _("Plugins") . '
$name". - ""; - break; - case SMOPT_TYPE_BOOLEAN: - if ( isset( $HTTP_POST_VARS[$e] ) ) { - $v = $HTTP_POST_VARS[$e]; - $newcfg[$k] = $v; - } else { - $v = strtoupper( $v ); + $i = 0; + foreach ( $plugins as $plg ) { + $k = "\$plugins[$i]"; + $newcfg[$k] = "'$plg'"; + $i++; } - if ( $v == 'TRUE' ) { - $ct = ' checked'; - $cf = ''; + while ( isset( $newcfg["\$plugins[$i]"] ) ) { + $k = "\$plugins[$i]"; + $newcfg[$k] = ''; + $i++; + } + } else { + $i = 0; + while ( isset( $newcfg["\$plugins[$i]"] ) ) { + $k = "\$plugins[$i]"; + $v = $newcfg[$k]; + $plugins[] = substr( $v, 1, strlen( $v ) - 2 ); + $i++; + } + } + echo "
' . + "". + "\n"; } - echo "\n"; + echo '
"; + foreach ( $op_plugin as $plg ) { + if ( in_array( $plg, $plugins ) ) { + $sw = ' checked'; } else { - $ct = ''; - $cf = ' checked'; + $sw = ''; } - echo "
$name" . - "" . _("Yes") . - "" . _("No"); - break; - default: - echo "
$name" . - "$v"; + echo '
$plg
'; + } echo "
$v ) { @@ -233,20 +502,25 @@ foreach ( $newcfg as $k => $v ) { fwrite( $fp, ', ' ); } fwrite( $fp, substr( $k, 0, $i) ); - $not_first = TRUE; } } else { if( $not_first ) { fwrite( $fp, ', ' ); } fwrite( $fp, $k ); - $not_first = TRUE; } + $not_first = TRUE; } } fwrite( $fp, ";\n" ); +*/ foreach ( $newcfg as $k => $v ) { - if ( $k{0} == '$' ) { + if ( $k{0} == '$' && $v <> '' ) { + if ( substr( $k, 1, 11 ) == 'ldap_server' ) { + $v = substr( $v, 0, strlen( $v ) - 1 ) . "\n)"; + $v = str_replace( 'array(', "array(\n\t", $v ); + $v = str_replace( "',", "',\n\t", $v ); + } fwrite( $fp, "$k = $v;\n" ); } }