X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fsiteconfig.c;h=041bcb1c26f5b0928e8f79b39ce8768d2c2da6bb;hb=7f5c03bd732302f360f6840f0d815ad3e644416d;hp=1a32942eaecb66f947e6e0ca303add2901298224;hpb=f0d4dec106f607b5bbd5bb1cf1467c55ffefa8c8;p=citadel.git diff --git a/webcit/siteconfig.c b/webcit/siteconfig.c index 1a32942ea..041bcb1c2 100644 --- a/webcit/siteconfig.c +++ b/webcit/siteconfig.c @@ -1,6 +1,4 @@ /* - * $Id$ - * * Administrative screen for site-wide configuration */ @@ -8,752 +6,269 @@ #include "webcit.h" #include "webserver.h" -/* - * \brief display all configuration items - */ -void display_siteconfig(void) + +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) + StrBufAppendBufPlain(WCC->ImportantMsg, + _("Higher access is required to access this function."), -1, 0); + FreeStrBuf(&Buf); +} + +void SaveExpirePolicyFromHTTP(GPEXWhichPolicy which) { - 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]; + 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) + StrBufAppendBufPlain(WC->ImportantMsg, + _("Higher access is required to access this function."), -1, 0); + 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); - /** expire policy settings */ - int sitepolicy = 0; - int sitevalue = 0; - int mboxpolicy = 0; - int mboxvalue = 0; + return WCC->Policy[which].expire_mode == CompareWith; +} - output_headers(1, 1, 2, 0, 0, 0); - wprintf("
\n"); +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); +} - wprintf("");
-
- char *tabnames[] = {
- _("General"),
- _("Access"),
- _("Network"),
- _("Tuning"),
- _("Directory"),
- _("Auto-purger"),
- _("Indexing/Journaling"),
- _("Push Email"),
- _("Pop3")
- };
-
- sprintf(general, "%s");
- wprintf("", _("Save changes"));
- wprintf(" ");
- wprintf("\n", _("Cancel"));
- wprintf(" \n");
- wprintf(" |