diff --git a/global.d.ts b/global.d.ts index 4680475..48855d9 100644 --- a/global.d.ts +++ b/global.d.ts @@ -2,6 +2,7 @@ declare type ResponseStream = { setContentType( type: string ): void; write( stream: string | Buffer ): void; end(): void; + metadata?: any; }; declare type StreamifyHandler = ( event: APIGatewayProxyEventV2, response: ResponseStream ) => Promise; @@ -13,7 +14,7 @@ declare var awslambda: { HttpResponseStream: { from( response: ResponseStream, metadata: { headers?: Record, - statusCode?: number, + statusCode: number, cookies?: string[], } ): ResponseStream } diff --git a/jest.config.js b/jest.config.js index f813a19..a1214ee 100644 --- a/jest.config.js +++ b/jest.config.js @@ -13,4 +13,7 @@ export default { }, ], }, + moduleNameMapper: { + "(.+)\\.js": "$1" + }, }; diff --git a/src/lambda-handler.ts b/src/lambda-handler.ts index 6a5e243..4325c41 100644 --- a/src/lambda-handler.ts +++ b/src/lambda-handler.ts @@ -1,4 +1,4 @@ -import { Args, getS3File, resizeBuffer, Config } from './lib'; +import { Args, getS3File, resizeBuffer, Config } from './lib.js'; /** * * @param event @@ -67,13 +67,14 @@ const streamify_handler: StreamifyHandler = async ( event, response ) => { // Somewhat undocumented API on how to pass headers to a stream response. response = awslambda.HttpResponseStream.from( response, { + statusCode: 200, headers: { 'Cache-Control': `max-age=${ maxAge }`, 'Last-Modified': ( new Date() ).toUTCString(), + 'Content-Type': 'image/' + info.format, }, } ); - response.setContentType( 'image/' + info.format ); response.write( data ); response.end(); }; @@ -96,6 +97,7 @@ if ( typeof awslambda === 'undefined' ) { from( response: ResponseStream, metadata: { headers?: Record, } ): ResponseStream { + response.metadata = metadata; return response; }, }, diff --git a/tests/test-lambda.ts b/tests/test-lambda.ts index adaf7a3..73fa969 100644 --- a/tests/test-lambda.ts +++ b/tests/test-lambda.ts @@ -32,6 +32,7 @@ class TestResponseStream { contentType: string | undefined; body: string | Buffer | undefined; headers: { [key: string]: string } = {}; + metadata: any; setContentType( type: string ): void { this.contentType = type; @@ -46,7 +47,9 @@ class TestResponseStream { } } end(): void { - + if ( this.metadata.headers['Content-Type'] ) { + this.contentType = this.metadata.headers['Content-Type']; + } } } @@ -63,7 +66,8 @@ global.awslambda = { * @param stream The response stream. * @param metadata The metadata for the response. */ - from( stream: ResponseStream, metadata ) : ResponseStream { + from( stream: TestResponseStream, metadata ) : TestResponseStream { + stream.metadata = metadata; return stream; }, }, diff --git a/tests/test-private-upload.ts b/tests/test-private-upload.ts index b54cad1..e7e6bf1 100644 --- a/tests/test-private-upload.ts +++ b/tests/test-private-upload.ts @@ -74,6 +74,9 @@ test( 'Test get private upload', async () => { * End the response. */ end(): void { + if ( this.metadata.headers['Cache-Control'] ) { + contentType = this.metadata.headers['Content-Type']; + } }, } ); @@ -115,6 +118,9 @@ test( 'Test get private upload with presign params', async () => { * End the response. */ end(): void { + if ( this.metadata.headers['Cache-Control'] ) { + contentType = this.metadata.headers['Content-Type']; + } }, } ); diff --git a/tsconfig.json b/tsconfig.json index 5527e68..52de306 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -4,8 +4,8 @@ "strict": true, "preserveConstEnums": true, "sourceMap": false, - "module": "ES2022", - "moduleResolution": "node", + "module": "Node16", + "moduleResolution": "node16", "esModuleInterop": true, "skipLibCheck": true, "forceConsistentCasingInFileNames": true, diff --git a/tsconfig.test.json b/tsconfig.test.json index 47e8a9a..0b73dc5 100644 --- a/tsconfig.test.json +++ b/tsconfig.test.json @@ -5,8 +5,8 @@ "preserveConstEnums": true, "noEmit": false, "sourceMap": true, - "module": "ES2022", - "moduleResolution": "node", + "module": "Node16", + "moduleResolution": "Node16", "esModuleInterop": true, "skipLibCheck": true, "forceConsistentCasingInFileNames": true,