From b8678e49cad11ca87729f7d915d0bc1f6a2707d1 Mon Sep 17 00:00:00 2001 From: oleiade Date: Mon, 27 May 2024 09:35:32 +0200 Subject: [PATCH] Make S3Client methods Encode URI before signing --- src/internal/s3.ts | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/src/internal/s3.ts b/src/internal/s3.ts index 0889ab2..672d28a 100644 --- a/src/internal/s3.ts +++ b/src/internal/s3.ts @@ -109,7 +109,7 @@ export class S3Client extends AWSClient { { method: method, endpoint: this.endpoint, - path: `/${bucketName}/`, + path: encodeURI(`/${bucketName}/`), query: { 'list-type': '2', prefix: prefix || '', @@ -176,13 +176,13 @@ export class S3Client extends AWSClient { { method: method, endpoint: this.endpoint, - path: `/${bucketName}/${objectKey}`, + path: encodeURI(`/${bucketName}/${objectKey}`), headers: {}, }, {} ) - const res = await http.asyncRequest(method, signedRequest.url, signedRequest.body || null, { + const res = await http.asyncRequest(method, signedRequest.url, null, { headers: signedRequest.headers, }) this._handle_error('GetObject', res) @@ -224,7 +224,7 @@ export class S3Client extends AWSClient { { method: method, endpoint: this.endpoint, - path: `/${bucketName}/${objectKey}`, + path: encodeURI(`/${bucketName}/${objectKey}`), headers: { Host: this.endpoint.host, ...(params?.contentDisposition && { @@ -263,7 +263,7 @@ export class S3Client extends AWSClient { { method: method, endpoint: this.endpoint, - path: `/${bucketName}/${objectKey}`, + path: encodeURI(`/${bucketName}/${objectKey}`), headers: {}, }, {} @@ -300,7 +300,7 @@ export class S3Client extends AWSClient { { method: method, endpoint: bucketEndpoint, - path: `/${destinationKey}`, + path: encodeURI(`/${destinationKey}`), headers: { 'x-amz-copy-source': `${sourceBucket}/${sourceKey}`, }, @@ -335,7 +335,7 @@ export class S3Client extends AWSClient { { method: method, endpoint: bucketEndpoint, - path: `/${objectKey}`, + path: encodeURI(`/${objectKey}`), headers: {}, query: { uploads: '' }, }, @@ -381,7 +381,7 @@ export class S3Client extends AWSClient { { method: method, endpoint: bucketEndpoint, - path: `/${objectKey}`, + path: encodeURI(`/${objectKey}`), headers: {}, body: data, query: { @@ -432,7 +432,7 @@ export class S3Client extends AWSClient { { method: method, endpoint: bucketEndpoint, - path: `/${objectKey}`, + path: encodeURI(`/${objectKey}`), headers: {}, body: body, query: { @@ -468,7 +468,7 @@ export class S3Client extends AWSClient { { method: method, endpoint: bucketEndpoint, - path: `/${objectKey}`, + path: encodeURI(`/${objectKey}`), headers: {}, query: { uploadId: `${uploadId}`,