@csermet/multiprovider
Version:
cloud-graph provider plugin for AWS used to fetch AWS cloud data.
48 lines (47 loc) • 2.06 kB
JavaScript
;
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'));
});