icalarray *zones;
int z;
long len;
- char this_zone[128];
- char *ZName;
+ const char *this_zone;
+ StrBuf *ZName;
ZoneHash = NewHash(1, NULL);
- len = sizeof("UTC") + 1;
- ZName = malloc(len + 1);
- memcpy(ZName, "UTC", len + 1);
- Put(ZoneHash, ZName, len, ZName, NULL);
+ ZName = NewStrBufPlain(HKEY("UTC"));
+ Put(ZoneHash, HKEY("UTC"), ZName, HFreeStrBuf);
zones = icaltimezone_get_builtin_timezones();
for (z = 0; z < zones->num_elements; ++z) {
- strcpy(this_zone, icaltimezone_get_location(icalarray_element_at(zones, z)));
+ this_zone = icaltimezone_get_location(icalarray_element_at(zones, z));
len = strlen(this_zone);
- ZName = (char*)malloc(len +1);
- memcpy(ZName, this_zone, len + 1);
- Put(ZoneHash, ZName, len, ZName, NULL);
+ ZName = NewStrBufPlain(this_zone, len);
+ Put(ZoneHash, this_zone, len, ZName, HFreeStrBuf);
}
SortByHashKey(ZoneHash, 0);
}
/*
- * \brief display all configuration items
+ * display all configuration items
*/
void display_siteconfig(void)
{
sprintf(&pop3[strlen(pop3)], "<input type=\"text\" name=\"c_pop3_fastest\" MAXLENGTH=\"5\" value=\"%s\">\n", buf);
sprintf(&pop3[strlen(pop3)], "</TD></TR>\n");
break;
+ case 66: /* Flag spam */
+ sprintf(&network[strlen(network)], "<TR><TD>");
+ sprintf(&network[strlen(network)], _("Flag message as spam, instead of rejecting it"));
+ sprintf(&network[strlen(network)], "</TD><TD>");
+ sprintf(&network[strlen(network)], "<input type=\"checkbox\" NAME=\"c_spam_flag_only\" VALUE=\"yes\" %s>",
+ (atoi(buf) ? "CHECKED" : ""));
+ sprintf(&network[strlen(network)], "</TD></TR>\n");
+ break;
}
{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_STR, HKEY("c_pop3_fastest")},
+ {CFG_YES , HKEY("c_spam_flag_only")}
};
/*
- * \brief display all configuration items
+ * display all configuration items
*/
void load_siteconfig(void)
{
serv_printf("CONF get");
serv_getln(buf, sizeof buf);
i = 0;
- while (len = serv_getln(buf, sizeof buf),
- strcmp(buf, "000") &&
- (i < sizeof(ServerConfig)))
+ 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,
- NewStrBufPlain(buf, len),
+ Buf,
HFreeStrBuf);
i++;
+ if (i <= sizeof(ServerConfig) / sizeof(CfgMapping))
+ Buf = NewStrBuf();
+ else
+ Buf = NULL;
}
+ FreeStrBuf(&Buf);
serv_puts("GPEX site");
Buf = NewStrBuf();
*/
void siteconfig(void)
{
+ struct wcsession *WCC = WC;
int i;
char buf[256];
serv_printf("CONF set");
serv_getln(buf, sizeof buf);
if (buf[0] != '4') {
- safestrncpy(WC->ImportantMessage, &buf[4], sizeof WC->ImportantMessage);
+ safestrncpy(WCC->ImportantMessage, &buf[4], sizeof WCC->ImportantMessage);
display_aide_menu();
return;
}
- i = sizeof(ServerConfig);
- for (i=0; i < sizeof(ServerConfig); i ++)
+ for (i=0; i < (sizeof(ServerConfig) / sizeof(CfgMapping)); i ++)
{
switch (ServerConfig[i].type) {
default:
break;
}
}
+ serv_puts("000");
serv_printf("SPEX site|%d|%d", ibstr("sitepolicy"), ibstr("sitevalue"));
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);
+ safestrncpy(WCC->ImportantMessage, _("Your system configuration has been updated."),
+ sizeof WCC->ImportantMessage);
+ DeleteHash(&WCC->ServCfg);
display_aide_menu();
}
-void tmplput_servcfg(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context)
+void tmplput_servcfg(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType)
{
struct wcsession *WCC = WC;
void *vBuf;
}
}
-int ConditionalServCfg(WCTemplateToken *Tokens, void *Context)
+int ConditionalServCfg(WCTemplateToken *Tokens, void *Context, int ContextType)
{
struct wcsession *WCC = WC;
void *vBuf;
else return 0;
}
+int ConditionalServCfgSubst(WCTemplateToken *Tokens, void *Context, int ContextType)
+{
+ struct wcsession *WCC = WC;
+ void *vBuf;
+ StrBuf *Buf;
+
+ if (WCC->is_aide) {
+ if (WCC->ServCfg == NULL)
+ load_siteconfig();
+ GetHash(WCC->ServCfg,
+ Tokens->Params[2]->Start,
+ Tokens->Params[2]->len,
+ &vBuf);
+ if (vBuf == NULL) return 0;
+ Buf = (StrBuf*) vBuf;
+
+ return CompareSubstToStrBuf(Buf, Tokens->Params[3]);
+ }
+ else return 0;
+}
+
void
InitModule_SITECONFIG
(void)
{
- WebcitAddUrlHandler(HKEY("display_siteconfig"), display_siteconfig, 0);
- WebcitAddUrlHandler(HKEY("siteconfig"), siteconfig, 0);
+ WebcitAddUrlHandler(HKEY("display_siteconfig"), display_siteconfig, CTX_NONE);
+ WebcitAddUrlHandler(HKEY("siteconfig"), siteconfig, CTX_NONE);
- RegisterNamespace("SERV:CFG", 1, 1, tmplput_servcfg);
- RegisterConditional(HKEY("COND:SERVCFG"), 3, ConditionalServCfg);
+ RegisterNamespace("SERV:CFG", 1, 1, tmplput_servcfg, CTX_NONE);
+ RegisterConditional(HKEY("COND:SERVCFG"), 3, ConditionalServCfg, CTX_NONE);
+ RegisterConditional(HKEY("COND:SERVCFG:SUBST"), 4, ConditionalServCfgSubst, CTX_NONE);
}
-/*@}*/