X-Git-Url: https://code.citadel.org/?p=citadel.git;a=blobdiff_plain;f=webcit%2Fsiteconfig.c;h=5cdeae1bc39b60595154518e5a113b6fbabe4196;hp=4a67d748bc7375ba9b79f88e9528ce2de71a05be;hb=47bcaaabae789a2f20de958b84714ff2e23dc5bb;hpb=995336d9fceefb5903909f52acc4d93345081a7b diff --git a/webcit/siteconfig.c b/webcit/siteconfig.c index 4a67d748b..5cdeae1bc 100644 --- a/webcit/siteconfig.c +++ b/webcit/siteconfig.c @@ -35,760 +35,6 @@ void LoadZoneFiles(void) } - - -/* - * display all configuration items - */ -void display_siteconfig(void) -{ - char buf[SIZ]; - int i, j; - struct wcsession *WCC = WC; - const char *VCZname; - - char general[65536]; - char access[SIZ]; - char network[SIZ]; - char tuning[SIZ]; - char directory[SIZ]; - char purger[SIZ]; - 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("

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

"); - wprintf("
\n"); - - wprintf("
\n"); - - serv_printf("CONF get"); - serv_getln(buf, sizeof buf); - if (buf[0] != '1') { - wprintf("
"); - wprintf(_("Error")); - wprintf("
\n"); - wprintf("%s
\n", &buf[4]); - wDumpContent(1); - wprintf("
\n"); - return; - } - - wprintf("
"); - - char *tabnames[] = { - _("General"), - _("Access"), - _("Network"), - _("Tuning"), - _("Directory"), - _("Auto-purger"), - _("Indexing/Journaling"), - _("Push Email"), - _("Pop3") - }; - - sprintf(general, "

%s

", - _("General site configuration items") - ); - - sprintf(access, "

%s

", - _("Access controls and site policy settings") - ); - - sprintf(network, "

%s

%s

", - _("Network services"), - _("Changes made on this screen will not take effect " - "until you restart the Citadel server.") - ); - - 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.") - ) - ); - - 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") - ); - - 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 0: - sprintf(&general[strlen(general)], "\n"); - break; - case 1: - sprintf(&general[strlen(general)], "\n"); - break; - case 2: - sprintf(&general[strlen(general)], "\n"); - break; - case 3: - sprintf(&general[strlen(general)], "\n"); - break; - case 4: - sprintf(&access[strlen(access)], "\n"); - break; - case 5: - sprintf(&tuning[strlen(tuning)], "\n"); - break; - case 6: - sprintf(&access[strlen(access)], "\n"); - break; - case 7: - sprintf(&access[strlen(access)], "\n"); - break; - case 8: - sprintf(&access[strlen(access)], "\n"); - break; - case 9: - sprintf(&access[strlen(access)], "\n"); - break; - case 10: - sprintf(&general[strlen(general)], "\n"); - break; - case 11: - sprintf(&access[strlen(access)], "\n"); - break; - case 12: - sprintf(&general[strlen(general)], "\n"); - break; - case 13: - sprintf(&general[strlen(general)], "\n"); - break; - case 14: - sprintf(&tuning[strlen(tuning)], "\n"); - break; - case 16: - sprintf(&tuning[strlen(tuning)], "\n"); - break; - case 17: - sprintf(&tuning[strlen(tuning)], "\n"); - break; - case 18: - sprintf(&access[strlen(access)], "\n"); - break; - case 19: - sprintf(&access[strlen(access)], "\n"); - break; - case 20: - sprintf(&tuning[strlen(tuning)], "\n"); - break; - case 21: - sprintf(&tuning[strlen(tuning)], "\n"); - break; - case 22: - sprintf(&tuning[strlen(tuning)], "\n"); - break; - case 23: - sprintf(&pop3[strlen(pop3)], "\n"); - break; - case 24: - 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: - sprintf(&network[strlen(network)], "\n"); - break; - case 28: - sprintf(&network[strlen(network)], "\n"); - break; - case 29: - sprintf(&access[strlen(access)], "\n"); - break; - case 31: - sprintf(&purger[strlen(purger)], "\n"); - break; - case 32: - sprintf(&directory[strlen(directory)], "\n"); - break; - case 33: - sprintf(&directory[strlen(directory)], "\n"); - break; - case 34: - sprintf(&directory[strlen(directory)], "\n"); - break; - case 35: - sprintf(&directory[strlen(directory)], "\n"); - break; - case 36: - sprintf(&directory[strlen(directory)], "\n"); - break; - case 37: - 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(&pop3[strlen(pop3)], "\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"); - } - 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; - case 66: /* Flag spam */ - sprintf(&network[strlen(network)], "\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); - } - - - sprintf(&purger[strlen(purger)], "\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)], "
%s %s
"); - sprintf(&general[strlen(general)], _("Node name")); - sprintf(&general[strlen(general)], ""); - sprintf(&general[strlen(general)], "", buf); - 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)], _("Human-readable node name")); - sprintf(&general[strlen(general)], ""); - sprintf(&general[strlen(general)], "", buf); - sprintf(&general[strlen(general)], "
"); - sprintf(&general[strlen(general)], _("Telephone number")); - sprintf(&general[strlen(general)], ""); - sprintf(&general[strlen(general)], "", buf); - sprintf(&general[strlen(general)], "
"); - 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(&tuning[strlen(tuning)], _("Server connection idle timeout (in seconds)")); - sprintf(&tuning[strlen(tuning)], ""); - sprintf(&tuning[strlen(tuning)], "", buf); - sprintf(&tuning[strlen(tuning)], "
"); - 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)], _("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)], _("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)], _("Name of quarantine room")); - sprintf(&access[strlen(access)], ""); - sprintf(&access[strlen(access)], "", buf); - sprintf(&access[strlen(access)], "
"); - sprintf(&general[strlen(general)], _("Paginator prompt (for text mode clients)")); - sprintf(&general[strlen(general)], ""); - sprintf(&general[strlen(general)], "", buf); - sprintf(&general[strlen(general)], "
"); - 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(&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)], _("Name of system administrator")); - sprintf(&general[strlen(general)], ""); - sprintf(&general[strlen(general)], "", buf); - sprintf(&general[strlen(general)], "
"); - 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)], "
"); - sprintf(&tuning[strlen(tuning)], _("Default room purge time (days)")); - sprintf(&tuning[strlen(tuning)], ""); - sprintf(&tuning[strlen(tuning)], "", buf); - sprintf(&tuning[strlen(tuning)], "
"); - 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)], _("Access level required to create rooms")); - sprintf(&access[strlen(access)], ""); - sprintf(&access[strlen(access)], ""); - sprintf(&access[strlen(access)], "
"); - sprintf(&tuning[strlen(tuning)], _("Maximum message length")); - sprintf(&tuning[strlen(tuning)], ""); - sprintf(&tuning[strlen(tuning)], "", buf); - 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)], _("Maximum number of worker threads")); - 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)], _("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)], "
"); - 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)], ""); - 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)], "
"); - 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)], ""); - sprintf(&directory[strlen(directory)], "", - 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(&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(&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)")); - 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(&network[strlen(network)], _("Flag message as spam, instead of rejecting it")); - sprintf(&network[strlen(network)], ""); - sprintf(&network[strlen(network)], "", - (atoi(buf) ? "CHECKED" : "")); - sprintf(&network[strlen(network)], "

"); - 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)], ""); - sprintf(&pop3[strlen(pop3)], ""); - - tabbed_dialog(9, tabnames); - - 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); - - begin_tab(9, 9); - wprintf("", _("Save changes")); - wprintf(" "); - wprintf("\n", _("Cancel")); - end_tab(9, 9); - - wprintf("\n"); - wprintf("\n"); - wDumpContent(1); -} - typedef struct _CfgMapping { int type; const char *Key; @@ -876,7 +122,7 @@ CfgMapping ServerConfig[] = { void load_siteconfig(void) { struct wcsession *WCC = WC; - StrBuf *Buf, *Token; + StrBuf *Buf, *CfgToken; HashList *Cfg; char buf[SIZ]; long len; @@ -910,18 +156,18 @@ void load_siteconfig(void) serv_puts("GPEX site"); Buf = NewStrBuf(); - Token = NULL; + CfgToken = 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); + CfgToken = NewStrBuf(); + StrBufExtract_token(CfgToken, Buf, 0, '|'); + Put(Cfg, HKEY("sitepolicy"), CfgToken, HFreeStrBuf); - Token = NewStrBuf(); - StrBufExtract_token(Token, Buf, 1, '|'); - Put(Cfg, HKEY("sitevalue"), Token, HFreeStrBuf); + CfgToken = NewStrBuf(); + StrBufExtract_token(CfgToken, Buf, 1, '|'); + Put(Cfg, HKEY("sitevalue"), CfgToken, HFreeStrBuf); } serv_puts("GPEX mailboxes"); @@ -929,13 +175,13 @@ void load_siteconfig(void) if (buf[0] == '2') { StrBufCutLeft(Buf, 4); - Token = NewStrBuf(); - StrBufExtract_token(Token, Buf, 0, '|'); - Put(Cfg, HKEY("mboxpolicy"), Token, HFreeStrBuf); + CfgToken = NewStrBuf(); + StrBufExtract_token(CfgToken, Buf, 0, '|'); + Put(Cfg, HKEY("mboxpolicy"), CfgToken, HFreeStrBuf); - Token = NewStrBuf(); - StrBufExtract_token(Token, Buf, 1, '|'); - Put(Cfg, HKEY("mboxvalue"), Token, HFreeStrBuf); + CfgToken = NewStrBuf(); + StrBufExtract_token(CfgToken, Buf, 1, '|'); + Put(Cfg, HKEY("mboxvalue"), CfgToken, HFreeStrBuf); } } @@ -1009,7 +255,7 @@ void tmplput_servcfg(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *C Tokens->Params[0]->len, &vBuf); Buf = (StrBuf*) vBuf; - StrBufAppendBuf(Target, Buf, 0); + StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, Buf, 1); } } @@ -1063,10 +309,9 @@ 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_NONE); + RegisterNamespace("SERV:CFG", 1, 2, tmplput_servcfg, CTX_NONE); RegisterConditional(HKEY("COND:SERVCFG"), 3, ConditionalServCfg, CTX_NONE); RegisterConditional(HKEY("COND:SERVCFG:SUBST"), 4, ConditionalServCfgSubst, CTX_NONE); }