#
# $Id$
############################################################
-$conf_pl_version = "x63";
+$conf_pl_version = "1.2.0";
############################################################
# Some people try to run this as a CGI. That's wrong!
if ( -e "config.php") {
open (FILE, "config.php");
while ($line = <FILE>) {
- if ($line =~ /^\s+\$/) {
- $line =~ s/^\s+\$//;
- $var = $line;
+ $line =~ s/^\s+//;
+ $line =~ s/^\$//;
+ $var = $line;
- $var =~ s/=/EQUALS/;
- if ($var =~ /^([a-z]|[A-Z])/) {
- @o = split(/\s*EQUALS\s*/, $var);
- if ($o[0] eq "config_version") {
- $o[1] =~ s/[\n|\r]//g;
- $o[1] =~ s/\";\s*$//;
- $o[1] =~ s/;$//;
- $o[1] =~ s/^"//;
-
- $config_version = $o[1];
- close (FILE);
- }
+ $var =~ s/=/EQUALS/;
+ if ($var =~ /^([a-z]|[A-Z])/) {
+ @o = split(/\s*EQUALS\s*/, $var);
+ if ($o[0] eq "config_version") {
+ $o[1] =~ s/[\n|\r]//g;
+ $o[1] =~ s/[\'|\"];\s*$//;
+ $o[1] =~ s/;$//;
+ $o[1] =~ s/^[\'|\"]//;
+
+ $config_version = $o[1];
+ close (FILE);
}
}
}
if ($config_version ne $conf_pl_version) {
system "clear";
print $WHT."WARNING:\n".$NRM;
- print " The file \"config/config.php\" was found, but it is for an older version of\n";
- print " SquirrelMail. It is possible to still read the defaults from this file\n";
- print " but be warned that many preferences change between versions. It is\n";
- print " recommended that you start with a clean config.php for each upgrade that\n";
- print " you do. To do this, just move config/config.php out of the way.\n\n";
+ print " The file \"config/config.php\" was found, but it is for\n";
+ print " an older version of SquirrelMail. It is possible to still\n";
+ print " read the defaults from this file but be warned that many\n";
+ print " preferences change between versions. It is recommended that\n";
+ print " you start with a clean config.php for each upgrade that you\n";
+ print " do. To do this, just move config/config.php out of the way.\n";
+ print "\n";
print "Continue loading with the old config.php [y/N]? ";
$ctu = <STDIN>;
if (($ctu !~ /^y\n/i) || ($ctu =~ /^\n/)) {
} elsif (-e "config_default.php") {
open (FILE, "config_default.php");
while ($line = <FILE>) {
- if ($line =~ /^\s+\$/) {
- $line =~ s/^\s+\$//;
- $var = $line;
+ $line =~ s/^\s+//;
+ $line =~ s/^\$//;
+ $var = $line;
- $var =~ s/=/EQUALS/;
- if ($var =~ /^([a-z]|[A-Z])/) {
- @o = split(/\s*EQUALS\s*/, $var);
- if ($o[0] eq "config_version") {
- $o[1] =~ s/[\n|\r]//g;
- $o[1] =~ s/\";\s*$//;
- $o[1] =~ s/;$//;
- $o[1] =~ s/^"//;
-
- $config_version = $o[1];
- close (FILE);
- }
+ $var =~ s/=/EQUALS/;
+ if ($var =~ /^([a-z]|[A-Z])/) {
+ @o = split(/\s*EQUALS\s*/, $var);
+ if ($o[0] eq "config_version") {
+ $o[1] =~ s/[\n|\r]//g;
+ $o[1] =~ s/[\'|\"];\s*$//;
+ $o[1] =~ s/;$//;
+ $o[1] =~ s/^[\'|\"]//;
+
+ $config_version = $o[1];
+ close (FILE);
}
}
}
if ($config_version ne $conf_pl_version) {
system "clear";
print $WHT."WARNING:\n".$NRM;
- print " You are trying to use a \"config_default.php\" from an older version of\n";
- print " SquirrelMail. This is HIGHLY unrecommended. You should get the\n";
- print " \"config_default.php\" that matches the version of SquirrelMail that you\n";
- print " are running. You can get this from the SquirrelMail web page by going\n";
- print " to: http://www.squirrelmail.org.\n\n";
- print "Continue loading with the old config_default.php (not a good idea) [y/N]? ";
+ print " You are trying to use a 'config_default.php' from an older\n";
+ print " version of SquirrelMail. This is HIGHLY unrecommended. You\n";
+ print " should get the 'config_default.php' that matches the version\n";
+ print " of SquirrelMail that you are running. You can get this from\n";
+ print " the SquirrelMail web page by going to the following URL:\n";
+ print " http://www.squirrelmail.org.\n";
+ print "\n";
+ print "Continue loading with old config_default.php (a bad idea) [y/N]? ";
$ctu = <STDIN>;
if (($ctu !~ /^y\n/i) || ($ctu =~ /^\n/)) {
exit;
$config = 2;
open (FILE, "config_default.php");
} else {
- print "No configuration file found. Please get config_default.php or\n";
- print "config.php before running this again. This program needs a\n";
- print "default config file to get default values.\n";
+ print "No configuration file found. Please get config_default.php\n";
+ print "or config.php before running this again. This program needs\n";
+ print "a default config file to get default values.\n";
exit;
}
-# Reads and parses the current configuration file (either
-# config.php or config_default.php).
-
+# Read and parse the current configuration file
+# (either config.php or config_default.php).
while ($line = <FILE>) {
- if ($line =~ /^\s+\$/) {
- $line =~ s/^\s+\$//;
- $var = $line;
+ $line =~ s/^\s+//;
+ $line =~ s/^\$//;
+ $var = $line;
- $var =~ s/=/EQUALS/;
- if ($var =~ /^([a-z]|[A-Z])/) {
- @options = split(/\s*EQUALS\s*/, $var);
- $options[1] =~ s/[\n|\r]//g;
- $options[1] =~ s/\";\s*$//;
- $options[1] =~ s/;$//;
- $options[1] =~ s/^\"//;
-
- if ($options[0] =~ /^theme\[[0-9]+\]\["PATH"\]/) {
- $sub = $options[0];
- $sub =~ s/\]\["PATH"\]//;
- $sub =~ s/.*\[//;
- if (-e "../themes") {
- $options[1] =~ s/^\.\.\/config/\.\.\/themes/;
- }
- $theme_path[$sub] = $options[1];
- } elsif ($options[0] =~ /^theme\[[0-9]+\]\["NAME"\]/) {
- $sub = $options[0];
- $sub =~ s/\]\["NAME"\]//;
- $sub =~ s/.*\[//;
- $theme_name[$sub] = $options[1];
- } elsif ($options[0] =~ /^plugins\[[0-9]+\]/) {
- $sub = $options[0];
- $sub =~ s/\]//;
- $sub =~ s/^plugins\[//;
- $plugins[$sub] = $options[1];
- } elsif ($options[0] =~ /^ldap_server\[[0-9]+\]/) {
- $sub = $options[0];
- $sub =~ s/\]//;
- $sub =~ s/^ldap_server\[//;
- $continue = 0;
- while (($tmp = <FILE>) && ($continue != 1)) {
- if ($tmp =~ /\);\s*$/) {
- $continue = 1;
- }
-
- if ($tmp =~ /^\s*\"host\"/i) {
- $tmp =~ s/^\s*\"host\"\s*=>\s*\"//i;
- $tmp =~ s/\",\s*$//;
- $tmp =~ s/\"\);\s*$//;
- $host = $tmp;
- } elsif ($tmp =~ /^\s*\"base\"/i) {
- $tmp =~ s/^\s*\"base\"\s*=>\s*\"//i;
- $tmp =~ s/\",\s*$//;
- $tmp =~ s/\"\);\s*$//;
- $base = $tmp;
- } elsif ($tmp =~ /^\s*\"charset\"/i) {
- $tmp =~ s/^\s*\"charset\"\s*=>\s*\"//i;
- $tmp =~ s/\",\s*$//;
- $tmp =~ s/\"\);\s*$//;
- $charset = $tmp;
- } elsif ($tmp =~ /^\s*\"port\"/i) {
- $tmp =~ s/^\s*\"port\"\s*=>\s*\"//i;
- $tmp =~ s/\",\s*$//;
- $tmp =~ s/\"\);\s*$//;
- $port = $tmp;
- } elsif ($tmp =~ /^\s*\"maxrows\"/i) {
- $tmp =~ s/^\s*\"maxrows\"\s*=>\s*\"//i;
- $tmp =~ s/\",\s*$//;
- $tmp =~ s/\"\);\s*$//;
- $maxrows = $tmp;
- } elsif ($tmp =~ /^\s*\"name\"/i) {
- $tmp =~ s/^\s*\"name\"\s*=>\s*\"//i;
- $tmp =~ s/\",\s*$//;
- $tmp =~ s/\"\);\s*$//;
- $name = $tmp;
- }
- }
- $ldap_host[$sub] = $host;
- $ldap_base[$sub] = $base;
- $ldap_name[$sub] = $name;
- $ldap_port[$sub] = $port;
- $ldap_maxrows[$sub] = $maxrows;
- $ldap_charset[$sub] = $charset;
- } else {
- ${$options[0]} = $options[1];
+ $var =~ s/=/EQUALS/;
+ if ($var =~ /^([a-z]|[A-Z])/) {
+ @options = split(/\s*EQUALS\s*/, $var);
+ $options[1] =~ s/[\n|\r]//g;
+ $options[1] =~ s/[\'|\"];\s*$//;
+ $options[1] =~ s/;$//;
+ $options[1] =~ s/^[\'|\"]//;
+
+ if ($options[0] =~ /^theme\[[0-9]+\]\[['|"]PATH['|"]\]/) {
+ $sub = $options[0];
+ $sub =~ s/\]\[['|"]PATH['|"]\]//;
+ $sub =~ s/.*\[//;
+ if (-e "../themes") {
+ $options[1] =~ s/^\.\.\/config/\.\.\/themes/;
}
+ $theme_path[$sub] = $options[1];
+ } elsif ($options[0] =~ /^theme\[[0-9]+\]\[['|"]NAME['|"]\]/) {
+ $sub = $options[0];
+ $sub =~ s/\]\[['|"]NAME['|"]\]//;
+ $sub =~ s/.*\[//;
+ $theme_name[$sub] = $options[1];
+ } elsif ($options[0] =~ /^plugins\[[0-9]+\]/) {
+ $sub = $options[0];
+ $sub =~ s/\]//;
+ $sub =~ s/^plugins\[//;
+ $plugins[$sub] = $options[1];
+ } elsif ($options[0] =~ /^ldap_server\[[0-9]+\]/) {
+ $sub = $options[0];
+ $sub =~ s/\]//;
+ $sub =~ s/^ldap_server\[//;
+ $continue = 0;
+ while (($tmp = <FILE>) && ($continue != 1)) {
+ if ($tmp =~ /\);\s*$/) {
+ $continue = 1;
+ }
+
+ if ($tmp =~ /^\s*[\'|\"]host[\'|\"]/i) {
+ $tmp =~ s/^\s*[\'|\"]host[\'|\"]\s*=>\s*[\'|\"]//i;
+ $tmp =~ s/[\'|\"],?\s*$//;
+ $tmp =~ s/[\'|\"]\);\s*$//;
+ $host = $tmp;
+ } elsif ($tmp =~ /^\s*[\'|\"]base[\'|\"]/i) {
+ $tmp =~ s/^\s*[\'|\"]base[\'|\"]\s*=>\s*[\'|\"]//i;
+ $tmp =~ s/[\'|\"],?\s*$//;
+ $tmp =~ s/[\'|\"]\);\s*$//;
+ $base = $tmp;
+ } elsif ($tmp =~ /^\s*[\'|\"]charset[\'|\"]/i) {
+ $tmp =~ s/^\s*[\'|\"]charset[\'|\"]\s*=>\s*[\'|\"]//i;
+ $tmp =~ s/[\'|\"],?\s*$//;
+ $tmp =~ s/[\'|\"]\);\s*$//;
+ $charset = $tmp;
+ } elsif ($tmp =~ /^\s*[\'|\"]port[\'|\"]/i) {
+ $tmp =~ s/^\s*[\'|\"]port[\'|\"]\s*=>\s*[\'|\"]//i;
+ $tmp =~ s/[\'|\"],?\s*$//;
+ $tmp =~ s/[\'|\"]\);\s*$//;
+ $port = $tmp;
+ } elsif ($tmp =~ /^\s*[\'|\"]maxrows[\'|\"]/i) {
+ $tmp =~ s/^\s*[\'|\"]maxrows[\'|\"]\s*=>\s*[\'|\"]//i;
+ $tmp =~ s/[\'|\"],?\s*$//;
+ $tmp =~ s/[\'|\"]\);\s*$//;
+ $maxrows = $tmp;
+ } elsif ($tmp =~ /^\s*[\'|\"]name[\'|\"]/i) {
+ $tmp =~ s/^\s*[\'|\"]name[\'|\"]\s*=>\s*[\'|\"]//i;
+ $tmp =~ s/[\'|\"],?\s*$//;
+ $tmp =~ s/[\'|\"]\);\s*$//;
+ $name = $tmp;
+ }
+ }
+ $ldap_host[$sub] = $host;
+ $ldap_base[$sub] = $base;
+ $ldap_name[$sub] = $name;
+ $ldap_port[$sub] = $port;
+ $ldap_maxrows[$sub] = $maxrows;
+ $ldap_charset[$sub] = $charset;
+ } else {
+ ${$options[0]} = $options[1];
}
- }
+ }
}
close FILE;
if ($useSendmail ne "true") {
$default_unseen_type = 1;
}
if (!$config_use_color) {
- $config_use_color = 1;
+ $config_use_color = 0;
}
if (!$invert_time) {
$invert_time = "false";
}
if (!$force_username_lowercase) {
- $force_username_lowercase = "false";
+ $force_username_lowercase = "false";
}
if (!$optional_delimiter) {
- $optional_delimiter = "detect";
+ $optional_delimiter = "detect";
}
if (!$use_authenticated_smtp) {
$use_authenticated_smtp = "false";
}
if (!$auto_create_special) {
- $auto_create_special = "false";
+ $auto_create_special = "false";
+}
+if(!$default_use_priority) {
+ $default_use_priority = "true";
+}
+if(!$hide_sm_attributions) {
+ $hide_sm_attributions = "false";
}
#####################################################################################
print $WHT."SquirrelMail Configuration : ".$NRM;
if ($config == 1) { print "Read: config.php"; }
elsif ($config == 2) { print "Read: config_default.php"; }
- print "\n";
+ print " ($print_config_version)\n";
print "---------------------------------------------------------\n";
if ($menu == 0) {
print "R Return to Main Menu\n";
} elsif ($menu == 3) {
print $WHT."Folder Defaults\n".$NRM;
- print "1. Default Folder Prefix : $WHT$default_folder_prefix$NRM\n";
- print "2. Show Folder Prefix Option : $WHT$show_prefix_option$NRM\n";
- print "3. Trash Folder : $WHT$trash_folder$NRM\n";
- print "4. Sent Folder : $WHT$sent_folder$NRM\n";
- print "5. By default, move to trash : $WHT$default_move_to_trash$NRM\n";
- print "6. By default, move to sent : $WHT$default_move_to_sent$NRM\n";
- print "7. List Special Folders First : $WHT$list_special_folders_first$NRM\n";
- print "8. Show Special Folders Color : $WHT$use_special_folder_color$NRM\n";
- print "9. Auto Expunge : $WHT$auto_expunge$NRM\n";
- print "10. Default Sub. of INBOX : $WHT$default_sub_of_inbox$NRM\n";
- print "11. Show 'Contain Sub.' Option : $WHT$show_contain_subfolders_option$NRM\n";
- print "12. Default Unseen Notify : $WHT$default_unseen_notify$NRM\n";
- print "13. Default Unseen Type : $WHT$default_unseen_type$NRM\n";
- print "14. Auto create Sent and Trash : $WHT$auto_create_special$NRM\n";
+ print "1. Default Folder Prefix : $WHT$default_folder_prefix$NRM\n";
+ print "2. Show Folder Prefix Option : $WHT$show_prefix_option$NRM\n";
+ print "3. Trash Folder : $WHT$trash_folder$NRM\n";
+ print "4. Sent Folder : $WHT$sent_folder$NRM\n";
+ print "5. Drafts Folder : $WHT$draft_folder$NRM\n";
+ print "6. By default, move to trash : $WHT$default_move_to_trash$NRM\n";
+ print "7. By default, move to sent : $WHT$default_move_to_sent$NRM\n";
+ print "8. By default, save as draft : $WHT$default_save_as_draft$NRM\n";
+ print "9. List Special Folders First : $WHT$list_special_folders_first$NRM\n";
+ print "10. Show Special Folders Color : $WHT$use_special_folder_color$NRM\n";
+ print "11. Auto Expunge : $WHT$auto_expunge$NRM\n";
+ print "12. Default Sub. of INBOX : $WHT$default_sub_of_inbox$NRM\n";
+ print "13. Show 'Contain Sub.' Option : $WHT$show_contain_subfolders_option$NRM\n";
+ print "14. Default Unseen Notify : $WHT$default_unseen_notify$NRM\n";
+ print "15. Default Unseen Type : $WHT$default_unseen_type$NRM\n";
+ print "16. Auto Create Special Folders : $WHT$auto_create_special$NRM\n";
print "\n";
print "R Return to Main Menu\n";
} elsif ($menu == 4) {
print "1. Default Charset : $WHT$default_charset$NRM\n";
print "2. Data Directory : $WHT$data_dir$NRM\n";
print "3. Attachment Directory : $WHT$attachment_dir$NRM\n";
- print "4. Default Left Size : $WHT$default_left_size$NRM\n";
- print "5. Usernames in Lowercase : $WHT$force_username_lowercase$NRM\n";
+ print "4. Directory Hash Level : $WHT$dir_hash_level$NRM\n";
+ print "5. Default Left Size : $WHT$default_left_size$NRM\n";
+ print "6. Usernames in Lowercase : $WHT$force_username_lowercase$NRM\n";
+ print "7. Allow use of priority : $WHT$default_use_priority$NRM\n";
+ print "8. Hide SM attributions : $WHT$hide_sm_attributions$NRM\n";
print "\n";
print "R Return to Main Menu\n";
} elsif ($menu == 5) {
}
closedir DIR;
+ print "\n";
+ print "A Sanitize all plugins for use with Squirrelmail 1.2\n";
print "\n";
print "R Return to Main Menu\n";
}
elsif ($command == 4) { $signout_page = command4 (); }
elsif ($command == 5) { $squirrelmail_default_language = command5(); }
} elsif ($menu == 2) {
- if ($command == 1) { $domain = command11 (); }
- elsif ($command == 2) { $imapServerAddress = command12 (); }
- elsif ($command == 3) { $imapPort = command13 (); }
- elsif ($command == 4) { $useSendmail = command14 (); }
- elsif ($command == 5) { $sendmail_path = command15 (); }
- elsif ($command == 6) { $smtpServerAddress = command16 (); }
- elsif ($command == 7) { $smtpPort = command17 (); }
- elsif ($command == 8) { $use_authenticated_smtp = command18 (); }
- elsif ($command == 9) { $imap_server_type = command19 (); }
- elsif ($command == 10) { $invert_time = command110 (); }
- elsif ($command == 11) { $optional_delimiter = command111 (); }
+ if ($command == 1) { $domain = command11 (); }
+ elsif ($command == 2) { $imapServerAddress = command12 (); }
+ elsif ($command == 3) { $imapPort = command13 (); }
+ elsif ($command == 4) { $useSendmail = command14 (); }
+ elsif ($command == 5) { $sendmail_path = command15 (); }
+ elsif ($command == 6) { $smtpServerAddress = command16 (); }
+ elsif ($command == 7) { $smtpPort = command17 (); }
+ elsif ($command == 8) { $use_authenticated_smtp = command18 (); }
+ elsif ($command == 9) { $imap_server_type = command19 (); }
+ elsif ($command == 10) { $invert_time = command110 (); }
+ elsif ($command == 11) { $optional_delimiter = command111 (); }
} elsif ($menu == 3) {
- if ($command == 1) { $default_folder_prefix = command21 (); }
- elsif ($command == 2) { $show_prefix_option = command22 (); }
- elsif ($command == 3) { $trash_folder = command23 (); }
- elsif ($command == 4) { $sent_folder = command24 (); }
- elsif ($command == 5) { $default_move_to_trash = command25 (); }
- elsif ($command == 6) { $default_move_to_sent = command26 (); }
- elsif ($command == 7) { $list_special_folders_first = command27 (); }
- elsif ($command == 8) { $use_special_folder_color = command28 (); }
- elsif ($command == 9) { $auto_expunge = command29 (); }
- elsif ($command == 10){ $default_sub_of_inbox = command210(); }
- elsif ($command == 11){ $show_contain_subfolders_option = command211(); }
- elsif ($command == 12){ $default_unseen_notify = command212(); }
- elsif ($command == 13){ $default_unseen_type = command213(); }
- elsif ($command == 14){ $auto_create_special = command214(); }
+ if ($command == 1) { $default_folder_prefix = command21 (); }
+ elsif ($command == 2) { $show_prefix_option = command22 (); }
+ elsif ($command == 3) { $trash_folder = command23a (); }
+ elsif ($command == 4) { $sent_folder = command23b (); }
+ elsif ($command == 5) { $draft_folder = command23c (); }
+ elsif ($command == 6) { $default_move_to_trash = command24a (); }
+ elsif ($command == 7) { $default_move_to_sent = command24b (); }
+ elsif ($command == 8) { $default_save_as_draft = command24c (); }
+ elsif ($command == 9) { $list_special_folders_first = command27 (); }
+ elsif ($command == 10) { $use_special_folder_color = command28 (); }
+ elsif ($command == 11) { $auto_expunge = command29 (); }
+ elsif ($command == 12) { $default_sub_of_inbox = command210(); }
+ elsif ($command == 13) { $show_contain_subfolders_option = command211(); }
+ elsif ($command == 14) { $default_unseen_notify = command212(); }
+ elsif ($command == 15) { $default_unseen_type = command213(); }
+ elsif ($command == 16) { $auto_create_special = command214(); }
} elsif ($menu == 4) {
if ($command == 1) { $default_charset = command31 (); }
- elsif ($command == 2) { $data_dir = command33 (); }
- elsif ($command == 3) { $attachment_dir = command34 (); }
- elsif ($command == 4) { $default_left_size = command35 (); }
- elsif ($command == 5) { $force_username_lowercase = command36 (); }
+ elsif ($command == 2) { $data_dir = command33a (); }
+ elsif ($command == 3) { $attachment_dir = command33b (); }
+ elsif ($command == 4) { $dir_hash_level = command33c (); }
+ elsif ($command == 5) { $default_left_size = command35 (); }
+ elsif ($command == 6) { $force_username_lowercase = command36 (); }
+ elsif ($command == 7) { $default_use_priority = command37 (); }
+ elsif ($command == 8) { $hide_sm_attributions = command38 (); }
} elsif ($menu == 5) {
if ($command == 1) { command41 (); }
elsif ($command == 2) { $theme_css = command42 (); }
if ($command == 1) { $motd = command71(); }
} elsif ($menu == 8) {
if ($command =~ /^[0-9]+/) { @plugins = command81(); }
+ elsif ($command eq "a") { command8s(); }
}
}
}
print "folders. For example, Cyrus uses '.' as the delimiter and a complete\n";
print "folder would look like 'INBOX.Friends.Bob', while UW uses '/' and would\n";
print "look like 'INBOX/Friends/Bob'. Normally this should be left at 'detect'\n";
- print "but if you are sure you konw what delimiter your server uses, you can\n";
+ print "but if you are sure you know what delimiter your server uses, you can\n";
print "specify it here.\n";
print "\nTo have it autodetect the delimiter, set it to 'detect'.\n\n";
print "[$WHT$optional_delimiter$NRM]: $WHT";
while ($ct <= $#unused_plugins) {
if ($ct == $num) {
@newplugins = (@newplugins, $unused_plugins[$ct]);
+ # sanitize the plugin
+ $dir = $unused_plugins[$ct];
+ `./ri_once.pl ../plugins/$dir`;
}
$ct++;
}
return @plugins;
}
+sub command8s {
+ print "This command will sanitize all plugins for use with\n";
+ print "Squirrelmail 1.2. That is, it will rewrite some php-\n";
+ print "constructs that are *incompatible* with the 1.2 design\n";
+ print "into ones that are *compatible*\n";
+ print "Do you wish to issue this command [y/N]? ";
+ $ctu = <STDIN>;
+ if ($ctu =~ /^y\n/i) {
+ `./ri_once.pl ../plugins`;
+ }
+}
+
################# FOLDERS ###################
# default_folder_prefix
}
# Trash Folder
-sub command23 {
+sub command23a {
print "You can now specify where the default trash folder is located.\n";
print "On servers where you do not want this, you can set it to anything\n";
- print "and set option 7 to false.\n";
+ print "and set option 6 to false.\n";
print "\n";
print "This is relative to where the rest of your email is kept. You do\n";
print "not need to worry about their mail directory. If this folder\n";
}
# Sent Folder
-sub command24 {
+sub command23b {
print "This is where messages that are sent will be stored. SquirrelMail\n";
print "by default puts a copy of all outgoing messages in this folder.\n";
print "\n";
return $new_sent_folder;
}
+# Draft Folder
+sub command23c {
+ print "You can now specify where the default draft folder is located.\n";
+ print "On servers where you do not want this, you can set it to anything\n";
+ print "and set option 9 to false.\n";
+ print "\n";
+ print "This is relative to where the rest of your email is kept. You do\n";
+ print "not need to worry about their mail directory. If this folder\n";
+ print "would be ~/mail/drafts on the filesystem, you only need to specify\n";
+ print "that this is 'drafts', and be sure to put 'mail/' in option 1.\n";
+ print "\n";
+
+ print "[$WHT$draft_folder$NRM]: $WHT";
+ $new_draft_folder = <STDIN>;
+ if ($new_draft_folder eq "\n") {
+ $new_draft_folder = $draft_folder;
+ } else {
+ $new_draft_folder =~ s/[\r|\n]//g;
+ }
+ return $new_draft_folder;
+}
+
# default move to trash
-sub command25 {
+sub command24a {
print "By default, should messages get moved to the trash folder? You\n";
print "can specify the default trash folder in option 3. If this is set\n";
print "to false, messages will get deleted immediately without moving\n";
}
# default move to sent
-sub command26 {
+sub command24b {
print "By default, should messages get moved to the sent folder? You\n";
print "can specify the default sent folder in option 4. If this is set\n";
print "to false, messages will get sent an no copy will be made.\n";
return $default_move_to_sent;
}
+# default save as draft
+sub command24c {
+ print "By default, should the save to draft option be shown? You can\n";
+ print "specify the default drafts folder in option 5. If this is set\n";
+ print "to false, users will not be shown the save to draft option.\n";
+ print "\n";
+ print "Drafts folder is currently: $draft_folder\n";
+ print "\n";
+
+ if ($default_move_to_draft eq "true") {
+ $default_value = "y";
+ } else {
+ $default_value = "n";
+ }
+ print "By default, save as draft (y/n) [$WHT$default_value$NRM]: $WHT";
+ $new_show = <STDIN>;
+ if (($new_show =~ /^y\n/i) || (($new_show =~ /^\n/) && ($default_value eq "y"))) {
+ $default_save_as_draft = "true";
+ } else {
+ $default_save_as_draft = "false";
+ }
+ return $default_save_as_draft;
+}
+
# List special folders first
sub command27 {
print "SquirrelMail has what we call 'special folders' that are not\n";
# Auto create special folders
sub command214 {
- print "Would you like the Sent and Trash folders to be created automatically for\n";
- print "you when a user loggs in? If the user accidentally deletes their special\n";
- print "folders, this option will automatically create it again for them.\n";
+ print "Would you like the Sent, Trash, and Drafts folders to be created\n";
+ print "automatically print for you when a user logs in? If the user\n";
+ print "accidentally deletes their special folders, this option will\n";
+ print "automatically create it again for them.\n";
print "\n";
if ($auto_create_special eq "true") {
}
# Data directory
-sub command33 {
+sub command33a {
print "It is a possible security hole to have a writable directory\n";
print "under the web server's root directory (ex: /home/httpd/html).\n";
print "For this reason, it is possible to put the data directory\n";
}
# Attachment directory
-sub command34 {
+sub command33b {
print "Path to directory used for storing attachments while a mail is\n";
print "being sent. There are a few security considerations regarding this\n";
print "directory:\n";
return $new_attachment_dir;
}
+sub command33c {
+ print "The directory hash level setting allows you to configure the level\n";
+ print "of hashing that Squirremail employs in your data and attachment\n";
+ print "directories. This value must be an integer ranging from 0 to 4.\n";
+ print "When this value is set to 0, Squirrelmail will simply store all\n";
+ print "files as normal in the data and attachment directories. However,\n";
+ print "when set to a value from 1 to 4, a simple hashing scheme will be\n";
+ print "used to organize the files in this directory. In short, the crc32\n";
+ print "value for a username will be computed. Then, up to the first 4\n";
+ print "digits of the hash, as set by this configuration value, will be\n";
+ print "used to directory hash the files for that user in the data and\n";
+ print "attachment directory. This allows for better performance on\n";
+ print "servers with larger numbers of users.\n";
+ print "\n";
+
+ print "[$WHT$dir_hash_level$NRM]: $WHT";
+ $new_dir_hash_level = <STDIN>;
+ if ($new_dir_hash_level eq "\n") {
+ $new_dir_hash_level = $dir_hash_level;
+ } else {
+ $new_dir_hash_level =~ s/[\r|\n]//g;
+ }
+ if ((int($new_dir_hash_level) < 0) ||
+ (int($new_dir_hash_level) > 4) ||
+ !(int($new_dir_hash_level) eq $new_dir_hash_level )) {
+ print "Invalid Directory Hash Level.\n";
+ print "Value must be an integer ranging from 0 to 4\n";
+ print "Hit enter to continue.\n";
+ $enter_key = <STDIN>;
+
+ $new_dir_hash_level = $dir_hash_level;
+ }
+
+ return $new_dir_hash_level;
+}
sub command35 {
print "This is the default size (in pixels) of the left folder list.\n";
return "false";
}
+sub command37 {
+ print "";
+ print "\n";
+
+ if ($default_use_priority eq "true") {
+ $default_value = "y";
+ } else {
+ $default_value = "n";
+ }
+
+ print "Allow users to specify priority of outgoing mail (y/n) [$WHT$default_value$NRM]: $WHT";
+ $new_show = <STDIN>;
+ if (($new_show =~ /^y\n/i) || (($new_show =~ /^\n/) && ($default_value eq "y"))) {
+ return "true";
+ }
+ return "false";
+}
+
+
+sub command38 {
+ print "";
+ print "\n";
+
+ if ($default_hide_attribution eq "true") {
+ $default_value = "y";
+ } else {
+ $default_value = "n";
+ }
+
+ print "Hide SM attributions (y/n) [$WHT$default_value$NRM]: $WHT";
+ $new_show = <STDIN>;
+ if (($new_show =~ /^y\n/i) || (($new_show =~ /^\n/) && ($default_value eq "y"))) {
+ return "true";
+ }
+ return "false";
+}
+
sub command41 {
print "\nNow we will define the themes that you wish to use. If you have added\n";
sub save_data {
- open (FILE, ">config.php");
-
- print FILE "<?php\n\t/** SquirrelMail configuration\n";
- print FILE "\t ** Created using the configure script, conf.pl\n\t **/\n\n";
-
- print FILE "if (defined('config_php'))\n return;\n";
- print FILE "define('config_php', true);\n\n";
+ $tab = " ";
+ open (CF, ">config.php");
- print FILE "\tglobal \$print_config_version, \$config_version, \$config_use_color;\n";
+ print CF "<?php\n";
+ print CF "\n";
- if ($print_config_version) {
- print FILE "\t\$config_version = \"$print_config_version\";\n";
- }
- print FILE "\t\$config_use_color = $config_use_color;\n";
- print FILE "\n";
-
- print FILE "\tglobal \$org_name, \$org_logo, \$org_title, \$signout_page;\n";
- print FILE "\t\$org_name = \"$org_name\";\n";
- print FILE "\t\$org_logo = \"$org_logo\";\n";
- print FILE "\t\$org_title = \"$org_title\";\n";
- print FILE "\t\$signout_page = \"$signout_page\";\n";
-
- print FILE "\n";
-
- print FILE "\tglobal \$domain, \$imapServerAddress, \$imapPort;\n";
- print FILE "\tglobal \$useSendmail, \$smtpServerAddress, \$smtpPort;\n";
- print FILE "\tglobal \$sendmail_path, \$use_authenticated_smtp, \$imap_server_type;\n";
- print FILE "\tglobal \$invert_time, \$optional_delimiter;\n";
- print FILE "\t\$domain = \"$domain\";\n";
- print FILE "\t\$imapServerAddress = \"$imapServerAddress\";\n";
- print FILE "\t\$imapPort = $imapPort;\n";
- print FILE "\t\$useSendmail = $useSendmail;\n";
- print FILE "\t\$smtpServerAddress = \"$smtpServerAddress\";\n";
- print FILE "\t\$smtpPort = $smtpPort;\n";
- print FILE "\t\$sendmail_path = \"$sendmail_path\";\n";
- print FILE "\t\$use_authenticated_smtp = $use_authenticated_smtp;\n";
- print FILE "\t\$imap_server_type = \"$imap_server_type\";\n";
- print FILE "\t\$invert_time = $invert_time;\n";
- print FILE "\t\$optional_delimiter = \"$optional_delimiter\";\n";
+ print CF "/**\n";
+ print CF " * SquirrelMail Configuration File\n";
+ print CF " * Created using the configure script, conf.pl\n";
+ print CF " */\n";
+ print CF "\n";
- print FILE "\n";
-
- print FILE "\tglobal \$default_folder_prefix, \$trash_folder, \$sent_folder;\n";
- print FILE "\tglobal \$default_move_to_trash, \$default_move_to_sent;\n";
- print FILE "\tglobal \$show_prefix_option, \$list_special_folders_first;\n";
- print FILE "\tglobal \$use_special_folder_color, \$auto_expunge, \$default_sub_of_inbox;\n";
- print FILE "\tglobal \$show_contain_subfolders_option, \$default_unseen_notify;\n";
- print FILE "\tglobal \$default_unseen_type, \$auto_create_special;\n";
- print FILE "\t\$default_folder_prefix = \"$default_folder_prefix\";\n";
- print FILE "\t\$trash_folder = \"$trash_folder\";\n";
- print FILE "\t\$sent_folder = \"$sent_folder\";\n";
- print FILE "\t\$default_move_to_trash = $default_move_to_trash;\n";
- print FILE "\t\$default_move_to_sent = $default_move_to_sent;\n";
- print FILE "\t\$show_prefix_option = $show_prefix_option;\n";
- print FILE "\t\$list_special_folders_first = $list_special_folders_first;\n";
- print FILE "\t\$use_special_folder_color = $use_special_folder_color;\n";
- print FILE "\t\$auto_expunge = $auto_expunge;\n";
- print FILE "\t\$default_sub_of_inbox = $default_sub_of_inbox;\n";
- print FILE "\t\$show_contain_subfolders_option = $show_contain_subfolders_option;\n";
- print FILE "\t\$default_unseen_notify = $default_unseen_notify;\n";
- print FILE "\t\$default_unseen_type = $default_unseen_type;\n";
- print FILE "\t\$auto_create_special = $auto_create_special;\n";
- print FILE "\n";
-
- print FILE "\tglobal \$default_charset, \$data_dir, \$attachment_dir;\n";
- print FILE "\tglobal \$default_left_size, \$force_username_lowercase;\n";
- print FILE "\t\$default_charset = \"$default_charset\";\n";
- print FILE "\t\$data_dir = \"$data_dir\";\n";
- print FILE "\t\$attachment_dir = \"$attachment_dir\";\n";
- print FILE "\t\$default_left_size = $default_left_size;\n";
- print FILE "\t\$force_username_lowercase = $force_username_lowercase;\n";
-
- print FILE "\n";
-
- print FILE "\tglobal \$plugins;\n";
+ print CF "global \$config_version, \$config_use_color;\n";
+ if ($print_config_version) {
+ print CF "\$config_version = '$print_config_version';\n";
+ }
+ print CF "\$config_use_color = $config_use_color;\n";
+ print CF "\n";
+
+ print CF "global \$org_name, \$org_logo, \$org_title, \$signout_page;\n";
+ print CF "\$org_name = \"$org_name\";\n";
+ print CF "\$org_logo = '$org_logo';\n";
+ print CF "\$org_title = \"$org_title\";\n";
+ print CF "\$signout_page = '$signout_page';\n";
+ print CF "\n";
+
+ print CF "global \$motd;\n";
+ print CF "\$motd = '$motd';\n";
+ print CF "\n";
+
+ print CF "global \$squirrelmail_default_language;\n";
+ print CF "\$squirrelmail_default_language = '$squirrelmail_default_language';\n";
+ print CF "\n";
+
+ print CF "global \$domain, \$imapServerAddress, \$imapPort;\n";
+ print CF "global \$useSendmail, \$smtpServerAddress, \$smtpPort;\n";
+ print CF "global \$sendmail_path, \$use_authenticated_smtp;\n";
+ print CF "global \$imap_server_type, \$invert_time;\n";
+ print CF "global \$optional_delimiter;\n";
+ print CF "\$domain = '$domain';\n";
+ print CF "\$imapServerAddress = '$imapServerAddress';\n";
+ print CF "\$imapPort = $imapPort;\n";
+ print CF "\$useSendmail = $useSendmail;\n";
+ print CF "\$smtpServerAddress = '$smtpServerAddress';\n";
+ print CF "\$smtpPort = $smtpPort;\n";
+ print CF "\$sendmail_path = '$sendmail_path';\n";
+ print CF "\$use_authenticated_smtp = $use_authenticated_smtp;\n";
+ print CF "\$imap_server_type = '$imap_server_type';\n";
+ print CF "\$invert_time = $invert_time;\n";
+ print CF "\$optional_delimiter = '$optional_delimiter';\n";
+ print CF "\n";
+
+ print CF "global \$default_folder_prefix;\n";
+ print CF "global \$trash_folder, \$default_move_to_trash;\n";
+ print CF "global \$sent_folder, \$default_move_to_sent;\n";
+ print CF "global \$draft_folder, \$default_save_to_draft;\n";
+ print CF "global \$show_prefix_option, \$list_special_folders_first;\n";
+ print CF "global \$use_special_folder_color, \$auto_expunge;\n";
+ print CF "global \$default_sub_of_inbox;\n";
+ print CF "global \$show_contain_subfolders_option;\n";
+ print CF "global \$default_unseen_notify;\n";
+ print CF "global \$default_unseen_type, \$auto_create_special;\n";
+ print CF "\$default_folder_prefix = '$default_folder_prefix';\n";
+ print CF "\$trash_folder = '$trash_folder';\n";
+ print CF "\$sent_folder = '$sent_folder';\n";
+ print CF "\$draft_folder = '$draft_folder';\n";
+ print CF "\$default_move_to_trash = $default_move_to_trash;\n";
+ print CF "\$default_move_to_sent = $default_move_to_sent;\n";
+ print CF "\$default_save_as_draft = $default_save_as_draft;\n";
+ print CF "\$show_prefix_option = $show_prefix_option;\n";
+ print CF "\$list_special_folders_first = $list_special_folders_first;\n";
+ print CF "\$use_special_folder_color = $use_special_folder_color;\n";
+ print CF "\$auto_expunge = $auto_expunge;\n";
+ print CF "\$default_sub_of_inbox = $default_sub_of_inbox;\n";
+ print CF "\$show_contain_subfolders_option = $show_contain_subfolders_option;\n";
+ print CF "\$default_unseen_notify = $default_unseen_notify;\n";
+ print CF "\$default_unseen_type = $default_unseen_type;\n";
+ print CF "\$auto_create_special = $auto_create_special;\n";
+ print CF "\n";
+
+ print CF "global \$default_charset;\n";
+ print CF "global \$data_dir, \$attachment_dir, \$dir_hash_level;\n";
+ print CF "global \$default_left_size, \$force_username_lowercase;\n";
+ print CF "global \$default_use_priority, \$hide_sm_attributions;\n";
+ print CF "\$default_charset = '$default_charset';\n";
+ print CF "\$data_dir = '$data_dir';\n";
+ print CF "\$attachment_dir = \"$attachment_dir\";\n";
+ print CF "\$dir_hash_level = $dir_hash_level;\n";
+ print CF "\$default_left_size = $default_left_size;\n";
+ print CF "\$force_username_lowercase = $force_username_lowercase;\n";
+ print CF "\$default_use_priority = $default_use_priority;\n";
+ print CF "\$hide_sm_attributions = $hide_sm_attributions;\n";
+ print CF "\n";
+
+ print CF "global \$plugins;\n";
for ($ct=0; $ct <= $#plugins; $ct++) {
- print FILE "\t\$plugins[$ct] = \"$plugins[$ct]\";\n";
+ print CF "\$plugins[$ct] = '$plugins[$ct]';\n";
}
-
- print FILE "\n";
+ print CF "\n";
- print FILE "\tglobal \$theme_css, \$theme;\n";
- print FILE "\t\$theme_css = \"$theme_css\";\n";
+ print CF "global \$theme_css, \$theme;\n";
+ print CF "\$theme_css = '$theme_css';\n";
for ($count=0; $count <= $#theme_name; $count++) {
- print FILE "\t\$theme[$count][\"PATH\"] = \"$theme_path[$count]\";\n";
- print FILE "\t\$theme[$count][\"NAME\"] = \"$theme_name[$count]\";\n";
+ print CF "\$theme[$count]['PATH'] = '$theme_path[$count]';\n";
+ print CF "\$theme[$count]['NAME'] = '$theme_name[$count]';\n";
}
-
- print FILE "\n";
+ print CF "\n";
if ($default_use_javascript_addr_book ne "true") {
$default_use_javascript_addr_book = "false";
}
- print FILE "\tglobal \$default_use_javascript_addr_book, \$ldap_server;\n";
- print FILE "\t\$default_use_javascript_addr_book = $default_use_javascript_addr_book;\n";
+ print CF "global \$default_use_javascript_addr_book, \$ldap_server;\n";
+ print CF "\$default_use_javascript_addr_book = $default_use_javascript_addr_book;\n";
for ($count=0; $count <= $#ldap_host; $count++) {
- print FILE "\t\$ldap_server[$count] = Array(\n";
- print FILE "\t\t\t\"host\" => \"$ldap_host[$count]\",\n";
- print FILE "\t\t\t\"base\" => \"$ldap_base[$count]\"";
+ print CF "\$ldap_server[$count] = array(\n";
+ print CF " 'host' => '$ldap_host[$count]',\n";
+ print CF " 'base' => '$ldap_base[$count]'";
if ($ldap_name[$count]) {
- print FILE ",\n\t\t\t\"name\" => \"$ldap_name[$count]\"";
+ print CF ",\n";
+ print CF " 'name' => '$ldap_name[$count]'";
}
if ($ldap_port[$count]) {
- print FILE ",\n\t\t\t\"port\" => \"$ldap_port[$count]\"";
+ print CF ",\n";
+ print CF " 'port' => '$ldap_port[$count]'";
}
if ($ldap_charset[$count]) {
- print FILE ",\n\t\t\t\"charset\" => \"$ldap_charset[$count]\"";
+ print CF ",\n";
+ print CF " 'charset' => '$ldap_charset[$count]'";
}
if ($ldap_maxrows[$count]) {
- print FILE ",\n\t\t\t\"maxrows\" => \"$ldap_maxrows[$count]\"";
+ print CF ",\n";
+ print CF " 'maxrows' => '$ldap_maxrows[$count]'";
}
- print FILE ");\n\n";
+ print CF "\n";
+ print CF ");\n";
+ print CF "\n";
}
- print FILE "\tglobal \$motd;\n";
- print FILE "\t\$motd = \"$motd\";\n";
-
- print FILE "\tglobal \$squirrelmail_default_language;\n";
- print FILE "\t\$squirrelmail_default_language = \"$squirrelmail_default_language\";\n";
+ print CF "/**\n";
+ print CF " * Make sure there are no characters after the PHP closing\n";
+ print CF " * tag below (including newline characters and whitespace).\n";
+ print CF " * Otherwise, that character will cause the headers to be\n";
+ print CF " * sent and regular output to begin, which will majorly screw\n";
+ print CF " * things up when we try to send more headers later.\n";
+ print CF " */\n";
+ print CF "?>";
- close FILE;
+ close CF;
}
sub set_defaults {
print "\n";
if ($server eq "cyrus") {
- $default_folder_prefix = "INBOX";
- $trash_folder = "INBOX.Trash";
- $sent_folder = "INBOX.Sent";
- $show_prefix_option = false;
- $default_sub_of_inbox = true;
- $show_contain_subfolders_option = false;
- $imap_server_type = "cyrus";
-
- print " default_folder_prefix = INBOX\n";
- print " trash_folder = INBOX.Trash\n";
- print " sent_folder = INBOX.Sent\n";
- print " show_prefix_option = false\n";
- print " default_sub_of_inbox = true\n";
- print "show_contain_subfolders_option = false\n";
- print " imap_server_type = cyrus\n";
+ $imap_server_type = "cyrus";
+ $default_folder_prefix = "";
+ $trash_folder = "INBOX.Trash";
+ $sent_folder = "INBOX.Sent";
+ $draft_folder = "INBOX.Drafts";
+ $show_prefix_option = false;
+ $default_sub_of_inbox = true;
+ $show_contain_subfolders_option = false;
+ $optional_delimiter = ".";
+ $disp_default_folder_prefix = "<none>";
$continue = 1;
} elsif ($server eq "uw") {
- $default_folder_prefix = "mail/";
- $trash_folder = "Trash";
- $sent_folder = "Sent";
- $show_prefix_option = true;
- $default_sub_of_inbox = false;
- $show_contain_subfolders_option = true;
- $imap_server_type = "uw";
-
- print " default_folder_prefix = mail/\n";
- print " trash_folder = Trash\n";
- print " sent_folder = Sent\n";
- print " show_prefix_option = true\n";
- print " default_sub_of_inbox = false\n";
- print "show_contain_subfolders_option = true\n";
- print " imap_server_type = uw\n";
-
+ $imap_server_type = "uw";
+ $default_folder_prefix = "mail/";
+ $trash_folder = "Trash";
+ $sent_folder = "Sent";
+ $draft_folder = "Drafts";
+ $show_prefix_option = true;
+ $default_sub_of_inbox = false;
+ $show_contain_subfolders_option = true;
+ $optional_delimiter = "/";
+ $disp_default_folder_prefix = $default_folder_prefix;
+
$continue = 1;
} elsif ($server eq "exchange") {
- $default_folder_prefix = "";
- $default_sub_of_inbox = true;
- $trash_folder = "INBOX/Deleted Items";
- $sent_folder = "INBOX/Sent Items";
- $show_prefix_option = false;
- $show_contain_subfolders_option = false;
- $imap_server_type = "exchange";
-
- print " default_folder_prefix = <none>\n";
- print " default_sub_of_inbox = true\n";
- print " trash_folder = \"INBOX/Deleted Items\"\n";
- print " sent_folder = \"INBOX/Sent Items\"\n";
- print " show_prefix_option = false\n";
- print " show_contain_subfolders_option = false\n";
- print " imap_server_type = exchange\n";
+ $imap_server_type = "exchange";
+ $default_folder_prefix = "";
+ $default_sub_of_inbox = true;
+ $trash_folder = "INBOX/Deleted Items";
+ $sent_folder = "INBOX/Sent Items";
+ $drafts_folder = "INBOX/Drafts";
+ $show_prefix_option = false;
+ $show_contain_subfolders_option = false;
+ $optional_delimiter = "detect";
+ $disp_default_folder_prefix = "<none>";
- $continue = 1;
+ $continue = 1;
} elsif ($server eq "courier") {
- $imap_server_type = "courier";
+ $imap_server_type = "courier";
+ $default_folder_prefix = "INBOX.";
+ $trash_folder = "Trash";
+ $sent_folder = "Sent";
+ $draft_folder = "Drafts";
+ $show_prefix_option = false;
+ $default_sub_of_inbox = false;
+ $show_contain_subfolders_option = false;
+ $optional_delimiter = ".";
+ $disp_default_folder_prefix = $default_folder_prefix;
- print " imap_server_type = courier\n";
-
$continue = 1;
- } elsif ($server eq "quit") {
- $continue = 1;
+ } elsif ($server eq "quit") {
+ $continue = 1;
} else {
+ $disp_default_folder_prefix = $default_folder_prefix;
print "Unrecognized server: $server\n";
- print "\n";
+ print "\n";
}
+
+ print " imap_server_type = $imap_server_type\n";
+ print " default_folder_prefix = $disp_default_folder_prefix\n";
+ print " trash_folder = $trash_folder\n";
+ print " sent_folder = $sent_folder\n";
+ print " draft_folder = $draft_folder\n";
+ print " show_prefix_option = $show_prefix_option\n";
+ print " default_sub_of_inbox = $default_sub_of_inbox\n";
+ print "show_contain_subfolders_option = $show_contain_subfolders_option\n";
+ print " optional_delimiter = $optional_delimiter\n";
}
print "\nPress any key to continue...";
$tmp = <STDIN>;