diff options
author | Yuqian Yang <crupest@crupest.life> | 2025-04-10 15:12:46 +0800 |
---|---|---|
committer | Yuqian Yang <crupest@crupest.life> | 2025-05-31 03:11:53 +0800 |
commit | 8cad2ca7812d654016dd7af2ee1695e81778b7db (patch) | |
tree | 9f996532b4bf3b0ebd5ace82f540565bc9f4e8d8 /services/docker/mail-server/relay/aws/context.ts | |
parent | cbeeaf281f400230e4161f08cfef2fe4715f3773 (diff) | |
download | crupest-8cad2ca7812d654016dd7af2ee1695e81778b7db.tar.gz crupest-8cad2ca7812d654016dd7af2ee1695e81778b7db.tar.bz2 crupest-8cad2ca7812d654016dd7af2ee1695e81778b7db.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..0dfafe9 --- /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 { getConfig } from "../config.ts"; + +export class AwsContext { + readonly region = "ap-southeast-1"; + + accessKeyId = getConfig().getValue("awsAccessKeyId"); + secretAccessKey = getConfig().getValue("awsSecretAccessKey"); + + getCredentials() { + const { accessKeyId, secretAccessKey } = this; + return Promise.resolve({ accessKeyId, secretAccessKey }); + } + + readonly credentials = this.getCredentials.bind(this); +} + +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); +} |