should update flags
This commit is contained in:
@@ -2,8 +2,15 @@ import Imap, { ImapMessageAttributes, Box } from "imap";
|
||||
import { getMailbox, updateMailbox } from "../../db/imap/imap-db";
|
||||
import { Attrs, AttrsWithEnvelope } from "../../interfaces/mail/attrs.interface";
|
||||
import logger from "../../system/Logger";
|
||||
import RegisterMessageInApp from "../saveMessage";
|
||||
import { saveMessage } from "../storeMessage";
|
||||
import RegisterMessageInApp from "../message/saveMessage";
|
||||
import { saveMessage } from "../message/storeMessage";
|
||||
import updateMessage from "../message/updateMessage";
|
||||
|
||||
export interface ImapInfo {
|
||||
uid: number;
|
||||
modseq: string;
|
||||
flags: string[];
|
||||
}
|
||||
|
||||
export default class Mailbox {
|
||||
imap: Imap;
|
||||
@@ -38,6 +45,7 @@ export default class Mailbox {
|
||||
logger.log("Already up to date")
|
||||
}
|
||||
|
||||
// wait for new mails
|
||||
this.imap.on("mail", (numNewMsgs: number) => {
|
||||
if (!this.syncing) {
|
||||
// if not syncing restart a sync
|
||||
@@ -47,6 +55,11 @@ export default class Mailbox {
|
||||
this.msgToSync += numNewMsgs;
|
||||
}
|
||||
});
|
||||
|
||||
this.imap.on("update", (seqno: number, info: ImapInfo) => {
|
||||
const updateMsg = new updateMessage(info.uid, info.flags);
|
||||
updateMsg.updateFlags();
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
43
back/mails/message/updateMessage.ts
Normal file
43
back/mails/message/updateMessage.ts
Normal file
@@ -0,0 +1,43 @@
|
||||
import { registerFlag } from "../../db/message/storeMessage-db";
|
||||
import { deleteFlag, getFlags, updateMailboxDeleted, updateMailboxSeen } from "../../db/message/updateMessage-db";
|
||||
import { getFlagId, getMessageIdOnUid } from "../../db/utils/mail";
|
||||
|
||||
export default class updateMessage {
|
||||
uid: number;
|
||||
flags: string[];
|
||||
|
||||
constructor(_uid: number, _flags: string[]) {
|
||||
this.uid = _uid;
|
||||
this.flags = _flags;
|
||||
}
|
||||
|
||||
async updateFlags() {
|
||||
const messageId = (await getMessageIdOnUid(this.uid))[0].message_id;
|
||||
const currentFlags = await getFlags(this.uid);
|
||||
|
||||
const flagsToAdd = this.flags.filter((flag) => !currentFlags.find((f) => flag == f.flag_name));
|
||||
const flagToRm = currentFlags.filter((f) => !this.flags.includes(f.flag_name));
|
||||
|
||||
flagsToAdd.forEach(async (flag) => {
|
||||
const flagId = await getFlagId(flag);
|
||||
registerFlag(messageId, flagId);
|
||||
});
|
||||
|
||||
flagToRm.forEach(async (flag) => {
|
||||
deleteFlag(messageId, flag.flag_id);
|
||||
});
|
||||
|
||||
// todo update seen counter rooms
|
||||
if (flagsToAdd.includes("\\Seen")) {
|
||||
updateMailboxSeen(messageId, true);
|
||||
} else if (flagToRm.find((f) => f.flag_name == "\\Seen")) {
|
||||
updateMailboxSeen(messageId, false);
|
||||
}
|
||||
|
||||
if (flagsToAdd.includes("\\Deleted")) {
|
||||
updateMailboxDeleted(messageId, true);
|
||||
} else if (flagToRm.find((f) => f.flag_name == "\\Deleted")) {
|
||||
updateMailboxDeleted(messageId, false);
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user