X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fsiteconfig.c;h=67c954a7118ea660cfadce1848c52b803356d975;hb=24fb51aa089fb0d81bfe455789e99aec52b2d413;hp=5d593235d89aa39d0927086d1bdbe79ec56a60ef;hpb=5e91a276d21a8386402e0a7444ac6a0301da924e;p=citadel.git diff --git a/webcit/siteconfig.c b/webcit/siteconfig.c index 5d593235d..67c954a71 100644 --- a/webcit/siteconfig.c +++ b/webcit/siteconfig.c @@ -2,749 +2,342 @@ * $Id$ * * Administrative screen for site-wide configuration - * */ -#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" +HashList *ZoneHash = NULL; -void display_siteconfig(void) +void LoadZoneFiles(void) { - char buf[SIZ]; - char *whichmenu; - int i, j; - - /* expire policy settings */ - int sitepolicy = 0; - int sitevalue = 0; - int mboxpolicy = 0; - int mboxvalue = 0; - - output_headers(1, 1, 2, 0, 0, 0, 0); - wprintf("
\n" - "
" - "Site configuration" - "
\n" - "
\n
\n" - ); - - wprintf("
" - "
"); - - whichmenu = bstr("whichmenu"); - - if (!strcmp(whichmenu, "")) { - wprintf("\n"); - - wprintf("\n" - ); - - wprintf("\n" - ); - - wprintf("\n" - ); - - wprintf("\n" - ); - - wprintf("\n" - ); - - wprintf("\n" - ); - - wprintf("
" - "" - "\" \"" - "" - "" - "General
" - "General site configuration items" - "
" - "" - "\" \"" - "" - "" - "Access
" - "Access controls and site policy settings" - "
" - "" - "\" \"" - "" - "" - "Network
" - "Network services" - "
" - "" - "\" \"" - "" - "" - "Tuning
" - "Advanced server fine-tuning controls" - "
" - "" - "\" \"" - "" - "" - "Directory
" - "Configure the LDAP connector for Citadel" - "
" - "" - "\" \"" - "" - "" - "Auto-purger
" - "Configure automatic expiry of old messages" - "
"); - wprintf("
\n"); - wDumpContent(1); - return; - } - - if (!strcasecmp(whichmenu, "general")) { - wprintf("

General site configuration items

\n"); - } - - if (!strcasecmp(whichmenu, "access")) { - wprintf("

Access controls and site policy settings

\n"); + 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) { + /* lprintf(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); +} - if (!strcasecmp(whichmenu, "network")) { - wprintf("

Network services

" - "Changes made on this screen will not take effect until you restart the Citadel server." - "
\n"); - } - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("

Advanced server fine-tuning controls

\n"); - } +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")} +}; - if (!strcasecmp(whichmenu, "ldap")) { - wprintf("

Citadel LDAP connector configuration

" - "Changes made on this screen will not take effect until you restart the Citadel server." - "
\n"); - } - if (!strcasecmp(whichmenu, "purger")) { - wprintf("

Message auto-purger settings

" - "These settings may be overridden on a per-floor or per-room basis." - "
\n"); - } +/* + * display all configuration items + */ +void load_siteconfig(void) +{ + wcsession *WCC = WC; + StrBuf *Buf, *CfgToken; + HashList *Cfg; + char buf[SIZ]; + long len; + int i; + + if (WCC->ServCfg == NULL) + WCC->ServCfg = NewHash(1, NULL); + Cfg = WCC->ServCfg; serv_printf("CONF get"); serv_getln(buf, sizeof buf); - if (buf[0] != '1') { - wprintf("
"); - wprintf("Error\n"); - wprintf("

\n"); - wprintf("%s
\n", &buf[4]); - do_template("endbox"); - wDumpContent(1); - return; - } - - wprintf("
\n"); - wprintf("\n"); - i = 0; - while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) { - switch (++i) { - case 1: - if (!strcasecmp(whichmenu, "general")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 2: - if (!strcasecmp(whichmenu, "general")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 3: - if (!strcasecmp(whichmenu, "general")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 4: - if (!strcasecmp(whichmenu, "general")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 5: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 6: - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 7: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 8: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 9: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 10: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 11: - if (!strcasecmp(whichmenu, "general")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 12: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 13: - if (!strcasecmp(whichmenu, "general")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 14: - if (!strcasecmp(whichmenu, "general")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 15: - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 17: - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 18: - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 19: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 20: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 21: - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 22: - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 23: - if (!strcasecmp(whichmenu, "tuning")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 24: - if (!strcasecmp(whichmenu, "network")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 25: - if (!strcasecmp(whichmenu, "network")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 27: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 28: - if (!strcasecmp(whichmenu, "network")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 29: - if (!strcasecmp(whichmenu, "network")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 30: - if (!strcasecmp(whichmenu, "access")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 31: - /* niu */ - break; - case 32: - if (!strcasecmp(whichmenu, "purger")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 33: - if ( (serv_info.serv_supports_ldap) && (!strcasecmp(whichmenu, "ldap")) ) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 34: - if ( (serv_info.serv_supports_ldap) && (!strcasecmp(whichmenu, "ldap")) ) { - wprintf("\n"); - } - else { - wprintf("", atoi(buf)); - } - break; - case 35: - if ( (serv_info.serv_supports_ldap) && (!strcasecmp(whichmenu, "ldap")) ) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 36: - if ( (serv_info.serv_supports_ldap) && (!strcasecmp(whichmenu, "ldap")) ) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 37: - if ( (serv_info.serv_supports_ldap) && (!strcasecmp(whichmenu, "ldap")) ) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 38: - if (!strcasecmp(whichmenu, "network")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 39: - if (!strcasecmp(whichmenu, "network")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 40: - if (!strcasecmp(whichmenu, "network")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 41: - if (!strcasecmp(whichmenu, "network")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 42: - if (!strcasecmp(whichmenu, "network")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - case 43: - if (!strcasecmp(whichmenu, "general")) { - wprintf("\n"); - } - else { - wprintf("", buf); - } - break; - } + Buf = NewStrBuf(); + while ((sizeof(ServerConfig) / sizeof(CfgMapping)) && + (len = StrBuf_ServGetln(Buf), + strcmp(ChrPtr(Buf), "000")) && + (i <= sizeof(ServerConfig))) + { + Put(Cfg, + ServerConfig[i].Key, + ServerConfig[i].len, + Buf, + HFreeStrBuf); + i++; + if (i <= sizeof(ServerConfig) / sizeof(CfgMapping)) + Buf = NewStrBuf(); + else + Buf = NULL; } + FreeStrBuf(&Buf); serv_puts("GPEX site"); - serv_getln(buf, sizeof buf); - if (buf[0] == '2') { - sitepolicy = extract_int(&buf[4], 0); - sitevalue = extract_int(&buf[4], 1); + Buf = NewStrBuf(); + CfgToken = NULL; + StrBuf_ServGetln(Buf); + if (GetServerStatus(Buf, NULL) == 2) { + StrBufCutLeft(Buf, 4); + + CfgToken = NewStrBuf(); + StrBufExtract_token(CfgToken, Buf, 0, '|'); + Put(Cfg, HKEY("sitepolicy"), CfgToken, HFreeStrBuf); + + CfgToken = NewStrBuf(); + StrBufExtract_token(CfgToken, Buf, 1, '|'); + Put(Cfg, HKEY("sitevalue"), CfgToken, HFreeStrBuf); } 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); - } + StrBuf_ServGetln(Buf); + if (GetServerStatus(Buf, NULL) == 2) { + StrBufCutLeft(Buf, 4); - if (!strcasecmp(whichmenu, "purger")) { - - wprintf("\n"); - - wprintf("\n"); - - wprintf("\n"); - - wprintf("\n"); - - wprintf("\n"); + CfgToken = NewStrBuf(); + StrBufExtract_token(CfgToken, Buf, 0, '|'); + Put(Cfg, HKEY("mboxpolicy"), CfgToken, HFreeStrBuf); + CfgToken = NewStrBuf(); + StrBufExtract_token(CfgToken, Buf, 1, '|'); + Put(Cfg, HKEY("mboxvalue"), CfgToken, HFreeStrBuf); } - else { - wprintf("\n", sitepolicy); - wprintf("\n", sitevalue); - wprintf("\n", mboxpolicy); - wprintf("\n", mboxvalue); - } - - wprintf("
Node name"); - wprintf("", buf); - wprintf("
Fully qualified domain name"); - wprintf("", buf); - wprintf("
Human-readable node name"); - wprintf("", buf); - wprintf("
Landline telephone number"); - wprintf("", buf); - wprintf("
Automatically grant room-aide status to users who create private rooms"); - wprintf("", ((atoi(buf) != 0) ? "CHECKED" : "")); - wprintf("
Server connection idle timeout (in seconds)"); - wprintf("", buf); - wprintf("
Initial access level for new users"); - wprintf(""); - wprintf("
Require registration for new users"); - wprintf("", ((atoi(buf) != 0) ? "CHECKED" : "")); - wprintf("
Quarantine messages from problem users"); - wprintf("", ((atoi(buf) != 0) ? "CHECKED" : "")); - wprintf("
Name of quarantine room"); - wprintf("", buf); - wprintf("
Paginator prompt (for text mode clients)"); - wprintf("", buf); - wprintf("
Restrict access to Internet mail"); - wprintf("", ((atoi(buf) != 0) ? "CHECKED" : "")); - wprintf("
Geographic location of this system"); - wprintf("", buf); - wprintf("
Name of system administrator"); - wprintf("", buf); - wprintf("
Maximum concurrent sessions (0 = no limit)"); - wprintf("", buf); - wprintf("
Default user purge time (days)"); - wprintf("", buf); - wprintf("
Default room purge time (days)"); - wprintf("", buf); - wprintf("
Name of room to log pages"); - wprintf("", buf); - wprintf("
Access level required to create rooms"); - wprintf(""); - wprintf("
Maximum message length"); - wprintf("", buf); - wprintf("
Minimum number of worker threads"); - wprintf("", buf); - wprintf("
Maximum number of worker threads"); - wprintf("", buf); - wprintf("
POP3 listener port (-1 to disable)"); - wprintf("", buf); - wprintf("
SMTP MTA port (-1 to disable)"); - wprintf("", buf); - wprintf("
Allow aides to zap (forget) rooms"); - wprintf("", ((atoi(buf) != 0) ? "CHECKED" : "")); - wprintf("
IMAP listener port (-1 to disable)"); - wprintf("", buf); - wprintf("
Network run frequency (in seconds)"); - wprintf("", buf); - wprintf("
Disable self-service user account creation"); - wprintf("", ((atoi(buf) != 0) ? "CHECKED" : "")); - wprintf("
Hour to run database auto-purge"); - wprintf(""); - wprintf("
Host name of LDAP server (blank to disable)"); - wprintf("", buf); - wprintf("
Port number of LDAP server (blank to disable)"); - wprintf("", atoi(buf)); - wprintf("
Base DN"); - wprintf("", buf); - wprintf("
Bind DN"); - wprintf("", buf); - wprintf("
Password for bind DN"); - wprintf("", buf); - wprintf("
Server IP address (0.0.0.0 for 'any')"); - wprintf("", buf); - wprintf("
SMTP MSA port (-1 to disable)"); - wprintf("", buf); - wprintf("
IMAP over SSL port (-1 to disable)"); - wprintf("", buf); - wprintf("
POP3 over SSL port (-1 to disable)"); - wprintf("", buf); - wprintf("
SMTP over SSL port (-1 to disable)"); - wprintf("", buf); - wprintf("
Enable full text index (warning: resource intensive)"); - wprintf("", ((atoi(buf) != 0) ? "CHECKED" : "")); - wprintf("

Default message expire policy for public rooms"); - wprintf("", - ((sitepolicy == 1) ? "CHECKED" : "") ); - wprintf("Never automatically expire messages
\n"); - wprintf("", - ((sitepolicy == 2) ? "CHECKED" : "") ); - wprintf("Expire by message count
\n"); - wprintf("", - ((sitepolicy == 3) ? "CHECKED" : "") ); - wprintf("Expire by message age
"); - wprintf("Number of messages or days: "); - wprintf("", sitevalue); - wprintf("

Default message expire policy for private mailboxes"); - wprintf("", - ((mboxpolicy == 0) ? "CHECKED" : "") ); - wprintf("Same policy as public rooms
\n"); - wprintf("", - ((mboxpolicy == 1) ? "CHECKED" : "") ); - wprintf("Never automatically expire messages
\n"); - wprintf("", - ((mboxpolicy == 2) ? "CHECKED" : "") ); - wprintf("Expire by message count
\n"); - wprintf("", - ((mboxpolicy == 3) ? "CHECKED" : "") ); - wprintf("Expire by message age
"); - wprintf("Number of messages or days: "); - wprintf("", mboxvalue); - wprintf("

"); - wprintf(""); - wprintf(" "); - wprintf("\n"); - wprintf("
\n"); - wprintf("
\n"); - wDumpContent(1); + FreeStrBuf(&Buf); } +/** + * parse siteconfig changes + */ void siteconfig(void) { - char buf[SIZ]; + wcsession *WCC = WC; + int i; + 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_getln(buf, sizeof buf); if (buf[0] != '4') { - safestrncpy(WC->ImportantMessage, &buf[4], sizeof WC->ImportantMessage); - display_siteconfig(); + safestrncpy(WCC->ImportantMessage, &buf[4], sizeof WCC->ImportantMessage); + display_aide_menu(); return; } - serv_printf("%s", bstr("c_nodename")); - serv_printf("%s", bstr("c_fqdn")); - serv_printf("%s", bstr("c_humannode")); - serv_printf("%s", bstr("c_phonenum")); - serv_printf("%s", ((!strcasecmp(bstr("c_creataide"), "yes") ? "1" : "0"))); - serv_printf("%s", bstr("c_sleeping")); - serv_printf("%s", bstr("c_initax")); - serv_printf("%s", ((!strcasecmp(bstr("c_regiscall"), "yes") ? "1" : "0"))); - serv_printf("%s", ((!strcasecmp(bstr("c_twitdetect"), "yes") ? "1" : "0"))); - serv_printf("%s", bstr("c_twitroom")); - serv_printf("%s", bstr("c_moreprompt")); - serv_printf("%s", ((!strcasecmp(bstr("c_restrict"), "yes") ? "1" : "0"))); - serv_printf("%s", bstr("c_bbs_city")); - serv_printf("%s", bstr("c_sysadm")); - serv_printf("%s", bstr("c_maxsessions")); - serv_printf(""); /* networking password -- deprecated */ - serv_printf("%s", bstr("c_userpurge")); - serv_printf("%s", bstr("c_roompurge")); - serv_printf("%s", bstr("c_logpages")); - serv_printf("%s", bstr("c_createax")); - serv_printf("%s", bstr("c_maxmsglen")); - serv_printf("%s", bstr("c_min_workers")); - serv_printf("%s", bstr("c_max_workers")); - serv_printf("%s", bstr("c_pop3_port")); - serv_printf("%s", bstr("c_smtp_port")); - serv_printf(""); /* moderation filter level -- not yet implemented */ - serv_printf("%s", ((!strcasecmp(bstr("c_aide_zap"), "yes") ? "1" : "0"))); - serv_printf("%s", bstr("c_imap_port")); - serv_printf("%s", bstr("c_net_freq")); - serv_printf("%s", ((!strcasecmp(bstr("c_disable_newu"), "yes") ? "1" : "0"))); - serv_printf("1"); - serv_printf("%s", bstr("c_purge_hour")); - serv_printf("%s", bstr("c_ldap_host")); - serv_printf("%s", bstr("c_ldap_port")); - serv_printf("%s", bstr("c_ldap_base_dn")); - serv_printf("%s", bstr("c_ldap_bind_dn")); - serv_printf("%s", bstr("c_ldap_bind_pw")); - serv_printf("%s", bstr("c_ip_addr")); - serv_printf("%s", bstr("c_msa_port")); - serv_printf("%s", bstr("c_imaps_port")); - serv_printf("%s", bstr("c_pop3s_port")); - serv_printf("%s", bstr("c_smtps_port")); - serv_printf("%s", ((!strcasecmp(bstr("c_enable_fulltext"), "yes") ? "1" : "0"))); - serv_printf("000"); - - serv_printf("SPEX site|%d|%d", atoi(bstr("sitepolicy")), atoi(bstr("sitevalue"))); + + for (i=0; i < (sizeof(ServerConfig) / sizeof(CfgMapping)); i ++) + { + switch (ServerConfig[i].type) { + default: + case CFG_STR: + serv_putbuf(SBstr(ServerConfig[i].Key, ServerConfig[i].len)); + break; + case CFG_YES: + serv_puts(YesBstr(ServerConfig[i].Key, + ServerConfig[i].len) ? + "1" : "0"); + break; + case CFG_NO: + serv_puts(YesBstr(ServerConfig[i].Key, + ServerConfig[i].len) ? + "0" : "1"); + break; + } + } + serv_puts("000"); + + serv_printf("SPEX site|%d|%d", ibstr("sitepolicy"), ibstr("sitevalue")); serv_getln(buf, sizeof buf); - serv_printf("SPEX mailboxes|%d|%d", atoi(bstr("mboxpolicy")), atoi(bstr("mboxvalue"))); + serv_printf("SPEX mailboxes|%d|%d", ibstr("mboxpolicy"), ibstr("mboxvalue")); serv_getln(buf, sizeof buf); + FreeStrBuf(&WCC->serv_info->serv_default_cal_zone); + WCC->serv_info->serv_default_cal_zone = NewStrBufDup(sbstr("c_default_cal_zone")); + + safestrncpy(WCC->ImportantMessage, _("Your system configuration has been updated."), + sizeof WCC->ImportantMessage); + DeleteHash(&WCC->ServCfg); + display_aide_menu(); +} - safestrncpy(WC->ImportantMessage, "System configuration has been updated.", - sizeof WC->ImportantMessage); - display_siteconfig(); +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 (TP->Tokens->Params[3]->Type == TYPE_STR) + return (strcmp(TP->Tokens->Params[3]->Start, ChrPtr(Buf)) == 0); + else return (StrTol(Buf) == TP->Tokens->Params[3]->lvalue); + } + else return 0; +} + +int ConditionalServCfgSubst(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; + + return CompareSubstToStrBuf(Buf, TP->Tokens->Params[3]); + } + else return 0; +} + +void CfgZoneTempl(StrBuf *TemplBuffer, WCTemplputParams *TP) +{ + StrBuf *Zone = (StrBuf*) CTX; + + SVPutBuf("ZONENAME", Zone, 1); +} + +void +InitModule_SITECONFIG +(void) +{ + WebcitAddUrlHandler(HKEY("siteconfig"), 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:SUBST"), 4, ConditionalServCfgSubst, CTX_NONE); + RegisterIterator("PREF:ZONE", 0, ZoneHash, NULL, CfgZoneTempl, NULL, CTX_PREF, CTX_NONE, IT_NOFLAG); +} + +void +ServerStartModule_SITECONFIG +(void) +{ + LoadZoneFiles(); +} + +void +ServerShutdownModule_SITECONFIG +(void) +{ + DeleteHash(&ZoneHash); +} + + +void +SessionDestroyModule_SITECONFIG +(wcsession *sess) +{ + DeleteHash(&sess->ServCfg); }