diff options
author | Yuqian Yang <crupest@crupest.life> | 2025-04-10 15:12:46 +0800 |
---|---|---|
committer | Yuqian Yang <crupest@crupest.life> | 2025-06-01 02:36:24 +0800 |
commit | 026c16ed1b1c80203e2648de482a545e22482b60 (patch) | |
tree | 47167c00b7362c330324517d1ab0460c362da942 /services/docker/mail-server/relay/aws/context.ts | |
parent | cbeeaf281f400230e4161f08cfef2fe4715f3773 (diff) | |
download | crupest-026c16ed1b1c80203e2648de482a545e22482b60.tar.gz crupest-026c16ed1b1c80203e2648de482a545e22482b60.tar.bz2 crupest-026c16ed1b1c80203e2648de482a545e22482b60.zip |
HALF WORK!
Diffstat (limited to 'services/docker/mail-server/relay/aws/context.ts')
-rw-r--r-- | services/docker/mail-server/relay/aws/context.ts | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/services/docker/mail-server/relay/aws/context.ts b/services/docker/mail-server/relay/aws/context.ts new file mode 100644 index 0000000..c4f67bc --- /dev/null +++ b/services/docker/mail-server/relay/aws/context.ts @@ -0,0 +1,41 @@ +import { + CopyObjectCommand, + DeleteObjectCommand, + S3Client, +} from "@aws-sdk/client-s3"; +import { FetchHttpHandler } from "@smithy/fetch-http-handler"; + +import { getConfigValue } from "../config.ts"; + +export class AwsContext { + readonly credentials = () => + Promise.resolve({ + accessKeyId: getConfigValue("awsAccessKeyId"), + secretAccessKey: getConfigValue("awsSecretAccessKey"), + }); + readonly requestHandler = new FetchHttpHandler(); + + get region() { + return getConfigValue("awsRegion"); + } +} + +export async function s3MoveObject( + client: S3Client, + bucket: string, + path: string, + newPath: string, +): Promise<void> { + const copyCommand = new CopyObjectCommand({ + Bucket: bucket, + Key: newPath, + CopySource: `${bucket}/${path}`, + }); + await client.send(copyCommand); + + const deleteCommand = new DeleteObjectCommand({ + Bucket: bucket, + Key: path, + }); + await client.send(deleteCommand); +} |