X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fmsg_renderers.c;h=e16ae34bae60bad33ce3e66ce478460d28e0d85a;hb=c13875c0b9e4b352589bc6c2de0d60a4de7f304a;hp=abf6b55e4d834d863da3c94fbb8b84cd699d85ab;hpb=77ad06c3f4bf4d2a4e3a7ff82ec94fcdff343273;p=citadel.git diff --git a/webcit/msg_renderers.c b/webcit/msg_renderers.c index abf6b55e4..e16ae34ba 100644 --- a/webcit/msg_renderers.c +++ b/webcit/msg_renderers.c @@ -1,8 +1,8 @@ -/*----------------------------------------------------------------------------*/ #include "webcit.h" #include "webserver.h" +#include "groupdav.h" -/** +/* * message index functions */ @@ -124,6 +124,17 @@ int summcmp_rsubj(const void *s1, const void *s2) { summ2 = (message_summary *)GetSearchPayload(s2); return strcasecmp(ChrPtr(summ2->subj), ChrPtr(summ1->subj)); } +/* + * comparator for message summary structs by descending subject. + */ +int groupchange_subj(const void *s1, const void *s2) { + message_summary *summ1; + message_summary *summ2; + + summ1 = (message_summary *)s1; + summ2 = (message_summary *)s2; + return ChrPtr(summ2->subj)[0] != ChrPtr(summ1->subj)[0]; +} /* * comparator for message summary structs by ascending sender. @@ -148,6 +159,18 @@ int summcmp_rsender(const void *s1, const void *s2) { summ2 = (message_summary *)GetSearchPayload(s2); return strcasecmp(ChrPtr(summ2->from), ChrPtr(summ1->from)); } +/* + * comparator for message summary structs by descending sender. + */ +int groupchange_sender(const void *s1, const void *s2) { + message_summary *summ1; + message_summary *summ2; + + summ1 = (message_summary *)s1; + summ2 = (message_summary *)s2; + return strcasecmp(ChrPtr(summ2->from), ChrPtr(summ1->from)) != 0; + +} /* * comparator for message summary structs by ascending date. @@ -179,6 +202,21 @@ int summcmp_rdate(const void *s1, const void *s2) { else return 0; } +/* + * comparator for message summary structs by descending date. + */ +const long DAYSECONDS = 24 * 60 * 60; +int groupchange_date(const void *s1, const void *s2) { + message_summary *summ1; + message_summary *summ2; + + summ1 = (message_summary *)s1; + summ2 = (message_summary *)s2; + + return (summ1->date % DAYSECONDS) != (summ2->date %DAYSECONDS); +} + + /*----------------------------------------------------------------------------*/ /* Don't wanna know... or? */ void examine_pref(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) {return;} @@ -195,13 +233,12 @@ void examine_nhdr(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) if (!strncasecmp(ChrPtr(HdrLine), "yes", 8)) Msg->nhdr = 1; } -int Conditional_ANONYMOUS_MESSAGE(WCTemplateToken *Tokens, void *Context, int ContextType) +int Conditional_ANONYMOUS_MESSAGE(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; + message_summary *Msg = (message_summary*) CTX; return Msg->nhdr != 0; } - void examine_type(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) { Msg->format_type = StrToi(HdrLine); @@ -214,10 +251,10 @@ void examine_from(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) Msg->from = NewStrBufPlain(NULL, StrLength(HdrLine)); StrBuf_RFC822_to_Utf8(Msg->from, HdrLine, WC->DefaultCharset, FoundCharset); } -void tmplput_MAIL_SUMM_FROM(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MAIL_SUMM_FROM(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, Msg->from, 0); + message_summary *Msg = (message_summary*) CTX; + StrBufAppendTemplate(Target, TP, Msg->from, 0); } @@ -228,11 +265,16 @@ void examine_subj(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) Msg->subj = NewStrBufPlain(NULL, StrLength(HdrLine)); StrBuf_RFC822_to_Utf8(Msg->subj, HdrLine, WC->DefaultCharset, FoundCharset); } -void tmplput_MAIL_SUMM_SUBJECT(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MAIL_SUMM_SUBJECT(StrBuf *Target, WCTemplputParams *TP) {/*////TODO: Fwd: and RE: filter!!*/ - message_summary *Msg = (message_summary*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, Msg->subj, 0); + message_summary *Msg = (message_summary*) CTX; + StrBufAppendTemplate(Target, TP, Msg->subj, 0); +} +int Conditional_MAIL_SUMM_SUBJECT(StrBuf *Target, WCTemplputParams *TP) +{ + message_summary *Msg = (message_summary*) CTX; + return StrLength(Msg->subj) > 0; } @@ -242,15 +284,15 @@ void examine_msgn(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) Msg->reply_inreplyto = NewStrBufPlain(NULL, StrLength(HdrLine)); StrBuf_RFC822_to_Utf8(Msg->reply_inreplyto, HdrLine, WC->DefaultCharset, FoundCharset); } -void tmplput_MAIL_SUMM_INREPLYTO(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MAIL_SUMM_INREPLYTO(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, Msg->reply_inreplyto, 0); + message_summary *Msg = (message_summary*) CTX; + StrBufAppendTemplate(Target, TP, Msg->reply_inreplyto, 0); } -int Conditional_MAIL_SUMM_UNREAD(WCTemplateToken *Tokens, void *Context, int ContextType) +int Conditional_MAIL_SUMM_UNREAD(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; + message_summary *Msg = (message_summary*) CTX; return Msg->is_new != 0; } @@ -260,10 +302,10 @@ void examine_wefw(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) Msg->reply_references = NewStrBufPlain(NULL, StrLength(HdrLine)); StrBuf_RFC822_to_Utf8(Msg->reply_references, HdrLine, WC->DefaultCharset, FoundCharset); } -void tmplput_MAIL_SUMM_REFIDS(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MAIL_SUMM_REFIDS(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, Msg->reply_references, 0); + message_summary *Msg = (message_summary*) CTX; + StrBufAppendTemplate(Target, TP, Msg->reply_references, 0); } @@ -279,25 +321,25 @@ void examine_cccc(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) } StrBufAppendBuf(Msg->AllRcpt, Msg->cccc, 0); } -void tmplput_MAIL_SUMM_CCCC(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MAIL_SUMM_CCCC(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, Msg->cccc, 0); + message_summary *Msg = (message_summary*) CTX; + StrBufAppendTemplate(Target, TP, Msg->cccc, 0); } void examine_room(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) { if ((StrLength(HdrLine) > 0) && - (strcasecmp(ChrPtr(HdrLine), WC->wc_roomname))) { + (strcasecmp(ChrPtr(HdrLine), ChrPtr(WC->wc_roomname)))) { FreeStrBuf(&Msg->Room); Msg->Room = NewStrBufDup(HdrLine); } } -void tmplput_MAIL_SUMM_ORGROOM(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MAIL_SUMM_ORGROOM(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, Msg->Room, 0); + message_summary *Msg = (message_summary*) CTX; + StrBufAppendTemplate(Target, TP, Msg->Room, 0); } @@ -306,35 +348,42 @@ void examine_rfca(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) FreeStrBuf(&Msg->Rfca); Msg->Rfca = NewStrBufDup(HdrLine); } -void tmplput_MAIL_SUMM_RFCA(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MAIL_SUMM_RFCA(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, Msg->Rfca, 0); + message_summary *Msg = (message_summary*) CTX; + StrBufAppendTemplate(Target, TP, Msg->Rfca, 0); } -int Conditional_MAIL_SUMM_RFCA(WCTemplateToken *Tokens, void *Context, int ContextType) +int Conditional_MAIL_SUMM_RFCA(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; + message_summary *Msg = (message_summary*) CTX; return StrLength(Msg->Rfca) > 0; } +int Conditional_MAIL_SUMM_CCCC(StrBuf *Target, WCTemplputParams *TP) +{ + message_summary *Msg = (message_summary*) CTX; + return StrLength(Msg->cccc) > 0; +} void examine_node(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) { + wcsession *WCC = WC; + if ( (StrLength(HdrLine) > 0) && ((WC->room_flags & QR_NETWORK) - || ((strcasecmp(ChrPtr(HdrLine), serv_info.serv_nodename) - && (strcasecmp(ChrPtr(HdrLine), serv_info.serv_fqdn)))))) { + || ((strcasecmp(ChrPtr(HdrLine), ChrPtr(WCC->serv_info->serv_nodename)) + && (strcasecmp(ChrPtr(HdrLine), ChrPtr(WCC->serv_info->serv_fqdn))))))) { FreeStrBuf(&Msg->OtherNode); Msg->OtherNode = NewStrBufDup(HdrLine); } } -void tmplput_MAIL_SUMM_OTHERNODE(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MAIL_SUMM_OTHERNODE(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, Msg->OtherNode, 0); + message_summary *Msg = (message_summary*) CTX; + StrBufAppendTemplate(Target, TP, Msg->OtherNode, 0); } -int Conditional_MAIL_SUMM_OTHERNODE(WCTemplateToken *Tokens, void *Context, int ContextType) +int Conditional_MAIL_SUMM_OTHERNODE(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; + message_summary *Msg = (message_summary*) CTX; return StrLength(Msg->OtherNode) > 0; } @@ -351,37 +400,61 @@ void examine_rcpt(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) } StrBufAppendBuf(Msg->AllRcpt, Msg->to, 0); } -void tmplput_MAIL_SUMM_TO(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MAIL_SUMM_TO(StrBuf *Target, WCTemplputParams *TP) +{ + message_summary *Msg = (message_summary*) CTX; + StrBufAppendTemplate(Target, TP, Msg->to, 0); +} +int Conditional_MAIL_SUMM_TO(StrBuf *Target, WCTemplputParams *TP) +{ + message_summary *Msg = (message_summary*) CTX; + return StrLength(Msg->to) != 0; +} +int Conditional_MAIL_SUMM_SUBJ(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, Msg->to, 0); + message_summary *Msg = (message_summary*) CTX; + return StrLength(Msg->subj) != 0; } -void tmplput_MAIL_SUMM_ALLRCPT(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MAIL_SUMM_ALLRCPT(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, Msg->AllRcpt, 0); + message_summary *Msg = (message_summary*) CTX; + StrBufAppendTemplate(Target, TP, Msg->AllRcpt, 0); } -HashList *iterate_get_mailsumm_All(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) + +void tmplput_SUMM_COUNT(StrBuf *Target, WCTemplputParams *TP) { - return WC->summ; + StrBufAppendPrintf(Target, "%d", GetCount( WC->summ)); } +HashList *iterate_get_mailsumm_All(StrBuf *Target, WCTemplputParams *TP) +{ + return WC->summ; +} void examine_time(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) { Msg->date = StrTol(HdrLine); } -void tmplput_MAIL_SUMM_DATE_STR(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) + +void tmplput_MAIL_SUMM_DATE_BRIEF(StrBuf *Target, WCTemplputParams *TP) +{ + char datebuf[64]; + message_summary *Msg = (message_summary*) CTX; + webcit_fmt_date(datebuf, 64, Msg->date, DATEFMT_BRIEF); + StrBufAppendBufPlain(Target, datebuf, -1, 0); +} + +void tmplput_MAIL_SUMM_DATE_FULL(StrBuf *Target, WCTemplputParams *TP) { char datebuf[64]; - message_summary *Msg = (message_summary*) Context; - webcit_fmt_date(datebuf, Msg->date, 1); + message_summary *Msg = (message_summary*) CTX; + webcit_fmt_date(datebuf, 64, Msg->date, DATEFMT_FULL); StrBufAppendBufPlain(Target, datebuf, -1, 0); } -void tmplput_MAIL_SUMM_DATE_NO(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MAIL_SUMM_DATE_NO(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; + message_summary *Msg = (message_summary*) CTX; StrBufAppendPrintf(Target, "%ld", Msg->date, 0); } @@ -389,8 +462,10 @@ void tmplput_MAIL_SUMM_DATE_NO(StrBuf *Target, int nArgs, WCTemplateToken *Token void render_MAIL(wc_mime_attachment *Mime, StrBuf *RawData, StrBuf *FoundCharset) { + const StrBuf *TemplateMime; + Mime->Data = NewStrBufPlain(NULL, Mime->length); - read_message(Mime->Data, HKEY("view_submessage"), Mime->msgnum, 0, Mime->PartNum); + read_message(Mime->Data, HKEY("view_submessage"), Mime->msgnum, Mime->PartNum, &TemplateMime); /* if ( (!IsEmptyStr(mime_submessages)) && (!section[0]) ) { for (i=0; iData) > 0) { StrBuf *Buf; Buf = NewStrBuf(); /** If it's my vCard I can edit it */ - if ( (!strcasecmp(WC->wc_roomname, USERCONFIGROOM)) - || (!strcasecmp(&WC->wc_roomname[11], USERCONFIGROOM)) + if ( (!strcasecmp(ChrPtr(WCC->wc_roomname), USERCONFIGROOM)) + || (!strcasecmp(&(ChrPtr(WCC->wc_roomname)[11]), USERCONFIGROOM)) || (WC->wc_view == VIEW_ADDRESSBOOK) ) { StrBufAppendPrintf(Buf, "", @@ -421,15 +497,48 @@ void render_MIME_VCard(wc_mime_attachment *Mime, StrBuf *RawData, StrBuf *FoundC } /* In all cases, display the full card */ - display_vcard(Buf, ChrPtr(Mime->Data), 0, 1, NULL, Mime->msgnum); + display_vcard(Buf, Mime->Data, 0, 1, NULL, Mime->msgnum); FreeStrBuf(&Mime->Data); Mime->Data = Buf; } } -void render_MIME_ICS(wc_mime_attachment *Mime, StrBuf *RawData, StrBuf *FoundCharset) + +void render_MIME_VNote(wc_mime_attachment *Mime, StrBuf *RawData, StrBuf *FoundCharset) { MimeLoadData(Mime); + if (StrLength(Mime->Data) > 0) { + struct vnote *v; + StrBuf *Buf; + char *vcard; + + Buf = NewStrBuf(); + vcard = SmashStrBuf(&Mime->Data); + v = vnote_new_from_str(vcard); + free (vcard); + if (v) { + WCTemplputParams TP; + + memset(&TP, 0, sizeof(WCTemplputParams)); + TP.Filter.ContextType = CTX_VNOTE; + TP.Context = v; + DoTemplate(HKEY("mail_vnoteitem"), + Buf, &TP); + + vnote_free(v); + Mime->Data = Buf; + } + else + Mime->Data = NewStrBuf(); + } + +} + +void render_MIME_ICS(wc_mime_attachment *Mime, StrBuf *RawData, StrBuf *FoundCharset) +{ + if (StrLength(Mime->Data) == 0) { + MimeLoadData(Mime); + } if (StrLength(Mime->Data) > 0) { cal_process_attachment(Mime); } @@ -460,7 +569,7 @@ void examine_mime_part(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundChars Mime->PartNum = NewStrBuf(); StrBufExtract_token(Mime->PartNum, HdrLine, 2, '|'); StrBufTrim(Mime->PartNum); - if (strchr(ChrPtr(Mime->PartNum), '.') != NULL) + if (strchr(ChrPtr(Mime->PartNum), '.') != NULL) Mime->level = 2; else Mime->level = 1; @@ -473,6 +582,10 @@ void examine_mime_part(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundChars StrBufTrim(Mime->ContentType); StrBufLowerCase(Mime->ContentType); + if (!strcmp(ChrPtr(Mime->ContentType), "application/octet-stream")) { + StrBufPlain(Mime->ContentType, + GuessMimeByFilename(SKEY(Mime->FileName)), -1); + } Mime->length = StrBufExtract_int(HdrLine, 5, '|'); if ( (StrLength(Mime->FileName) == 0) && (StrLength(Mime->Name) > 0) ) { @@ -534,9 +647,9 @@ void evaluate_mime_part(message_summary *Msg, wc_mime_attachment *Mime) } } -void tmplput_MAIL_SUMM_NATTACH(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MAIL_SUMM_NATTACH(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; + message_summary *Msg = (message_summary*) CTX; StrBufAppendPrintf(Target, "%ld", GetCount(Msg->Attachments)); } @@ -547,14 +660,14 @@ void examine_hnod(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) Msg->hnod = NewStrBufPlain(NULL, StrLength(HdrLine)); StrBuf_RFC822_to_Utf8(Msg->hnod, HdrLine, WC->DefaultCharset, FoundCharset); } -void tmplput_MAIL_SUMM_H_NODE(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MAIL_SUMM_H_NODE(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, Msg->hnod, 0); + message_summary *Msg = (message_summary*) CTX; + StrBufAppendTemplate(Target, TP, Msg->hnod, 0); } -int Conditional_MAIL_SUMM_H_NODE(WCTemplateToken *Tokens, void *Context, int ContextType) +int Conditional_MAIL_SUMM_H_NODE(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; + message_summary *Msg = (message_summary*) CTX; return StrLength(Msg->hnod) > 0; } @@ -562,7 +675,7 @@ int Conditional_MAIL_SUMM_H_NODE(WCTemplateToken *Tokens, void *Context, int Con void examine_text(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) { - Msg->MsgBody->Data = NewStrBuf(); + Msg->MsgBody->Data = NewStrBufPlain(NULL, SIZ); } void examine_msg4_partnum(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) @@ -571,7 +684,6 @@ void examine_msg4_partnum(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCh StrBufTrim(Msg->MsgBody->PartNum); } - void examine_content_lengh(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) { Msg->MsgBody->length = StrTol(HdrLine); @@ -629,57 +741,83 @@ void examine_content_type(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCh } } -void tmplput_MAIL_SUMM_N(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MAIL_SUMM_N(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; + message_summary *Msg = (message_summary*) CTX; StrBufAppendPrintf(Target, "%ld", Msg->msgnum); } -int Conditional_MAIL_MIME_ALL(WCTemplateToken *Tokens, void *Context, int ContextType) +int Conditional_MAIL_MIME_ALL(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; + message_summary *Msg = (message_summary*) CTX; return GetCount(Msg->Attachments) > 0; } -int Conditional_MAIL_MIME_SUBMESSAGES(WCTemplateToken *Tokens, void *Context, int ContextType) +int Conditional_MAIL_MIME_SUBMESSAGES(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; + message_summary *Msg = (message_summary*) CTX; return GetCount(Msg->Submessages) > 0; } -int Conditional_MAIL_MIME_ATTACHLINKS(WCTemplateToken *Tokens, void *Context, int ContextType) +int Conditional_MAIL_MIME_ATTACHLINKS(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; + message_summary *Msg = (message_summary*) CTX; return GetCount(Msg->AttachLinks) > 0; } -int Conditional_MAIL_MIME_ATTACH(WCTemplateToken *Tokens, void *Context, int ContextType) +int Conditional_MAIL_MIME_ATTACH(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; + message_summary *Msg = (message_summary*) CTX; return GetCount(Msg->AllAttach) > 0; } +void tmplput_QUOTED_MAIL_BODY(StrBuf *Target, WCTemplputParams *TP) +{ + const StrBuf *Mime; + long MsgNum; + StrBuf *Buf; + MsgNum = LBstr(TKEY(0)); + Buf = NewStrBuf(); + read_message(Buf, HKEY("view_message_replyquote"), MsgNum, NULL, &Mime); + StrBufAppendTemplate(Target, TP, Buf, 1); + FreeStrBuf(&Buf); +} -/*----------------------------------------------------------------------------*/ -void tmplput_QUOTED_MAIL_BODY(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_EDIT_MAIL_BODY(StrBuf *Target, WCTemplputParams *TP) { - long MsgNum; + const StrBuf *Mime; + long MsgNum; StrBuf *Buf; MsgNum = LBstr(TKEY(0)); Buf = NewStrBuf(); - read_message(Buf, HKEY("view_message_replyquote"), MsgNum, 0, NULL); - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, Buf, 1); + read_message(Buf, HKEY("view_message_edit"), MsgNum, NULL, &Mime); + StrBufAppendTemplate(Target, TP, Buf, 1); FreeStrBuf(&Buf); } -void tmplput_MAIL_BODY(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_EDIT_WIKI_BODY(StrBuf *Target, WCTemplputParams *TP) // FIXME +{ + const StrBuf *Mime; + long msgnum; + StrBuf *Buf; + + msgnum = locate_message_by_uid(BSTR("wikipage")); + if (msgnum >= 0L) { + Buf = NewStrBuf(); + read_message(Buf, HKEY("view_message_wikiedit"), msgnum, NULL, &Mime); + StrBufAppendTemplate(Target, TP, Buf, 1); + FreeStrBuf(&Buf); + } +} + +void tmplput_MAIL_BODY(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, Msg->MsgBody->Data, 0); + message_summary *Msg = (message_summary*) CTX; + StrBufAppendTemplate(Target, TP, Msg->MsgBody->Data, 0); } @@ -694,7 +832,6 @@ void render_MAIL_variformat(wc_mime_attachment *Mime, StrBuf *RawData, StrBuf *F void render_MAIL_text_plain(wc_mime_attachment *Mime, StrBuf *RawData, StrBuf *FoundCharset) { - StrBuf *cs = NULL; const char *ptr, *pte; const char *BufPtr = NULL; StrBuf *Line; @@ -702,27 +839,21 @@ void render_MAIL_text_plain(wc_mime_attachment *Mime, StrBuf *RawData, StrBuf *F StrBuf *Line2; StrBuf *Target; - int ConvertIt = 1; int bn = 0; int bq = 0; - int i, n, done = 0; + int i; long len; #ifdef HAVE_ICONV + StrBuf *cs = NULL; + int ConvertIt = 1; iconv_t ic = (iconv_t)(-1) ; #endif if ((StrLength(Mime->Data) == 0) && (Mime->length > 0)) { FreeStrBuf(&Mime->Data); - Mime->Data = NewStrBufPlain(NULL, Mime->length); - if (!read_message(Mime->Data, HKEY("view_submessage"), Mime->msgnum, 0, Mime->PartNum)) - return; + MimeLoadData(Mime); } - /* Boring old 80-column fixed format text gets handled this way... */ - if ((strcasecmp(ChrPtr(Mime->Charset), "us-ascii") == 0) && - (strcasecmp(ChrPtr(Mime->Charset), "UTF-8") == 0)) - ConvertIt = 0; - #ifdef HAVE_ICONV if (ConvertIt) { if (StrLength(Mime->Charset) != 0) @@ -734,6 +865,12 @@ void render_MAIL_text_plain(wc_mime_attachment *Mime, StrBuf *RawData, StrBuf *F if (cs == NULL) { ConvertIt = 0; } + else if (!strcasecmp(ChrPtr(cs), "utf-8")) { + ConvertIt = 0; + } + else if (!strcasecmp(ChrPtr(cs), "us-ascii")) { + ConvertIt = 0; + } else { ctdl_iconv_open("UTF-8", ChrPtr(cs), &ic); if (ic == (iconv_t)(-1) ) { @@ -743,50 +880,55 @@ void render_MAIL_text_plain(wc_mime_attachment *Mime, StrBuf *RawData, StrBuf *F } } #endif - Line = NewStrBuf(); - Line1 = NewStrBuf(); - Line2 = NewStrBuf(); + Line = NewStrBufPlain(NULL, SIZ); + Line1 = NewStrBufPlain(NULL, SIZ); + Line2 = NewStrBufPlain(NULL, SIZ); Target = NewStrBufPlain(NULL, StrLength(Mime->Data)); - while ((n = StrBufSipLine(Line, Mime->Data, &BufPtr), n >= 0) && !done) - { - done = n == 0; - bq = 0; - i = 0; - ptr = ChrPtr(Line); - len = StrLength(Line); - pte = ptr + len; - - while ((ptr < pte) && - ((*ptr == '>') || - isspace(*ptr))) + if (StrLength(Mime->Data) > 0) + do { - if (*ptr == '>') - bq++; - ptr ++; - i++; - } - if (i > 0) StrBufCutLeft(Line, i); + StrBufSipLine(Line, Mime->Data, &BufPtr); + bq = 0; + i = 0; + ptr = ChrPtr(Line); + len = StrLength(Line); + pte = ptr + len; + + while ((ptr < pte) && + ((*ptr == '>') || + isspace(*ptr))) + { + if (*ptr == '>') + bq++; + ptr ++; + i++; + } + if (i > 0) StrBufCutLeft(Line, i); - if (StrLength(Line) == 0) - continue; + if (StrLength(Line) == 0) { + StrBufAppendBufPlain(Target, HKEY("
\n"), 0); + continue; + } - for (i = bn; i < bq; i++) - StrBufAppendBufPlain(Target, HKEY("
"), 0); - for (i = bq; i < bn; i++) - StrBufAppendBufPlain(Target, HKEY("
"), 0); + for (i = bn; i < bq; i++) + StrBufAppendBufPlain(Target, HKEY("
"), 0); + for (i = bq; i < bn; i++) + StrBufAppendBufPlain(Target, HKEY("
"), 0); +#ifdef HAVE_ICONV + if (ConvertIt) { + StrBufConvert(Line, Line1, &ic); + } +#endif + StrBufAppendBufPlain(Target, HKEY(""), 0); + UrlizeText(Line1, Line, Line2); - if (ConvertIt == 1) { - StrBufConvert(Line, Line1, &ic); + StrEscAppend(Target, Line1, NULL, 0, 0); + StrBufAppendBufPlain(Target, HKEY("
\n"), 0); + bn = bq; } - - StrBufAppendBufPlain(Target, HKEY(""), 0); - UrlizeText(Line1, Line, Line2); - - StrEscAppend(Target, Line1, NULL, 0, 0); - StrBufAppendBufPlain(Target, HKEY("
\n"), 0); - bn = bq; - } + while ((BufPtr != StrBufNOTNULL) && + (BufPtr != NULL)); for (i = 0; i < bn; i++) StrBufAppendBufPlain(Target, HKEY(""), 0); @@ -797,8 +939,13 @@ void render_MAIL_text_plain(wc_mime_attachment *Mime, StrBuf *RawData, StrBuf *F iconv_close(ic); } #endif + FreeStrBuf(&Mime->Data); Mime->Data = Target; + FlushStrBuf(Mime->ContentType); + StrBufAppendBufPlain(Mime->ContentType, HKEY("text/html"), 0); + FlushStrBuf(Mime->Charset); + StrBufAppendBufPlain(Mime->Charset, HKEY("UTF-8"), 0); FreeStrBuf(&Line); FreeStrBuf(&Line1); FreeStrBuf(&Line2); @@ -807,15 +954,16 @@ void render_MAIL_text_plain(wc_mime_attachment *Mime, StrBuf *RawData, StrBuf *F void render_MAIL_html(wc_mime_attachment *Mime, StrBuf *RawData, StrBuf *FoundCharset) { StrBuf *Buf; - /* HTML is fun, but we've got to strip it first */ + if (StrLength(Mime->Data) == 0) return; Buf = NewStrBufPlain(NULL, StrLength(Mime->Data)); + /* HTML is fun, but we've got to strip it first */ output_html(ChrPtr(Mime->Charset), (WC->wc_view == VIEW_WIKI ? 1 : 0), - StrToi(Mime->PartNum), + Mime->msgnum, Mime->Data, Buf); FreeStrBuf(&Mime->Data); Mime->Data = Buf; @@ -831,65 +979,61 @@ void render_MAIL_UNKNOWN(wc_mime_attachment *Mime, StrBuf *RawData, StrBuf *Foun } - - - - -HashList *iterate_get_mime_All(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +HashList *iterate_get_mime_All(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; + message_summary *Msg = (message_summary*) CTX; return Msg->Attachments; } -HashList *iterate_get_mime_Submessages(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +HashList *iterate_get_mime_Submessages(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; + message_summary *Msg = (message_summary*) CTX; return Msg->Submessages; } -HashList *iterate_get_mime_AttachLinks(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +HashList *iterate_get_mime_AttachLinks(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; + message_summary *Msg = (message_summary*) CTX; return Msg->AttachLinks; } -HashList *iterate_get_mime_Attachments(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +HashList *iterate_get_mime_Attachments(StrBuf *Target, WCTemplputParams *TP) { - message_summary *Msg = (message_summary*) Context; + message_summary *Msg = (message_summary*) CTX; return Msg->AllAttach; } -void tmplput_MIME_Name(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MIME_Name(StrBuf *Target, WCTemplputParams *TP) { - wc_mime_attachment *mime = (wc_mime_attachment*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, mime->Name, 0); + wc_mime_attachment *mime = (wc_mime_attachment*) CTX; + StrBufAppendTemplate(Target, TP, mime->Name, 0); } -void tmplput_MIME_FileName(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MIME_FileName(StrBuf *Target, WCTemplputParams *TP) { - wc_mime_attachment *mime = (wc_mime_attachment*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, mime->FileName, 0); + wc_mime_attachment *mime = (wc_mime_attachment*) CTX; + StrBufAppendTemplate(Target, TP, mime->FileName, 0); } -void tmplput_MIME_PartNum(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MIME_PartNum(StrBuf *Target, WCTemplputParams *TP) { - wc_mime_attachment *mime = (wc_mime_attachment*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, mime->PartNum, 0); + wc_mime_attachment *mime = (wc_mime_attachment*) CTX; + StrBufAppendTemplate(Target, TP, mime->PartNum, 0); } -void tmplput_MIME_MsgNum(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MIME_MsgNum(StrBuf *Target, WCTemplputParams *TP) { - wc_mime_attachment *mime = (wc_mime_attachment*) Context; + wc_mime_attachment *mime = (wc_mime_attachment*) CTX; StrBufAppendPrintf(Target, "%ld", mime->msgnum); } -void tmplput_MIME_Disposition(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MIME_Disposition(StrBuf *Target, WCTemplputParams *TP) { - wc_mime_attachment *mime = (wc_mime_attachment*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, mime->Disposition, 0); + wc_mime_attachment *mime = (wc_mime_attachment*) CTX; + StrBufAppendTemplate(Target, TP, mime->Disposition, 0); } -void tmplput_MIME_ContentType(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MIME_ContentType(StrBuf *Target, WCTemplputParams *TP) { - wc_mime_attachment *mime = (wc_mime_attachment*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, mime->ContentType, 0); + wc_mime_attachment *mime = (wc_mime_attachment*) CTX; + StrBufAppendTemplate(Target, TP, mime->ContentType, 0); } void examine_charset(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset) @@ -897,25 +1041,25 @@ void examine_charset(message_summary *Msg, StrBuf *HdrLine, StrBuf *FoundCharset Msg->MsgBody->Charset = NewStrBufDup(HdrLine); } -void tmplput_MIME_Charset(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MIME_Charset(StrBuf *Target, WCTemplputParams *TP) { - wc_mime_attachment *mime = (wc_mime_attachment*) Context; - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, mime->Charset, 0); + wc_mime_attachment *mime = (wc_mime_attachment*) CTX; + StrBufAppendTemplate(Target, TP, mime->Charset, 0); } -void tmplput_MIME_Data(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MIME_Data(StrBuf *Target, WCTemplputParams *TP) { - wc_mime_attachment *mime = (wc_mime_attachment*) Context; + wc_mime_attachment *mime = (wc_mime_attachment*) CTX; if (mime->Renderer != NULL) mime->Renderer->f(mime, NULL, NULL); - StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, mime->Data, 0); + StrBufAppendTemplate(Target, TP, mime->Data, 0); /* TODO: check whether we need to load it now? */ } -void tmplput_MIME_LoadData(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MIME_LoadData(StrBuf *Target, WCTemplputParams *TP) { wcsession *WCC = WC; - wc_mime_attachment *mime = (wc_mime_attachment*) Context; + wc_mime_attachment *mime = (wc_mime_attachment*) CTX; wc_mime_attachment *att; if ( (!strcasecmp(ChrPtr(mime->Disposition), "inline"))|| @@ -940,13 +1084,105 @@ void tmplput_MIME_LoadData(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, v } } -void tmplput_MIME_Length(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +void tmplput_MIME_Length(StrBuf *Target, WCTemplputParams *TP) { - wc_mime_attachment *mime = (wc_mime_attachment*) Context; + wc_mime_attachment *mime = (wc_mime_attachment*) CTX; StrBufAppendPrintf(Target, "%ld", mime->length); } -HashList *iterate_get_registered_Attachments(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType) +/* startmsg is an index within the message list. + * starting_from is the Citadel message number to be supplied to a "MSGS GT" operation + */ +long DrawMessageDropdown(StrBuf *Selector, long maxmsgs, long startmsg, int nMessages, long starting_from) +{ + StrBuf *TmpBuf; + wcsession *WCC = WC; + void *vMsg; + int lo, hi; + long ret; + long hklen; + const char *key; + int done = 0; + int nItems; + HashPos *At; + long vector[16]; + WCTemplputParams SubTP; + + memset(&SubTP, 0, sizeof(WCTemplputParams)); + SubTP.Filter.ContextType = CTX_LONGVECTOR; + SubTP.Context = &vector; + TmpBuf = NewStrBufPlain(NULL, SIZ); + At = GetNewHashPos(WCC->summ, nMessages); + nItems = GetCount(WCC->summ); + ret = nMessages; + vector[0] = 7; + vector[2] = 1; + vector[1] = startmsg; + vector[3] = 0; + vector[7] = starting_from; + + while (!done) { + vector[3] = abs(nMessages); + lo = GetHashPosCounter(At); + if (nMessages > 0) { + if (lo + nMessages >= nItems) { + hi = nItems - 1; + vector[3] = nItems - lo; + if (startmsg == lo) + ret = vector[3]; + } + else { + hi = lo + nMessages - 1; + } + } else { + if (lo + nMessages < -1) { + hi = 0; + } + else { + if ((lo % abs(nMessages)) != 0) { + int offset = (lo % abs(nMessages) * + (nMessages / abs(nMessages))); + hi = lo + offset; + vector[3] = abs(offset); + if (startmsg == lo) + ret = offset; + } + else + hi = lo + nMessages; + } + } + done = !GetNextHashPos(WCC->summ, At, &hklen, &key, &vMsg); + + /* + * Bump these because although we're thinking in zero base, the user + * is a drooling idiot and is thinking in one base. + */ + vector[4] = lo + 1; + vector[5] = hi + 1; + vector[6] = lo; + FlushStrBuf(TmpBuf); + dbg_print_longvector(vector); + DoTemplate(HKEY("select_messageindex"), TmpBuf, &SubTP); + StrBufAppendBuf(Selector, TmpBuf, 0); + } + vector[6] = 0; + FlushStrBuf(TmpBuf); + if (maxmsgs == 9999999) { + vector[1] = 1; + ret = maxmsgs; + } + else + vector[1] = 0; + vector[2] = 0; + dbg_print_longvector(vector); + DoTemplate(HKEY("select_messageindex_all"), TmpBuf, &SubTP); + StrBufAppendBuf(Selector, TmpBuf, 0); + FreeStrBuf(&TmpBuf); + DeleteHashPos(&At); + return ret; +} + +HashList *iterate_get_registered_Attachments(StrBuf *Target, WCTemplputParams *TP) { return WC->attachments; } @@ -966,6 +1202,11 @@ void servcmd_readfwd(char *buf, long bufsize) snprintf(buf, bufsize, "MSGS ALL"); } +void servcmd_readgt(char *buf, long bufsize) +{ + snprintf(buf, bufsize, "MSGS GT|%s", bstr("gt")); +} + void servcmd_readnew(char *buf, long bufsize) { snprintf(buf, bufsize, "MSGS NEW"); @@ -982,54 +1223,274 @@ readloop_struct rlid[] = { { {HKEY("headers")}, servcmd_headers}, { {HKEY("readfwd")}, servcmd_readfwd}, { {HKEY("readnew")}, servcmd_readnew}, - { {HKEY("readold")}, servcmd_readold} + { {HKEY("readold")}, servcmd_readold}, + { {HKEY("readgt")}, servcmd_readgt} }; +/* Spit out the new summary view. This is basically a static page, so clients can cache the layout, all the dirty work is javascript :) */ +void new_summary_view(void) { + DoTemplate(HKEY("msg_listview"),NULL,&NoCtx); + DoTemplate(HKEY("trailing"),NULL,&NoCtx); +} + + +int mailview_GetParamsGetServerCall(SharedMessageStatus *Stat, + void **ViewSpecific, + long oper, + char *cmd, + long len) +{ + if (!WC->is_ajax) { + new_summary_view(); + return 200; + } else { + Stat->defaultsortorder = 2; + Stat->sortit = 1; + Stat->load_seen = 1; + /* Generally using maxmsgs|startmsg is not required + in mailbox view, but we have a 'safemode' for clients + (*cough* Exploder) that simply can't handle too many */ + if (havebstr("maxmsgs")) Stat->maxmsgs = ibstr("maxmsgs"); + else Stat->maxmsgs = 9999999; + if (havebstr("startmsg")) Stat->startmsg = lbstr("startmsg"); + snprintf(cmd, len, "MSGS %s|%s||1", + (oper == do_search) ? "SEARCH" : "ALL", + (oper == do_search) ? bstr("query") : "" + ); + } + return 200; +} + +int mailview_RenderView_or_Tail(SharedMessageStatus *Stat, + void **ViewSpecific, + long oper) +{ + WCTemplputParams SubTP; + DoTemplate(HKEY("mailsummary_json"),NULL, &SubTP); + return 0; +} -void SetAccessCommand(long Oper) +int mailview_Cleanup(void **ViewSpecific) { - wcsession *WCC = WC; + /* Note: wDumpContent() will output one additional tag. */ + /* We ought to move this out into template */ + if (WC->is_ajax) + end_burst(); + else + wDumpContent(1); + return 0; +} + + + +typedef struct _bbsview_stuct { + StrBuf *BBViewToolBar; + StrBuf *MessageDropdown; + long *displayed_msgs; + int a; +}bbsview_struct; + +int bbsview_GetParamsGetServerCall(SharedMessageStatus *Stat, + void **ViewSpecific, + long oper, + char *cmd, + long len) +{ + bbsview_struct *VS; - if (WCC->UrlFragment1 != NULL ) { - FlushStrBuf(WCC->UrlFragment1); - StrBufAppendBufPlain(WCC->UrlFragment1, - rlid[Oper].name.Key, rlid[Oper].name.len, 0); + VS = (bbsview_struct*) malloc(sizeof(bbsview_struct)); + memset(VS, 0, sizeof(bbsview_struct)); + *ViewSpecific = (void*)VS; + Stat->defaultsortorder = 1; + Stat->startmsg = -1; + Stat->sortit = 1; + + rlid[oper].cmd(cmd, len); + + if (havebstr("maxmsgs")) + Stat->maxmsgs = ibstr("maxmsgs"); + if (Stat->maxmsgs == 0) Stat->maxmsgs = DEFAULT_MAXMSGS; + + if (havebstr("startmsg")) { + Stat->startmsg = lbstr("startmsg"); + } + if (lbstr("SortOrder") == 2) { + Stat->reverse = 1; + Stat->num_displayed = -DEFAULT_MAXMSGS; + } + else { + Stat->reverse = 0; + Stat->num_displayed = DEFAULT_MAXMSGS; + } + + return 200; +} + +int bbsview_PrintViewHeader(SharedMessageStatus *Stat, void **ViewSpecific) +{ + bbsview_struct *VS; + WCTemplputParams SubTP; + + VS = (bbsview_struct*)*ViewSpecific; + + VS->BBViewToolBar = NewStrBufPlain(NULL, SIZ); + VS->MessageDropdown = NewStrBufPlain(NULL, SIZ); + + /*** startmsg->maxmsgs = **/DrawMessageDropdown(VS->MessageDropdown, + Stat->maxmsgs, + Stat->startmsg, + Stat->num_displayed, + Stat->lowest_found-1); + if (Stat->num_displayed < 0) { + Stat->startmsg += Stat->maxmsgs; + if (Stat->num_displayed != Stat->maxmsgs) + Stat->maxmsgs = abs(Stat->maxmsgs) + 1; + else + Stat->maxmsgs = abs(Stat->maxmsgs); + + } + if (Stat->nummsgs > 0) { + memset(&SubTP, 0, sizeof(WCTemplputParams)); + SubTP.Filter.ContextType = CTX_STRBUF; + SubTP.Context = VS->MessageDropdown; + DoTemplate(HKEY("msg_listselector_top"), VS->BBViewToolBar, &SubTP); + StrBufAppendBuf(WC->WBuf, VS->BBViewToolBar, 0); + FlushStrBuf(VS->BBViewToolBar); + } + return 200; +} + +int bbsview_LoadMsgFromServer(SharedMessageStatus *Stat, + void **ViewSpecific, + message_summary* Msg, + int is_new, + int i) +{ + bbsview_struct *VS; + + VS = (bbsview_struct*)*ViewSpecific; + if (VS->displayed_msgs == NULL) { + VS->displayed_msgs = malloc(sizeof(long) * + ((Stat->maxmsgs < Stat->nummsgs) ? + Stat->maxmsgs + 1 : + Stat->nummsgs + 1)); + } + if ((i >= Stat->startmsg) && (i < Stat->startmsg + Stat->maxmsgs)) { + VS->displayed_msgs[Stat->num_displayed] = Msg->msgnum; + Stat->num_displayed++; + } + return 200; +} + + +int bbsview_RenderView_or_Tail(SharedMessageStatus *Stat, + void **ViewSpecific, + long oper) +{ + wcsession *WCC = WC; + bbsview_struct *VS; + WCTemplputParams SubTP; + const StrBuf *Mime; + + VS = (bbsview_struct*)*ViewSpecific; + if (Stat->nummsgs == 0) { + wprintf("

"); + switch (oper) { + case readnew: + wprintf(_("No new messages.")); + break; + case readold: + wprintf(_("No old messages.")); + break; + default: + wprintf(_("No messages here.")); + } + wprintf("
\n"); } else - WCC->UrlFragment1 = NewStrBufPlain(rlid[Oper].name.Key, rlid[Oper].name.len); + { + if (VS->displayed_msgs != NULL) { + /* if we do a split bbview in the future, begin messages div here */ + int a;/// todo + for (a=0; a < Stat->num_displayed; ++a) { + read_message(WCC->WBuf, HKEY("view_message"), VS->displayed_msgs[a], NULL, &Mime); + } + + /* if we do a split bbview in the future, end messages div here */ + + free(VS->displayed_msgs); + VS->displayed_msgs = NULL; + } + memset(&SubTP, 0, sizeof(WCTemplputParams)); + SubTP.Filter.ContextType = CTX_STRBUF; + SubTP.Context = VS->MessageDropdown; + DoTemplate(HKEY("msg_listselector_bottom"), VS->BBViewToolBar, &SubTP); + StrBufAppendBuf(WCC->WBuf, VS->BBViewToolBar, 0); + } + return 0; + } - +int bbsview_Cleanup(void **ViewSpecific) +{ + bbsview_struct *VS; + VS = (bbsview_struct*)*ViewSpecific; + end_burst(); + FreeStrBuf(&VS->BBViewToolBar); + FreeStrBuf(&VS->MessageDropdown); + free(VS); + return 0; +} void InitModule_MSGRENDERERS (void) { + RegisterReadLoopHandlerset( + VIEW_MAILBOX, + mailview_GetParamsGetServerCall, + NULL, /// TODO: is this right? + NULL, //// "" + mailview_RenderView_or_Tail, + mailview_Cleanup); + + RegisterReadLoopHandlerset( + VIEW_BBS, + bbsview_GetParamsGetServerCall, + bbsview_PrintViewHeader, + bbsview_LoadMsgFromServer, + bbsview_RenderView_or_Tail, + bbsview_Cleanup); + RegisterSortFunc(HKEY("date"), NULL, 0, summcmp_date, summcmp_rdate, + groupchange_date, CTX_MAILSUM); RegisterSortFunc(HKEY("subject"), NULL, 0, summcmp_subj, summcmp_rsubj, + groupchange_subj, CTX_MAILSUM); RegisterSortFunc(HKEY("sender"), NULL, 0, summcmp_sender, summcmp_rsender, + groupchange_sender, CTX_MAILSUM); + RegisterNamespace("SUMM:COUNT", 0, 0, tmplput_SUMM_COUNT, CTX_NONE); /* iterate over all known mails in WC->summ */ RegisterIterator("MAIL:SUMM:MSGS", 0, NULL, iterate_get_mailsumm_All, - NULL,NULL, CTX_MAILSUM, CTX_NONE); + NULL,NULL, CTX_MAILSUM, CTX_NONE, IT_NOFLAG); - /* render parts of the message struct */ - RegisterNamespace("MAIL:SUMM:DATESTR", 0, 0, tmplput_MAIL_SUMM_DATE_STR, CTX_MAILSUM); + RegisterNamespace("MAIL:SUMM:DATEBRIEF", 0, 0, tmplput_MAIL_SUMM_DATE_BRIEF, CTX_MAILSUM); + RegisterNamespace("MAIL:SUMM:DATEFULL", 0, 0, tmplput_MAIL_SUMM_DATE_FULL, CTX_MAILSUM); RegisterNamespace("MAIL:SUMM:DATENO", 0, 0, tmplput_MAIL_SUMM_DATE_NO, CTX_MAILSUM); RegisterNamespace("MAIL:SUMM:N", 0, 0, tmplput_MAIL_SUMM_N, CTX_MAILSUM); RegisterNamespace("MAIL:SUMM:FROM", 0, 2, tmplput_MAIL_SUMM_FROM, CTX_MAILSUM); @@ -1042,17 +1503,21 @@ InitModule_MSGRENDERERS RegisterNamespace("MAIL:SUMM:ORGROOM", 0, 2, tmplput_MAIL_SUMM_ORGROOM, CTX_MAILSUM); RegisterNamespace("MAIL:SUMM:RFCA", 0, 2, tmplput_MAIL_SUMM_RFCA, CTX_MAILSUM); RegisterNamespace("MAIL:SUMM:OTHERNODE", 2, 0, tmplput_MAIL_SUMM_OTHERNODE, CTX_MAILSUM); - RegisterNamespace("MAIL:SUMM:REFIDS", 0, 0, tmplput_MAIL_SUMM_REFIDS, CTX_MAILSUM); + RegisterNamespace("MAIL:SUMM:REFIDS", 0, 1, tmplput_MAIL_SUMM_REFIDS, CTX_MAILSUM); RegisterNamespace("MAIL:SUMM:INREPLYTO", 0, 2, tmplput_MAIL_SUMM_INREPLYTO, CTX_MAILSUM); RegisterNamespace("MAIL:BODY", 0, 2, tmplput_MAIL_BODY, CTX_MAILSUM); RegisterNamespace("MAIL:QUOTETEXT", 1, 2, tmplput_QUOTED_MAIL_BODY, CTX_NONE); - + RegisterNamespace("MAIL:EDITTEXT", 1, 2, tmplput_EDIT_MAIL_BODY, CTX_NONE); + RegisterNamespace("MAIL:EDITWIKI", 1, 2, tmplput_EDIT_WIKI_BODY, CTX_NONE); RegisterConditional(HKEY("COND:MAIL:SUMM:RFCA"), 0, Conditional_MAIL_SUMM_RFCA, CTX_MAILSUM); + RegisterConditional(HKEY("COND:MAIL:SUMM:CCCC"), 0, Conditional_MAIL_SUMM_CCCC, CTX_MAILSUM); RegisterConditional(HKEY("COND:MAIL:SUMM:UNREAD"), 0, Conditional_MAIL_SUMM_UNREAD, CTX_MAILSUM); RegisterConditional(HKEY("COND:MAIL:SUMM:H_NODE"), 0, Conditional_MAIL_SUMM_H_NODE, CTX_MAILSUM); RegisterConditional(HKEY("COND:MAIL:SUMM:OTHERNODE"), 0, Conditional_MAIL_SUMM_OTHERNODE, CTX_MAILSUM); + RegisterConditional(HKEY("COND:MAIL:SUMM:SUBJECT"), 0, Conditional_MAIL_SUMM_SUBJECT, CTX_MAILSUM); RegisterConditional(HKEY("COND:MAIL:ANON"), 0, Conditional_ANONYMOUS_MESSAGE, CTX_MAILSUM); - + RegisterConditional(HKEY("COND:MAIL:TO"), 0, Conditional_MAIL_SUMM_TO, CTX_MAILSUM); + RegisterConditional(HKEY("COND:MAIL:SUBJ"), 0, Conditional_MAIL_SUMM_SUBJ, CTX_MAILSUM); /* do we have mimetypes to iterate over? */ RegisterConditional(HKEY("COND:MAIL:MIME:ATTACH"), 0, Conditional_MAIL_MIME_ALL, CTX_MAILSUM); @@ -1060,13 +1525,13 @@ InitModule_MSGRENDERERS RegisterConditional(HKEY("COND:MAIL:MIME:ATTACH:LINKS"), 0, Conditional_MAIL_MIME_ATTACHLINKS, CTX_MAILSUM); RegisterConditional(HKEY("COND:MAIL:MIME:ATTACH:ATT"), 0, Conditional_MAIL_MIME_ATTACH, CTX_MAILSUM); RegisterIterator("MAIL:MIME:ATTACH", 0, NULL, iterate_get_mime_All, - NULL, NULL, CTX_MIME_ATACH, CTX_MAILSUM); + NULL, NULL, CTX_MIME_ATACH, CTX_MAILSUM, IT_NOFLAG); RegisterIterator("MAIL:MIME:ATTACH:SUBMESSAGES", 0, NULL, iterate_get_mime_Submessages, - NULL, NULL, CTX_MIME_ATACH, CTX_MAILSUM); + NULL, NULL, CTX_MIME_ATACH, CTX_MAILSUM, IT_NOFLAG); RegisterIterator("MAIL:MIME:ATTACH:LINKS", 0, NULL, iterate_get_mime_AttachLinks, - NULL, NULL, CTX_MIME_ATACH, CTX_MAILSUM); + NULL, NULL, CTX_MIME_ATACH, CTX_MAILSUM, IT_NOFLAG); RegisterIterator("MAIL:MIME:ATTACH:ATT", 0, NULL, iterate_get_mime_Attachments, - NULL, NULL, CTX_MIME_ATACH, CTX_MAILSUM); + NULL, NULL, CTX_MIME_ATACH, CTX_MAILSUM, IT_NOFLAG); /* Parts of a mime attachent */ RegisterNamespace("MAIL:MIME:NAME", 0, 2, tmplput_MIME_Name, CTX_MIME_ATACH); @@ -1083,10 +1548,11 @@ InitModule_MSGRENDERERS /* iterate the WC->attachments; use the above tokens for their contents */ RegisterIterator("MSG:ATTACHNAMES", 0, NULL, iterate_get_registered_Attachments, - NULL, NULL, CTX_MIME_ATACH, CTX_NONE); + NULL, NULL, CTX_MIME_ATACH, CTX_NONE, IT_NOFLAG); /* mime renderers translate an attachment into webcit viewable html text */ RegisterMimeRenderer(HKEY("message/rfc822"), render_MAIL); + RegisterMimeRenderer(HKEY("text/vnote"), render_MIME_VNote); RegisterMimeRenderer(HKEY("text/x-vcard"), render_MIME_VCard); RegisterMimeRenderer(HKEY("text/vcard"), render_MIME_VCard); RegisterMimeRenderer(HKEY("text/calendar"), render_MIME_ICS); @@ -1125,3 +1591,30 @@ InitModule_MSGRENDERERS RegisterMsgHdr(HKEY("suff"), examine_suff, 0); RegisterMsgHdr(HKEY("path"), examine_path, 0); } + +void +ServerStartModule_MSGRENDERERS +(void) +{ + MsgHeaderHandler = NewHash(1, NULL); + MimeRenderHandler = NewHash(1, NULL); + ReadLoopHandler = NewHash(1, NULL); +} + +void +ServerShutdownModule_MSGRENDERERS +(void) +{ + DeleteHash(&MsgHeaderHandler); + DeleteHash(&MimeRenderHandler); + DeleteHash(&ReadLoopHandler); +} + + + +void +SessionDestroyModule_MSGRENDERERS +(wcsession *sess) +{ + DeleteHash(&sess->attachments); +}