diff options
author | Yuqian Yang <crupest@crupest.life> | 2025-04-10 15:12:46 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2025-06-02 18:04:47 +0800 |
commit | 72800db7e71bbd696eebc75bd128c46546f53c33 (patch) | |
tree | cfd3b33c5a36f81b18f5203e5677d14ab362933a /services/docker/mail-server/relay/aws/deliver.ts | |
parent | 76d393fe895573e00af8a02ab9f363690934afe7 (diff) | |
download | crupest-72800db7e71bbd696eebc75bd128c46546f53c33.tar.gz crupest-72800db7e71bbd696eebc75bd128c46546f53c33.tar.bz2 crupest-72800db7e71bbd696eebc75bd128c46546f53c33.zip |
feat(mail-server): done (except aws message-id map).
Diffstat (limited to 'services/docker/mail-server/relay/aws/deliver.ts')
-rw-r--r-- | services/docker/mail-server/relay/aws/deliver.ts | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/services/docker/mail-server/relay/aws/deliver.ts b/services/docker/mail-server/relay/aws/deliver.ts new file mode 100644 index 0000000..9c62496 --- /dev/null +++ b/services/docker/mail-server/relay/aws/deliver.ts @@ -0,0 +1,52 @@ +import { SendEmailCommand, SESv2Client } from "@aws-sdk/client-sesv2"; + +import { AwsContext } from "./context.ts"; +import { + Mail, + MailDeliverContext, + MailDeliverer, + MailDeliverRecipientResult, +} from "./mail.ts"; +import log from "../log.ts"; + +export class AwsMailDeliverer extends MailDeliverer { + readonly name = "aws"; + readonly #ses; + + constructor(aws: AwsContext) { + super(); + this.#ses = new SESv2Client(aws); + } + + protected override async doDeliver( + mail: Mail, + context: MailDeliverContext, + ): Promise<void> { + log.info("Begin to call aws send-email api..."); + + const result: MailDeliverRecipientResult = { + kind: "done", + message: "Success to call send-email api of aws.", + }; + + try { + const sendCommand = new SendEmailCommand({ + Content: { + Raw: { Data: mail.toUtf8Bytes() }, + }, + }); + + const res = await this.#ses.send(sendCommand); + if (res.MessageId == null) { + log.warn("Aws send-email returns no message id."); + } + mail.awsMessageId = res.MessageId; + } catch (cause) { + result.kind = "fail"; + result.message = "An error was thrown when calling aws send-email." + + cause; + result.cause = cause; + } + context.result.set("*", result); + } +} |