From 8ba08870fdb3bafa7b8739c4f1c57a70b8780143 Mon Sep 17 00:00:00 2001 From: Yuqian Yang Date: Wed, 30 Apr 2025 00:20:23 +0800 Subject: HALF WORK!: 2025-5-14 --- .../mail-server/aws-sendmail/aws/retriver.ts | 31 +++++++++++++--------- 1 file changed, 19 insertions(+), 12 deletions(-) (limited to 'services/docker/mail-server/aws-sendmail/aws/retriver.ts') diff --git a/services/docker/mail-server/aws-sendmail/aws/retriver.ts b/services/docker/mail-server/aws-sendmail/aws/retriver.ts index 1544c04..b599c15 100644 --- a/services/docker/mail-server/aws-sendmail/aws/retriver.ts +++ b/services/docker/mail-server/aws-sendmail/aws/retriver.ts @@ -6,10 +6,10 @@ import { S3Client, } from "@aws-sdk/client-s3"; -import { generateTimeStringForFileName } from "../util.ts"; -import { getLogger } from "../logger.ts"; import { AwsContext, s3MoveObject } from "./context.ts"; +import { getLogger } from "../logger.ts"; import { getConfig } from "../config.ts"; +import { Mail } from "../mail.ts"; export class AwsMailRetriever { readonly liveMailPrefix = "mail/live/"; @@ -21,7 +21,7 @@ export class AwsMailRetriever { constructor( aws: AwsContext, - private readonly callback: (rawMail: string) => Promise, + private readonly callback: (mail: Mail) => Promise, ) { const { region, credentials } = aws; this.s3Client = new S3Client({ region, credentials }); @@ -34,12 +34,6 @@ export class AwsMailRetriever { }); } - generateArchivePrefix(instant: Date | Temporal.Instant): string { - return `${this.archiveMailPrefix}${ - generateTimeStringForFileName(instant, true) - }/`; - } - async listLiveMails(): Promise { const listCommand = new ListObjectsV2Command({ Bucket: this.mailBucket, @@ -55,7 +49,8 @@ export class AwsMailRetriever { const result: string[] = []; for (const object of res.Contents) { if (object.Key != null) { - result.push(object.Key); + // TODO: check prefix consistence here. + result.push(object.Key.slice(this.liveMailPrefix.length)); } else { getLogger().warn( "Listing live mails in S3 returns an object with no Key.", @@ -79,13 +74,25 @@ export class AwsMailRetriever { } const rawMail = await res.Body.transformToString(); - await this.callback(rawMail); + const mail = new Mail(rawMail); + mail.awsMessageId = messageId; + await this.callback(mail); // TODO: Continue here. - await s3MoveObject(this.s3Client, this.mailBucket, mailPath, ); + await s3MoveObject( + this.s3Client, + this.mailBucket, + mailPath, + `${this.archiveMailPrefix}${ + mail.simpleGetDateString("invalid-date") + }/${messageId}`, + ); } async recycleLiveMails() { const mails = await this.listLiveMails(); + for (const messageId of mails) { + await this.deliverS3MailObject(messageId); + } } } -- cgit v1.2.3