]> code.citadel.org Git - citadel.git/blobdiff - webcit/siteconfig.c
* Corrected overly-escaped reply-to addresses in "reply" button
[citadel.git] / webcit / siteconfig.c
index 5d814bbbb034d6e0e92069f3d2fd2c55ee6a1b5f..bd78bb1206f6d3be5f22d545d351c0bc616ff0d0 100644 (file)
@@ -35,6 +35,12 @@ void display_siteconfig(void)
        char *whichmenu;
        int i, j;
 
+       /* expire policy settings */
+       int sitepolicy = 0;
+       int sitevalue = 0;
+       int mboxpolicy = 0;
+       int mboxvalue = 0;
+
        output_headers(3);
 
        whichmenu = bstr("whichmenu");
@@ -46,7 +52,6 @@ void display_siteconfig(void)
                wprintf("<TABLE border=0 cellspacing=0 cellpadding=3 width=100%%>\n");
 
                wprintf("<TR BGCOLOR=\"#CCCCCC\"><TD>"
-                       "</TD><TD>"
                        "<A HREF=\"/display_siteconfig?whichmenu=general\">"
                        "<IMG BORDER=\"0\" WIDTH=\"48\" HEIGHT=\"48\" "
                        "SRC=\"/static/advanced-icon.gif\" ALT=\"&nbsp;\">"
@@ -58,7 +63,6 @@ void display_siteconfig(void)
                );
 
                wprintf("<TR><TD>"
-                       "</TD><TD>"
                        "<A HREF=\"/display_siteconfig?whichmenu=access\">"
                        "<IMG BORDER=\"0\" WIDTH=\"48\" HEIGHT=\"48\" "
                        "SRC=\"/static/advanced-icon.gif\" ALT=\"&nbsp;\">"
@@ -70,7 +74,6 @@ void display_siteconfig(void)
                );
 
                wprintf("<TR BGCOLOR=\"#CCCCCC\"><TD>"
-                       "</TD><TD>"
                        "<A HREF=\"/display_siteconfig?whichmenu=network\">"
                        "<IMG BORDER=\"0\" WIDTH=\"48\" HEIGHT=\"48\" "
                        "SRC=\"/static/advanced-icon.gif\" ALT=\"&nbsp;\">"
@@ -82,7 +85,6 @@ void display_siteconfig(void)
                );
 
                wprintf("<TR><TD>"
-                       "</TD><TD>"
                        "<A HREF=\"/display_siteconfig?whichmenu=tuning\">"
                        "<IMG BORDER=\"0\" WIDTH=\"48\" HEIGHT=\"48\" "
                        "SRC=\"/static/advanced-icon.gif\" ALT=\"&nbsp;\">"
@@ -94,7 +96,6 @@ void display_siteconfig(void)
                );
 
                wprintf("<TR BGCOLOR=\"#CCCCCC\"><TD>"
-                       "</TD><TD>"
                        "<A HREF=\"/display_siteconfig?whichmenu=ldap\">"
                        "<IMG BORDER=\"0\" WIDTH=\"48\" HEIGHT=\"48\" "
                        "SRC=\"/static/advanced-icon.gif\" ALT=\"&nbsp;\">"
@@ -105,6 +106,17 @@ void display_siteconfig(void)
                        "</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");
@@ -121,7 +133,9 @@ void display_siteconfig(void)
        }
 
        if (!strcasecmp(whichmenu, "network")) {
-               wprintf("<CENTER><H2>Network services</H2></CENTER>\n");
+               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")) {
@@ -129,7 +143,15 @@ void display_siteconfig(void)
        }
 
        if (!strcasecmp(whichmenu, "ldap")) {
-               wprintf("<CENTER><H2>Citadel LDAP connector configuration</H2></CENTER>\n");
+               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");
+       }
+
+       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");
        }
 
        serv_printf("CONF get");
@@ -144,7 +166,6 @@ void display_siteconfig(void)
                return;
        }
 
-
        wprintf("<FORM METHOD=\"POST\" ACTION=\"/siteconfig\">\n");
        wprintf("<TABLE border=0>\n");
 
@@ -397,7 +418,7 @@ void display_siteconfig(void)
                        break;
                case 25:
                        if (!strcasecmp(whichmenu, "network")) {
-                               wprintf("<TR><TD>SMTP listener port (-1 to disable)</TD><TD>");
+                               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");
                        }
@@ -446,14 +467,7 @@ void display_siteconfig(void)
                        }
                        break;
                case 31:
-                       if (!strcasecmp(whichmenu, "access")) {
-                               wprintf("<TR><TD>Allow system Aides access to mailboxes</TD><TD>");
-                               wprintf("<INPUT TYPE=\"checkbox\" NAME=\"c_aide_mailboxes\" VALUE=\"yes\" %s>", ((atoi(buf) != 0) ? "CHECKED" : ""));
-                               wprintf("</TD></TR>\n");
-                       }
-                       else {
-                               wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_aide_mailboxes\" VALUE=\"%s\">", buf);
-                       }
+                       /* placeholder -- there is no option 31 */
                        break;
                case 32:
                        if (!strcasecmp(whichmenu, "tuning")) {
@@ -524,11 +538,93 @@ void display_siteconfig(void)
                                wprintf("<INPUT TYPE=\"hidden\" NAME=\"c_ldap_bind_pw\" VALUE=\"%s\">", buf);
                        }
                        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);
+                       }
+                       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);
+                       }
+                       break;
                }
        }
 
+       serv_puts("GPEX site");
+       serv_gets(buf);
+       if (buf[0] == '2') {
+               sitepolicy = extract_int(&buf[4], 0);
+               sitevalue = extract_int(&buf[4], 1);
+       }
+
+       serv_puts("GPEX mailboxes");
+       serv_gets(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\">");
+       wprintf("&nbsp;");
        wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">\n");
        wprintf("</CENTER></FORM>\n");
        do_template("endbox");
@@ -580,15 +676,23 @@ void siteconfig(void)
        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("%s", bstr("c_aide_mailboxes"));
+       serv_printf("%s", ((!strcasecmp(bstr("c_disable_newu"), "yes") ? "1" : "0")));
+       serv_printf("1");       /* placeholder -- deprecated */
        serv_printf("%s", bstr("c_purge_hour"));
        serv_printf("%s", bstr("c_ldap_host"));
        serv_printf("%s", bstr("c_ldap_port"));
        serv_printf("%s", bstr("c_ldap_base_dn"));
        serv_printf("%s", bstr("c_ldap_bind_dn"));
        serv_printf("%s", bstr("c_ldap_bind_pw"));
+       serv_printf("%s", bstr("c_ip_addr"));
+       serv_printf("%s", bstr("c_msa_port"));
        serv_printf("000");
+
+       serv_printf("SPEX site|%d|%d", atoi(bstr("sitepolicy")), atoi(bstr("sitevalue")));
+       serv_gets(buf);
+       serv_printf("SPEX mailboxes|%d|%d", atoi(bstr("mboxpolicy")), atoi(bstr("mboxvalue")));
+       serv_gets(buf);
+
        strcpy(WC->ImportantMessage, "System configuration has been updated.");
        display_siteconfig();
 }