X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fsiteconfig.c;h=61593d39174c71c99c8bfc514441120a6455ff36;hb=1166cb557e4c5ca0dcee699a38da9c62ccbee393;hp=46a65c2bd6a99d5a251c260e7ae0e8585ff569e0;hpb=5be595f9e533d6638143c5c35339404de95b2e80;p=citadel.git diff --git a/webcit/siteconfig.c b/webcit/siteconfig.c index 46a65c2bd..61593d391 100644 --- a/webcit/siteconfig.c +++ b/webcit/siteconfig.c @@ -1,547 +1,681 @@ /* - * Administrative screen for site-wide configuration - * + * $Id$ */ +/** + * \defgroup AdminConfig Administrative screen for site-wide configuration + * \ingroup CitadelConfig + */ +/*@{*/ - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include #include "webcit.h" +#include "webserver.h" - - - - +/** + * \brief display all configuration items + */ void display_siteconfig(void) { char buf[SIZ]; - char *whichmenu; int i, j; - output_headers(3); - - whichmenu = bstr("whichmenu"); - - svprintf("BOXTITLE", WCS_STRING, "Site configuration"); - do_template("beginbox"); + 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; - if (!strcmp(whichmenu, "")) { - wprintf("\n"); - - wprintf("\n" - ); - - wprintf("\n" - ); - - wprintf("\n" - ); - - wprintf("\n" - ); + output_headers(1, 1, 2, 0, 0, 0); + wprintf("
\n" + "
" - "" - "" - "\" \"" - "" - "" - "General
" - "General site configuration items" - "
" - "" - "" - "\" \"" - "" - "" - "Access
" - "Access controls and site policy settings" - "
" - "" - "" - "\" \"" - "" - "" - "Network
" - "Network services" - "
" - "" - "" - "\" \"" - "" - "" - "Tuning
" - "Advanced server fine-tuning controls" - "
" + ""); + wprintf(_("Site configuration")); + wprintf("" + "
\n" + "\n
\n" + ); - wprintf("" - "" - "" - "\" \"" - "" - "" - "Directory
" - "Configure the LDAP connector for Citadel" - "
\n" - ); - - wprintf(""); - - do_template("endbox"); + serv_printf("CONF get"); + serv_getln(buf, sizeof buf); + if (buf[0] != '1') { + wprintf("
"); + wprintf(""); + wprintf(_("Error")); + wprintf("\n"); + wprintf("

\n"); + wprintf("%s
\n", &buf[4]); wDumpContent(1); return; } - if (!strcasecmp(whichmenu, "general")) { - wprintf("

General site configuration items

\n"); - } + wprintf("
" + "\n"); + + sprintf(&purger[strlen(purger)], "\n"); + + sprintf(&purger[strlen(purger)], "\n"); + + sprintf(&purger[strlen(purger)], "\n"); + + sprintf(&purger[strlen(purger)], "\n"); + + + sprintf(&general[strlen(general)], "
"); - if (!strcasecmp(whichmenu, "access")) { - wprintf("

Access controls and site policy settings

\n"); - } + char *tabnames[] = { + _("General"), + _("Access"), + _("Network"), + _("Tuning"), + _("Directory"), + _("Auto-purger"), + _("Indexing/Journaling"), + _("Push Email") + }; - if (!strcasecmp(whichmenu, "network")) { - wprintf("

Network services

\n"); - } + sprintf(general, "

%s

", + _("General site configuration items") + ); - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("

Advanced server fine-tuning controls

\n"); - } + sprintf(access, "

%s

", + _("Access controls and site policy settings") + ); - if (!strcasecmp(whichmenu, "ldap")) { - wprintf("

Citadel LDAP connector configuration

\n"); - } + sprintf(network, "

%s

%s

", + _("Network services"), + _("Changes made on this screen will not take effect " + "until you restart the Citadel server.") + ); - serv_printf("CONF get"); - serv_gets(buf); - if (buf[0] != '1') { - wprintf("
"); - wprintf("Error\n"); - wprintf("

\n"); - wprintf("%s
\n", &buf[4]); - do_template("endbox"); - wDumpContent(1); - return; - } + sprintf(tuning, "

%s

", + _("Advanced server fine-tuning controls") + ); + sprintf(directory, "

%s

%s

", + _("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.") + ) + ); - wprintf("\n"); - wprintf("
\n"); + sprintf(purger, "

%s

%s

", + _("Configure automatic expiry of old messages"), + _("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") + ); + + wprintf("\n"); + wprintf("\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)], "\n"); + break; case 1: - if (!strcasecmp(whichmenu, "general")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&general[strlen(general)], "\n"); break; case 2: - if (!strcasecmp(whichmenu, "general")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&general[strlen(general)], "\n"); break; case 3: - if (!strcasecmp(whichmenu, "general")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&general[strlen(general)], "\n"); break; case 4: - if (!strcasecmp(whichmenu, "general")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&access[strlen(access)], "\n"); break; case 5: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&tuning[strlen(tuning)], "\n"); break; case 6: - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&access[strlen(access)], "\n"); break; case 7: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&access[strlen(access)], "\n"); break; case 8: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&access[strlen(access)], "\n"); break; case 9: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&access[strlen(access)], "\n"); break; case 10: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&general[strlen(general)], "\n"); break; case 11: - if (!strcasecmp(whichmenu, "general")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&access[strlen(access)], "\n"); break; case 12: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&general[strlen(general)], "\n"); break; case 13: - if (!strcasecmp(whichmenu, "general")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&general[strlen(general)], "\n"); break; case 14: - if (!strcasecmp(whichmenu, "general")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 15: - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&tuning[strlen(tuning)], "\n"); + break; + case 16: + sprintf(&tuning[strlen(tuning)], "\n"); break; case 17: - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&tuning[strlen(tuning)], "\n"); break; case 18: - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&access[strlen(access)], "\n"); break; case 19: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&access[strlen(access)], "\n"); break; case 20: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&tuning[strlen(tuning)], "\n"); break; case 21: - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&tuning[strlen(tuning)], "\n"); break; case 22: - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&tuning[strlen(tuning)], "\n"); break; case 23: - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&network[strlen(network)], "\n"); break; case 24: - if (!strcasecmp(whichmenu, "network")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 25: - if (!strcasecmp(whichmenu, "network")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&network[strlen(network)], "\n"); + break; + case 25: /* note: reverse bool */ + sprintf(&network[strlen(network)], "\n"); + break; + case 26: + sprintf(&access[strlen(access)], "\n"); break; case 27: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&network[strlen(network)], "\n"); break; case 28: - if (!strcasecmp(whichmenu, "network")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&network[strlen(network)], "\n"); break; case 29: - if (!strcasecmp(whichmenu, "network")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 30: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&access[strlen(access)], "\n"); break; case 31: - /* placeholder -- there is no option 31 */ + sprintf(&purger[strlen(purger)], "\n"); break; case 32: - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&directory[strlen(directory)], "\n"); break; case 33: - if ( (serv_info.serv_supports_ldap) && (!strcasecmp(whichmenu, "ldap")) ) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&directory[strlen(directory)], "\n"); break; case 34: - if ( (serv_info.serv_supports_ldap) && (!strcasecmp(whichmenu, "ldap")) ) { - wprintf("\n"); - } - else { - wprintf("", atoi(buf)); - } + sprintf(&directory[strlen(directory)], "\n"); break; case 35: - if ( (serv_info.serv_supports_ldap) && (!strcasecmp(whichmenu, "ldap")) ) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&directory[strlen(directory)], "\n"); break; case 36: - if ( (serv_info.serv_supports_ldap) && (!strcasecmp(whichmenu, "ldap")) ) { - wprintf("\n"); - } - else { - wprintf("", buf); - } + sprintf(&directory[strlen(directory)], "\n"); break; case 37: - if ( (serv_info.serv_supports_ldap) && (!strcasecmp(whichmenu, "ldap")) ) { - wprintf("\n"); - } - else { - wprintf("", buf); + sprintf(&network[strlen(network)], "\n"); + break; + case 38: + sprintf(&network[strlen(network)], "\n"); + break; + case 39: + sprintf(&network[strlen(network)], "\n"); + break; + case 40: + sprintf(&network[strlen(network)], "\n"); + break; + case 41: + sprintf(&network[strlen(network)], "\n"); + break; + case 42: + sprintf(&idxjnl[strlen(idxjnl)], "\n"); + break; + case 43: + sprintf(&tuning[strlen(tuning)], "\n"); + break; + case 44: + sprintf(&network[strlen(network)], "\n"); + break; + 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"); + } +#ifdef WEBCIT_WITH_CALENDAR_SERVICE + sprintf(&general[strlen(general)], "\n"); +#else /* WEBCIT_WITH_CALENDAR_SERVICE */ + wprintf("\n", buf); +#endif /* WEBCIT_WITH_CALENDAR_SERVICE */ + 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; } + + } + + serv_puts("GPEX site"); + 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_getln(buf, sizeof buf); + if (buf[0] == '2') { + mboxpolicy = extract_int(&buf[4], 0); + mboxvalue = extract_int(&buf[4], 1); } - wprintf("
"); + sprintf(&general[strlen(general)], _("Node name")); + sprintf(&general[strlen(general)], ""); + sprintf(&general[strlen(general)], "", buf); + sprintf(&general[strlen(general)], "
Node name"); - wprintf("", buf); - wprintf("
"); + sprintf(&general[strlen(general)], _("Fully qualified domain name")); + sprintf(&general[strlen(general)], ""); + sprintf(&general[strlen(general)], "", buf); + sprintf(&general[strlen(general)], "
Fully qualified domain name"); - wprintf("", buf); - wprintf("
"); + sprintf(&general[strlen(general)], _("Human-readable node name")); + sprintf(&general[strlen(general)], ""); + sprintf(&general[strlen(general)], "", buf); + sprintf(&general[strlen(general)], "
Human-readable node name"); - wprintf("", buf); - wprintf("
"); + sprintf(&general[strlen(general)], _("Telephone number")); + sprintf(&general[strlen(general)], ""); + sprintf(&general[strlen(general)], "", buf); + sprintf(&general[strlen(general)], "
Landline telephone number"); - wprintf("", buf); - wprintf("
"); + 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)], "
Automatically grant room-aide status to users who create private rooms"); - wprintf("", ((atoi(buf) != 0) ? "CHECKED" : "")); - wprintf("
"); + sprintf(&tuning[strlen(tuning)], _("Server connection idle timeout (in seconds)")); + sprintf(&tuning[strlen(tuning)], ""); + sprintf(&tuning[strlen(tuning)], "", buf); + sprintf(&tuning[strlen(tuning)], "
Server connection idle timeout (in seconds)"); - wprintf("", buf); - wprintf("
"); + sprintf(&access[strlen(access)], _("Initial access level for new users")); + sprintf(&access[strlen(access)], ""); + sprintf(&access[strlen(access)], ""); + sprintf(&access[strlen(access)], "
Initial access level for new users"); - wprintf(""); - wprintf("
"); + 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)], "
Require registration for new users"); - wprintf("", ((atoi(buf) != 0) ? "CHECKED" : "")); - wprintf("
"); + 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)], "
Quarantine messages from problem users"); - wprintf("", ((atoi(buf) != 0) ? "CHECKED" : "")); - wprintf("
"); + sprintf(&access[strlen(access)], _("Name of quarantine room")); + sprintf(&access[strlen(access)], ""); + sprintf(&access[strlen(access)], "", buf); + sprintf(&access[strlen(access)], "
Name of quarantine room"); - wprintf("", buf); - wprintf("
"); + sprintf(&general[strlen(general)], _("Paginator prompt (for text mode clients)")); + sprintf(&general[strlen(general)], ""); + sprintf(&general[strlen(general)], "", buf); + sprintf(&general[strlen(general)], "
Paginator prompt (for text mode clients)"); - wprintf("", buf); - wprintf("
"); + 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)], "
Restrict access to Internet mail"); - wprintf("", ((atoi(buf) != 0) ? "CHECKED" : "")); - wprintf("
"); + sprintf(&general[strlen(general)], _("Geographic location of this system")); + sprintf(&general[strlen(general)], ""); + sprintf(&general[strlen(general)], "", buf); + sprintf(&general[strlen(general)], "
Geographic location of this system"); - wprintf("", buf); - wprintf("
"); + sprintf(&general[strlen(general)], _("Name of system administrator")); + sprintf(&general[strlen(general)], ""); + sprintf(&general[strlen(general)], "", buf); + sprintf(&general[strlen(general)], "
Name of system administrator"); - wprintf("", buf); - wprintf("
Maximum concurrent sessions"); - wprintf("", buf); - wprintf("
"); + 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)], _("Default user purge time (days)")); + sprintf(&tuning[strlen(tuning)], ""); + sprintf(&tuning[strlen(tuning)], "", buf); + sprintf(&tuning[strlen(tuning)], "
Default user purge time (days)"); - wprintf("", buf); - wprintf("
"); + sprintf(&tuning[strlen(tuning)], _("Default room purge time (days)")); + sprintf(&tuning[strlen(tuning)], ""); + sprintf(&tuning[strlen(tuning)], "", buf); + sprintf(&tuning[strlen(tuning)], "
Default room purge time (days)"); - wprintf("", buf); - wprintf("
"); + sprintf(&access[strlen(access)], _("Name of room to log pages")); + sprintf(&access[strlen(access)], ""); + sprintf(&access[strlen(access)], "", buf); + sprintf(&access[strlen(access)], "
Name of room to log pages"); - wprintf("", buf); - wprintf("
"); + sprintf(&access[strlen(access)], _("Access level required to create rooms")); + sprintf(&access[strlen(access)], ""); + sprintf(&access[strlen(access)], ""); + sprintf(&access[strlen(access)], "
Access level required to create rooms"); - wprintf(""); - wprintf("
"); + sprintf(&tuning[strlen(tuning)], _("Maximum message length")); + sprintf(&tuning[strlen(tuning)], ""); + sprintf(&tuning[strlen(tuning)], "", buf); + sprintf(&tuning[strlen(tuning)], "
Maximum message length"); - wprintf("", buf); - wprintf("
"); + sprintf(&tuning[strlen(tuning)], _("Minimum number of worker threads")); + sprintf(&tuning[strlen(tuning)], ""); + sprintf(&tuning[strlen(tuning)], "", buf); + sprintf(&tuning[strlen(tuning)], "
Minimum number of worker threads"); - wprintf("", buf); - wprintf("
"); + sprintf(&tuning[strlen(tuning)], _("Maximum number of worker threads")); + sprintf(&tuning[strlen(tuning)], ""); + sprintf(&tuning[strlen(tuning)], "", buf); + sprintf(&tuning[strlen(tuning)], "
Maximum number of worker threads"); - wprintf("", buf); - wprintf("
"); + sprintf(&network[strlen(network)], _("POP3 listener port (-1 to disable)")); + sprintf(&network[strlen(network)], ""); + sprintf(&network[strlen(network)], "", buf); + sprintf(&network[strlen(network)], "
POP3 listener port (-1 to disable)"); - wprintf("", buf); - wprintf("
SMTP listener port (-1 to disable)"); - wprintf("", buf); - wprintf("
"); + sprintf(&network[strlen(network)], _("SMTP MTA port (-1 to disable)")); + sprintf(&network[strlen(network)], ""); + sprintf(&network[strlen(network)], "", buf); + sprintf(&network[strlen(network)], "
"); + sprintf(&network[strlen(network)], _("Correct forged From: lines during authenticated SMTP")); + sprintf(&network[strlen(network)], ""); + 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)], ""); + sprintf(&access[strlen(access)], "", + ((atoi(buf) != 0) ? "CHECKED" : "")); + sprintf(&access[strlen(access)], "
Allow aides to zap (forget) rooms"); - wprintf("", ((atoi(buf) != 0) ? "CHECKED" : "")); - wprintf("
"); + sprintf(&network[strlen(network)], _("IMAP listener port (-1 to disable)")); + sprintf(&network[strlen(network)], ""); + sprintf(&network[strlen(network)], "", buf); + sprintf(&network[strlen(network)], "
IMAP listener port (-1 to disable)"); - wprintf("", buf); - wprintf("
"); + sprintf(&network[strlen(network)], _("Network run frequency (in seconds)")); + sprintf(&network[strlen(network)], ""); + sprintf(&network[strlen(network)], "", buf); + sprintf(&network[strlen(network)], "
Network run frequency (in seconds)"); - wprintf("", buf); - wprintf("
Disable self-service user account creation"); - wprintf("", ((atoi(buf) != 0) ? "CHECKED" : "")); - wprintf("
"); + sprintf(&access[strlen(access)], _("Disable self-service user account creation")); + sprintf(&access[strlen(access)], ""); + sprintf(&access[strlen(access)], "", + ((atoi(buf) != 0) ? "CHECKED" : "")); + sprintf(&access[strlen(access)], "
"); + sprintf(&purger[strlen(purger)], _("Hour to run database auto-purge")); + sprintf(&purger[strlen(purger)], ""); + sprintf(&purger[strlen(purger)], ""); + sprintf(&purger[strlen(purger)], "
Hour to run database auto-purge"); - wprintf(""); - wprintf("
"); + 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)], "
Host name of LDAP server (blank to disable)"); - wprintf("", buf); - wprintf("
"); + 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)], "
Port number of LDAP server (blank to disable)"); - wprintf("", atoi(buf)); - wprintf("
"); + sprintf(&directory[strlen(directory)], _("Base DN")); + sprintf(&directory[strlen(directory)], ""); + sprintf(&directory[strlen(directory)], "", buf); + sprintf(&directory[strlen(directory)], "
Base DN"); - wprintf("", buf); - wprintf("
"); + sprintf(&directory[strlen(directory)], _("Bind DN")); + sprintf(&directory[strlen(directory)], ""); + sprintf(&directory[strlen(directory)], "", buf); + sprintf(&directory[strlen(directory)], "
Bind DN"); - wprintf("", buf); - wprintf("
"); + sprintf(&directory[strlen(directory)], _("Password for bind DN")); + sprintf(&directory[strlen(directory)], ""); + sprintf(&directory[strlen(directory)], "", + buf); + sprintf(&directory[strlen(directory)], "
Password for bind DN"); - wprintf("", buf); - wprintf("
"); + 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(&network[strlen(network)], _("SMTP over SSL port (-1 to disable)")); + sprintf(&network[strlen(network)], ""); + sprintf(&network[strlen(network)], "", buf); + sprintf(&network[strlen(network)], "
"); + sprintf(&idxjnl[strlen(idxjnl)], _("Enable full text index")); + sprintf(&idxjnl[strlen(idxjnl)], ""); + sprintf(&idxjnl[strlen(idxjnl)], "", + ((atoi(buf) != 0) ? "CHECKED" : "")); + sprintf(&idxjnl[strlen(idxjnl)], "
"); + sprintf(&tuning[strlen(tuning)], _("Automatically delete committed database logs")); + sprintf(&tuning[strlen(tuning)], ""); + sprintf(&tuning[strlen(tuning)], "", + ((atoi(buf) != 0) ? "CHECKED" : "")); + sprintf(&tuning[strlen(tuning)], "
"); + sprintf(&network[strlen(network)], _("Instantly expunge deleted messages in IMAP")); + sprintf(&network[strlen(network)], ""); + sprintf(&network[strlen(network)], "", + ((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)], ""); + sprintf(&network[strlen(network)], "", + ((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 in Base64)")); + sprintf(&funambol[strlen(funambol)], ""); + sprintf(&funambol[strlen(funambol)], "", buf); + sprintf(&funambol[strlen(funambol)], "
"); - wprintf(""); - wprintf("\n"); - wprintf("
\n"); - do_template("endbox"); + + sprintf(&purger[strlen(purger)], "

"); + sprintf(&purger[strlen(purger)], _("Default message expire policy for public rooms")); + sprintf(&purger[strlen(purger)], ""); + sprintf(&purger[strlen(purger)], "", + ((sitepolicy == 1) ? "CHECKED" : "") ); + sprintf(&purger[strlen(purger)], _("Never automatically expire messages")); + sprintf(&purger[strlen(purger)], "
\n"); + sprintf(&purger[strlen(purger)], "", + ((sitepolicy == 2) ? "CHECKED" : "") ); + sprintf(&purger[strlen(purger)], _("Expire by message count")); + sprintf(&purger[strlen(purger)], "
\n"); + sprintf(&purger[strlen(purger)], "", + ((sitepolicy == 3) ? "CHECKED" : "") ); + sprintf(&purger[strlen(purger)], _("Expire by message age")); + sprintf(&purger[strlen(purger)], "
"); + sprintf(&purger[strlen(purger)], _("Number of messages or days: ")); + sprintf(&purger[strlen(purger)], "", sitevalue); + sprintf(&purger[strlen(purger)], "

"); + sprintf(&purger[strlen(purger)], _("Default message expire policy for private mailboxes")); + sprintf(&purger[strlen(purger)], ""); + sprintf(&purger[strlen(purger)], "", + ((mboxpolicy == 0) ? "CHECKED" : "") ); + sprintf(&purger[strlen(purger)], _("Same policy as public rooms")); + sprintf(&purger[strlen(purger)], "
\n"); + sprintf(&purger[strlen(purger)], "", + ((mboxpolicy == 1) ? "CHECKED" : "") ); + sprintf(&purger[strlen(purger)], _("Never automatically expire messages")); + sprintf(&purger[strlen(purger)], "
\n"); + sprintf(&purger[strlen(purger)], "", + ((mboxpolicy == 2) ? "CHECKED" : "") ); + sprintf(&purger[strlen(purger)], _("Expire by message count")); + sprintf(&purger[strlen(purger)], "
\n"); + sprintf(&purger[strlen(purger)], "", + ((mboxpolicy == 3) ? "CHECKED" : "") ); + sprintf(&purger[strlen(purger)], _("Expire by message age")); + sprintf(&purger[strlen(purger)], "
"); + sprintf(&purger[strlen(purger)], _("Number of messages or days: ")); + sprintf(&purger[strlen(purger)], "", mboxvalue); + sprintf(&purger[strlen(purger)], "

"); + sprintf(&access[strlen(access)], ""); + sprintf(&network[strlen(network)], ""); + sprintf(&tuning[strlen(tuning)], ""); + sprintf(&directory[strlen(directory)], ""); + sprintf(&purger[strlen(purger)], ""); + sprintf(&idxjnl[strlen(idxjnl)], ""); + sprintf(&funambol[strlen(funambol)], ""); + + 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("

"); + wprintf("", _("Save changes")); + wprintf(" "); + wprintf("\n", _("Cancel")); + wprintf("
\n"); + wprintf("
\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")); @@ -559,7 +693,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")); @@ -569,19 +703,51 @@ 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")); 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("%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"); - strcpy(WC->ImportantMessage, "System configuration has been updated."); - display_siteconfig(); + + serv_printf("SPEX site|%d|%d", atoi(bstr("sitepolicy")), atoi(bstr("sitevalue"))); + serv_getln(buf, sizeof buf); + serv_printf("SPEX mailboxes|%d|%d", atoi(bstr("mboxpolicy")), atoi(bstr("mboxvalue"))); + serv_getln(buf, sizeof buf); + + 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(); } + + +/*@}*/