\n");
- wc_printf("
"
- "\n");
+ wc_printf("\n"
+ "\n\n");
wc_printf(" | ");
+ wc_printf(" |
\n");
wc_printf("
\n",
_("Add rule")
);
- wc_printf(" \n");
+ wc_printf("\n");
free(rooms);
}
@@ -1255,6 +1266,7 @@ HashList *GetSieveScriptListing(StrBuf *Target, WCTemplputParams *TP)
Ruleset->Name = NewStrBufPlain(NULL, StrLength(Line));
StrBufExtract_NextToken(Ruleset->Name, Line, &pch, '|');
Ruleset->IsActive = StrBufExtractNext_int(Line, &pch, '|');
+ Ruleset->Content = NULL;
if (!strcasecmp(ChrPtr(Ruleset->Name), RULES_SCRIPT))
{
@@ -1456,36 +1468,11 @@ int ConditionalSieveRule_Active(StrBuf *Target, WCTemplputParams *TP)
SieveRule *Rule = (SieveRule *)CTX;
return Rule->active;
}
-
-
-/*
-void tmplput_SieveRule_hfield(StrBuf *Target, WCTemplputParams *TP)
-{
- SieveRule *Rule = (SieveRule *)CTX;
- StrBufAppendTemplate(Target, TP, Rule->hfield, 0);
-}
-void tmplput_SieveRule_compare(StrBuf *Target, WCTemplputParams *TP)
-{
- SieveRule *Rule = (SieveRule *)CTX;
- StrBufAppendTemplate(Target, TP, Rule->compare, 0);
-}
-*/
void tmplput_SieveRule_htext(StrBuf *Target, WCTemplputParams *TP)
{
SieveRule *Rule = (SieveRule *)CTX;
StrBufAppendTemplate(Target, TP, Rule->htext, 0);
}
-/*
-void tmplput_SieveRule_sizecomp(StrBuf *Target, WCTemplputParams *TP)
-{
- SieveRule *Rule = (SieveRule *)CTX;
- StrBufAppendTemplate(Target, TP, Rule->sizecomp, 0);
-}
-void tmplput_SieveRule_action(StrBuf *Target, WCTemplputParams *TP)
-{
- SieveRule *Rule = (SieveRule *)CTX;
- StrBufAppendTemplate(Target, TP, Rule->action, 0);
- }*/
void tmplput_SieveRule_fileinto(StrBuf *Target, WCTemplputParams *TP)
{
SieveRule *Rule = (SieveRule *)CTX;
@@ -1501,17 +1488,10 @@ void tmplput_SieveRule_automsg(StrBuf *Target, WCTemplputParams *TP)
SieveRule *Rule = (SieveRule *)CTX;
StrBufAppendTemplate(Target, TP, Rule->automsg, 0);
}
-/*
-void tmplput_SieveRule_final(StrBuf *Target, WCTemplputParams *TP)
-{
- SieveRule *Rule = (SieveRule *)CTX;
- StrBufAppendTemplate(Target, TP, Rule->final, 0);
-}
-*/
void tmplput_SieveRule_sizeval(StrBuf *Target, WCTemplputParams *TP)
{
SieveRule *Rule = (SieveRule *)CTX;
- wc_printf("%d", Rule->sizeval);
+ StrBufAppendPrintf(Target, "%d", Rule->sizeval);
}
void tmplput_SieveRule_lookup_FileIntoRoom(StrBuf *Target, WCTemplputParams *TP)
@@ -1548,14 +1528,13 @@ HashList *GetSieveRules(StrBuf *Target, WCTemplputParams *TP)
int Done = 0;
SieveRule *Rule;
+ SieveRules = NewHash(1, Flathash);
serv_printf("MSIV getscript|"RULES_SCRIPT);
Line = NewStrBuf();
EncodedRule = NewStrBuf();
StrBuf_ServGetln(Line);
if (GetServerStatus(Line, NULL) == 1)
{
- SieveRules = NewHash(1, Flathash);
-
while(!Done && (StrBuf_ServGetln(Line) >= 0) )
if ( (StrLength(Line)==3) &&
!strcmp(ChrPtr(Line), "000"))
@@ -1602,32 +1581,25 @@ HashList *GetSieveRules(StrBuf *Target, WCTemplputParams *TP)
StrBufExtract_NextToken(Line, EncodedRule, &pch, '|');
Rule->final = (eSieveFinal) GetTokenDefine(SKEY(Line), econtinue);
Put(SieveRules, IKEY(n), Rule, FreeSieveRule);
+ n++;
}
}
}
+ while (n < MAX_RULES) {
+ Rule = (SieveRule*) malloc(sizeof(SieveRule));
+ memset(Rule, 0, sizeof(SieveRule));
+ Put(SieveRules, IKEY(n), Rule, FreeSieveRule);
+
+ n++;
+ }
+
+
FreeStrBuf(&EncodedRule);
FreeStrBuf(&Line);
return SieveRules;
}
-
-HashList *GetEmptySieveRule(StrBuf *Target, WCTemplputParams *TP)
-{
- int n = 0;
- HashList *OneSieveRule;
- SieveRule *Rule;
-
- OneSieveRule = NewHash(1, Flathash);
-
- /* We just care for our encoded header and skip everything else */
- Rule = (SieveRule*) malloc(sizeof(SieveRule));
- memset(Rule, 0, sizeof(SieveRule));
- Put(OneSieveRule, IKEY(n), Rule, FreeSieveRule);
-
- return OneSieveRule;
-}
-
void
SessionDetachModule_SIEVE
(wcsession *sess)
@@ -1685,7 +1657,6 @@ InitModule_SIEVE
RegisterIterator("SIEVE:RULES", 0, NULL, GetSieveRules, NULL, DeleteHash, CTX_SIEVESCRIPT, CTX_NONE, IT_NOFLAG);
- RegisterIterator("SIEVE:RULE:EMPTY", 0, NULL, GetEmptySieveRule, NULL, DeleteHash, CTX_SIEVESCRIPT, CTX_NONE, IT_NOFLAG);
RegisterConditional(HKEY("COND:SIEVE:ACTIVE"), 1, ConditionalSieveRule_Active, CTX_SIEVESCRIPT);
RegisterConditional(HKEY("COND:SIEVE:HFIELD"), 1, ConditionalSieveRule_hfield, CTX_SIEVESCRIPT);
@@ -1695,15 +1666,12 @@ InitModule_SIEVE
RegisterConditional(HKEY("COND:SIEVE:FINAL"), 1, ConditionalSieveRule_final, CTX_SIEVESCRIPT);
RegisterConditional(HKEY("COND:SIEVE:THISROOM"), 1, ConditionalSieveRule_ThisRoom, CTX_SIEVESCRIPT);
- //RegisterNamespace("SIEVE:SCRIPT:HFIELD", 0, 1, tmplput_SieveRule_hfield, NULL, CTX_SIEVESCRIPT);
- //RegisterNamespace("SIEVE:SCRIPT:COMPARE", 0, 1, tmplput_SieveRule_compare, NULL, CTX_SIEVESCRIPT);
RegisterNamespace("SIEVE:SCRIPT:HTEXT", 0, 1, tmplput_SieveRule_htext, NULL, CTX_SIEVESCRIPT);
RegisterNamespace("SIEVE:SCRIPT:SIZE", 0, 1, tmplput_SieveRule_sizeval, NULL, CTX_SIEVESCRIPT);
- ///RegisterNamespace("SIEVE:SCRIPT:ACTION", 0, 1, tmplput_SieveRule_action, NULL, CTX_SIEVESCRIPT);
RegisterNamespace("SIEVE:SCRIPT:FILEINTO", 0, 1, tmplput_SieveRule_fileinto, NULL, CTX_SIEVESCRIPT);
RegisterNamespace("SIEVE:SCRIPT:REDIRECT", 0, 1, tmplput_SieveRule_redirect, NULL, CTX_SIEVESCRIPT);
RegisterNamespace("SIEVE:SCRIPT:AUTOMSG", 0, 1, tmplput_SieveRule_automsg, NULL, CTX_SIEVESCRIPT);
- ///RegisterNamespace("SIEVE:SCRIPT:FINAL", 0, 1, tmplput_SieveRule_final, NULL, CTX_SIEVESCRIPT);
+
/* fetch our room into WCC->ThisRoom, to evaluate while iterating over rooms with COND:THIS:THAT:ROOM */
RegisterNamespace("SIEVE:SCRIPT:LOOKUP_FILEINTO", 0, 1, tmplput_SieveRule_lookup_FileIntoRoom, NULL, CTX_SIEVESCRIPT);