X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fsiteconfig.c;h=1a760033570b3befe85ae9801ed1243e8439d553;hb=b4ad306de9560ec731db113ed509a1172209c444;hp=1b866524e1472885ee780a4d1a6df2adb2436a4f;hpb=3abfd5bfcc3dd94bf554917f20144ca36dfc4218;p=citadel.git diff --git a/webcit/siteconfig.c b/webcit/siteconfig.c index 1b866524e..1a7600335 100644 --- a/webcit/siteconfig.c +++ b/webcit/siteconfig.c @@ -2,56 +2,89 @@ * $Id$ * * Administrative screen for site-wide configuration - * */ #include "webcit.h" +#include "webserver.h" + + +HashList *ZoneHash = NULL; + + + +void LoadZoneFiles(void) +{ + icalarray *zones; + int z; + long len; + const char *this_zone; + StrBuf *ZName; + + ZoneHash = NewHash(1, NULL); + ZName = NewStrBufPlain(HKEY("UTC")); + Put(ZoneHash, HKEY("UTC"), ZName, HFreeStrBuf); + zones = icaltimezone_get_builtin_timezones(); + for (z = 0; z < zones->num_elements; ++z) { + this_zone = icaltimezone_get_location(icalarray_element_at(zones, z)); + len = strlen(this_zone); + ZName = NewStrBufPlain(this_zone, len); + Put(ZoneHash, this_zone, len, ZName, HFreeStrBuf); + } + SortByHashKey(ZoneHash, 0); +} + + +/* + * \brief display all configuration items + */ void display_siteconfig(void) { char buf[SIZ]; int i, j; + struct wcsession *WCC = WC; + const char *VCZname; - char general[SIZ]; + char general[65536]; char access[SIZ]; char network[SIZ]; char tuning[SIZ]; char directory[SIZ]; char purger[SIZ]; - - /* expire policy settings */ + char idxjnl[SIZ]; + char funambol[SIZ]; + char pop3[SIZ]; + + /** expire policy settings */ int sitepolicy = 0; int sitevalue = 0; int mboxpolicy = 0; int mboxvalue = 0; output_headers(1, 1, 2, 0, 0, 0); - wprintf("
\n" - "
" - ""); + wprintf("
\n"); + wprintf("

"); wprintf(_("Site configuration")); - wprintf("" - "

\n" - "
\n
\n" - ); + wprintf(""); + wprintf("
\n"); + + wprintf("
\n"); serv_printf("CONF get"); serv_getln(buf, sizeof buf); if (buf[0] != '1') { - wprintf("
"); - wprintf(""); + wprintf("
"); wprintf(_("Error")); - wprintf("\n"); - wprintf("

\n"); + wprintf("
\n"); wprintf("%s
\n", &buf[4]); wDumpContent(1); + wprintf("
\n"); return; } - wprintf("
" - "
"); + wprintf("
"); char *tabnames[] = { _("General"), @@ -59,7 +92,10 @@ void display_siteconfig(void) _("Network"), _("Tuning"), _("Directory"), - _("Auto-purger") + _("Auto-purger"), + _("Indexing/Journaling"), + _("Push Email"), + _("Pop3") }; sprintf(general, "

%s

", @@ -82,8 +118,12 @@ void display_siteconfig(void) sprintf(directory, "

%s

%s

", _("Configure the LDAP connector for Citadel"), - _("Changes made on this screen will not take effect " - "until you restart the Citadel server.") + (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, "

%s

%s

", @@ -91,199 +131,222 @@ void display_siteconfig(void) _("These settings may be overridden on a per-floor or per-room basis.") ); + sprintf(idxjnl, "

%s

%s

", + _("Indexing and Journaling"), + _("Warning: these facilities are resource intensive.") + ); + sprintf(funambol, "

%s

", + _("Push Email") + ); + sprintf(pop3, "

%s

", + _("POP3") + ); + wprintf("\n"); + wprintf("\n", WCC->nonce); + + sprintf(&general[strlen(general)], "", _("Change Login Logo")); + sprintf(&general[strlen(general)], "\n", _("Change Logout Logo")); i = 0; while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) { - switch (++i) { - case 1: - sprintf(&general[strlen(general)], "\n"); + sprintf(&general[strlen(general)], "\n"); break; - case 2: - sprintf(&general[strlen(general)], "\n"); + sprintf(&general[strlen(general)], "\n"); break; - case 3: - sprintf(&general[strlen(general)], "\n"); + sprintf(&general[strlen(general)], "\n"); break; - case 4: - sprintf(&general[strlen(general)], "\n"); + sprintf(&general[strlen(general)], "\n"); break; - case 5: - sprintf(&access[strlen(access)], "\n"); + sprintf(&access[strlen(access)], "\n"); break; - case 6: - sprintf(&tuning[strlen(tuning)], "\n"); + sprintf(&tuning[strlen(tuning)], "\n"); break; - case 7: - sprintf(&access[strlen(access)], "\n"); + sprintf(&access[strlen(access)], ""); + sprintf(&access[strlen(access)], "\n"); break; - case 8: - sprintf(&access[strlen(access)], "\n"); + sprintf(&access[strlen(access)], "\n"); break; - case 9: - sprintf(&access[strlen(access)], "\n"); + sprintf(&access[strlen(access)], "\n"); break; - case 10: - sprintf(&access[strlen(access)], "\n"); + sprintf(&access[strlen(access)], "\n"); break; - case 11: - sprintf(&general[strlen(general)], "\n"); + sprintf(&general[strlen(general)], "\n"); break; - case 12: - sprintf(&access[strlen(access)], "\n"); + sprintf(&access[strlen(access)], "\n"); break; - case 13: - sprintf(&general[strlen(general)], "\n"); + sprintf(&general[strlen(general)], "\n"); break; - case 14: - sprintf(&general[strlen(general)], "\n"); + sprintf(&general[strlen(general)], "\n"); break; - case 15: - sprintf(&tuning[strlen(tuning)], "\n"); + sprintf(&tuning[strlen(tuning)], "\n"); break; - case 17: - sprintf(&tuning[strlen(tuning)], "\n"); + sprintf(&tuning[strlen(tuning)], "\n"); break; - case 18: - sprintf(&tuning[strlen(tuning)], "\n"); + sprintf(&tuning[strlen(tuning)], "\n"); break; - case 19: - sprintf(&access[strlen(access)], "\n"); + sprintf(&access[strlen(access)], "\n"); break; - case 20: - sprintf(&access[strlen(access)], "\n"); + sprintf(&access[strlen(access)], ""); + sprintf(&access[strlen(access)], "\n"); break; - case 21: - sprintf(&tuning[strlen(tuning)], "\n"); + sprintf(&tuning[strlen(tuning)], "\n"); break; - case 22: - sprintf(&tuning[strlen(tuning)], "\n"); + sprintf(&tuning[strlen(tuning)], "\n"); break; - case 23: - sprintf(&tuning[strlen(tuning)], "\n"); + sprintf(&tuning[strlen(tuning)], "\n"); + break; + case 23: + sprintf(&pop3[strlen(pop3)], "\n"); break; case 24: sprintf(&network[strlen(network)], "\n"); break; - case 25: + case 25: /* note: reverse bool */ sprintf(&network[strlen(network)], "\n"); break; - case 27: + case 26: sprintf(&access[strlen(access)], "\n"); break; - case 28: + case 27: sprintf(&network[strlen(network)], "\n"); break; - case 29: + case 28: sprintf(&network[strlen(network)], "\n"); break; - case 30: + case 29: sprintf(&access[strlen(access)], "\n"); break; case 31: - /* position 31 is no longer in use */ - break; - case 32: sprintf(&purger[strlen(purger)], "\n"); break; - case 33: + case 32: sprintf(&directory[strlen(directory)], "\n"); break; - case 34: + case 33: sprintf(&directory[strlen(directory)], "\n"); break; - case 35: + case 34: sprintf(&directory[strlen(directory)], "\n"); break; - case 36: + case 35: sprintf(&directory[strlen(directory)], "\n"); break; - case 37: + case 36: sprintf(&directory[strlen(directory)], "\n"); break; - case 38: + case 37: sprintf(&network[strlen(network)], "\n"); break; - case 39: + case 38: sprintf(&network[strlen(network)], "\n"); break; - case 40: + case 39: sprintf(&network[strlen(network)], "\n"); break; - case 41: - sprintf(&network[strlen(network)], "\n"); + case 40: + sprintf(&pop3[strlen(pop3)], "\n"); break; - case 42: + case 41: sprintf(&network[strlen(network)], "\n"); break; - case 43: - sprintf(&general[strlen(general)], "\n"); + sprintf(&idxjnl[strlen(idxjnl)], "\n"); break; - case 44: + case 43: sprintf(&tuning[strlen(tuning)], "\n"); break; - case 45: + case 44: sprintf(&network[strlen(network)], "\n"); break; - case 46: + case 45: sprintf(&network[strlen(network)], "\n"); break; + case 46: + sprintf(&idxjnl[strlen(idxjnl)], "\n"); + break; + case 47: + sprintf(&idxjnl[strlen(idxjnl)], "\n"); + break; + case 48: + sprintf(&idxjnl[strlen(idxjnl)], "\n"); + break; + case 49: + if (strlen(buf) == 0) { + strcpy(buf, "UTC"); + } + sprintf(&general[strlen(general)], "\n"); + break; + case 50: + sprintf(&network[strlen(network)], "\n"); + break; + case 51: + sprintf(&network[strlen(network)], "\n"); + break; + case 52: + sprintf(&access[strlen(access)], "\n"); + break; + case 53: + sprintf(&funambol[strlen(funambol)], "\n"); + break; + case 54: + sprintf(&funambol[strlen(funambol)], "\n"); + break; + case 55: + sprintf(&funambol[strlen(funambol)], "\n"); + break; + case 56: + sprintf(&funambol[strlen(funambol)], "\n"); + break; + case 57: + sprintf(&network[strlen(network)], "\n"); + break; + case 58: + sprintf(&access[strlen(access)], "\n"); + break; + case 59: + sprintf(&access[strlen(access)], "\n"); + break; + case 60: + sprintf(&funambol[strlen(funambol)], "\n"); + break; + case 61: + sprintf(&network[strlen(network)], "\n"); + break; + case 62: + sprintf(&network[strlen(network)], "\n"); + break; + case 63: + sprintf(&network[strlen(network)], "\n"); + break; + case 64: + sprintf(&pop3[strlen(pop3)], "\n"); + break; + case 65: + sprintf(&pop3[strlen(pop3)], "\n"); + break; + } + } serv_puts("GPEX site"); @@ -508,95 +754,311 @@ void display_siteconfig(void) sprintf(&tuning[strlen(tuning)], "
%s %s
"); + switch (i++) { + case 0: + sprintf(&general[strlen(general)], "
"); sprintf(&general[strlen(general)], _("Node name")); - sprintf(&general[strlen(general)], ""); - sprintf(&general[strlen(general)], "", buf); - sprintf(&general[strlen(general)], "
"); + sprintf(&general[strlen(general)], "", buf); + sprintf(&general[strlen(general)], "
"); + case 1: + sprintf(&general[strlen(general)], "
"); sprintf(&general[strlen(general)], _("Fully qualified domain name")); - sprintf(&general[strlen(general)], ""); - sprintf(&general[strlen(general)], "", buf); - sprintf(&general[strlen(general)], "
"); + sprintf(&general[strlen(general)], "", buf); + sprintf(&general[strlen(general)], "
"); + case 2: + sprintf(&general[strlen(general)], "
"); sprintf(&general[strlen(general)], _("Human-readable node name")); - sprintf(&general[strlen(general)], ""); - sprintf(&general[strlen(general)], "", buf); - sprintf(&general[strlen(general)], "
"); + sprintf(&general[strlen(general)], "", buf); + sprintf(&general[strlen(general)], "
"); + case 3: + sprintf(&general[strlen(general)], "
"); sprintf(&general[strlen(general)], _("Telephone number")); - sprintf(&general[strlen(general)], ""); - sprintf(&general[strlen(general)], "", buf); - sprintf(&general[strlen(general)], "
"); + sprintf(&general[strlen(general)], "", buf); + sprintf(&general[strlen(general)], "
"); + case 4: + sprintf(&access[strlen(access)], "
"); sprintf(&access[strlen(access)], _("Automatically grant room-aide status to users who create private rooms")); - sprintf(&access[strlen(access)], ""); - sprintf(&access[strlen(access)], "", - ((atoi(buf) != 0) ? "CHECKED" : "")); - sprintf(&access[strlen(access)], "
"); + sprintf(&access[strlen(access)], "", + ((atoi(buf) != 0) ? "checked" : "")); + sprintf(&access[strlen(access)], "
"); + case 5: + sprintf(&tuning[strlen(tuning)], "
"); sprintf(&tuning[strlen(tuning)], _("Server connection idle timeout (in seconds)")); - sprintf(&tuning[strlen(tuning)], ""); - sprintf(&tuning[strlen(tuning)], "", buf); - sprintf(&tuning[strlen(tuning)], "
"); + sprintf(&tuning[strlen(tuning)], "", buf); + sprintf(&tuning[strlen(tuning)], "
"); + case 6: + sprintf(&access[strlen(access)], "
"); sprintf(&access[strlen(access)], _("Initial access level for new users")); - sprintf(&access[strlen(access)], ""); - sprintf(&access[strlen(access)], ""); + sprintf(&access[strlen(access)], ""); - sprintf(&access[strlen(access)], "
"); + case 7: + sprintf(&access[strlen(access)], "
"); sprintf(&access[strlen(access)], _("Require registration for new users")); - sprintf(&access[strlen(access)], ""); - sprintf(&access[strlen(access)], "", - ((atoi(buf) != 0) ? "CHECKED" : "")); - sprintf(&access[strlen(access)], "
"); + sprintf(&access[strlen(access)], "", + ((atoi(buf) != 0) ? "checked" : "")); + sprintf(&access[strlen(access)], "
"); + case 8: + sprintf(&access[strlen(access)], "
"); sprintf(&access[strlen(access)], _("Quarantine messages from problem users")); - sprintf(&access[strlen(access)], ""); - sprintf(&access[strlen(access)], "", - ((atoi(buf) != 0) ? "CHECKED" : "")); - sprintf(&access[strlen(access)], "
"); + sprintf(&access[strlen(access)], "", + ((atoi(buf) != 0) ? "checked" : "")); + sprintf(&access[strlen(access)], "
"); + case 9: + sprintf(&access[strlen(access)], "
"); sprintf(&access[strlen(access)], _("Name of quarantine room")); - sprintf(&access[strlen(access)], ""); - sprintf(&access[strlen(access)], "", buf); - sprintf(&access[strlen(access)], "
"); + sprintf(&access[strlen(access)], "", buf); + sprintf(&access[strlen(access)], "
"); + case 10: + sprintf(&general[strlen(general)], "
"); sprintf(&general[strlen(general)], _("Paginator prompt (for text mode clients)")); - sprintf(&general[strlen(general)], ""); - sprintf(&general[strlen(general)], "", buf); - sprintf(&general[strlen(general)], "
"); + sprintf(&general[strlen(general)], "", buf); + sprintf(&general[strlen(general)], "
"); + case 11: + sprintf(&access[strlen(access)], "
"); sprintf(&access[strlen(access)], _("Restrict access to Internet mail")); - sprintf(&access[strlen(access)], ""); - sprintf(&access[strlen(access)], "", - ((atoi(buf) != 0) ? "CHECKED" : "")); - sprintf(&access[strlen(access)], "
"); + sprintf(&access[strlen(access)], "", + ((atoi(buf) != 0) ? "checked" : "")); + sprintf(&access[strlen(access)], "
"); + case 12: + sprintf(&general[strlen(general)], "
"); sprintf(&general[strlen(general)], _("Geographic location of this system")); - sprintf(&general[strlen(general)], ""); - sprintf(&general[strlen(general)], "", buf); - sprintf(&general[strlen(general)], "
"); + sprintf(&general[strlen(general)], "", buf); + sprintf(&general[strlen(general)], "
"); + case 13: + sprintf(&general[strlen(general)], "
"); sprintf(&general[strlen(general)], _("Name of system administrator")); - sprintf(&general[strlen(general)], ""); - sprintf(&general[strlen(general)], "", buf); - sprintf(&general[strlen(general)], "
"); + sprintf(&general[strlen(general)], "", buf); + sprintf(&general[strlen(general)], "
"); + case 14: + sprintf(&tuning[strlen(tuning)], "
"); sprintf(&tuning[strlen(tuning)], _("Maximum concurrent sessions (0 = no limit)")); - sprintf(&tuning[strlen(tuning)], ""); - sprintf(&tuning[strlen(tuning)], "", buf); - sprintf(&tuning[strlen(tuning)], "
"); + sprintf(&tuning[strlen(tuning)], "", buf); + sprintf(&tuning[strlen(tuning)], "
"); + case 16: + sprintf(&tuning[strlen(tuning)], "
"); sprintf(&tuning[strlen(tuning)], _("Default user purge time (days)")); - sprintf(&tuning[strlen(tuning)], ""); - sprintf(&tuning[strlen(tuning)], "", buf); - sprintf(&tuning[strlen(tuning)], "
"); + sprintf(&tuning[strlen(tuning)], "", buf); + sprintf(&tuning[strlen(tuning)], "
"); + case 17: + sprintf(&tuning[strlen(tuning)], "
"); sprintf(&tuning[strlen(tuning)], _("Default room purge time (days)")); - sprintf(&tuning[strlen(tuning)], ""); - sprintf(&tuning[strlen(tuning)], "", buf); - sprintf(&tuning[strlen(tuning)], "
"); + sprintf(&tuning[strlen(tuning)], "", buf); + sprintf(&tuning[strlen(tuning)], "
"); + case 18: + sprintf(&access[strlen(access)], "
"); sprintf(&access[strlen(access)], _("Name of room to log pages")); - sprintf(&access[strlen(access)], ""); - sprintf(&access[strlen(access)], "", buf); - sprintf(&access[strlen(access)], "
"); + sprintf(&access[strlen(access)], "", buf); + sprintf(&access[strlen(access)], "
"); + case 19: + sprintf(&access[strlen(access)], "
"); sprintf(&access[strlen(access)], _("Access level required to create rooms")); - sprintf(&access[strlen(access)], ""); - sprintf(&access[strlen(access)], ""); + sprintf(&access[strlen(access)], ""); - sprintf(&access[strlen(access)], "
"); + case 20: + sprintf(&tuning[strlen(tuning)], "
"); sprintf(&tuning[strlen(tuning)], _("Maximum message length")); - sprintf(&tuning[strlen(tuning)], ""); - sprintf(&tuning[strlen(tuning)], "", buf); - sprintf(&tuning[strlen(tuning)], "
"); + sprintf(&tuning[strlen(tuning)], "", buf); + sprintf(&tuning[strlen(tuning)], "
"); + case 21: + sprintf(&tuning[strlen(tuning)], "
"); sprintf(&tuning[strlen(tuning)], _("Minimum number of worker threads")); - sprintf(&tuning[strlen(tuning)], ""); - sprintf(&tuning[strlen(tuning)], "", buf); - sprintf(&tuning[strlen(tuning)], "
"); + sprintf(&tuning[strlen(tuning)], "", buf); + sprintf(&tuning[strlen(tuning)], "
"); + case 22: + sprintf(&tuning[strlen(tuning)], "
"); sprintf(&tuning[strlen(tuning)], _("Maximum number of worker threads")); - sprintf(&tuning[strlen(tuning)], ""); - sprintf(&tuning[strlen(tuning)], "", buf); - sprintf(&tuning[strlen(tuning)], "
"); + sprintf(&tuning[strlen(tuning)], "", buf); + sprintf(&tuning[strlen(tuning)], "
"); + sprintf(&pop3[strlen(pop3)], _("POP3 listener port (-1 to disable)")); + sprintf(&pop3[strlen(pop3)], ""); + sprintf(&pop3[strlen(pop3)], "", buf); + sprintf(&pop3[strlen(pop3)], "
"); - sprintf(&network[strlen(network)], _("POP3 listener port (-1 to disable)")); + sprintf(&network[strlen(network)], _("SMTP MTA port (-1 to disable)")); sprintf(&network[strlen(network)], ""); - sprintf(&network[strlen(network)], "", buf); + sprintf(&network[strlen(network)], "", buf); sprintf(&network[strlen(network)], "
"); - sprintf(&network[strlen(network)], _("SMTP MTA port (-1 to disable)")); + sprintf(&network[strlen(network)], _("Correct forged From: lines during authenticated SMTP")); sprintf(&network[strlen(network)], ""); - sprintf(&network[strlen(network)], "", buf); + sprintf(&network[strlen(network)], "", + ((atoi(buf) == 0) ? "CHECKED" : "")); sprintf(&network[strlen(network)], "
"); sprintf(&access[strlen(access)], _("Allow aides to zap (forget) rooms")); sprintf(&access[strlen(access)], ""); @@ -291,21 +354,21 @@ void display_siteconfig(void) ((atoi(buf) != 0) ? "CHECKED" : "")); sprintf(&access[strlen(access)], "
"); sprintf(&network[strlen(network)], _("IMAP listener port (-1 to disable)")); sprintf(&network[strlen(network)], ""); sprintf(&network[strlen(network)], "", buf); sprintf(&network[strlen(network)], "
"); sprintf(&network[strlen(network)], _("Network run frequency (in seconds)")); sprintf(&network[strlen(network)], ""); sprintf(&network[strlen(network)], "", buf); sprintf(&network[strlen(network)], "
"); sprintf(&access[strlen(access)], _("Disable self-service user account creation")); sprintf(&access[strlen(access)], ""); @@ -314,9 +377,6 @@ void display_siteconfig(void) sprintf(&access[strlen(access)], "
"); sprintf(&purger[strlen(purger)], _("Hour to run database auto-purge")); sprintf(&purger[strlen(purger)], ""); @@ -325,42 +385,42 @@ void display_siteconfig(void) sprintf(&purger[strlen(purger)], "\n", ((atoi(buf) == j) ? "SELECTED" : ""), j, - ((j == 0) ? 12 : ((j>12) ? j-12 : j)), - ((j >= 12) ? "pm" : "am") + (get_time_format_cached() == WC_TIMEFORMAT_24) ? j : ((j == 0) ? 12 : ((j>12) ? j-12 : j)), + (get_time_format_cached() == WC_TIMEFORMAT_24) ? "" : ((j >= 12) ? "pm" : "am") ); } sprintf(&purger[strlen(purger)], ""); sprintf(&purger[strlen(purger)], "
"); sprintf(&directory[strlen(directory)], _("Host name of LDAP server (blank to disable)")); sprintf(&directory[strlen(directory)], ""); sprintf(&directory[strlen(directory)], "", buf); sprintf(&directory[strlen(directory)], "
"); sprintf(&directory[strlen(directory)], _("Port number of LDAP server (blank to disable)")); sprintf(&directory[strlen(directory)], ""); sprintf(&directory[strlen(directory)], "", atoi(buf)); sprintf(&directory[strlen(directory)], "
"); sprintf(&directory[strlen(directory)], _("Base DN")); sprintf(&directory[strlen(directory)], ""); sprintf(&directory[strlen(directory)], "", buf); sprintf(&directory[strlen(directory)], "
"); sprintf(&directory[strlen(directory)], _("Bind DN")); sprintf(&directory[strlen(directory)], ""); sprintf(&directory[strlen(directory)], "", buf); sprintf(&directory[strlen(directory)], "
"); sprintf(&directory[strlen(directory)], _("Password for bind DN")); sprintf(&directory[strlen(directory)], ""); @@ -368,50 +428,50 @@ void display_siteconfig(void) buf); sprintf(&directory[strlen(directory)], "
"); sprintf(&network[strlen(network)], _("Server IP address (0.0.0.0 for 'any')")); sprintf(&network[strlen(network)], ""); sprintf(&network[strlen(network)], "", buf); sprintf(&network[strlen(network)], "
"); sprintf(&network[strlen(network)], _("SMTP MSA port (-1 to disable)")); sprintf(&network[strlen(network)], ""); sprintf(&network[strlen(network)], "", buf); sprintf(&network[strlen(network)], "
"); sprintf(&network[strlen(network)], _("IMAP over SSL port (-1 to disable)")); sprintf(&network[strlen(network)], ""); sprintf(&network[strlen(network)], "", buf); sprintf(&network[strlen(network)], "
"); - sprintf(&network[strlen(network)], _("POP3 over SSL port (-1 to disable)")); - sprintf(&network[strlen(network)], ""); - sprintf(&network[strlen(network)], "", buf); - sprintf(&network[strlen(network)], "
"); + sprintf(&pop3[strlen(pop3)], _("POP3 over SSL port (-1 to disable)")); + sprintf(&pop3[strlen(pop3)], ""); + sprintf(&pop3[strlen(pop3)], "", buf); + sprintf(&pop3[strlen(pop3)], "
"); sprintf(&network[strlen(network)], _("SMTP over SSL port (-1 to disable)")); sprintf(&network[strlen(network)], ""); sprintf(&network[strlen(network)], "", buf); sprintf(&network[strlen(network)], "
"); - sprintf(&general[strlen(general)], _("Enable full text index (warning: resource intensive)")); - sprintf(&general[strlen(general)], ""); - sprintf(&general[strlen(general)], "", + case 42: + sprintf(&idxjnl[strlen(idxjnl)], "
"); + sprintf(&idxjnl[strlen(idxjnl)], _("Enable full text index")); + sprintf(&idxjnl[strlen(idxjnl)], ""); + sprintf(&idxjnl[strlen(idxjnl)], "", ((atoi(buf) != 0) ? "CHECKED" : "")); - sprintf(&general[strlen(general)], "
"); sprintf(&tuning[strlen(tuning)], _("Automatically delete committed database logs")); sprintf(&tuning[strlen(tuning)], ""); @@ -419,7 +479,7 @@ void display_siteconfig(void) ((atoi(buf) != 0) ? "CHECKED" : "")); sprintf(&tuning[strlen(tuning)], "
"); sprintf(&network[strlen(network)], _("Instantly expunge deleted messages in IMAP")); sprintf(&network[strlen(network)], ""); @@ -427,7 +487,7 @@ void display_siteconfig(void) ((atoi(buf) != 0) ? "CHECKED" : "")); sprintf(&network[strlen(network)], "
"); sprintf(&network[strlen(network)], _("Allow unauthenticated SMTP clients to spoof this site's domains")); sprintf(&network[strlen(network)], ""); @@ -435,7 +495,193 @@ void display_siteconfig(void) ((atoi(buf) != 0) ? "CHECKED" : "")); sprintf(&network[strlen(network)], "
"); + sprintf(&idxjnl[strlen(idxjnl)], _("Perform journaling of email messages")); + sprintf(&idxjnl[strlen(idxjnl)], ""); + sprintf(&idxjnl[strlen(idxjnl)], "", + ((atoi(buf) != 0) ? "CHECKED" : "")); + sprintf(&idxjnl[strlen(idxjnl)], "
"); + sprintf(&idxjnl[strlen(idxjnl)], _("Perform journaling of non-email messages")); + sprintf(&idxjnl[strlen(idxjnl)], ""); + sprintf(&idxjnl[strlen(idxjnl)], "", + ((atoi(buf) != 0) ? "CHECKED" : "")); + sprintf(&idxjnl[strlen(idxjnl)], "
"); + sprintf(&idxjnl[strlen(idxjnl)], _("Email destination of journalized messages")); + sprintf(&idxjnl[strlen(idxjnl)], ""); + sprintf(&idxjnl[strlen(idxjnl)], "", buf); + sprintf(&idxjnl[strlen(idxjnl)], "
"); + sprintf(&general[strlen(general)], _("Default timezone for unzoned calendar items")); + sprintf(&general[strlen(general)], ""); + sprintf(&general[strlen(general)], ""); + sprintf(&general[strlen(general)], "
"); + sprintf(&network[strlen(network)], _("Postfix TCP Dictionary Port (-1 to disable)")); + sprintf(&network[strlen(network)], ""); + sprintf(&network[strlen(network)], "", buf); + sprintf(&network[strlen(network)], "
"); + sprintf(&network[strlen(network)], _("ManageSieve Port (-1 to disable)")); + sprintf(&network[strlen(network)], ""); + sprintf(&network[strlen(network)], "", buf); + sprintf(&network[strlen(network)], "
"); + sprintf(&access[strlen(access)], _("Enable host based authentication mode")); + sprintf(&access[strlen(access)], "%s", + buf, + ((atoi(buf) != 0) ? "Yes" : "No")); + sprintf(&access[strlen(access)], "
"); + sprintf(&funambol[strlen(funambol)], _("Funambol server host (blank to disable)")); + sprintf(&funambol[strlen(funambol)], ""); + sprintf(&funambol[strlen(funambol)], "", buf); + sprintf(&funambol[strlen(funambol)], "
"); + sprintf(&funambol[strlen(funambol)], _("Funambol server port ")); + sprintf(&funambol[strlen(funambol)], ""); + sprintf(&funambol[strlen(funambol)], "", buf); + sprintf(&funambol[strlen(funambol)], "
"); + sprintf(&funambol[strlen(funambol)], _("Funambol sync source")); + sprintf(&funambol[strlen(funambol)], ""); + sprintf(&funambol[strlen(funambol)], "", buf); + sprintf(&funambol[strlen(funambol)], "
"); + sprintf(&funambol[strlen(funambol)], _("Funambol auth details (user:pass)")); + sprintf(&funambol[strlen(funambol)], ""); + sprintf(&funambol[strlen(funambol)], "", buf); + sprintf(&funambol[strlen(funambol)], "
"); + sprintf(&network[strlen(network)], _("Perform RBL checks upon connect instead of after RCPT")); + sprintf(&network[strlen(network)], ""); + sprintf(&network[strlen(network)], "", + ((atoi(buf) != 0) ? "CHECKED" : "")); + sprintf(&network[strlen(network)], "
"); + sprintf(&access[strlen(access)], _("Master user name (blank to disable)")); + sprintf(&access[strlen(access)], ""); + sprintf(&access[strlen(access)], "", buf); + sprintf(&access[strlen(access)], "
"); + sprintf(&access[strlen(access)], _("Master user password")); + sprintf(&access[strlen(access)], ""); + sprintf(&access[strlen(access)], "", + buf); + sprintf(&directory[strlen(directory)], "
"); + sprintf(&funambol[strlen(funambol)], _("External pager tool (blank to disable)")); + sprintf(&funambol[strlen(funambol)], ""); + sprintf(&funambol[strlen(funambol)], "", buf); + sprintf(&funambol[strlen(funambol)], "
"); + sprintf(&network[strlen(network)], _("Keep original from headers in IMAP")); + sprintf(&network[strlen(network)], ""); + sprintf(&network[strlen(network)], "", + ((atoi(buf) != 0) ? "CHECKED" : "")); + sprintf(&network[strlen(network)], "
"); + sprintf(&network[strlen(network)], _("XMPP (Jabber) client to server port (-1 to disable)")); + sprintf(&network[strlen(network)], ""); + sprintf(&network[strlen(network)], "", buf); + sprintf(&network[strlen(network)], "
"); + sprintf(&network[strlen(network)], _("XMPP (Jabber) server to server port (-1 to disable)")); + sprintf(&network[strlen(network)], ""); + sprintf(&network[strlen(network)], "\n", buf); + sprintf(&network[strlen(network)], "
"); + sprintf(&pop3[strlen(pop3)], _("POP3 fetch frequency in seconds")); + sprintf(&pop3[strlen(pop3)], ""); + sprintf(&pop3[strlen(pop3)], "\n", buf); + sprintf(&pop3[strlen(pop3)], "
"); + sprintf(&pop3[strlen(pop3)], _("POP3 fastest fetch frequency in seconds")); + sprintf(&pop3[strlen(pop3)], ""); + sprintf(&pop3[strlen(pop3)], "\n", buf); + sprintf(&pop3[strlen(pop3)], "
"); sprintf(&directory[strlen(directory)], "
"); sprintf(&purger[strlen(purger)], "
"); + sprintf(&idxjnl[strlen(idxjnl)], ""); + sprintf(&funambol[strlen(funambol)], ""); + sprintf(&pop3[strlen(pop3)], ""); - tabbed_dialog(6, tabnames); + tabbed_dialog(9, tabnames); - begin_tab(0, 6); wprintf("%s", general); end_tab(0, 6); - begin_tab(1, 6); wprintf("%s", access); end_tab(1, 6); - begin_tab(2, 6); wprintf("%s", network); end_tab(2, 6); - begin_tab(3, 6); wprintf("%s", tuning); end_tab(3, 6); - begin_tab(4, 6); wprintf("%s", directory); end_tab(4, 6); - begin_tab(5, 6); wprintf("%s", purger); end_tab(5, 6); + begin_tab(0, 9); StrBufAppendBufPlain(WCC->WBuf, general, strlen(general), 0); end_tab(0, 9); + begin_tab(1, 9); StrBufAppendBufPlain(WCC->WBuf, access, strlen(access), 0); end_tab(1, 9); + begin_tab(2, 9); StrBufAppendBufPlain(WCC->WBuf, network, strlen(network), 0); end_tab(2, 9); + begin_tab(3, 9); StrBufAppendBufPlain(WCC->WBuf, tuning, strlen(tuning), 0); end_tab(3, 9); + begin_tab(4, 9); StrBufAppendBufPlain(WCC->WBuf, directory, strlen(directory), 0); end_tab(4, 9); + begin_tab(5, 9); StrBufAppendBufPlain(WCC->WBuf, purger, strlen(purger), 0); end_tab(5, 9); + begin_tab(6, 9); StrBufAppendBufPlain(WCC->WBuf, idxjnl, strlen(idxjnl), 0); end_tab(6, 9); + begin_tab(7, 9); StrBufAppendBufPlain(WCC->WBuf, funambol, strlen(funambol), 0); end_tab(7, 9); + begin_tab(8, 9); StrBufAppendBufPlain(WCC->WBuf, pop3, strlen(pop3), 0); end_tab(8, 9); - wprintf("
"); + begin_tab(9, 9); wprintf("", _("Save changes")); wprintf(" "); wprintf("\n", _("Cancel")); - wprintf("
\n"); - wprintf("
\n"); + end_tab(9, 9); + + wprintf("\n"); + wprintf("\n"); wDumpContent(1); } +typedef struct _CfgMapping { + int type; + const char *Key; + long len; +}CfgMapping; + +#define CFG_STR 1 +#define CFG_YES 2 +#define CFG_NO 3 + +CfgMapping ServerConfig[] = { + {CFG_STR, HKEY("c_nodename")}, + {CFG_STR, HKEY("c_fqdn")}, + {CFG_STR, HKEY("c_humannode")}, + {CFG_STR, HKEY("c_phonenum")}, + {CFG_YES, HKEY("c_creataide")}, + {CFG_STR, HKEY("c_sleeping")}, + {CFG_STR, HKEY("c_initax")}, + {CFG_YES, HKEY("c_regiscall")}, + {CFG_YES, HKEY("c_twitdetect")}, + {CFG_STR, HKEY("c_twitroom")}, + {CFG_STR, HKEY("c_moreprompt")}, + {CFG_YES, HKEY("c_restrict")}, + {CFG_STR, HKEY("c_bbs_city")}, + {CFG_STR, HKEY("c_sysadm")}, + {CFG_STR, HKEY("c_maxsessions")}, + {CFG_STR, HKEY("reserved1")}, + {CFG_STR, HKEY("c_userpurge")}, + {CFG_STR, HKEY("c_roompurge")}, + {CFG_STR, HKEY("c_logpages")}, + {CFG_STR, HKEY("c_createax")}, + {CFG_STR, HKEY("c_maxmsglen")}, + {CFG_STR, HKEY("c_min_workers")}, + {CFG_STR, HKEY("c_max_workers")}, + {CFG_STR, HKEY("c_pop3_port")}, + {CFG_STR, HKEY("c_smtp_port")}, + {CFG_NO , HKEY("c_rfc822_strict_from")}, /* note: reverse bool */ + {CFG_YES, HKEY("c_aide_zap")}, + {CFG_STR, HKEY("c_imap_port")}, + {CFG_STR, HKEY("c_net_freq")}, + {CFG_YES, HKEY("c_disable_newu")}, + {CFG_STR, HKEY("reserved2")}, + {CFG_STR, HKEY("c_purge_hour")}, + {CFG_STR, HKEY("c_ldap_host")}, + {CFG_STR, HKEY("c_ldap_port")}, + {CFG_STR, HKEY("c_ldap_base_dn")}, + {CFG_STR, HKEY("c_ldap_bind_dn")}, + {CFG_STR, HKEY("c_ldap_bind_pw")}, + {CFG_STR, HKEY("c_ip_addr")}, + {CFG_STR, HKEY("c_msa_port")}, + {CFG_STR, HKEY("c_imaps_port")}, + {CFG_STR, HKEY("c_pop3s_port")}, + {CFG_STR, HKEY("c_smtps_port")}, + {CFG_YES, HKEY("c_enable_fulltext")}, + {CFG_YES, HKEY("c_auto_cull")}, + {CFG_YES, HKEY("c_instant_expunge")}, + {CFG_YES, HKEY("c_allow_spoofing")}, + {CFG_YES, HKEY("c_journal_email")}, + {CFG_YES, HKEY("c_journal_pubmsgs")}, + {CFG_STR, HKEY("c_journal_dest")}, + {CFG_STR, HKEY("c_default_cal_zone")}, + {CFG_STR, HKEY("c_pftcpdict_port")}, + {CFG_STR, HKEY("c_mgesve_port")}, + {CFG_STR, HKEY("c_auth_mode")}, + {CFG_STR, HKEY("c_funambol_host")}, + {CFG_STR, HKEY("c_funambol_port")}, + {CFG_STR, HKEY("c_funambol_source")}, + {CFG_STR, HKEY("c_funambol_auth")}, + {CFG_YES, HKEY("c_rbl_at_greeting")}, + {CFG_STR, HKEY("c_master_user")}, + {CFG_STR, HKEY("c_master_pass")}, + {CFG_STR, HKEY("c_pager_program")}, + {CFG_YES, HKEY("c_imap_keep_from")}, + {CFG_STR, HKEY("c_xmpp_c2s_port")}, + {CFG_STR, HKEY("c_xmpp_s2s_port")}, + {CFG_STR, HKEY("c_pop3_fetch")}, + {CFG_STR, HKEY("c_pop3_fastest")} +}; + +/* + * \brief display all configuration items + */ +void load_siteconfig(void) +{ + struct wcsession *WCC = WC; + StrBuf *Buf, *Token; + HashList *Cfg; + char buf[SIZ]; + long len; + int i; + + if (WCC->ServCfg == NULL) + WCC->ServCfg = NewHash(1, NULL); + Cfg = WCC->ServCfg; + + serv_printf("CONF get"); + serv_getln(buf, sizeof buf); + i = 0; + Buf = NewStrBuf(); + while ((sizeof(ServerConfig) / sizeof(CfgMapping)) && + (len = StrBuf_ServGetln(Buf), + strcmp(ChrPtr(Buf), "000")) && + (i <= sizeof(ServerConfig))) + { + Put(Cfg, + ServerConfig[i].Key, + ServerConfig[i].len, + Buf, + HFreeStrBuf); + i++; + if (i <= sizeof(ServerConfig) / sizeof(CfgMapping)) + Buf = NewStrBuf(); + else + Buf = NULL; + } + FreeStrBuf(&Buf); + + serv_puts("GPEX site"); + Buf = NewStrBuf(); + Token = NULL; + StrBuf_ServGetln(Buf); + if (ChrPtr(Buf)[0] == '2') { + StrBufCutLeft(Buf, 4); + + Token = NewStrBuf(); + StrBufExtract_token(Token, Buf, 0, '|'); + Put(Cfg, HKEY("sitepolicy"), Token, HFreeStrBuf); + + Token = NewStrBuf(); + StrBufExtract_token(Token, Buf, 1, '|'); + Put(Cfg, HKEY("sitevalue"), Token, HFreeStrBuf); + } + + serv_puts("GPEX mailboxes"); + serv_getln(buf, sizeof buf); + if (buf[0] == '2') { + StrBufCutLeft(Buf, 4); + + Token = NewStrBuf(); + StrBufExtract_token(Token, Buf, 0, '|'); + Put(Cfg, HKEY("mboxpolicy"), Token, HFreeStrBuf); + + Token = NewStrBuf(); + StrBufExtract_token(Token, Buf, 1, '|'); + Put(Cfg, HKEY("mboxvalue"), Token, HFreeStrBuf); + } +} + + +/** + * parse siteconfig changes + */ void siteconfig(void) { + struct wcsession *WCC = WC; + int i; char buf[256]; if (strlen(bstr("ok_button")) == 0) { - display_siteconfig(); + display_aide_menu(); return; } serv_printf("CONF set"); serv_getln(buf, sizeof buf); if (buf[0] != '4') { - safestrncpy(WC->ImportantMessage, &buf[4], sizeof WC->ImportantMessage); - display_siteconfig(); + safestrncpy(WCC->ImportantMessage, &buf[4], sizeof WCC->ImportantMessage); + display_aide_menu(); return; } - serv_printf("%s", bstr("c_nodename")); - serv_printf("%s", bstr("c_fqdn")); - serv_printf("%s", bstr("c_humannode")); - serv_printf("%s", bstr("c_phonenum")); - serv_printf("%s", ((!strcasecmp(bstr("c_creataide"), "yes") ? "1" : "0"))); - serv_printf("%s", bstr("c_sleeping")); - serv_printf("%s", bstr("c_initax")); - serv_printf("%s", ((!strcasecmp(bstr("c_regiscall"), "yes") ? "1" : "0"))); - serv_printf("%s", ((!strcasecmp(bstr("c_twitdetect"), "yes") ? "1" : "0"))); - serv_printf("%s", bstr("c_twitroom")); - serv_printf("%s", bstr("c_moreprompt")); - serv_printf("%s", ((!strcasecmp(bstr("c_restrict"), "yes") ? "1" : "0"))); - 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("%s", bstr("c_userpurge")); - serv_printf("%s", bstr("c_roompurge")); - serv_printf("%s", bstr("c_logpages")); - serv_printf("%s", bstr("c_createax")); - serv_printf("%s", bstr("c_maxmsglen")); - serv_printf("%s", bstr("c_min_workers")); - 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_aide_zap"), "yes") ? "1" : "0"))); - 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"); - 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("%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("000"); - - serv_printf("SPEX site|%d|%d", atoi(bstr("sitepolicy")), atoi(bstr("sitevalue"))); + + for (i=0; i < (sizeof(ServerConfig) / sizeof(CfgMapping)); i ++) + { + switch (ServerConfig[i].type) { + default: + case CFG_STR: + serv_putbuf(SBstr(ServerConfig[i].Key, ServerConfig[i].len)); + break; + case CFG_YES: + serv_puts(YesBstr(ServerConfig[i].Key, + ServerConfig[i].len) ? + "1" : "0"); + break; + case CFG_NO: + serv_puts(YesBstr(ServerConfig[i].Key, + ServerConfig[i].len) ? + "0" : "1"); + break; + } + } + serv_puts("000"); + + serv_printf("SPEX site|%d|%d", ibstr("sitepolicy"), ibstr("sitevalue")); serv_getln(buf, sizeof buf); - serv_printf("SPEX mailboxes|%d|%d", atoi(bstr("mboxpolicy")), atoi(bstr("mboxvalue"))); + serv_printf("SPEX mailboxes|%d|%d", ibstr("mboxpolicy"), ibstr("mboxvalue")); serv_getln(buf, sizeof buf); - safestrncpy(WC->ImportantMessage, _("Your system configuration has been updated."), - sizeof WC->ImportantMessage); - display_siteconfig(); + strcpy(serv_info.serv_default_cal_zone, bstr("c_default_cal_zone")); + + safestrncpy(WCC->ImportantMessage, _("Your system configuration has been updated."), + sizeof WCC->ImportantMessage); + DeleteHash(&WCC->ServCfg); + display_aide_menu(); +} + +void tmplput_servcfg(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +{ + struct wcsession *WCC = WC; + void *vBuf; + StrBuf *Buf; + + if (WCC->is_aide) { + if (WCC->ServCfg == NULL) + load_siteconfig(); + GetHash(WCC->ServCfg, + Tokens->Params[0]->Start, + Tokens->Params[0]->len, + &vBuf); + Buf = (StrBuf*) vBuf; + StrBufAppendBuf(Target, Buf, 0); + } +} + +int ConditionalServCfg(WCTemplateToken *Tokens, void *Context, int ContextType) +{ + struct wcsession *WCC = WC; + void *vBuf; + StrBuf *Buf; + + if (WCC->is_aide) { + if (WCC->ServCfg == NULL) + load_siteconfig(); + GetHash(WCC->ServCfg, + Tokens->Params[2]->Start, + Tokens->Params[2]->len, + &vBuf); + if (vBuf == NULL) return 0; + Buf = (StrBuf*) vBuf; + if (Tokens->nParameters == 3) { + return 1; + } + else if (Tokens->Params[3]->Type == TYPE_STR) + return (strcmp(Tokens->Params[3]->Start, ChrPtr(Buf)) == 0); + else return (StrTol(Buf) == Tokens->Params[3]->lvalue); + } + else return 0; +} + +int ConditionalServCfgSubst(WCTemplateToken *Tokens, void *Context, int ContextType) +{ + struct wcsession *WCC = WC; + void *vBuf; + StrBuf *Buf; + + if (WCC->is_aide) { + if (WCC->ServCfg == NULL) + load_siteconfig(); + GetHash(WCC->ServCfg, + Tokens->Params[2]->Start, + Tokens->Params[2]->len, + &vBuf); + if (vBuf == NULL) return 0; + Buf = (StrBuf*) vBuf; + + return CompareSubstToStrBuf(Buf, Tokens->Params[3]); + } + else return 0; +} + +void +InitModule_SITECONFIG +(void) +{ + WebcitAddUrlHandler(HKEY("display_siteconfig"), display_siteconfig, CTX_NONE); + WebcitAddUrlHandler(HKEY("siteconfig"), siteconfig, CTX_NONE); + + RegisterNamespace("SERV:CFG", 1, 1, tmplput_servcfg, CTX_SITECFG); + RegisterConditional(HKEY("COND:SERVCFG"), 3, ConditionalServCfg, CTX_NONE); + RegisterConditional(HKEY("COND:SERVCFG:SUBST"), 4, ConditionalServCfgSubst, CTX_NONE); } +/*@}*/