X-Git-Url: https://code.citadel.org/?p=citadel.git;a=blobdiff_plain;f=webcit%2Fsiteconfig.c;h=bdc3cc20576c288af5bf7d66b9aa481891f9ecf3;hp=ac50269ce8bfeb4dad039643be4967002d45a66a;hb=4b4dc864ede7c5d8d956febe4a0afb422b78e7c4;hpb=375c84d4ed58b49836588adf5eb62d1c6bdbc90b diff --git a/webcit/siteconfig.c b/webcit/siteconfig.c index ac50269ce..bdc3cc205 100644 --- a/webcit/siteconfig.c +++ b/webcit/siteconfig.c @@ -1,753 +1,436 @@ /* - * $Id$ + * Administrative screen for site-wide configuration + * + * Copyright (c) 1996-2011 by the citadel.org team + * + * This program is open source software. You can redistribute it and/or + * modify it under the terms of the GNU General Public License, version 3. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. */ -/** - * \defgroup AdminConfig Administrative screen for site-wide configuration - * \ingroup CitadelConfig - */ -/*@{*/ #include "webcit.h" #include "webserver.h" -/** - * \brief display all configuration items +HashList *ZoneHash = NULL; + +ConstStr ExpirePolicyString = {CStrOf(roompolicy) }; + +ConstStr ExpirePolicyStrings[][2] = { + { { CStrOf(roompolicy) } , { strof(roompolicy) "_value", sizeof(strof(roompolicy) "_value") - 1 } }, + { { CStrOf(floorpolicy) } , { strof(floorpolicy) "_value", sizeof(strof(floorpolicy) "_value") - 1 } }, + { { CStrOf(sitepolicy) } , { strof(sitepolicy) "_value", sizeof(strof(sitepolicy) "_value") - 1 } }, + { { CStrOf(mailboxespolicy)} , { strof(mailboxespolicy)"_value", sizeof(strof(mailboxespolicy)"_value") - 1 } } +}; + +void LoadExpirePolicy(GPEXWhichPolicy which) +{ + StrBuf *Buf; + wcsession *WCC = WC; + long State; + const char *Pos = NULL; + + serv_printf("GPEX %s", ExpirePolicyStrings[which][0].Key); + Buf = NewStrBuf(); + StrBuf_ServGetln(Buf); + WCC->Policy[which].loaded = 1; + if (GetServerStatus(Buf, &State) == 2) { + Pos = ChrPtr(Buf) + 4; + WCC->Policy[which].expire_mode = StrBufExtractNext_long(Buf, &Pos, '|'); + WCC->Policy[which].expire_value = StrBufExtractNext_long(Buf, &Pos, '|'); + } + else if (State == 550) + AppendImportantMessage(_("Higher access is required to access this function."), -1); + FreeStrBuf(&Buf); +} + +void SaveExpirePolicyFromHTTP(GPEXWhichPolicy which) +{ + StrBuf *Buf; + long State; + + serv_printf("SPEX %s|%d|%d", + ExpirePolicyStrings[which][0].Key, + ibcstr( ExpirePolicyStrings[which][1] ), + ibcstr( ExpirePolicyStrings[which][1] ) ); + + Buf = NewStrBuf(); + StrBuf_ServGetln(Buf); + GetServerStatus(Buf, &State); + if (State == 550) + AppendImportantMessage(_("Higher access is required to access this function."), -1); + FreeStrBuf(&Buf); +} + +int ConditionalExpire(StrBuf *Target, WCTemplputParams *TP) +{ + wcsession *WCC = WC; + GPEXWhichPolicy which; + int CompareWith; + + which = GetTemplateTokenNumber(Target, TP, 2, 0); + CompareWith = GetTemplateTokenNumber(Target, TP, 3, 0); + + if (WCC->Policy[which].loaded == 0) LoadExpirePolicy(which); + + return WCC->Policy[which].expire_mode == CompareWith; +} + +void tmplput_ExpireValue(StrBuf *Target, WCTemplputParams *TP) +{ + GPEXWhichPolicy which; + wcsession *WCC = WC; + + which = GetTemplateTokenNumber(Target, TP, 0, 0); + if (WCC->Policy[which].loaded == 0) LoadExpirePolicy(which); + StrBufAppendPrintf(Target, "%d", WCC->Policy[which].expire_value); +} + + +void tmplput_ExpireMode(StrBuf *Target, WCTemplputParams *TP) +{ + GPEXWhichPolicy which; + wcsession *WCC = WC; + + which = GetTemplateTokenNumber(Target, TP, 2, 0); + if (WCC->Policy[which].loaded == 0) LoadExpirePolicy(which); + StrBufAppendPrintf(Target, "%d", WCC->Policy[which].expire_mode); +} + + +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) { + /* syslog(9, "Location: %-40s tzid: %s\n", + icaltimezone_get_location(icalarray_element_at(zones, z)), + icaltimezone_get_tzid(icalarray_element_at(zones, 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); +} + + +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")}, + {CFG_YES, HKEY("c_spam_flag_only")}, + {CFG_YES, HKEY("c_guest_logins")} +}; + + + +/* + * display all configuration items */ -void display_siteconfig(void) +void load_siteconfig(void) { - char buf[SIZ]; + wcsession *WCC = WC; + StrBuf *Buf; + HashList *Cfg; + long len; int i, j; + + if (WCC->ServCfg == NULL) + WCC->ServCfg = NewHash(1, NULL); + Cfg = WCC->ServCfg; - 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; - - output_headers(1, 1, 2, 0, 0, 0); - wprintf("
\n" - "
" - ""); - wprintf(_("Site configuration")); - wprintf("" - "
\n" - "
\n
\n" - ); + Buf = NewStrBuf(); 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); + StrBuf_ServGetln(Buf); + if (GetServerStatus(Buf, NULL) != 1) { + StrBufCutLeft(Buf, 4); + AppendImportantMessage(SKEY(Buf)); + FreeStrBuf(&Buf); return; + } - - wprintf("
" - "
"); - - char *tabnames[] = { - _("General"), - _("Access"), - _("Network"), - _("Tuning"), - _("Directory"), - _("Auto-purger"), - _("Indexing/Journaling"), - _("Push Email") - }; - - 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") - ); - - wprintf("\n"); - wprintf("\n", WC->nonce); - - 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(&network[strlen(network)], "\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(&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; + j = i = 0; + while (len = StrBuf_ServGetln(Buf), + (len >= 0) && + ((len != 3) || strcmp(ChrPtr(Buf), "000"))) + { + if (i < (sizeof(ServerConfig) / sizeof(CfgMapping))) + { + Put(Cfg, + ServerConfig[i].Key, + ServerConfig[i].len, + Buf, + HFreeStrBuf); + i++; + Buf = NewStrBuf(); + } + else { + if (j == 0) + AppendImportantMessage(_("WARNING: Failed to parse Server Config; do you run a to new citserver?"), -1); + j++; } - - } - - 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); } + FreeStrBuf(&Buf); - 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); - } + LoadExpirePolicy(sitepolicy); + LoadExpirePolicy(mailboxespolicy); +} - 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)], "
"); - 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(&network[strlen(network)], _("POP3 listener port (-1 to disable)")); - sprintf(&network[strlen(network)], ""); - sprintf(&network[strlen(network)], "", buf); - sprintf(&network[strlen(network)], "
"); - 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(&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)], "

"); - 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[256]; + wcsession *WCC = WC; + int i; + StrBuf *Line; if (strlen(bstr("ok_button")) == 0) { display_aide_menu(); return; } + Line = NewStrBuf(); serv_printf("CONF set"); - serv_getln(buf, sizeof buf); - if (buf[0] != '4') { - safestrncpy(WC->ImportantMessage, &buf[4], sizeof WC->ImportantMessage); + StrBuf_ServGetln(Line); + if (GetServerStatusMsg(Line, NULL, 1, 4) != 4) { display_aide_menu(); + FreeStrBuf(&Line); 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(""); /* 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")); - 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("%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", ((!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"); - - 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); + + FreeStrBuf(&Line); + + 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"); + + SaveExpirePolicyFromHTTP(sitepolicy); + SaveExpirePolicyFromHTTP(mailboxespolicy); + + FreeStrBuf(&WCC->serv_info->serv_default_cal_zone); + WCC->serv_info->serv_default_cal_zone = NewStrBufDup(sbstr("c_default_cal_zone")); + + AppendImportantMessage(_("Your system configuration has been updated."), -1); + DeleteHash(&WCC->ServCfg); display_aide_menu(); } +void tmplput_servcfg(StrBuf *Target, WCTemplputParams *TP) +{ + wcsession *WCC = WC; + void *vBuf; + StrBuf *Buf; + + if (WCC->is_aide) { + if (WCC->ServCfg == NULL) + load_siteconfig(); + GetHash(WCC->ServCfg, TKEY(0), &vBuf); + Buf = (StrBuf*) vBuf; + StrBufAppendTemplate(Target, TP, Buf, 1); + } +} + +int ConditionalServCfg(StrBuf *Target, WCTemplputParams *TP) +{ + wcsession *WCC = WC; + void *vBuf; + StrBuf *Buf; + + if (WCC->is_aide) { + if (WCC->ServCfg == NULL) + load_siteconfig(); + GetHash(WCC->ServCfg, TKEY(2), &vBuf); + if (vBuf == NULL) return 0; + Buf = (StrBuf*) vBuf; + if (TP->Tokens->nParameters == 3) { + return 1; + } + else if (IS_NUMBER(TP->Tokens->Params[3]->Type)) + return (StrTol(Buf) == GetTemplateTokenNumber (Target, TP, 3, 0)); + else + { + const char *pch; + long len; + + GetTemplateTokenString(Target, TP, 3, &pch, &len); + + return ((len == StrLength(Buf)) && + (strcmp(pch, ChrPtr(Buf)) == 0)); + } + + } + else return 0; +} + +int ConditionalServCfgCTXStrBuf(StrBuf *Target, WCTemplputParams *TP) +{ + wcsession *WCC = WC; + void *vBuf; + StrBuf *Buf; + StrBuf *ZoneToCheck = (StrBuf*) CTX; + + if ((WCC->is_aide) || (ZoneToCheck == NULL)) { + if (WCC->ServCfg == NULL) + load_siteconfig(); + GetHash(WCC->ServCfg, TKEY(2), &vBuf); + if (vBuf == NULL) return 0; + Buf = (StrBuf*) vBuf; + + return strcmp(ChrPtr(Buf), ChrPtr(ZoneToCheck)) == 0; + } + else return 0; +} -/*@}*/ +void +InitModule_SITECONFIG +(void) +{ + WebcitAddUrlHandler(HKEY("siteconfig"), "", 0, siteconfig, CTX_NONE); + + RegisterNamespace("SERV:CFG", 1, 2, tmplput_servcfg, NULL, CTX_NONE); + RegisterConditional(HKEY("COND:SERVCFG"), 3, ConditionalServCfg, CTX_NONE); + RegisterConditional(HKEY("COND:SERVCFG:CTXSTRBUF"), 4, ConditionalServCfgCTXStrBuf, CTX_STRBUF); + RegisterIterator("PREF:ZONE", 0, ZoneHash, NULL, NULL, NULL, CTX_STRBUF, CTX_NONE, IT_NOFLAG); + + REGISTERTokenParamDefine(roompolicy); + REGISTERTokenParamDefine(floorpolicy); + REGISTERTokenParamDefine(sitepolicy); + REGISTERTokenParamDefine(mailboxespolicy); + + REGISTERTokenParamDefine(EXPIRE_NEXTLEVEL); + REGISTERTokenParamDefine(EXPIRE_MANUAL); + REGISTERTokenParamDefine(EXPIRE_NUMMSGS); + REGISTERTokenParamDefine(EXPIRE_AGE); + + RegisterConditional(HKEY("COND:EXPIRE:MODE"), 2, ConditionalExpire, CTX_NONE); + RegisterNamespace("EXPIRE:VALUE", 1, 2, tmplput_ExpireValue, NULL, CTX_NONE); + RegisterNamespace("EXPIRE:MODE", 1, 2, tmplput_ExpireMode, NULL, CTX_NONE); +} + +void +ServerStartModule_SITECONFIG +(void) +{ + LoadZoneFiles(); +} + +void +ServerShutdownModule_SITECONFIG +(void) +{ + DeleteHash(&ZoneHash); +} + + +void +SessionDestroyModule_SITECONFIG +(wcsession *sess) +{ + DeleteHash(&sess->ServCfg); +}