aboutsummaryrefslogtreecommitdiff
path: root/services/docker/mail-server/aws-sendmail/delivers/dovecot.ts
diff options
context:
space:
mode:
authorYuqian Yang <crupest@crupest.life>2025-04-30 00:20:23 +0800
committerYuqian Yang <crupest@crupest.life>2025-04-30 00:20:54 +0800
commit84148346e29547cfba92dd697be9bbf31a23a926 (patch)
tree6750ed1d0ee974cc6144afcc294fd3bdc03defa1 /services/docker/mail-server/aws-sendmail/delivers/dovecot.ts
parent6aeff979ada4a1775bddb87a0ccad354faaa8093 (diff)
downloadcrupest-84148346e29547cfba92dd697be9bbf31a23a926.tar.gz
crupest-84148346e29547cfba92dd697be9bbf31a23a926.tar.bz2
crupest-84148346e29547cfba92dd697be9bbf31a23a926.zip
HALF WORK!: 2025-4-30
Diffstat (limited to 'services/docker/mail-server/aws-sendmail/delivers/dovecot.ts')
-rw-r--r--services/docker/mail-server/aws-sendmail/delivers/dovecot.ts35
1 files changed, 10 insertions, 25 deletions
diff --git a/services/docker/mail-server/aws-sendmail/delivers/dovecot.ts b/services/docker/mail-server/aws-sendmail/delivers/dovecot.ts
index e30c558..2b35872 100644
--- a/services/docker/mail-server/aws-sendmail/delivers/dovecot.ts
+++ b/services/docker/mail-server/aws-sendmail/delivers/dovecot.ts
@@ -1,31 +1,20 @@
-import { Logger } from "../logger.ts";
-import { MailDeliverContext, MailDeliverer } from "../deliver.ts";
+import { getLogger } from "../logger.ts";
+import { MailDeliverer } from "../deliver.ts";
+import { Mail } from "../mail.ts";
export class DovecotMailDeliverer extends MailDeliverer {
- constructor(private readonly logger: Logger) {
+ constructor() {
super("dovecot");
}
readonly ldaBin = "dovecot-lda";
- protected override doPrepare(
- rawMail: string,
- ): Promise<MailDeliverContext> {
- return Promise.resolve(new MailDeliverContext(rawMail));
- }
-
- protected override async doDeliver(
- context: MailDeliverContext,
- ): Promise<void> {
- const { logger, ldaBin } = this;
- const { rawMail } = context;
+ protected override async doDeliver(mail: Mail): Promise<void> {
+ const { ldaBin } = this;
let status;
try {
- const utf8Encoder = new TextEncoder();
- // TODO: A problem here is if mail is VERY long, this will block for a long time.
- // Maybe some task queue can be used.
- const utf8Stream = utf8Encoder.encode(rawMail);
+ const utf8Stream = mail.encodeUtf8();
const ldaCommand = new Deno.Command(ldaBin, {
stdin: "piped",
@@ -33,7 +22,7 @@ export class DovecotMailDeliverer extends MailDeliverer {
stderr: "piped",
});
const ldaProcess = ldaCommand.spawn();
- logger.logProgramOutput(ldaProcess, ldaBin);
+ getLogger().logProgramOutput(ldaProcess, ldaBin);
const stdinWriter = ldaProcess.stdin.getWriter();
await stdinWriter.ready;
@@ -42,15 +31,11 @@ export class DovecotMailDeliverer extends MailDeliverer {
status = await ldaProcess.status;
} catch (cause) {
- this.throwError(
- "external error.",
- rawMail,
- cause,
- );
+ this.throwError("external error.", mail, cause);
}
if (!status.success) {
- this.throwError(`${ldaBin} exited with non-zero.`, rawMail);
+ this.throwError(`${ldaBin} exited with non-zero.`, mail);
}
}
}