From c4f0d5c38b0ef95285c26c0f98b192550ab23ad7 Mon Sep 17 00:00:00 2001 From: nicholas-yong <40938341+nicholas-yong@users.noreply.github.com> Date: Thu, 9 Nov 2023 02:32:39 +0900 Subject: [PATCH] add in log streaming fixes for aws-sdk-v3 (#119) --- package.json | 3 ++- src/aws_cloud_trail_log_listener.js | 32 +++++++++++++++-------------- 2 files changed, 19 insertions(+), 16 deletions(-) diff --git a/package.json b/package.json index ed5b8d5..81f8617 100644 --- a/package.json +++ b/package.json @@ -6,7 +6,8 @@ "private": true, "dependencies": { "babel-polyfill": "^6.7.4", - "lodash": "^4.17.14" + "lodash": "^4.17.14", + "zlib": "^1.0.5" }, "optionalDependencies": { "@aws-sdk/client-auto-scaling": "^3.410.0", diff --git a/src/aws_cloud_trail_log_listener.js b/src/aws_cloud_trail_log_listener.js index 142ed2b..694045c 100644 --- a/src/aws_cloud_trail_log_listener.js +++ b/src/aws_cloud_trail_log_listener.js @@ -1,9 +1,9 @@ -import zlib from 'zlib.js'; -import { S3 } from "@aws-sdk/client-s3"; -import each from 'lodash/each.js'; -import constants from './cloud_trail_event_config.js'; -import AutotagFactory from './autotag_factory.js'; -import SETTINGS from './autotag_settings.js'; +import zlib from 'zlib'; +import { GetObjectCommand, S3 } from '@aws-sdk/client-s3'; +import each from 'lodash/each'; +import constants from './cloud_trail_event_config'; +import AutotagFactory from './autotag_factory'; +import SETTINGS from './autotag_settings'; class AwsCloudTrailLogListener { constructor(cloudtrailEvent, applicationContext, enabledServices) { @@ -94,16 +94,18 @@ class AwsCloudTrailLogListener { return rawContent; } - retrieveFromS3(logFile) { - return new Promise((resolve, reject) => { - this.s3.getObject(logFile, (err, res) => { - if (err) { - reject(err); - } else { - resolve(res.Body); - } - }); + async retrieveFromS3(logFile) { + const getObjectCommand = new GetObjectCommand(logFile); + const { Body } = await this.s3.send(getObjectCommand); + + const streamToString = new Promise((resolve, reject) => { + const chunks = []; + Body.on('error', reject); + Body.on('data', chunk => chunks.push(chunk)); + Body.on('end', () => resolve(Buffer.concat(chunks))); }); + + return streamToString; } unGzipContent(zippedContent) {