}
/*
- * Convert a struct room to an IMAP-compatible mailbox name.
+ * Convert a struct ctdlroom to an IMAP-compatible mailbox name.
*/
-void imap_mailboxname(char *buf, int bufsize, struct room *qrbuf)
+void imap_mailboxname(char *buf, int bufsize, struct ctdlroom *qrbuf)
{
struct floor *fl;
int i;
/*
- * For mailboxes, just do it straight...
+ * For mailboxes, just do it straight.
+ * Also handle Kolab-compatible groupware folder names.
*/
if (qrbuf->QRflags & QR_MAILBOX) {
safestrncpy(buf, qrbuf->QRname, bufsize);
strcpy(buf, &buf[11]);
- if (!strcasecmp(buf, MAILROOM))
+ if (!strcasecmp(buf, MAILROOM)) {
strcpy(buf, "INBOX");
+ }
+ if (!strcasecmp(buf, USERCALENDARROOM)) {
+ sprintf(buf, "INBOX|%s", USERCALENDARROOM);
+ }
+ if (!strcasecmp(buf, USERCONTACTSROOM)) {
+ sprintf(buf, "INBOX|%s", USERCONTACTSROOM);
+ }
+ if (!strcasecmp(buf, USERTASKSROOM)) {
+ sprintf(buf, "INBOX|%s", USERTASKSROOM);
+ }
+ if (!strcasecmp(buf, USERNOTESROOM)) {
+ sprintf(buf, "INBOX|%s", USERNOTESROOM);
+ }
}
/*
* Otherwise, prefix the floor name as a "public folders" moniker
/*
* Convert the crispy idiot's reserved names to our reserved names.
+ * Also handle Kolab-compatible groupware folder names.
*/
if (!strcasecmp(foldername, "INBOX")) {
safestrncpy(rbuf, MAILROOM, bufsize);
ret = (0 | IR_MAILBOX);
}
+ else if ( (!strncasecmp(foldername, "INBOX", 5))
+ && (!strcasecmp(&foldername[6], USERCALENDARROOM)) ) {
+ safestrncpy(rbuf, USERCALENDARROOM, bufsize);
+ ret = (0 | IR_MAILBOX);
+ }
+ else if ( (!strncasecmp(foldername, "INBOX", 5))
+ && (!strcasecmp(&foldername[6], USERCONTACTSROOM)) ) {
+ safestrncpy(rbuf, USERCONTACTSROOM, bufsize);
+ ret = (0 | IR_MAILBOX);
+ }
+ else if ( (!strncasecmp(foldername, "INBOX", 5))
+ && (!strcasecmp(&foldername[6], USERTASKSROOM)) ) {
+ safestrncpy(rbuf, USERTASKSROOM, bufsize);
+ ret = (0 | IR_MAILBOX);
+ }
+ else if ( (!strncasecmp(foldername, "INBOX", 5))
+ && (!strcasecmp(&foldername[6], USERNOTESROOM)) ) {
+ safestrncpy(rbuf, USERNOTESROOM, bufsize);
+ ret = (0 | IR_MAILBOX);
+ }
else if (levels > 1) {
extract(floorname, foldername, 0);
strcpy(roomname, &foldername[strlen(floorname)+1]);
}
return (do_imap_match(mailboxname, pattern) == WILDMAT_TRUE);
}
+
+
+
+/*
+ * Compare an IMAP date string (date only, no time) to the date found in
+ * a Unix timestamp.
+ */
+int imap_datecmp(char *datestr, time_t msgtime) {
+ char daystr[SIZ];
+ char monthstr[SIZ];
+ char yearstr[SIZ];
+ int i;
+ int day, month, year;
+ int msgday, msgmonth, msgyear;
+ struct tm msgtm;
+
+ if (datestr == NULL) return(0);
+
+ /* Expecting a date in the form dd-Mmm-yyyy */
+ extract_token(daystr, datestr, 0, '-');
+ extract_token(monthstr, datestr, 1, '-');
+ extract_token(yearstr, datestr, 2, '-');
+
+ day = atoi(daystr);
+ year = atoi(yearstr);
+ month = 0;
+ for (i=0; i<12; ++i) {
+ if (!strcasecmp(monthstr, ascmonths[i])) {
+ month = i;
+ }
+ }
+
+ /* Extract day/month/year from message timestamp */
+ memcpy(&msgtm, localtime(&msgtime), sizeof(struct tm));
+ msgday = msgtm.tm_mday;
+ msgmonth = msgtm.tm_mon;
+ msgyear = msgtm.tm_year + 1900;
+
+ /* Now start comparing */
+
+ if (year < msgyear) return(+1);
+ if (year > msgyear) return(-1);
+
+ if (month < msgmonth) return(+1);
+ if (month > msgmonth) return(-1);
+
+ if (day < msgday) return(+1);
+ if (day > msgday) return(-1);
+
+ return(0);
+}