]> code.citadel.org Git - citadel.git/blobdiff - webcit/siteconfig.c
* Integrated the first batch of new icons.
[citadel.git] / webcit / siteconfig.c
index c477ceaf061285167b802da416addaf0df11cdf9..5d593235d89aa39d0927086d1bdbe79ec56a60ef 100644 (file)
@@ -43,12 +43,18 @@ void display_siteconfig(void)
        int mboxpolicy = 0;
        int mboxvalue = 0;
 
-       output_headers(1, 1, 0, 0, 0, 0, 0);
+       output_headers(1, 1, 2, 0, 0, 0, 0);
+       wprintf("<div id=\"banner\">\n"
+               "<TABLE WIDTH=100%% BORDER=0 BGCOLOR=\"#444455\"><TR><TD>"
+               "<SPAN CLASS=\"titlebar\">Site configuration</SPAN>"
+               "</TD></TR></TABLE>\n"
+               "</div>\n<div id=\"content\">\n"
+       );
 
-       whichmenu = bstr("whichmenu");
+       wprintf("<div id=\"fix_scrollbar_bug\">"
+               "<table border=0 width=100%% bgcolor=\"#ffffff\"><tr><td>");
 
-       svprintf("BOXTITLE", WCS_STRING, "Site configuration");
-       do_template("beginbox_nt");
+       whichmenu = bstr("whichmenu");
 
        if (!strcmp(whichmenu, "")) {
                wprintf("<TABLE border=0 cellspacing=0 cellpadding=3 width=100%%>\n");
@@ -56,7 +62,7 @@ void display_siteconfig(void)
                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;\">"
+                       "SRC=\"/static/advanpage_48x.gif\" ALT=\"&nbsp;\">"
                        "</TD><TD>"
                        "<A HREF=\"/display_siteconfig?whichmenu=general\">"
                        "<B>General</B><br />"
@@ -67,7 +73,7 @@ void display_siteconfig(void)
                wprintf("<TR><TD>"
                        "<A HREF=\"/display_siteconfig?whichmenu=access\">"
                        "<IMG BORDER=\"0\" WIDTH=\"48\" HEIGHT=\"48\" "
-                       "SRC=\"/static/advanced-icon.gif\" ALT=\"&nbsp;\">"
+                       "SRC=\"/static/advanpage_48x.gif\" ALT=\"&nbsp;\">"
                        "</TD><TD>"
                        "<A HREF=\"/display_siteconfig?whichmenu=access\">"
                        "<B>Access</B><br />"
@@ -78,7 +84,7 @@ void display_siteconfig(void)
                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;\">"
+                       "SRC=\"/static/advanpage_48x.gif\" ALT=\"&nbsp;\">"
                        "</TD><TD>"
                        "<A HREF=\"/display_siteconfig?whichmenu=network\">"
                        "<B>Network</B><br />"
@@ -89,7 +95,7 @@ void display_siteconfig(void)
                wprintf("<TR><TD>"
                        "<A HREF=\"/display_siteconfig?whichmenu=tuning\">"
                        "<IMG BORDER=\"0\" WIDTH=\"48\" HEIGHT=\"48\" "
-                       "SRC=\"/static/advanced-icon.gif\" ALT=\"&nbsp;\">"
+                       "SRC=\"/static/advanpage_48x.gif\" ALT=\"&nbsp;\">"
                        "</TD><TD>"
                        "<A HREF=\"/display_siteconfig?whichmenu=tuning\">"
                        "<B>Tuning</B><br />"
@@ -100,7 +106,7 @@ void display_siteconfig(void)
                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;\">"
+                       "SRC=\"/static/advanpage_48x.gif\" ALT=\"&nbsp;\">"
                        "</TD><TD>"
                        "<A HREF=\"/display_siteconfig?whichmenu=ldap\">"
                        "<B>Directory</B><br />"
@@ -111,7 +117,7 @@ void display_siteconfig(void)
                wprintf("<TR><TD>"
                        "<A HREF=\"/display_siteconfig?whichmenu=purger\">"
                        "<IMG BORDER=\"0\" WIDTH=\"48\" HEIGHT=\"48\" "
-                       "SRC=\"/static/advanced-icon.gif\" ALT=\"&nbsp;\">"
+                       "SRC=\"/static/advanpage_48x.gif\" ALT=\"&nbsp;\">"
                        "</TD><TD>"
                        "<A HREF=\"/display_siteconfig?whichmenu=purger\">"
                        "<B>Auto-purger</B><br />"
@@ -120,8 +126,7 @@ void display_siteconfig(void)
                );
 
                wprintf("</TABLE>");
-
-               do_template("endbox");
+               wprintf("</td></tr></table></center>\n");
                wDumpContent(1);
                return;
        }
@@ -157,7 +162,7 @@ void display_siteconfig(void)
        }
 
        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");
@@ -172,7 +177,7 @@ void display_siteconfig(void)
        wprintf("<TABLE border=0>\n");
 
        i = 0;
-       while (serv_gets(buf), strcmp(buf, "000")) {
+       while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
                switch (++i) {
                case 1:
                        if (!strcasecmp(whichmenu, "general")) {
@@ -323,7 +328,7 @@ void display_siteconfig(void)
                        break;
                case 15:
                        if (!strcasecmp(whichmenu, "tuning")) {
-                               wprintf("<TR><TD>Maximum concurrent sessions</TD><TD>");
+                               wprintf("<TR><TD>Maximum concurrent sessions (0 = no limit)</TD><TD>");
                                wprintf("<INPUT TYPE=\"text\" NAME=\"c_maxsessions\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
                                wprintf("</TD></TR>\n");
                        }
@@ -469,10 +474,10 @@ void display_siteconfig(void)
                        }
                        break;
                case 31:
-                       /* placeholder -- there is no option 31 */
+                       /* niu */
                        break;
                case 32:
-                       if (!strcasecmp(whichmenu, "tuning")) {
+                       if (!strcasecmp(whichmenu, "purger")) {
                                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) {
@@ -560,18 +565,58 @@ void display_siteconfig(void)
                                wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_msa_port\" VALUE=\"%s\">", buf);
                        }
                        break;
+               case 40:
+                       if (!strcasecmp(whichmenu, "network")) {
+                               wprintf("<TR><TD>IMAP over SSL port (-1 to disable)</TD><TD>");
+                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_imaps_port\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
+                               wprintf("</TD></TR>\n");
+                       }
+                       else {
+                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_imaps_port\" VALUE=\"%s\">", buf);
+                       }
+                       break;
+               case 41:
+                       if (!strcasecmp(whichmenu, "network")) {
+                               wprintf("<TR><TD>POP3 over SSL port (-1 to disable)</TD><TD>");
+                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_pop3s_port\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
+                               wprintf("</TD></TR>\n");
+                       }
+                       else {
+                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_pop3s_port\" VALUE=\"%s\">", buf);
+                       }
+                       break;
+               case 42:
+                       if (!strcasecmp(whichmenu, "network")) {
+                               wprintf("<TR><TD>SMTP over SSL port (-1 to disable)</TD><TD>");
+                               wprintf("<INPUT TYPE=\"text\" NAME=\"c_smtps_port\" MAXLENGTH=\"5\" VALUE=\"%s\">", buf);
+                               wprintf("</TD></TR>\n");
+                       }
+                       else {
+                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_smtps_port\" VALUE=\"%s\">", buf);
+                       }
+                       break;
+               case 43:
+                       if (!strcasecmp(whichmenu, "general")) {
+                               wprintf("<TR><TD>Enable full text index (warning: resource intensive)</TD><TD>");
+                               wprintf("<INPUT TYPE=\"checkbox\" NAME=\"c_enable_fulltext\" VALUE=\"yes\" %s>", ((atoi(buf) != 0) ? "CHECKED" : ""));
+                               wprintf("</TD></TR>\n");
+                       }
+                       else {
+                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_enable_fulltext\" VALUE=\"%s\">", buf);
+                       }
+                       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);
@@ -629,7 +674,7 @@ void display_siteconfig(void)
        wprintf("&nbsp;");
        wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">\n");
        wprintf("</CENTER></FORM>\n");
-       do_template("endbox");
+       wprintf("</td></tr></table></div>\n");
        wDumpContent(1);
 }
 
@@ -643,9 +688,9 @@ void siteconfig(void)
                return;
        }
        serv_printf("CONF set");
-       serv_gets(buf);
+       serv_getln(buf, sizeof buf);
        if (buf[0] != '4') {
-               strcpy(WC->ImportantMessage, &buf[4]);
+               safestrncpy(WC->ImportantMessage, &buf[4], sizeof WC->ImportantMessage);
                display_siteconfig();
                return;
        }
@@ -679,7 +724,7 @@ void siteconfig(void)
        serv_printf("%s", bstr("c_imap_port"));
        serv_printf("%s", bstr("c_net_freq"));
        serv_printf("%s", ((!strcasecmp(bstr("c_disable_newu"), "yes") ? "1" : "0")));
-       serv_printf("1");       /* placeholder -- deprecated */
+       serv_printf("1");
        serv_printf("%s", bstr("c_purge_hour"));
        serv_printf("%s", bstr("c_ldap_host"));
        serv_printf("%s", bstr("c_ldap_port"));
@@ -688,13 +733,18 @@ 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("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.");
+       safestrncpy(WC->ImportantMessage, "System configuration has been updated.",
+               sizeof WC->ImportantMessage);
        display_siteconfig();
 }