UNPKG

@csermet/multiprovider

Version:

cloud-graph provider plugin for AWS used to fetch AWS cloud data.

48 lines (47 loc) 2.06 kB
"use strict"; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); const sdk_1 = __importDefault(require("@cloudgraph/sdk")); const securityhub_1 = __importDefault(require("aws-sdk/clients/securityhub")); const groupBy_1 = __importDefault(require("lodash/groupBy")); const isEmpty_1 = __importDefault(require("lodash/isEmpty")); const utils_1 = require("../../utils"); const errorLog_1 = __importDefault(require("../../utils/errorLog")); const logger_1 = __importDefault(require("../../properties/logger")); const { logger } = sdk_1.default; const lt = { ...logger_1.default }; const serviceName = 'SecurityHub'; const errorLog = new errorLog_1.default(serviceName); const endpoint = utils_1.initTestEndpoint(serviceName); exports.default = async ({ regions, config, }) => new Promise(async (resolve) => { const hubData = []; const regionPromises = regions.split(',').map(region => { const securityHub = new securityhub_1.default({ ...config, region, endpoint }); return new Promise(resolveRegion => securityHub.describeHub({}, (err, data) => { if (err) { errorLog.generateAwsErrorLog({ functionName: 'securityHub:describeHub', err, }); } if (isEmpty_1.default(data) || !data) { logger.debug(lt.securityHubNotFound(region)); return resolveRegion(); } logger.debug(lt.fetchedSecurityHub(region)); hubData.push({ HubArn: data.HubArn, SubscribedAt: data.SubscribedAt, AutoEnableControls: data.AutoEnableControls, region, }); resolveRegion(); })); }); logger.debug(lt.fetchingSecurityHub); await Promise.all(regionPromises); errorLog.reset(); resolve(groupBy_1.default(hubData, 'region')); });