* cleaning HTML/CSS codes
[citadel.git] / webcit / siteconfig.c
index 1a83ae95f1e4063a487384506c98636807133ca7..203fdefacc53586fa60e135c398fe55034acf1b3 100644 (file)
 /*
- * Administrative screen for site-wide configuration
- *
+ * $Id$
  */
+/**
+ * \defgroup AdminConfig Administrative screen for site-wide configuration
+ * \ingroup CitadelConfig
+ */
+/*@{*/
 
-
-#include <ctype.h>
-#include <stdlib.h>
-#include <unistd.h>
-#include <stdio.h>
-#include <fcntl.h>
-#include <signal.h>
-#include <sys/types.h>
-#include <sys/wait.h>
-#include <sys/socket.h>
-#include <sys/time.h>
-#include <limits.h>
-#include <netinet/in.h>
-#include <netdb.h>
-#include <string.h>
-#include <pwd.h>
-#include <errno.h>
-#include <stdarg.h>
-#include <pthread.h>
-#include <signal.h>
 #include "webcit.h"
+#include "webserver.h"
 
-
-
-
-
+/**
+ * \brief display all configuration items
+ */
 void display_siteconfig(void)
 {
        char buf[SIZ];
-       char *whichmenu;
        int i, j;
 
-       /* expire policy settings */
+       char general[65536];
+       char access[SIZ];
+       char network[SIZ];
+       char tuning[SIZ];
+       char directory[SIZ];
+       char purger[SIZ];
+       char idxjnl[SIZ];
+       char funambol[SIZ];
+       /** expire policy settings */
        int sitepolicy = 0;
        int sitevalue = 0;
        int mboxpolicy = 0;
        int mboxvalue = 0;
 
-       output_headers(3);
-
-       whichmenu = bstr("whichmenu");
-
-       svprintf("BOXTITLE", WCS_STRING, "Site configuration");
-       do_template("beginbox");
-
-       if (!strcmp(whichmenu, "")) {
-               wprintf("<TABLE border=0 cellspacing=0 cellpadding=3 width=100%%>\n");
-
-               wprintf("<TR BGCOLOR=\"#CCCCCC\"><TD>"
-                       "<A HREF=\"/display_siteconfig?whichmenu=general\">"
-                       "<IMG BORDER=\"0\" WIDTH=\"48\" HEIGHT=\"48\" "
-                       "SRC=\"/static/advanced-icon.gif\" ALT=\"&nbsp;\">"
-                       "</TD><TD>"
-                       "<A HREF=\"/display_siteconfig?whichmenu=general\">"
-                       "<B>General</B><BR>"
-                       "General site configuration items"
-                       "</A></TD></TR>\n"
-               );
-
-               wprintf("<TR><TD>"
-                       "<A HREF=\"/display_siteconfig?whichmenu=access\">"
-                       "<IMG BORDER=\"0\" WIDTH=\"48\" HEIGHT=\"48\" "
-                       "SRC=\"/static/advanced-icon.gif\" ALT=\"&nbsp;\">"
-                       "</TD><TD>"
-                       "<A HREF=\"/display_siteconfig?whichmenu=access\">"
-                       "<B>Access</B><BR>"
-                       "Access controls and site policy settings"
-                       "</A></TD></TR>\n"
-               );
-
-               wprintf("<TR BGCOLOR=\"#CCCCCC\"><TD>"
-                       "<A HREF=\"/display_siteconfig?whichmenu=network\">"
-                       "<IMG BORDER=\"0\" WIDTH=\"48\" HEIGHT=\"48\" "
-                       "SRC=\"/static/advanced-icon.gif\" ALT=\"&nbsp;\">"
-                       "</TD><TD>"
-                       "<A HREF=\"/display_siteconfig?whichmenu=network\">"
-                       "<B>Network</B><BR>"
-                       "Network services"
-                       "</A></TD></TR>\n"
-               );
-
-               wprintf("<TR><TD>"
-                       "<A HREF=\"/display_siteconfig?whichmenu=tuning\">"
-                       "<IMG BORDER=\"0\" WIDTH=\"48\" HEIGHT=\"48\" "
-                       "SRC=\"/static/advanced-icon.gif\" ALT=\"&nbsp;\">"
-                       "</TD><TD>"
-                       "<A HREF=\"/display_siteconfig?whichmenu=tuning\">"
-                       "<B>Tuning</B><BR>"
-                       "Advanced server fine-tuning controls"
-                       "</A></TD></TR>\n"
-               );
-
-               wprintf("<TR BGCOLOR=\"#CCCCCC\"><TD>"
-                       "<A HREF=\"/display_siteconfig?whichmenu=ldap\">"
-                       "<IMG BORDER=\"0\" WIDTH=\"48\" HEIGHT=\"48\" "
-                       "SRC=\"/static/advanced-icon.gif\" ALT=\"&nbsp;\">"
-                       "</TD><TD>"
-                       "<A HREF=\"/display_siteconfig?whichmenu=ldap\">"
-                       "<B>Directory</B><BR>"
-                       "Configure the LDAP connector for Citadel"
-                       "</A></TD></TR>\n"
-               );
-
-               wprintf("<TR><TD>"
-                       "<A HREF=\"/display_siteconfig?whichmenu=purger\">"
-                       "<IMG BORDER=\"0\" WIDTH=\"48\" HEIGHT=\"48\" "
-                       "SRC=\"/static/advanced-icon.gif\" ALT=\"&nbsp;\">"
-                       "</TD><TD>"
-                       "<A HREF=\"/display_siteconfig?whichmenu=purger\">"
-                       "<B>Auto-purger</B><BR>"
-                       "Configure automatic expiry of old messages"
-                       "</A></TD></TR>\n"
-               );
-
-               wprintf("</TABLE>");
-
-               do_template("endbox");
-               wDumpContent(1);
-               return;
-       }
-
-       if (!strcasecmp(whichmenu, "general")) {
-               wprintf("<CENTER><H2>General site configuration items</H2></CENTER>\n");
-       }
-
-       if (!strcasecmp(whichmenu, "access")) {
-               wprintf("<CENTER><H2>Access controls and site policy settings</H2></CENTER>\n");
-       }
-
-       if (!strcasecmp(whichmenu, "network")) {
-               wprintf("<CENTER><H2>Network services</H2>"
-                       "Changes made on this screen will not take effect until you restart the Citadel server."
-                       "</CENTER>\n");
-       }
-
-       if (!strcasecmp(whichmenu, "tuning")) {
-               wprintf("<CENTER><H2>Advanced server fine-tuning controls</H2></CENTER>\n");
-       }
-
-       if (!strcasecmp(whichmenu, "ldap")) {
-               wprintf("<CENTER><H2>Citadel LDAP connector configuration</H2>"
-                       "Changes made on this screen will not take effect until you restart the Citadel server."
-                       "</CENTER>\n");
-       }
+       output_headers(1, 1, 2, 0, 0, 0);
+       wprintf("<div id=\"banner\">\n");
+       wprintf("<h1>");
+       wprintf(_("Site configuration"));
+       wprintf("</h1>");
+       wprintf("</div>\n");
 
-       if (!strcasecmp(whichmenu, "purger")) {
-               wprintf("<CENTER><H2>Message auto-purger settings</H2>"
-                       "These settings may be overridden on a per-floor or per-room basis."
-                       "</CENTER>\n");
-       }
+       wprintf("</div id=\"content\" class=\"service fix_scrollbar_bug\">\n");
 
        serv_printf("CONF get");
-       serv_gets(buf);
+       serv_getln(buf, sizeof buf);
        if (buf[0] != '1') {
-               wprintf("<TABLE WIDTH=100%% BORDER=0 BGCOLOR=\"#444455\"><TR><TD>");
-               wprintf("<SPAN CLASS=\"titlebar\">Error</SPAN>\n");
-               wprintf("</TD></TR></TABLE><BR>\n");
-               wprintf("%s<BR>\n", &buf[4]);
-               do_template("endbox");
+               wprintf("<div class=\"errormsg\">");
+               wprintf(_("Error"));
+               wprintf("<br />\n");
+               wprintf("%s<br />\n", &buf[4]);
                wDumpContent(1);
+               wprintf("</div>\n");
                return;
        }
 
-       wprintf("<FORM METHOD=\"POST\" ACTION=\"/siteconfig\">\n");
-       wprintf("<TABLE border=0>\n");
+       wprintf("<table><tr><td>");
+
+       char *tabnames[] = {
+               _("General"),
+               _("Access"),
+               _("Network"),
+               _("Tuning"),
+               _("Directory"),
+               _("Auto-purger"),
+               _("Indexing/Journaling"),
+               _("Push Email")
+       };
+
+       sprintf(general, "<center><h1>%s</h1><table border=\"0\">",
+                       _("General site configuration items")
+       );
+
+       sprintf(access, "<center><h1>%s</h1><table border=\"0\">",
+                       _("Access controls and site policy settings")
+       );
+
+       sprintf(network, "<center><h1>%s</h1><h2>%s</h2><table border=\"0\">",
+                       _("Network services"),
+                       _("Changes made on this screen will not take effect "
+                       "until you restart the Citadel server.")
+       );
+
+       sprintf(tuning, "<center><h1>%s</h1><table border=\"0\">",
+                       _("Advanced server fine-tuning controls")
+       );
+
+       sprintf(directory, "<center><h1>%s</h1><h2>%s</h2><table border=\"0\">",
+                       _("Configure the LDAP connector for Citadel"),
+                       (serv_info.serv_supports_ldap
+                       ?       _("Changes made on this screen will not take effect "
+                               "until you restart the Citadel server.")
+                       :       _("NOTE: This Citadel server has been built without "
+                               "LDAP support.  These options will have no effect.")
+                       )
+       );
+
+       sprintf(purger, "<center><h1>%s</h1><h2>%s</h2><table border=\"0\">",
+                       _("Configure automatic expiry of old messages"),
+                       _("These settings may be overridden on a per-floor or per-room basis.")
+       );
+
+       sprintf(idxjnl, "<center><h1>%s</h1><h2>%s</h2><table border=\"0\">",
+                       _("Indexing and Journaling"),
+                       _("Warning: these facilities are resource intensive.")
+       );
+       sprintf(funambol, "<center><h1>%s</h1><table border=\"0\">",
+               _("Push Email")
+               );
+
+       wprintf("<form method=\"post\" action=\"siteconfig\">\n");
+       wprintf("<input type=\"hidden\" name=\"nonce\" value=\"%ld\">\n", WC->nonce);
 
        i = 0;
-       while (serv_gets(buf), strcmp(buf, "000")) {
-               switch (++i) {
+       while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
+               switch (i++) {
+               case 0:
+                       sprintf(&general[strlen(general)], "<tr><td>");
+                       sprintf(&general[strlen(general)], _("Node name"));
+                       sprintf(&general[strlen(general)], "</td><td>");
+                       sprintf(&general[strlen(general)], "<input type=\"text\" name=\"c_nodename\" maxlength=\"15\" value=\"%s\">", buf);
+                       sprintf(&general[strlen(general)], "</td></tr>\n");
+                       break;
                case 1:
-                       if (!strcasecmp(whichmenu, "general")) {
-                               wprintf("<TR><TD>Node name</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_nodename\" MAXLENGTH=\"15\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_nodename\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&general[strlen(general)], "<tr><td>");
+                       sprintf(&general[strlen(general)], _("Fully qualified domain name"));
+                       sprintf(&general[strlen(general)], "</td><td>");
+                       sprintf(&general[strlen(general)], "<input type=\"text\" name=\"c_fqdn\" maxlength=\"63\" value=\"%s\">", buf);
+                       sprintf(&general[strlen(general)], "</td></tr>\n");
                        break;
                case 2:
-                       if (!strcasecmp(whichmenu, "general")) {
-                               wprintf("<TR><TD>Fully qualified domain name</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_fqdn\" MAXLENGTH=\"63\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_fqdn\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&general[strlen(general)], "<tr><td>");
+                       sprintf(&general[strlen(general)], _("Human-readable node name"));
+                       sprintf(&general[strlen(general)], "</td><td>");
+                       sprintf(&general[strlen(general)], "<input type=\"text\" name=\"c_humannode\" maxlength=\"20\" value=\"%s\">", buf);
+                       sprintf(&general[strlen(general)], "</td></tr>\n");
                        break;
                case 3:
-                       if (!strcasecmp(whichmenu, "general")) {
-                               wprintf("<TR><TD>Human-readable node name</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_humannode\" MAXLENGTH=\"20\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_humannode\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&general[strlen(general)], "<tr><td>");
+                       sprintf(&general[strlen(general)], _("Telephone number"));
+                       sprintf(&general[strlen(general)], "</td><td>");
+                       sprintf(&general[strlen(general)], "<input type=\"text\" name=\"c_phonenum\" maxlength=\"15\" value=\"%s\">", buf);
+                       sprintf(&general[strlen(general)], "</td></tr>\n");
                        break;
                case 4:
-                       if (!strcasecmp(whichmenu, "general")) {
-                               wprintf("<TR><TD>Landline telephone number</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_phonenum\" MAXLENGTH=\"15\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_phonenum\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&access[strlen(access)], "<tr><td>");
+                       sprintf(&access[strlen(access)], _("Automatically grant room-aide status to users who create private rooms"));
+                       sprintf(&access[strlen(access)], "</td><td>");
+                       sprintf(&access[strlen(access)], "<input type=\"checkbox\" name=\"c_creataide\" value=\"yes\" %s>",
+                               ((atoi(buf) != 0) ? "checked" : ""));
+                       sprintf(&access[strlen(access)], "</td></tr>\n");
                        break;
                case 5:
-                       if (!strcasecmp(whichmenu, "access")) {
-                               wprintf("<TR><TD>Automatically grant room-aide status to users who create private rooms</TD><TD>");
-                               wprintf("<INPUT TYPE=\"checkbox\" NAME=\"c_creataide\" VALUE=\"yes\" %s>", ((atoi(buf) != 0) ? "CHECKED" : ""));
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_creataide\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&tuning[strlen(tuning)], "<tr><td>");
+                       sprintf(&tuning[strlen(tuning)], _("Server connection idle timeout (in seconds)"));
+                       sprintf(&tuning[strlen(tuning)], "</td><td>");
+                       sprintf(&tuning[strlen(tuning)], "<input type=\"text\" name=\"c_sleeping\" maxlength=\"15\" value=\"%s\">", buf);
+                       sprintf(&tuning[strlen(tuning)], "</td></tr>\n");
                        break;
                case 6:
-                       if (!strcasecmp(whichmenu, "tuning")) {
-                               wprintf("<TR><TD>Server connection idle timeout (in seconds)</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_sleeping\" MAXLENGTH=\"15\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_sleeping\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&access[strlen(access)], "<tr><td>");
+                       sprintf(&access[strlen(access)], _("Initial access level for new users"));
+                       sprintf(&access[strlen(access)], "</td><td>");
+                       sprintf(&access[strlen(access)], "<select name=\"c_initax\" size=\"1\">\n");
+                       for (j=0; j<=6; ++j) {
+                               sprintf(&access[strlen(access)], "<option %s value=\"%d\">%d - %s</option>\n",
+                                       ((atoi(buf) == j) ? "selected" : ""),
+                                       j, j, axdefs[j]
+                               );
+                       }
+                       sprintf(&access[strlen(access)], "</select>");
+                       sprintf(&access[strlen(access)], "</td></tr>\n");
                        break;
                case 7:
-                       if (!strcasecmp(whichmenu, "access")) {
-                               wprintf("<TR><TD>Initial access level for new users</TD><TD>");
-                               wprintf("<SELECT NAME=\"c_initax\" SIZE=\"1\">\n");
-                               for (j=0; j<=6; ++j) {
-                                       wprintf("<OPTION %s VALUE=\"%d\">%d - %s</OPTION>\n",
-                                               ((atoi(buf) == j) ? "SELECTED" : ""),
-                                               j, j, axdefs[j]
-                                       );
-                               }
-                               wprintf("</SELECT>");
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_initax\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&access[strlen(access)], "<tr><td>");
+                       sprintf(&access[strlen(access)], _("Require registration for new users"));
+                       sprintf(&access[strlen(access)], "</td><td>");
+                       sprintf(&access[strlen(access)], "<input type=\"checkbox\" name=\"c_regiscall\" value=\"yes\" %s>",
+                               ((atoi(buf) != 0) ? "checked" : ""));
+                       sprintf(&access[strlen(access)], "</td></tr>\n");
                        break;
                case 8:
-                       if (!strcasecmp(whichmenu, "access")) {
-                               wprintf("<TR><TD>Require registration for new users</TD><TD>");
-                               wprintf("<INPUT TYPE=\"checkbox\" NAME=\"c_regiscall\" VALUE=\"yes\" %s>", ((atoi(buf) != 0) ? "CHECKED" : ""));
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_regiscall\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&access[strlen(access)], "<tr><td>");
+                       sprintf(&access[strlen(access)], _("Quarantine messages from problem users"));
+                       sprintf(&access[strlen(access)], "</td><td>");
+                       sprintf(&access[strlen(access)], "<input type=\"checkbox\" name=\"c_twitdetect\" value=\"yes\" %s>",
+                               ((atoi(buf) != 0) ? "checked" : ""));
+                       sprintf(&access[strlen(access)], "</td></tr>\n");
                        break;
                case 9:
-                       if (!strcasecmp(whichmenu, "access")) {
-                               wprintf("<TR><TD>Quarantine messages from problem users</TD><TD>");
-                               wprintf("<INPUT TYPE=\"checkbox\" NAME=\"c_twitdetect\" VALUE=\"yes\" %s>", ((atoi(buf) != 0) ? "CHECKED" : ""));
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_twitdetect\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&access[strlen(access)], "<tr><td>");
+                       sprintf(&access[strlen(access)], _("Name of quarantine room"));
+                       sprintf(&access[strlen(access)], "</td><td>");
+                       sprintf(&access[strlen(access)], "<input type=\"text\" name=\"c_twitroom\" maxlength=\"63\" value=\"%s\">", buf);
+                       sprintf(&access[strlen(access)], "</td></tr>\n");
                        break;
                case 10:
-                       if (!strcasecmp(whichmenu, "access")) {
-                               wprintf("<TR><TD>Name of quarantine room</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_twitroom\" MAXLENGTH=\"63\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_twitroom\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&general[strlen(general)], "<tr><td>");
+                       sprintf(&general[strlen(general)], _("Paginator prompt (for text mode clients)"));
+                       sprintf(&general[strlen(general)], "</td><td>");
+                       sprintf(&general[strlen(general)], "<input type=\"text\" name=\"c_moreprompt\" maxlength=\"79\" value=\"%s\">", buf);
+                       sprintf(&general[strlen(general)], "</td></tr>\n");
                        break;
                case 11:
-                       if (!strcasecmp(whichmenu, "general")) {
-                               wprintf("<TR><TD>Paginator prompt (for text mode clients)</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_moreprompt\" MAXLENGTH=\"79\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_moreprompt\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&access[strlen(access)], "<tr><td>");
+                       sprintf(&access[strlen(access)], _("Restrict access to Internet mail"));
+                       sprintf(&access[strlen(access)], "</td><td>");
+                       sprintf(&access[strlen(access)], "<input type=\"checkbox\" name=\"c_restrict\" value=\"yes\" %s>",
+                               ((atoi(buf) != 0) ? "checked" : ""));
+                       sprintf(&access[strlen(access)], "</td></tr>\n");
                        break;
                case 12:
-                       if (!strcasecmp(whichmenu, "access")) {
-                               wprintf("<TR><TD>Restrict access to Internet mail</TD><TD>");
-                               wprintf("<INPUT TYPE=\"checkbox\" NAME=\"c_restrict\" VALUE=\"yes\" %s>", ((atoi(buf) != 0) ? "CHECKED" : ""));
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_restrict\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&general[strlen(general)], "<tr><td>");
+                       sprintf(&general[strlen(general)], _("Geographic location of this system"));
+                       sprintf(&general[strlen(general)], "</td><td>");
+                       sprintf(&general[strlen(general)], "<input type=\"text\" name=\"c_bbs_city\" maxlength=\"31\" value=\"%s\">", buf);
+                       sprintf(&general[strlen(general)], "</td></tr>\n");
                        break;
                case 13:
-                       if (!strcasecmp(whichmenu, "general")) {
-                               wprintf("<TR><TD>Geographic location of this system</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_bbs_city\" MAXLENGTH=\"31\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_bbs_city\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&general[strlen(general)], "<tr><td>");
+                       sprintf(&general[strlen(general)], _("Name of system administrator"));
+                       sprintf(&general[strlen(general)], "</td><td>");
+                       sprintf(&general[strlen(general)], "<input type=\"text\" name=\"c_sysadm\" MAXLENGTH=\"25\" VALUE=\"%s\">", buf);
+                       sprintf(&general[strlen(general)], "</td></tr>\n");
                        break;
                case 14:
-                       if (!strcasecmp(whichmenu, "general")) {
-                               wprintf("<TR><TD>Name of system administrator</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_sysadm\" MAXLENGTH=\"25\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_sysadm\" VALUE=\"%s\">", buf);
-                       }
-                       break;
-               case 15:
-                       if (!strcasecmp(whichmenu, "tuning")) {
-                               wprintf("<TR><TD>Maximum concurrent sessions</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_maxsessions\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_maxsessions\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&tuning[strlen(tuning)], "<tr><td>");
+                       sprintf(&tuning[strlen(tuning)], _("Maximum concurrent sessions (0 = no limit)"));
+                       sprintf(&tuning[strlen(tuning)], "</td><td>");
+                       sprintf(&tuning[strlen(tuning)], "<input type=\"text\" name=\"c_maxsessions\" maxlength=\"5\" value=\"%s\">", buf);
+                       sprintf(&tuning[strlen(tuning)], "</td></tr>\n");
+                       break;
+               case 16:
+                       sprintf(&tuning[strlen(tuning)], "<tr><td>");
+                       sprintf(&tuning[strlen(tuning)], _("Default user purge time (days)"));
+                       sprintf(&tuning[strlen(tuning)], "</td><td>");
+                       sprintf(&tuning[strlen(tuning)], "<input type=\"text\" name=\"c_userpurge\" maxlength=\"5\" value=\"%s\">", buf);
+                       sprintf(&tuning[strlen(tuning)], "</td></tr>\n");
                        break;
                case 17:
-                       if (!strcasecmp(whichmenu, "tuning")) {
-                               wprintf("<TR><TD>Default user purge time (days)</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_userpurge\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_userpurge\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&tuning[strlen(tuning)], "<tr><td>");
+                       sprintf(&tuning[strlen(tuning)], _("Default room purge time (days)"));
+                       sprintf(&tuning[strlen(tuning)], "</td><td>");
+                       sprintf(&tuning[strlen(tuning)], "<input type=\"text\" name=\"c_roompurge\" maxlength=\"5\" value=\"%s\">", buf);
+                       sprintf(&tuning[strlen(tuning)], "</td></tr>\n");
                        break;
                case 18:
-                       if (!strcasecmp(whichmenu, "tuning")) {
-                               wprintf("<TR><TD>Default room purge time (days)</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_roompurge\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_roompurge\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&access[strlen(access)], "<tr><td>");
+                       sprintf(&access[strlen(access)], _("Name of room to log pages"));
+                       sprintf(&access[strlen(access)], "</td><td>");
+                       sprintf(&access[strlen(access)], "<input type=\"text\" name=\"c_logpages\" maxlength=\"63\" value=\"%s\">", buf);
+                       sprintf(&access[strlen(access)], "</td></tr>\n");
                        break;
                case 19:
-                       if (!strcasecmp(whichmenu, "access")) {
-                               wprintf("<TR><TD>Name of room to log pages</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_logpages\" MAXLENGTH=\"63\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_logpages\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&access[strlen(access)], "<tr><td>");
+                       sprintf(&access[strlen(access)], _("Access level required to create rooms"));
+                       sprintf(&access[strlen(access)], "</td><td>");
+                       sprintf(&access[strlen(access)], "<select name=\"c_createax\" size=\"1\">\n");
+                       for (j=0; j<=6; ++j) {
+                               sprintf(&access[strlen(access)], "<option %s value=\"%d\">%d - %s</option>\n",
+                                       ((atoi(buf) == j) ? "selected" : ""),
+                                       j, j, axdefs[j]
+                               );
+                       }
+                       sprintf(&access[strlen(access)], "</select>");
+                       sprintf(&access[strlen(access)], "</td></tr>\n");
                        break;
                case 20:
-                       if (!strcasecmp(whichmenu, "access")) {
-                               wprintf("<TR><TD>Access level required to create rooms</TD><TD>");
-                               wprintf("<SELECT NAME=\"c_createax\" SIZE=\"1\">\n");
-                               for (j=0; j<=6; ++j) {
-                                       wprintf("<OPTION %s VALUE=\"%d\">%d - %s</OPTION>\n",
-                                               ((atoi(buf) == j) ? "SELECTED" : ""),
-                                               j, j, axdefs[j]
-                                       );
-                               }
-                               wprintf("</SELECT>");
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_createax\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&tuning[strlen(tuning)], "<tr><td>");
+                       sprintf(&tuning[strlen(tuning)], _("Maximum message length"));
+                       sprintf(&tuning[strlen(tuning)], "</td><td>");
+                       sprintf(&tuning[strlen(tuning)], "<input type=\"text\" name=\"c_maxmsglen\" maxlength=\"20\" value=\"%s\">", buf);
+                       sprintf(&tuning[strlen(tuning)], "</td></tr>\n");
                        break;
                case 21:
-                       if (!strcasecmp(whichmenu, "tuning")) {
-                               wprintf("<TR><TD>Maximum message length</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_maxmsglen\" MAXLENGTH=\"20\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_maxmsglen\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&tuning[strlen(tuning)], "<tr><td>");
+                       sprintf(&tuning[strlen(tuning)], _("Minimum number of worker threads"));
+                       sprintf(&tuning[strlen(tuning)], "</td><td>");
+                       sprintf(&tuning[strlen(tuning)], "<input type=\"text\" name=\"c_min_workers\" maxlength=\"5\" value=\"%s\">", buf);
+                       sprintf(&tuning[strlen(tuning)], "</td></tr>\n");
                        break;
                case 22:
-                       if (!strcasecmp(whichmenu, "tuning")) {
-                               wprintf("<TR><TD>Minimum number of worker threads</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_min_workers\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_min_workers\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&tuning[strlen(tuning)], "<tr><td>");
+                       sprintf(&tuning[strlen(tuning)], _("Maximum number of worker threads"));
+                       sprintf(&tuning[strlen(tuning)], "</td><td>");
+                       sprintf(&tuning[strlen(tuning)], "<input type=\"text\" name=\"c_max_workers\" maxlength=\"5\" value=\"%s\">", buf);
+                       sprintf(&tuning[strlen(tuning)], "</td></tr>\n");
                        break;
                case 23:
-                       if (!strcasecmp(whichmenu, "tuning")) {
-                               wprintf("<TR><TD>Maximum number of worker threads</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_max_workers\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_max_workers\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&network[strlen(network)], "<tr><td>");
+                       sprintf(&network[strlen(network)], _("POP3 listener port (-1 to disable)"));
+                       sprintf(&network[strlen(network)], "</td><td>");
+                       sprintf(&network[strlen(network)], "<input type=\"text\" name=\"c_pop3_port\" maxlength=\"5\" value=\"%s\">", buf);
+                       sprintf(&network[strlen(network)], "</TD></TR>\n");
                        break;
                case 24:
-                       if (!strcasecmp(whichmenu, "network")) {
-                               wprintf("<TR><TD>POP3 listener port (-1 to disable)</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_pop3_port\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_pop3_port\" VALUE=\"%s\">", buf);
-                       }
-                       break;
-               case 25:
-                       if (!strcasecmp(whichmenu, "network")) {
-                               wprintf("<TR><TD>SMTP MTA port (-1 to disable)</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_smtp_port\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_smtp_port\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&network[strlen(network)], "<TR><TD>");
+                       sprintf(&network[strlen(network)], _("SMTP MTA port (-1 to disable)"));
+                       sprintf(&network[strlen(network)], "</TD><TD>");
+                       sprintf(&network[strlen(network)], "<input type=\"text\" NAME=\"c_smtp_port\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
+                       sprintf(&network[strlen(network)], "</TD></TR>\n");
+                       break;
+               case 25:        /* note: reverse bool */
+                       sprintf(&network[strlen(network)], "<TR><TD>");
+                       sprintf(&network[strlen(network)], _("Correct forged From: lines during authenticated SMTP"));
+                       sprintf(&network[strlen(network)], "</TD><TD>");
+                       sprintf(&network[strlen(network)], "<input type=\"checkbox\" NAME=\"c_rfc822_strict_from\" VALUE=\"yes\" %s>",
+                               ((atoi(buf) == 0) ? "CHECKED" : ""));
+                       sprintf(&network[strlen(network)], "</TD></TR>\n");
+                       break;
+               case 26:
+                       sprintf(&access[strlen(access)], "<TR><TD>");
+                       sprintf(&access[strlen(access)], _("Allow aides to zap (forget) rooms"));
+                       sprintf(&access[strlen(access)], "</TD><TD>");
+                       sprintf(&access[strlen(access)], "<input type=\"checkbox\" NAME=\"c_aide_zap\" VALUE=\"yes\" %s>",
+                               ((atoi(buf) != 0) ? "CHECKED" : ""));
+                       sprintf(&access[strlen(access)], "</TD></TR>\n");
                        break;
                case 27:
-                       if (!strcasecmp(whichmenu, "access")) {
-                               wprintf("<TR><TD>Allow aides to zap (forget) rooms</TD><TD>");
-                               wprintf("<INPUT TYPE=\"checkbox\" NAME=\"c_aide_zap\" VALUE=\"yes\" %s>", ((atoi(buf) != 0) ? "CHECKED" : ""));
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_aide_zap\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&network[strlen(network)], "<TR><TD>");
+                       sprintf(&network[strlen(network)], _("IMAP listener port (-1 to disable)"));
+                       sprintf(&network[strlen(network)], "</TD><TD>");
+                       sprintf(&network[strlen(network)], "<input type=\"text\" NAME=\"c_imap_port\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
+                       sprintf(&network[strlen(network)], "</TD></TR>\n");
                        break;
                case 28:
-                       if (!strcasecmp(whichmenu, "network")) {
-                               wprintf("<TR><TD>IMAP listener port (-1 to disable)</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_imap_port\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_imap_port\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&network[strlen(network)], "<TR><TD>");
+                       sprintf(&network[strlen(network)], _("Network run frequency (in seconds)"));
+                       sprintf(&network[strlen(network)], "</TD><TD>");
+                       sprintf(&network[strlen(network)], "<input type=\"text\" NAME=\"c_net_freq\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
+                       sprintf(&network[strlen(network)], "</TD></TR>\n");
                        break;
                case 29:
-                       if (!strcasecmp(whichmenu, "network")) {
-                               wprintf("<TR><TD>Network run frequency (in seconds)</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_net_freq\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_net_freq\" VALUE=\"%s\">", buf);
-                       }
-                       break;
-               case 30:
-                       if (!strcasecmp(whichmenu, "access")) {
-                               wprintf("<TR><TD>Disable self-service user account creation</TD><TD>");
-                               wprintf("<INPUT TYPE=\"checkbox\" NAME=\"c_disable_newu\" VALUE=\"yes\" %s>", ((atoi(buf) != 0) ? "CHECKED" : ""));
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_disable_newu\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&access[strlen(access)], "<TR><TD>");
+                       sprintf(&access[strlen(access)], _("Disable self-service user account creation"));
+                       sprintf(&access[strlen(access)], "</TD><TD>");
+                       sprintf(&access[strlen(access)], "<input type=\"checkbox\" NAME=\"c_disable_newu\" VALUE=\"yes\" %s>",
+                               ((atoi(buf) != 0) ? "CHECKED" : ""));
+                       sprintf(&access[strlen(access)], "</TD></TR>\n");
                        break;
                case 31:
-                       /* placeholder -- there is no option 31 */
+                       sprintf(&purger[strlen(purger)], "<TR><TD>");
+                       sprintf(&purger[strlen(purger)], _("Hour to run database auto-purge"));
+                       sprintf(&purger[strlen(purger)], "</TD><TD>");
+                       sprintf(&purger[strlen(purger)], "<SELECT NAME=\"c_purge_hour\" SIZE=\"1\">\n");
+                       for (j=0; j<=23; ++j) {
+                               sprintf(&purger[strlen(purger)], "<OPTION %s VALUE=\"%d\">%d:00%s</OPTION>\n",
+                                       ((atoi(buf) == j) ? "SELECTED" : ""),
+                                       j,
+                                       ((j == 0) ? 12 : ((j>12) ? j-12 : j)),
+                                       ((j >= 12) ? "pm" : "am")
+                               );
+                       }
+                       sprintf(&purger[strlen(purger)], "</SELECT>");
+                       sprintf(&purger[strlen(purger)], "</TD></TR>\n");
                        break;
                case 32:
-                       if (!strcasecmp(whichmenu, "tuning")) {
-                               wprintf("<TR><TD>Hour to run database auto-purge</TD><TD>");
-                               wprintf("<SELECT NAME=\"c_purge_hour\" SIZE=\"1\">\n");
-                               for (j=0; j<=23; ++j) {
-                                       wprintf("<OPTION %s VALUE=\"%d\">%d:00%s</OPTION>\n",
-                                               ((atoi(buf) == j) ? "SELECTED" : ""),
-                                               j,
-                                               ((j == 0) ? 12 : ((j>12) ? j-12 : j)),
-                                               ((j >= 12) ? "pm" : "am")
-                                       );
-                               }
-                               wprintf("</SELECT>");
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_purge_hour\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&directory[strlen(directory)], "<TR><TD>");
+                       sprintf(&directory[strlen(directory)], _("Host name of LDAP server (blank to disable)"));
+                       sprintf(&directory[strlen(directory)], "</TD><TD>");
+                       sprintf(&directory[strlen(directory)], "<input type=\"text\" NAME=\"c_ldap_host\" MAXLENGTH=\"127\" VALUE=\"%s\">", buf);
+                       sprintf(&directory[strlen(directory)], "</TD></TR>\n");
                        break;
                case 33:
-                       if ( (serv_info.serv_supports_ldap) && (!strcasecmp(whichmenu, "ldap")) ) {
-                               wprintf("<TR><TD>Host name of LDAP server (blank to disable)</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_ldap_host\" MAXLENGTH=\"127\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_ldap_host\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&directory[strlen(directory)], "<TR><TD>");
+                       sprintf(&directory[strlen(directory)], _("Port number of LDAP server (blank to disable)"));
+                       sprintf(&directory[strlen(directory)], "</TD><TD>");
+                       sprintf(&directory[strlen(directory)], "<input type=\"text\" NAME=\"c_ldap_port\" MAXLENGTH=\"127\" VALUE=\"%d\">", atoi(buf));
+                       sprintf(&directory[strlen(directory)], "</TD></TR>\n");
                        break;
                case 34:
-                       if ( (serv_info.serv_supports_ldap) && (!strcasecmp(whichmenu, "ldap")) ) {
-                               wprintf("<TR><TD>Port number of LDAP server (blank to disable)</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_ldap_port\" MAXLENGTH=\"127\" VALUE=\"%d\">", atoi(buf));
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_ldap_port\" VALUE=\"%d\">", atoi(buf));
-                       }
+                       sprintf(&directory[strlen(directory)], "<TR><TD>");
+                       sprintf(&directory[strlen(directory)], _("Base DN"));
+                       sprintf(&directory[strlen(directory)], "</TD><TD>");
+                       sprintf(&directory[strlen(directory)], "<input type=\"text\" NAME=\"c_ldap_base_dn\" MAXLENGTH=\"255\" VALUE=\"%s\">", buf);
+                       sprintf(&directory[strlen(directory)], "</TD></TR>\n");
                        break;
                case 35:
-                       if ( (serv_info.serv_supports_ldap) && (!strcasecmp(whichmenu, "ldap")) ) {
-                               wprintf("<TR><TD>Base DN</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_ldap_base_dn\" MAXLENGTH=\"255\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_ldap_base_dn\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&directory[strlen(directory)], "<TR><TD>");
+                       sprintf(&directory[strlen(directory)], _("Bind DN"));
+                       sprintf(&directory[strlen(directory)], "</TD><TD>");
+                       sprintf(&directory[strlen(directory)], "<input type=\"text\" NAME=\"c_ldap_bind_dn\" MAXLENGTH=\"255\" VALUE=\"%s\">", buf);
+                       sprintf(&directory[strlen(directory)], "</TD></TR>\n");
                        break;
                case 36:
-                       if ( (serv_info.serv_supports_ldap) && (!strcasecmp(whichmenu, "ldap")) ) {
-                               wprintf("<TR><TD>Bind DN</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_ldap_bind_dn\" MAXLENGTH=\"255\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_ldap_bind_dn\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&directory[strlen(directory)], "<TR><TD>");
+                       sprintf(&directory[strlen(directory)], _("Password for bind DN"));
+                       sprintf(&directory[strlen(directory)], "</TD><TD>");
+                       sprintf(&directory[strlen(directory)], "<input type=\"password\" NAME=\"c_ldap_bind_pw\" MAXLENGTH=\"255\" VALUE=\"%s\">",
+                               buf);
+                       sprintf(&directory[strlen(directory)], "</TD></TR>\n");
                        break;
                case 37:
-                       if ( (serv_info.serv_supports_ldap) && (!strcasecmp(whichmenu, "ldap")) ) {
-                               wprintf("<TR><TD>Password for bind DN</TD><TD>");
-                               wprintf("<INPUT TYPE=\"password\" NAME=\"c_ldap_bind_pw\" MAXLENGTH=\"255\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_ldap_bind_pw\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&network[strlen(network)], "<TR><TD>");
+                       sprintf(&network[strlen(network)], _("Server IP address (0.0.0.0 for 'any')"));
+                       sprintf(&network[strlen(network)], "</TD><TD>");
+                       sprintf(&network[strlen(network)], "<input type=\"text\" NAME=\"c_ip_addr\" MAXLENGTH=\"15\" VALUE=\"%s\">", buf);
+                       sprintf(&network[strlen(network)], "</TD></TR>\n");
                        break;
                case 38:
-                       if (!strcasecmp(whichmenu, "network")) {
-                               wprintf("<TR><TD>Server IP address (0.0.0.0 for 'any')</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_ip_addr\" MAXLENGTH=\"15\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_ip_addr\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&network[strlen(network)], "<TR><TD>");
+                       sprintf(&network[strlen(network)], _("SMTP MSA port (-1 to disable)"));
+                       sprintf(&network[strlen(network)], "</TD><TD>");
+                       sprintf(&network[strlen(network)], "<input type=\"text\" NAME=\"c_msa_port\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
+                       sprintf(&network[strlen(network)], "</TD></TR>\n");
                        break;
                case 39:
-                       if (!strcasecmp(whichmenu, "network")) {
-                               wprintf("<TR><TD>SMTP MSA port (-1 to disable)</TD><TD>");
-                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_msa_port\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_msa_port\" VALUE=\"%s\">", buf);
-                       }
+                       sprintf(&network[strlen(network)], "<TR><TD>");
+                       sprintf(&network[strlen(network)], _("IMAP over SSL port (-1 to disable)"));
+                       sprintf(&network[strlen(network)], "</TD><TD>");
+                       sprintf(&network[strlen(network)], "<input type=\"text\" NAME=\"c_imaps_port\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
+                       sprintf(&network[strlen(network)], "</TD></TR>\n");
+                       break;
+               case 40:
+                       sprintf(&network[strlen(network)], "<TR><TD>");
+                       sprintf(&network[strlen(network)], _("POP3 over SSL port (-1 to disable)"));
+                       sprintf(&network[strlen(network)], "</TD><TD>");
+                       sprintf(&network[strlen(network)], "<input type=\"text\" NAME=\"c_pop3s_port\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
+                       sprintf(&network[strlen(network)], "</TD></TR>\n");
+                       break;
+               case 41:
+                       sprintf(&network[strlen(network)], "<TR><TD>");
+                       sprintf(&network[strlen(network)], _("SMTP over SSL port (-1 to disable)"));
+                       sprintf(&network[strlen(network)], "</TD><TD>");
+                       sprintf(&network[strlen(network)], "<input type=\"text\" NAME=\"c_smtps_port\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
+                       sprintf(&network[strlen(network)], "</TD></TR>\n");
+                       break;
+               case 42:
+                               sprintf(&idxjnl[strlen(idxjnl)], "<TR><TD>");
+                               sprintf(&idxjnl[strlen(idxjnl)], _("Enable full text index"));
+                               sprintf(&idxjnl[strlen(idxjnl)], "</TD><TD>");
+                               sprintf(&idxjnl[strlen(idxjnl)], "<input type=\"checkbox\" NAME=\"c_enable_fulltext\" VALUE=\"yes\" %s>",
+                                       ((atoi(buf) != 0) ? "CHECKED" : ""));
+                               sprintf(&idxjnl[strlen(idxjnl)], "</TD></TR>\n");
+                       break;
+               case 43:
+                       sprintf(&tuning[strlen(tuning)], "<TR><TD>");
+                       sprintf(&tuning[strlen(tuning)], _("Automatically delete committed database logs"));
+                       sprintf(&tuning[strlen(tuning)], "</TD><TD>");
+                       sprintf(&tuning[strlen(tuning)], "<input type=\"checkbox\" NAME=\"c_auto_cull\" VALUE=\"yes\" %s>",
+                               ((atoi(buf) != 0) ? "CHECKED" : ""));
+                       sprintf(&tuning[strlen(tuning)], "</TD></TR>\n");
+                       break;
+               case 44:
+                       sprintf(&network[strlen(network)], "<TR><TD>");
+                       sprintf(&network[strlen(network)], _("Instantly expunge deleted messages in IMAP"));
+                       sprintf(&network[strlen(network)], "</TD><TD>");
+                       sprintf(&network[strlen(network)], "<input type=\"checkbox\" NAME=\"c_instant_expunge\" VALUE=\"yes\" %s>",
+                               ((atoi(buf) != 0) ? "CHECKED" : ""));
+                       sprintf(&network[strlen(network)], "</TD></TR>\n");
+                       break;
+               case 45:
+                       sprintf(&network[strlen(network)], "<TR><TD>");
+                       sprintf(&network[strlen(network)], _("Allow unauthenticated SMTP clients to spoof this site's domains"));
+                       sprintf(&network[strlen(network)], "</TD><TD>");
+                       sprintf(&network[strlen(network)], "<input type=\"checkbox\" NAME=\"c_allow_spoofing\" VALUE=\"yes\" %s>",
+                               ((atoi(buf) != 0) ? "CHECKED" : ""));
+                       sprintf(&network[strlen(network)], "</TD></TR>\n");
+                       break;
+               case 46:
+                       sprintf(&idxjnl[strlen(idxjnl)], "<TR><TD>");
+                       sprintf(&idxjnl[strlen(idxjnl)], _("Perform journaling of email messages"));
+                       sprintf(&idxjnl[strlen(idxjnl)], "</TD><TD>");
+                       sprintf(&idxjnl[strlen(idxjnl)], "<input type=\"checkbox\" NAME=\"c_journal_email\" VALUE=\"yes\" %s>",
+                               ((atoi(buf) != 0) ? "CHECKED" : ""));
+                       sprintf(&idxjnl[strlen(idxjnl)], "</TD></TR>\n");
+                       break;
+               case 47:
+                       sprintf(&idxjnl[strlen(idxjnl)], "<TR><TD>");
+                       sprintf(&idxjnl[strlen(idxjnl)], _("Perform journaling of non-email messages"));
+                       sprintf(&idxjnl[strlen(idxjnl)], "</TD><TD>");
+                       sprintf(&idxjnl[strlen(idxjnl)], "<input type=\"checkbox\" NAME=\"c_journal_pubmsgs\" VALUE=\"yes\" %s>",
+                               ((atoi(buf) != 0) ? "CHECKED" : ""));
+                       sprintf(&idxjnl[strlen(idxjnl)], "</TD></TR>\n");
+                       break;
+               case 48:
+                       sprintf(&idxjnl[strlen(idxjnl)], "<TR><TD>");
+                       sprintf(&idxjnl[strlen(idxjnl)], _("Email destination of journalized messages"));
+                       sprintf(&idxjnl[strlen(idxjnl)], "</TD><TD>");
+                       sprintf(&idxjnl[strlen(idxjnl)], "<input type=\"text\" NAME=\"c_journal_dest\" MAXLENGTH=\"127\" VALUE=\"%s\">", buf);
+                       sprintf(&idxjnl[strlen(idxjnl)], "</TD></TR>\n");
+                       break;
+               case 49:
+                       if (strlen(buf) == 0) {
+                               strcpy(buf, "UTC");
+                       }
+#ifdef WEBCIT_WITH_CALENDAR_SERVICE
+                       sprintf(&general[strlen(general)], "<TR><TD>");
+                       sprintf(&general[strlen(general)], _("Default timezone for unzoned calendar items"));
+                       sprintf(&general[strlen(general)], "</TD><TD>");
+                       sprintf(&general[strlen(general)], "<select name=\"c_default_cal_zone\" size=\"1\">\n");
+
+                       sprintf(&general[strlen(general)], "<option %s value=\"UTC\">UTC</option>\n",
+                               (!strcasecmp(buf, "UTC") ? "selected" : "")
+                       );
+
+                       icalarray *zones;
+                       int z;
+                       char this_zone[128];
+                       zones = icaltimezone_get_builtin_timezones();
+                       for (z = 0; z < zones->num_elements; ++z) {
+                               strcpy(this_zone, icaltimezone_get_location(icalarray_element_at(zones, z)));
+                               sprintf(&general[strlen(general)], "<option %s value=\"%s\">%s</option>\n",
+                                       (!strcasecmp(this_zone, buf) ? "selected" : ""),
+                                       this_zone, this_zone
+                               );
+                       }
+
+                       sprintf(&general[strlen(general)], "</select>");
+                       sprintf(&general[strlen(general)], "</TD></TR>\n");
+#else /* WEBCIT_WITH_CALENDAR_SERVICE */
+                       wprintf("<input type=\"hidden\" name=\"c_default_cal_zone\" value=\"%s\">\n", buf);
+#endif /* WEBCIT_WITH_CALENDAR_SERVICE */
+                       break;
+               case 50:
+                       sprintf(&network[strlen(network)], "<TR><TD>");
+                       sprintf(&network[strlen(network)], _("<a href=\"http://www.postfix.org/tcp_table.5.html\">Postfix TCP Dictionary Port </a> (-1 to disable)"));
+                       sprintf(&network[strlen(network)], "</TD><TD>");
+                       sprintf(&network[strlen(network)], "<input type=\"text\" NAME=\"c_pftcpdict_port\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
+                       sprintf(&network[strlen(network)], "</TD></TR>\n");
+                       break;
+               case 51:
+                       sprintf(&network[strlen(network)], "<TR><TD>");
+                       sprintf(&network[strlen(network)], _("ManageSieve Port (-1 to disable)"));
+                       sprintf(&network[strlen(network)], "</TD><TD>");
+                       sprintf(&network[strlen(network)], "<input type=\"text\" NAME=\"c_mgesve_port\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
+                       sprintf(&network[strlen(network)], "</TD></TR>\n");
+                       break;
+               case 52:
+                       sprintf(&access[strlen(access)], "<TR><TD>");
+                       sprintf(&access[strlen(access)], _("Enable host based authentication mode"));
+                       sprintf(&access[strlen(access)], "</TD><TD><input type=\"hidden\" NAME=\"c_auth_mode\" VALUE=\"%s\">%s",
+                               buf,
+                               ((atoi(buf) != 0) ? "Yes" : "No"));
+                       sprintf(&access[strlen(access)], "</TD></TR>\n");
+                       break;
+               case 53:
+                       sprintf(&funambol[strlen(funambol)], "<TR><TD>");
+                       sprintf(&funambol[strlen(funambol)], _("Funambol server host (blank to disable)"));
+                       sprintf(&funambol[strlen(funambol)], "</TD><TD>");
+                       sprintf(&funambol[strlen(funambol)], "<input type=\"text\" NAME=\"c_funambol_host\" MAXLENGTH=\"255\" VALUE=\"%s\">", buf);
+                       sprintf(&funambol[strlen(funambol)], "</TD></TR>\n");
+                       break;
+               case 54:
+                       sprintf(&funambol[strlen(funambol)], "<TR><TD>");
+                       sprintf(&funambol[strlen(funambol)], _("Funambol server port "));
+                       sprintf(&funambol[strlen(funambol)], "</TD><TD>");
+                       sprintf(&funambol[strlen(funambol)], "<input type=\"text\" NAME=\"c_funambol_port\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
+                       sprintf(&funambol[strlen(funambol)], "</TD></TR>\n");
+                       break;
+               case 55:
+                       sprintf(&funambol[strlen(funambol)], "<TR><TD>");
+                       sprintf(&funambol[strlen(funambol)], _("Funambol sync source"));
+                       sprintf(&funambol[strlen(funambol)], "</TD><TD>");
+                       sprintf(&funambol[strlen(funambol)], "<input type=\"text\" NAME=\"c_funambol_source\" MAXLENGTH=\"255\" VALUE=\"%s\">", buf);
+                       sprintf(&funambol[strlen(funambol)], "</TD></TR>\n");
+                       break;
+               case 56:
+                       sprintf(&funambol[strlen(funambol)], "<TR><TD>");
+                       sprintf(&funambol[strlen(funambol)], _("Funambol auth details (user:pass in Base64)"));
+                       sprintf(&funambol[strlen(funambol)], "</TD><TD>");
+                       sprintf(&funambol[strlen(funambol)], "<input type=\"text\" NAME=\"c_funambol_auth\" MAXLENGTH=\"255\" VAUE=\"%s\">", buf);
+                       sprintf(&funambol[strlen(funambol)], "</TD></TR>\n");
                        break;
                }
+       
        }
 
        serv_puts("GPEX site");
-       serv_gets(buf);
+       serv_getln(buf, sizeof buf);
        if (buf[0] == '2') {
                sitepolicy = extract_int(&buf[4], 0);
                sitevalue = extract_int(&buf[4], 1);
        }
 
        serv_puts("GPEX mailboxes");
-       serv_gets(buf);
+       serv_getln(buf, sizeof buf);
        if (buf[0] == '2') {
                mboxpolicy = extract_int(&buf[4], 0);
                mboxvalue = extract_int(&buf[4], 1);
        }
 
-       if (!strcasecmp(whichmenu, "purger")) {
-
-               wprintf("<TR><TD COLSPAN=2><HR></TD></TR>\n");
-
-               wprintf("<TR><TD>Default message expire policy for public rooms</TD><TD>");
-               wprintf("<INPUT TYPE=\"radio\" NAME=\"sitepolicy\" VALUE=\"1\" %s>",
-                       ((sitepolicy == 1) ? "CHECKED" : "") );
-               wprintf("Never automatically expire messages<BR>\n");
-               wprintf("<INPUT TYPE=\"radio\" NAME=\"sitepolicy\" VALUE=\"2\" %s>",
-                       ((sitepolicy == 2) ? "CHECKED" : "") );
-               wprintf("Expire by message count<BR>\n");
-               wprintf("<INPUT TYPE=\"radio\" NAME=\"sitepolicy\" VALUE=\"3\" %s>",
-                       ((sitepolicy == 3) ? "CHECKED" : "") );
-               wprintf("Expire by message age<BR>");
-               wprintf("Number of messages or days: ");
-               wprintf("<INPUT TYPE=\"text\" NAME=\"sitevalue\" MAXLENGTH=\"5\" VALUE=\"%d\">", sitevalue);
-               wprintf("</TD></TR>\n");
-
-               wprintf("<TR><TD COLSPAN=2><HR></TD></TR>\n");
-
-               wprintf("<TR><TD>Default message expire policy for private mailboxes</TD><TD>");
-               wprintf("<INPUT TYPE=\"radio\" NAME=\"mboxpolicy\" VALUE=\"0\" %s>",
-                       ((mboxpolicy == 0) ? "CHECKED" : "") );
-               wprintf("Same policy as public rooms<BR>\n");
-               wprintf("<INPUT TYPE=\"radio\" NAME=\"mboxpolicy\" VALUE=\"1\" %s>",
-                       ((mboxpolicy == 1) ? "CHECKED" : "") );
-               wprintf("Never automatically expire messages<BR>\n");
-               wprintf("<INPUT TYPE=\"radio\" NAME=\"mboxpolicy\" VALUE=\"2\" %s>",
-                       ((mboxpolicy == 2) ? "CHECKED" : "") );
-               wprintf("Expire by message count<BR>\n");
-               wprintf("<INPUT TYPE=\"radio\" NAME=\"mboxpolicy\" VALUE=\"3\" %s>",
-                       ((mboxpolicy == 3) ? "CHECKED" : "") );
-               wprintf("Expire by message age<BR>");
-               wprintf("Number of messages or days: ");
-               wprintf("<INPUT TYPE=\"text\" NAME=\"mboxvalue\" MAXLENGTH=\"5\" VALUE=\"%d\">", mboxvalue);
-               wprintf("</TD></TR>\n");
-
-               wprintf("<TR><TD COLSPAN=2><HR></TD></TR>\n");
-
-       }
-       else {
-               wprintf("<INPUT TYPE=\"hidden\" NAME=\"sitepolicy\" VALUE=\"%d\">\n", sitepolicy);
-               wprintf("<INPUT TYPE=\"hidden\" NAME=\"sitevalue\" VALUE=\"%d\">\n", sitevalue);
-               wprintf("<INPUT TYPE=\"hidden\" NAME=\"mboxpolicy\" VALUE=\"%d\">\n", mboxpolicy);
-               wprintf("<INPUT TYPE=\"hidden\" NAME=\"mboxvalue\" VALUE=\"%d\">\n", mboxvalue);
-       }
 
-       wprintf("</TABLE><CENTER>");
-       wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"OK\">");
+       sprintf(&purger[strlen(purger)], "<TR><TD COLSPAN=2><hr /></TD></TR>\n");
+
+       sprintf(&purger[strlen(purger)], "<TR><TD>");
+       sprintf(&purger[strlen(purger)], _("Default message expire policy for public rooms"));
+       sprintf(&purger[strlen(purger)], "</TD><TD>");
+       sprintf(&purger[strlen(purger)], "<input type=\"radio\" NAME=\"sitepolicy\" VALUE=\"1\" %s>",
+               ((sitepolicy == 1) ? "CHECKED" : "") );
+       sprintf(&purger[strlen(purger)], _("Never automatically expire messages"));
+       sprintf(&purger[strlen(purger)], "<br />\n");
+       sprintf(&purger[strlen(purger)], "<input type=\"radio\" NAME=\"sitepolicy\" VALUE=\"2\" %s>",
+               ((sitepolicy == 2) ? "CHECKED" : "") );
+       sprintf(&purger[strlen(purger)], _("Expire by message count"));
+       sprintf(&purger[strlen(purger)], "<br />\n");
+       sprintf(&purger[strlen(purger)], "<input type=\"radio\" NAME=\"sitepolicy\" VALUE=\"3\" %s>",
+               ((sitepolicy == 3) ? "CHECKED" : "") );
+       sprintf(&purger[strlen(purger)], _("Expire by message age"));
+       sprintf(&purger[strlen(purger)], "<br />");
+       sprintf(&purger[strlen(purger)], _("Number of messages or days: "));
+       sprintf(&purger[strlen(purger)], "<input type=\"text\" NAME=\"sitevalue\" MAXLENGTH=\"5\" VALUE=\"%d\">", sitevalue);
+       sprintf(&purger[strlen(purger)], "</TD></TR>\n");
+
+       sprintf(&purger[strlen(purger)], "<TR><TD COLSPAN=2><hr /></TD></TR>\n");
+
+       sprintf(&purger[strlen(purger)], "<TR><TD>");
+       sprintf(&purger[strlen(purger)], _("Default message expire policy for private mailboxes"));
+       sprintf(&purger[strlen(purger)], "</TD><TD>");
+       sprintf(&purger[strlen(purger)], "<input type=\"radio\" NAME=\"mboxpolicy\" VALUE=\"0\" %s>",
+               ((mboxpolicy == 0) ? "CHECKED" : "") );
+       sprintf(&purger[strlen(purger)], _("Same policy as public rooms"));
+       sprintf(&purger[strlen(purger)], "<br />\n");
+       sprintf(&purger[strlen(purger)], "<input type=\"radio\" NAME=\"mboxpolicy\" VALUE=\"1\" %s>",
+                       ((mboxpolicy == 1) ? "CHECKED" : "") );
+       sprintf(&purger[strlen(purger)], _("Never automatically expire messages"));
+       sprintf(&purger[strlen(purger)], "<br />\n");
+       sprintf(&purger[strlen(purger)], "<input type=\"radio\" NAME=\"mboxpolicy\" VALUE=\"2\" %s>",
+               ((mboxpolicy == 2) ? "CHECKED" : "") );
+       sprintf(&purger[strlen(purger)], _("Expire by message count"));
+       sprintf(&purger[strlen(purger)], "<br />\n");
+       sprintf(&purger[strlen(purger)], "<input type=\"radio\" NAME=\"mboxpolicy\" VALUE=\"3\" %s>",
+               ((mboxpolicy == 3) ? "CHECKED" : "") );
+       sprintf(&purger[strlen(purger)], _("Expire by message age"));
+       sprintf(&purger[strlen(purger)], "<br />");
+       sprintf(&purger[strlen(purger)], _("Number of messages or days: "));
+       sprintf(&purger[strlen(purger)], "<input type=\"text\" NAME=\"mboxvalue\" MAXLENGTH=\"5\" VALUE=\"%d\">", mboxvalue);
+       sprintf(&purger[strlen(purger)], "</TD></TR>\n");
+
+       sprintf(&purger[strlen(purger)], "<TR><TD COLSPAN=2><hr /></TD></TR>\n");
+
+
+       sprintf(&general[strlen(general)], "</table>");
+       sprintf(&access[strlen(access)], "</table>");
+       sprintf(&network[strlen(network)], "</table>");
+       sprintf(&tuning[strlen(tuning)], "</table>");
+       sprintf(&directory[strlen(directory)], "</table>");
+       sprintf(&purger[strlen(purger)], "</table>");
+       sprintf(&idxjnl[strlen(idxjnl)], "</table>");
+       sprintf(&funambol[strlen(funambol)], "</table>");
+
+       tabbed_dialog(8, tabnames);
+
+       begin_tab(0, 8);        client_write(general, strlen(general));          end_tab(0, 8);
+       begin_tab(1, 8);        client_write(access, strlen(access));            end_tab(1, 8);
+       begin_tab(2, 8);        client_write(network, strlen(network));          end_tab(2, 8);
+       begin_tab(3, 8);        client_write(tuning, strlen(tuning));            end_tab(3, 8);
+       begin_tab(4, 8);        client_write(directory, strlen(directory));      end_tab(4, 8);
+       begin_tab(5, 8);        client_write(purger, strlen(purger));            end_tab(5, 8);
+       begin_tab(6, 8);        client_write(idxjnl, strlen(idxjnl));            end_tab(6, 8);
+       begin_tab(7, 8);        client_write(funambol, strlen(funambol));        end_tab(7, 8);
+       wprintf("<div align=\"center\"><br>");
+       wprintf("<input type=\"submit\" NAME=\"ok_button\" VALUE=\"%s\">", _("Save changes"));
        wprintf("&nbsp;");
-       wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">\n");
-       wprintf("</CENTER></FORM>\n");
-       do_template("endbox");
+       wprintf("<input type=\"submit\" NAME=\"cancel_button\" VALUE=\"%s\">\n", _("Cancel"));
+       wprintf("</div></FORM>\n");
+       wprintf("</td></tr></table>\n");
        wDumpContent(1);
 }
 
-
+/**
+ * parse siteconfig changes 
+ */
 void siteconfig(void)
 {
-       char buf[SIZ];
+       char buf[256];
 
-       if (strcasecmp(bstr("sc"), "OK")) {
-               display_siteconfig();
+       if (strlen(bstr("ok_button")) == 0) {
+               display_aide_menu();
                return;
        }
        serv_printf("CONF set");
-       serv_gets(buf);
+       serv_getln(buf, sizeof buf);
        if (buf[0] != '4') {
-               strcpy(WC->ImportantMessage, &buf[4]);
-               display_siteconfig();
+               safestrncpy(WC->ImportantMessage, &buf[4], sizeof WC->ImportantMessage);
+               display_aide_menu();
                return;
        }
        serv_printf("%s", bstr("c_nodename"));
@@ -662,7 +690,7 @@ void siteconfig(void)
        serv_printf("%s", bstr("c_bbs_city"));
        serv_printf("%s", bstr("c_sysadm"));
        serv_printf("%s", bstr("c_maxsessions"));
-       serv_printf("");  /* networking password -- deprecated */
+       serv_printf("");  /* placeholder - this field is not in use */
        serv_printf("%s", bstr("c_userpurge"));
        serv_printf("%s", bstr("c_roompurge"));
        serv_printf("%s", bstr("c_logpages"));
@@ -672,12 +700,12 @@ void siteconfig(void)
        serv_printf("%s", bstr("c_max_workers"));
        serv_printf("%s", bstr("c_pop3_port"));
        serv_printf("%s", bstr("c_smtp_port"));
-       serv_printf("");  /* moderation filter level -- not yet implemented */
+       serv_printf("%s", ((!strcasecmp(bstr("c_rfc822_strict_from"), "yes") ? "0" : "1"))); /* note: reverse bool */
        serv_printf("%s", ((!strcasecmp(bstr("c_aide_zap"), "yes") ? "1" : "0")));
        serv_printf("%s", bstr("c_imap_port"));
        serv_printf("%s", bstr("c_net_freq"));
-       serv_printf("%s", bstr("c_disable_newu"));
-       serv_printf("1");       /* placeholder -- deprecated */
+       serv_printf("%s", ((!strcasecmp(bstr("c_disable_newu"), "yes") ? "1" : "0")));
+       serv_printf("1"); /* placeholder - this field is not in use */
        serv_printf("%s", bstr("c_purge_hour"));
        serv_printf("%s", bstr("c_ldap_host"));
        serv_printf("%s", bstr("c_ldap_port"));
@@ -686,13 +714,37 @@ void siteconfig(void)
        serv_printf("%s", bstr("c_ldap_bind_pw"));
        serv_printf("%s", bstr("c_ip_addr"));
        serv_printf("%s", bstr("c_msa_port"));
+       serv_printf("%s", bstr("c_imaps_port"));
+       serv_printf("%s", bstr("c_pop3s_port"));
+       serv_printf("%s", bstr("c_smtps_port"));
+       serv_printf("%s", ((!strcasecmp(bstr("c_enable_fulltext"), "yes") ? "1" : "0")));
+       serv_printf("%s", ((!strcasecmp(bstr("c_auto_cull"), "yes") ? "1" : "0")));
+       serv_printf("%s", ((!strcasecmp(bstr("c_instant_expunge"), "yes") ? "1" : "0")));
+       serv_printf("%s", ((!strcasecmp(bstr("c_allow_spoofing"), "yes") ? "1" : "0")));
+       serv_printf("%s", ((!strcasecmp(bstr("c_journal_email"), "yes") ? "1" : "0")));
+       serv_printf("%s", ((!strcasecmp(bstr("c_journal_pubmsgs"), "yes") ? "1" : "0")));
+       serv_printf("%s", bstr("c_journal_dest"));
+       serv_printf("%s", bstr("c_default_cal_zone"));
+       serv_printf("%s", bstr("c_pftcpdict_port"));
+       serv_printf("%s", bstr("c_mgesve_port"));
+       serv_printf("%s", bstr("c_auth_mode"));
+       serv_printf("%s", bstr("c_funambol_host"));
+       serv_printf("%s", bstr("c_funambol_port"));
+       serv_printf("%s", bstr("c_funambol_source"));
+       serv_printf("%s", bstr("c_funambol_auth"));
        serv_printf("000");
 
        serv_printf("SPEX site|%d|%d", atoi(bstr("sitepolicy")), atoi(bstr("sitevalue")));
-       serv_gets(buf);
+       serv_getln(buf, sizeof buf);
        serv_printf("SPEX mailboxes|%d|%d", atoi(bstr("mboxpolicy")), atoi(bstr("mboxvalue")));
-       serv_gets(buf);
+       serv_getln(buf, sizeof buf);
 
-       strcpy(WC->ImportantMessage, "System configuration has been updated.");
-       display_siteconfig();
+       strcpy(serv_info.serv_default_cal_zone, bstr("c_default_cal_zone"));
+
+       safestrncpy(WC->ImportantMessage, _("Your system configuration has been updated."),
+               sizeof WC->ImportantMessage);
+       display_aide_menu();
 }
+
+
+/*@}*/