ACC SHELL

Path : /srv/www/htdocs/squirrelmail/plugins/administrator/
File Upload :
Current File : /srv/www/htdocs/squirrelmail/plugins/administrator/options.php

<?php
/**
 * Administrator Plugin - Options Page
 *
 * This script creates separate page, that allows to review and modify
 * SquirrelMail configuration file.
 *
 * @version $Id: options.php 13893 2010-01-25 02:47:41Z pdontthink $
 * @author Philippe Mingo
 * @copyright (c) 1999-2010 The SquirrelMail Project Team
 * @license http://opensource.org/licenses/gpl-license.php GNU Public License
 * @package plugins
 * @subpackage administrator
 */

/** This is the administrator_options page */
define('PAGE_NAME', 'administrator_options');

/**
 * parse the config file
 *
 * @param string $cfg_file
 * @access private
 */
function parseConfig( $cfg_file ) {

    global $newcfg;

    $cfg = file( $cfg_file );
    $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 {
                    $key .= $line{$j};
                }
                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;
                }
            }
        }
    }
}

/**
 * Change paths containing SM_PATH to admin-friendly paths
 * relative to the config dir, i.e.:
 *    ''                          --> <empty string>
 *    SM_PATH . 'images/logo.gif' --> ../images/logo.gif
 *    '/absolute/path/logo.gif'   --> /absolute/path/logo.gif
 *    'http://whatever/'          --> http://whatever
 *  Note removal of quotes in returned value
 *  
 * @param string $old_path path that has to be converted
 * @return string new path
 * @access private
 */
function change_to_rel_path($old_path) {
    $new_path = str_replace("SM_PATH . '", "../", $old_path); 
    $new_path = str_replace("../config/","", $new_path);
    $new_path = str_replace("'","", $new_path);
    return $new_path;
}

/**
 * Change relative path (relative to config dir) to 
 *  internal SM_PATH, i.e.:
 *     empty_string            --> ''
 *     ../images/logo.gif      --> SM_PATH . 'images/logo.gif'
 *     images/logo.gif         --> SM_PATH . 'config/images/logo.gif'
 *     /absolute/path/logo.gif --> '/absolute/path/logo.gif'
 *     C:/absolute/win/path    --> 'C:/absolute/win/path'
 *     http://whatever/        --> 'http://whatever'
 *  
 * @param string $old_path path that has to be converted
 * @return string new path
 * @access private
*/     
function change_to_sm_path($old_path) {
    if ( $old_path === '' || $old_path == "''" ) {
        return "''";
    } elseif ( preg_match("/^(\/|http)/", $old_path) ||
        substr($old_path,1,2) == ':/' ) {
        return "'" . $old_path . "'";
    } elseif ( preg_match("/^(\$|SM_PATH)/", $old_path) ) {
        return $old_path;
    }
   
    $new_path = '';
    $rel_path = explode("../", $old_path);
    if ( count($rel_path) > 2 ) {
        // Since we're relative to the config dir, 
        // more than 1 ../ puts us OUTSIDE the SM tree.
        // get full path to config.php, then pop the filename
        $abs_path = explode('/', realpath (SM_PATH . 'config/config.php'));
        array_pop ($abs_path); 
        foreach ( $rel_path as $subdir ) {
            if ( $subdir === '' ) {
                array_pop ($abs_path);
            } else {
                array_push($abs_path, $subdir);
            }
        }
        foreach ($abs_path as $subdir) {
            $new_path .= $subdir . '/';
        }
        $new_path = "'$new_path'";
    } elseif ( count($rel_path) > 1 ) {
        // we're within the SM tree, prepend SM_PATH
        $new_path = str_replace('../',"SM_PATH . '", $old_path . "'");
    } else {
        // Last, if it's a relative path without a .. prefix, 
        // we're somewhere within the config dir, so prepend
        //  SM_PATH . 'config/  
        $new_path = "SM_PATH . 'config/" . $old_path . "'";
    }
    return $new_path;
}


/* ---------------------- main -------------------------- */

/** @ignore */
define('SM_PATH','../../');

/* SquirrelMail required files. */
require_once(SM_PATH . 'include/validate.php');
require_once(SM_PATH . 'plugins/administrator/defines.php');
require_once(SM_PATH . 'plugins/administrator/auth.php');

global $data_dir, $username;

if ( !adm_check_user() ) {
    header('Location: ' . SM_PATH . 'src/options.php') ;
    exit;
}

displayPageHeader($color, 'None');

$newcfg = array( );

foreach ( $defcfg as $key => $def ) {
    $newcfg[$key] = '';
}

$cfgfile = SM_PATH . 'config/config.php';
parseConfig( SM_PATH . 'config/config_default.php' );
parseConfig( $cfgfile );

$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' ),
                  'Group9' => getPref($data_dir, $username, 'adm_Group9', 'on' ),
                  'Group10' => getPref($data_dir, $username, 'adm_Group10', 'on' ) );

/* look in $_GET array for 'switch' */
if ( sqgetGlobalVar('switch', $switch, SQ_GET) ) {
    if ( $colapse[$switch] == 'on' ) {
        $colapse[$switch] = 'off';
    } else {
        $colapse[$switch] = 'on';
    }
    setPref($data_dir, $username, "adm_$switch", $colapse[$switch] );
}

echo '<form action="options.php" method="post" name="options">' .
     '<center><table width="95%" bgcolor="'.$color[5].'"><tr><td>'.
     '<table width="100%" cellspacing="0" bgcolor="'.$color[4].'">'.
     '<tr bgcolor="'.$color[5].'"><th colspan="2">'.
     _("Configuration Administrator").'</th></tr>'.
     '<tr bgcolor="'.$color[5].'"><td colspan="2" align="center"><small>'.
     _("Note: it is recommended that you configure your system using conf.pl, and not this plugin. conf.pl contains additional information regarding the purpose of variables and appropriate values, as well as additional verification steps.").
     '<br />'.
     _("Run or consult conf.pl should you run into difficulty with your configuration.").
     '</small></td></tr>';


$act_grp = 'Titles';  /* Active group */

foreach ( $newcfg as $k => $v ) {
    $l = strtolower( $v );
    $type = SMOPT_TYPE_UNDEFINED;
    $n = substr( $k, 1 );
    $n = str_replace( '[', '_', $n );
    $n = str_replace( ']', '_', $n );
    $e = 'adm_' . $n;
    $name = $k;
    $size = 50;
    if ( isset( $defcfg[$k] ) ) {
        $name = $defcfg[$k]['name'];
        $type = $defcfg[$k]['type'];
        if ( isset( $defcfg[$k]['size'] ) ) {
            $size = $defcfg[$k]['size'];
        } else {
            $size = 40;
        }
    } else if ( $l == 'true' ) {
        $v = 'TRUE';
        $type = SMOPT_TYPE_BOOLEAN;
    } else if ( $l == 'false' ) {
        $v = 'FALSE';
        $type = SMOPT_TYPE_BOOLEAN;
    } else if ( $v{0} == "'" ) {
        $type = SMOPT_TYPE_STRING;
    } else if ( $v{0} == '"' ) {
        $type = SMOPT_TYPE_STRING;
    }

    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 "<tr><td>$name</td><td><b>" .
                 $defcfg[$k]['value'] .
                 '</b></td></tr>';
            break;
        case SMOPT_TYPE_TITLE:
            if ( $colapse[$k] == 'on' ) {
                $sw = '(+)';
            } else {
                $sw = '(-)';
            }
            echo '<tr bgcolor="'.$color[0].'"><th colspan="2">'.
                 "<a href=\"options.php?switch=$k\" style=\"text-decoration:none\">".
                 '<b>'.$sw.'</b></a> '.$name.'</th></tr>';
            $act_grp = $k;
            break;
        case SMOPT_TYPE_COMMENT:
            $v = substr( $v, 1, strlen( $v ) - 2 );
            echo "<tr><td>$name</td><td>".
                 "<b>$v</b>";
            $newcfg[$k] = "'$v'";
            if ( isset( $defcfg[$k]['comment'] ) ) {
                echo ' &nbsp; ' . $defcfg[$k]['comment'];
            }
            echo "</td></tr>\n";
            break;
        case SMOPT_TYPE_INTEGER:
            /* look for variable $e in POST, fill into $v */
            if ( sqgetGlobalVar($e, $new_v, SQ_POST) ) {
                $v = intval( $new_v );
                $newcfg[$k] = $v;
            }
            echo "<tr><td>$name</td><td>".
                 "<input size=\"10\" name=\"adm_$n\" value=\"$v\" />";
            if ( isset( $defcfg[$k]['comment'] ) ) {
                echo ' &nbsp; ' . $defcfg[$k]['comment'];
            }
            echo "</td></tr>\n";
            break;
        case SMOPT_TYPE_NUMLIST:
            if (  sqgetGlobalVar($e, $new_v, SQ_POST) ) {
                $v = $new_v;
                $newcfg[$k] = $v;
            }
            echo "<tr><td>$name</td><td>";
            echo "<select name=\"adm_$n\">";
            foreach ( $defcfg[$k]['posvals'] as $kp => $vp ) {
                echo "<option value=\"$kp\"";
                if ( $kp == $v ) {
                    echo ' selected="selected"';
                }
                echo ">$vp</option>";
            }
            echo '</select>';
            if ( isset( $defcfg[$k]['comment'] ) ) {
                echo ' &nbsp; ' . $defcfg[$k]['comment'];
            }
            echo "</td></tr>\n";
            break;
        case SMOPT_TYPE_STRLIST:
            if (  sqgetGlobalVar($e, $new_v, SQ_POST) ) {
                $v = '"' . $new_v . '"';
                $newcfg[$k] = $v;
            }
            echo "<tr><td>$name</td><td>".
                 "<select name=\"adm_$n\">";
            foreach ( $defcfg[$k]['posvals'] as $kp => $vp ) {
                echo "<option value=\"$kp\"";
                if ( $kp == substr( $v, 1, strlen( $v ) - 2 ) ) {
                    echo ' selected="selected"';
                }
                echo ">$vp</option>";
            }
            echo '</select>';
            if ( isset( $defcfg[$k]['comment'] ) ) {
                echo ' &nbsp; ' . $defcfg[$k]['comment'];
            }
            echo "</td></tr>\n";
            break;

        case SMOPT_TYPE_TEXTAREA:
            if (  sqgetGlobalVar($e, $new_v, SQ_POST) ) {
                $v = '"' . $new_v . '"';
                $newcfg[$k] = str_replace( "\n", '', $v );
            }
            echo "<tr><td valign=\"top\">$name</td><td>".
                 "<textarea cols=\"$size\" rows=\"4\" name=\"adm_$n\">" . substr( $v, 1, strlen( $v ) - 2 ) . "</textarea>";
            if ( isset( $defcfg[$k]['comment'] ) ) {
                echo ' &nbsp; ' . $defcfg[$k]['comment'];
            }
            echo "</td></tr>\n";
            break;
        case SMOPT_TYPE_STRING:
            if (  sqgetGlobalVar($e, $new_v, SQ_POST) ) {
                $v = '"' . $new_v . '"';
                $newcfg[$k] = $v;
            }
            if ( $v == '""' && isset( $defcfg[$k]['default'] ) ) {
                $v = "'" . $defcfg[$k]['default'] . "'";
                $newcfg[$k] = $v;
            }
            echo "<tr><td>$name</td><td>".
                 "<input size=\"$size\" name=\"adm_$n\" value=\"" . substr( $v, 1, strlen( $v ) - 2 ) . '" />';
            if ( isset( $defcfg[$k]['comment'] ) ) {
                echo ' &nbsp; ' . $defcfg[$k]['comment'];
            }
            echo "</td></tr>\n";
            break;
        case SMOPT_TYPE_BOOLEAN:
            if (  sqgetGlobalVar($e, $new_v, SQ_POST) ) {
                $v = $new_v;
                $newcfg[$k] = $v;
            } else {
                $v = strtoupper( $v );
            }
            if ( $v == 'TRUE' ) {
                $ct = ' checked="checked"';
                $cf = '';
            } else {
                $ct = '';
                $cf = ' checked="checked"';
            }
            echo "<tr><td>$name</td><td>" .
                 "<input$ct type=\"radio\" name=\"adm_$n\" value=\"TRUE\" />" . _("Yes") .
                 "<input$cf type=\"radio\" name=\"adm_$n\" value=\"FALSE\" />" . _("No");
            if ( isset( $defcfg[$k]['comment'] ) ) {
                echo ' &nbsp; ' . $defcfg[$k]['comment'];
            }
            echo "</td></tr>\n";
            break;
        case SMOPT_TYPE_PATH:
            if (  sqgetGlobalVar($e, $new_v, SQ_POST) ) {
               $v = change_to_sm_path($new_v);
               $newcfg[$k] = $v;
            }
            if ( $v == "''" && isset( $defcfg[$k]['default'] ) ) {
               $v = change_to_sm_path($defcfg[$k]['default']);
               $newcfg[$k] = $v;
            }
            echo "<tr><td>$name</td><td>".
                 "<input size=\"$size\" name=\"adm_$n\" value=\"" . change_to_rel_path($v) . '" />';
            if ( isset( $defcfg[$k]['comment'] ) ) {
                 echo ' &nbsp; ' . $defcfg[$k]['comment'];
            }
            echo "</td></tr>\n";
            break;
        default:
            echo "<tr><td>$name</td><td>" .
                 "<b><i>$v</i></b>";
            if ( isset( $defcfg[$k]['comment'] ) ) {
                echo ' &nbsp; ' . $defcfg[$k]['comment'];
            }
            echo "</td></tr>\n";
        }
    }
}

/* Special Themes Block */
if ( $colapse['Group7'] == 'off' ) {
    $i = 0;
    echo '<tr><th>' . _("Theme Name") .
         '</th><th>' . _("Theme Path") .
         '</th></tr>';
    while ( isset( $newcfg["\$theme[$i]['NAME']"] ) ) {
        $k1 = "\$theme[$i]['NAME']";
        $e1 = "theme_name_$i";
        if (  sqgetGlobalVar($e, $v1, SQ_POST) ) {
            $v1 = '"' . str_replace( '\"', '"', $v1 ) . '"';
            $v1 = '"' . str_replace( '"', '\"', $v1 ) . '"';
            $newcfg[$k1] = $v1;
        } else {
            $v1 = $newcfg[$k1];
        }
        $k2 = "\$theme[$i]['PATH']";
        $e2 = "theme_path_$i";
        if (  sqgetGlobalVar($e, $v2, SQ_POST) ) {
            $v2 = change_to_sm_path($v2);
            $newcfg[$k2] = $v2;
        } else {
            $v2 = $newcfg[$k2];
        }
        $name = substr( $v1, 1, strlen( $v1 ) - 2 );
        $path = change_to_rel_path($v2);
        echo '<tr>'.
             "<td align=\"right\">$i. <input name=\"$e1\" value=\"$name\" size=\"30\" /></td>".
             "<td><input name=\"$e2\" value=\"$path\" size=\"40\" /></td>".
             "</tr>\n";
        $i++;

    }
}

/* Special Plugins Block */
if ( $colapse['Group8'] == 'on' ) {
    $sw = '(+)';
} else {
    $sw = '(-)';
}
echo '<tr bgcolor="'.$color[0].'"><th colspan="2">'.
     '<a href="options.php?switch=Group8" style="text-decoration:none"><b>'.
     $sw.'</b></a> '._("Plugins").'</th></tr>';

if ( $colapse['Group8'] == 'off' ) {

    $plugpath = SM_PATH . 'plugins/';
    if ( file_exists($plugpath) ) {
        $fd = opendir( $plugpath );
        $op_plugin = array();
        $p_count = 0;
        while (false !== ($file = readdir($fd))) {
            if ($file != '.' && $file != '..' && $file != 'CVS' && is_dir($plugpath . $file) ) {
                $op_plugin[] = $file;
                $p_count++;
            }
        }
        closedir($fd);
        asort( $op_plugin );

        /* Lets get the plugins that are active */
        $plugins = array();
        if (  sqgetGlobalVar('plg', $v, SQ_POST) ) {
            foreach ( $op_plugin as $plg ) {
                if (  sqgetGlobalVar("plgs_$plg", $v2, SQ_POST) && $v2 == 'on' ) {
                    $plugins[] = $plg;
                }
            }
            $i = 0;
            foreach ( $plugins as $plg ) {
                $k = "\$plugins[$i]";
                $newcfg[$k] = "'$plg'";
                $i++;
            }
            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 '<tr><td colspan="2"><input type="hidden" name="plg" value="on" /><center><table>';
        foreach ( $op_plugin as $plg ) {
            if ( in_array( $plg, $plugins ) ) {
                $sw = ' checked="checked"';
            } else {
                $sw = '';
            }
            echo '<tr><td>';
            if (file_exists(SM_PATH . "plugins/$plg/README")) {
                echo "<a href=\"../$plg/README\" target=\"_blank\">$plg</a>";
            } else {
                echo $plg;
            }
            echo "</td>\n".
                 "<td><input$sw type=\"checkbox\" name=\"plgs_$plg\" /></td>".
                 "</tr>\n";
        }
        echo '</table></center></td></tr>';
    } else {
        echo '<tr><td colspan="2" align="center">'.
             sprintf(_("Plugin directory could not be found: %s"), $plugpath).
             "</td></tr>\n";
    }
}
echo '<tr bgcolor="'.$color[5].'"><th colspan="2"><input value="'.
     _("Change Settings").'" type="submit" /><br />'.
     '<a href="'.SM_PATH.'src/configtest.php" target="_blank">'.
     _("Test Configuration")."</a></th></tr>\n".
     '</table></td></tr></table></center></form>';

/*
    Write the options to the file.
*/

if ( $fp = @fopen( $cfgfile, 'w' ) ) {
    fwrite( $fp, "<?php\n".
    "/**\n".
    " * SquirrelMail Configuration File\n".
    " * Created using the Administrator Plugin\n".
    " */\n".
    "\n".
    "global \$version;\n" );

    foreach ( $newcfg as $k => $v ) {
        if ( $k{0} == '$' && $v <> '' || is_int($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" );
        }
    }
    // add local config support
    fwrite( $fp, "@include SM_PATH . 'config/config_local.php';\n" );
    // close php
    fwrite( $fp, '?>' );
    fclose( $fp );
} else {
    echo '<br /><p align="center"><big>'.
         _("Config file can't be opened. Please check config.php.").
         '</big></p>';
}
?>
</body></html>

ACC SHELL 2018