@mitre/hdf-converters 2.5.1 → 2.6.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/data/aws-config-mapping.json +638 -0
- package/lib/data/cci-nist-mapping.json +3553 -0
- package/lib/data/converters/csv2json.d.ts +1 -0
- package/lib/data/converters/csv2json.js +36 -0
- package/lib/data/converters/csv2json.js.map +1 -0
- package/lib/data/converters/csv2json.ts +36 -0
- package/lib/data/converters/xml2json.d.ts +14 -0
- package/lib/data/converters/xml2json.js +42 -0
- package/lib/data/converters/xml2json.js.map +1 -0
- package/lib/data/converters/xml2json.ts +57 -0
- package/lib/data/cwe-nist-mapping.json +1416 -0
- package/lib/data/nessus-plugins-nist-mapping.json +644 -0
- package/lib/data/nikto-nist-mapping.json +53648 -0
- package/lib/data/owasp-nist-mapping.json +72 -0
- package/lib/data/scoutsuite-nist-mapping.json +558 -0
- package/lib/index.d.ts +4 -0
- package/lib/index.js +4 -0
- package/lib/index.js.map +1 -1
- package/lib/package.json +17 -7
- package/lib/src/asff-mapper.d.ts +15 -0
- package/lib/src/asff-mapper.js +508 -0
- package/lib/src/asff-mapper.js.map +1 -0
- package/lib/src/aws-config-mapper.d.ts +28 -0
- package/lib/src/aws-config-mapper.js +369 -0
- package/lib/src/aws-config-mapper.js.map +1 -0
- package/lib/src/base-converter.d.ts +3 -7
- package/lib/src/base-converter.js +26 -8
- package/lib/src/base-converter.js.map +1 -1
- package/lib/src/burpsuite-mapper.js +1 -3
- package/lib/src/burpsuite-mapper.js.map +1 -1
- package/lib/src/converters-from-hdf/asff/asff-types.d.ts +88 -0
- package/lib/src/converters-from-hdf/asff/asff-types.js +3 -0
- package/lib/src/converters-from-hdf/asff/asff-types.js.map +1 -0
- package/lib/src/converters-from-hdf/asff/reverse-asff-mapper.d.ts +31 -0
- package/lib/src/converters-from-hdf/asff/reverse-asff-mapper.js +132 -0
- package/lib/src/converters-from-hdf/asff/reverse-asff-mapper.js.map +1 -0
- package/lib/src/converters-from-hdf/asff/transformers.d.ts +44 -0
- package/lib/src/converters-from-hdf/asff/transformers.js +397 -0
- package/lib/src/converters-from-hdf/asff/transformers.js.map +1 -0
- package/lib/src/converters-from-hdf/reverse-base-converter.d.ts +24 -0
- package/lib/src/converters-from-hdf/reverse-base-converter.js +111 -0
- package/lib/src/converters-from-hdf/reverse-base-converter.js.map +1 -0
- package/lib/src/jfrog-xray-mapper.js +1 -3
- package/lib/src/jfrog-xray-mapper.js.map +1 -1
- package/lib/src/mappings/AwsConfigMapping.d.ts +6 -0
- package/lib/src/mappings/AwsConfigMapping.js +39 -0
- package/lib/src/mappings/AwsConfigMapping.js.map +1 -0
- package/lib/src/mappings/AwsConfigMappingItem.d.ts +7 -0
- package/lib/src/mappings/AwsConfigMappingItem.js +28 -0
- package/lib/src/mappings/AwsConfigMappingItem.js.map +1 -0
- package/lib/src/mappings/CciNistMapping.d.ts +1 -1
- package/lib/src/mappings/CciNistMapping.js +5 -24
- package/lib/src/mappings/CciNistMapping.js.map +1 -1
- package/lib/src/mappings/CweNistMapping.d.ts +8 -1
- package/lib/src/mappings/CweNistMapping.js +4 -27
- package/lib/src/mappings/CweNistMapping.js.map +1 -1
- package/lib/src/mappings/CweNistMappingItem.d.ts +2 -1
- package/lib/src/mappings/CweNistMappingItem.js +9 -9
- package/lib/src/mappings/CweNistMappingItem.js.map +1 -1
- package/lib/src/mappings/NessusPluginsNistMapping.d.ts +7 -1
- package/lib/src/mappings/NessusPluginsNistMapping.js +4 -8
- package/lib/src/mappings/NessusPluginsNistMapping.js.map +1 -1
- package/lib/src/mappings/NessusPluginsNistMappingItem.d.ts +2 -1
- package/lib/src/mappings/NessusPluginsNistMappingItem.js +16 -6
- package/lib/src/mappings/NessusPluginsNistMappingItem.js.map +1 -1
- package/lib/src/mappings/NiktoNistMapping.d.ts +7 -1
- package/lib/src/mappings/NiktoNistMapping.js +4 -8
- package/lib/src/mappings/NiktoNistMapping.js.map +1 -1
- package/lib/src/mappings/NiktoNistMappingItem.d.ts +2 -1
- package/lib/src/mappings/NiktoNistMappingItem.js +7 -7
- package/lib/src/mappings/NiktoNistMappingItem.js.map +1 -1
- package/lib/src/mappings/OwaspNistMapping.d.ts +8 -1
- package/lib/src/mappings/OwaspNistMapping.js +4 -8
- package/lib/src/mappings/OwaspNistMapping.js.map +1 -1
- package/lib/src/mappings/OwaspNistMappingItem.d.ts +2 -1
- package/lib/src/mappings/OwaspNistMappingItem.js +9 -9
- package/lib/src/mappings/OwaspNistMappingItem.js.map +1 -1
- package/lib/src/mappings/ScoutsuiteNistMapping.d.ts +5 -1
- package/lib/src/mappings/ScoutsuiteNistMapping.js +4 -10
- package/lib/src/mappings/ScoutsuiteNistMapping.js.map +1 -1
- package/lib/src/mappings/ScoutsuiteNistMappingItem.d.ts +2 -1
- package/lib/src/mappings/ScoutsuiteNistMappingItem.js +4 -4
- package/lib/src/mappings/ScoutsuiteNistMappingItem.js.map +1 -1
- package/lib/src/nessus-mapper.js +2 -5
- package/lib/src/nessus-mapper.js.map +1 -1
- package/lib/src/netsparker-mapper.js +2 -5
- package/lib/src/netsparker-mapper.js.map +1 -1
- package/lib/src/nikto-mapper.js +1 -3
- package/lib/src/nikto-mapper.js.map +1 -1
- package/lib/src/sarif-mapper.js +1 -3
- package/lib/src/sarif-mapper.js.map +1 -1
- package/lib/src/scoutsuite-mapper.js +1 -3
- package/lib/src/scoutsuite-mapper.js.map +1 -1
- package/lib/src/snyk-mapper.js +1 -6
- package/lib/src/snyk-mapper.js.map +1 -1
- package/lib/src/sonarqube-mapper.d.ts +54 -0
- package/lib/src/sonarqube-mapper.js +196 -0
- package/lib/src/sonarqube-mapper.js.map +1 -0
- package/lib/src/xccdf-results-mapper.js +1 -3
- package/lib/src/xccdf-results-mapper.js.map +1 -1
- package/lib/src/zap-mapper.d.ts +1 -1
- package/lib/src/zap-mapper.js +7 -4
- package/lib/src/zap-mapper.js.map +1 -1
- package/package.json +17 -7
- package/lib/data/U_CCI_List.xml +0 -38403
- package/lib/data/aws-config-mapping.csv +0 -107
- package/lib/data/cwe-nist-mapping.csv +0 -203
- package/lib/data/nessus-plugins-nist-mapping.csv +0 -108
- package/lib/data/nikto-nist-mapping.csv +0 -8942
- package/lib/data/owasp-nist-mapping.csv +0 -11
- package/lib/data/scoutsuite-nist-mapping.csv +0 -140
|
@@ -0,0 +1,369 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.AwsConfigMapper = void 0;
|
|
7
|
+
const aws_sdk_1 = __importDefault(require("aws-sdk"));
|
|
8
|
+
const https_1 = __importDefault(require("https"));
|
|
9
|
+
const inspecjs_1 = require("inspecjs");
|
|
10
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
11
|
+
const package_json_1 = require("../package.json");
|
|
12
|
+
const AwsConfigMapping_1 = require("./mappings/AwsConfigMapping");
|
|
13
|
+
const NOT_APPLICABLE_MSG = 'No AWS resources found to evaluate compliance for this rule';
|
|
14
|
+
const INSUFFICIENT_DATA_MSG = 'Not enough data has been collected to determine compliance yet.';
|
|
15
|
+
const NAME = 'AWS Config';
|
|
16
|
+
const AWS_CONFIG_MAPPING = new AwsConfigMapping_1.AwsConfigMapping();
|
|
17
|
+
class AwsConfigMapper {
|
|
18
|
+
constructor(options, verifySSLCertificates = true) {
|
|
19
|
+
aws_sdk_1.default.config.update({
|
|
20
|
+
httpOptions: {
|
|
21
|
+
agent: new https_1.default.Agent({
|
|
22
|
+
rejectUnauthorized: verifySSLCertificates
|
|
23
|
+
})
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
this.configService = new aws_sdk_1.default.ConfigService(options);
|
|
27
|
+
this.results = [];
|
|
28
|
+
this.issues = this.getAllConfigRules();
|
|
29
|
+
}
|
|
30
|
+
delay(ms) {
|
|
31
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
32
|
+
}
|
|
33
|
+
async getAllConfigRules() {
|
|
34
|
+
let params = {
|
|
35
|
+
ConfigRuleNames: [],
|
|
36
|
+
NextToken: ''
|
|
37
|
+
};
|
|
38
|
+
const configRules = [];
|
|
39
|
+
let response = await this.getConfigRulePage(params);
|
|
40
|
+
if (response.ConfigRules === undefined) {
|
|
41
|
+
throw new Error('No data was returned');
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
while (response !== undefined && response.ConfigRules !== undefined) {
|
|
45
|
+
response.ConfigRules.forEach((rule) => {
|
|
46
|
+
configRules.push(rule);
|
|
47
|
+
});
|
|
48
|
+
if (response.NextToken) {
|
|
49
|
+
params = lodash_1.default.set(params, 'NextToken', response.NextToken);
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
break;
|
|
53
|
+
}
|
|
54
|
+
response = await this.getConfigRulePage(params);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
this.results = await this.getResults(configRules);
|
|
58
|
+
return configRules;
|
|
59
|
+
}
|
|
60
|
+
chunkArray(sourceArray, chunkSize) {
|
|
61
|
+
const result = [];
|
|
62
|
+
for (let i = 0; i < sourceArray.length; i += chunkSize) {
|
|
63
|
+
result.push(sourceArray.slice(i, i + chunkSize));
|
|
64
|
+
}
|
|
65
|
+
return result;
|
|
66
|
+
}
|
|
67
|
+
async getConfigRulePage(params) {
|
|
68
|
+
await this.delay(150);
|
|
69
|
+
return this.configService.describeConfigRules(params).promise();
|
|
70
|
+
}
|
|
71
|
+
async getResults(configRules) {
|
|
72
|
+
const complianceResults = await this.fetchAllComplianceInfo(configRules);
|
|
73
|
+
const ruleData = [];
|
|
74
|
+
const allRulesResolved = [];
|
|
75
|
+
for (const configRule of configRules) {
|
|
76
|
+
const result = [];
|
|
77
|
+
let params = {
|
|
78
|
+
ConfigRuleName: configRule.ConfigRuleName || '',
|
|
79
|
+
Limit: 100
|
|
80
|
+
};
|
|
81
|
+
await this.delay(150);
|
|
82
|
+
let response = await this.configService
|
|
83
|
+
.getComplianceDetailsByConfigRule(params)
|
|
84
|
+
.promise();
|
|
85
|
+
let ruleResults = response.EvaluationResults || [];
|
|
86
|
+
allRulesResolved.push(...ruleResults);
|
|
87
|
+
while (response.NextToken !== undefined) {
|
|
88
|
+
params = lodash_1.default.set(params, 'NextToken', response.NextToken);
|
|
89
|
+
await this.delay(150);
|
|
90
|
+
response = await this.configService
|
|
91
|
+
.getComplianceDetailsByConfigRule(params)
|
|
92
|
+
.promise();
|
|
93
|
+
ruleResults = ruleResults === null || ruleResults === void 0 ? void 0 : ruleResults.concat(response.EvaluationResults || []);
|
|
94
|
+
allRulesResolved.push(...ruleResults);
|
|
95
|
+
}
|
|
96
|
+
ruleResults.forEach((evaluation) => {
|
|
97
|
+
var _a, _b, _c;
|
|
98
|
+
const hdfResult = {
|
|
99
|
+
code_desc: this.getCodeDesc(evaluation),
|
|
100
|
+
start_time: ((_a = evaluation.ConfigRuleInvokedTime) === null || _a === void 0 ? void 0 : _a.toISOString()) || '',
|
|
101
|
+
run_time: this.getRunTime(evaluation),
|
|
102
|
+
status: this.getStatus(evaluation),
|
|
103
|
+
message: this.getMessage(evaluation, this.getCodeDesc(evaluation), this.getStatus(evaluation))
|
|
104
|
+
};
|
|
105
|
+
result.push(hdfResult);
|
|
106
|
+
const currentDate = new Date().toISOString();
|
|
107
|
+
if (result.length === 0) {
|
|
108
|
+
switch ((_c = (_b = complianceResults.find((complianceResult) => complianceResult.ConfigRuleName === configRule.ConfigRuleName)) === null || _b === void 0 ? void 0 : _b.Compliance) === null || _c === void 0 ? void 0 : _c.ComplianceType) {
|
|
109
|
+
case 'NOT_APPLICABLE':
|
|
110
|
+
return [
|
|
111
|
+
{
|
|
112
|
+
run_time: 0,
|
|
113
|
+
code_desc: NOT_APPLICABLE_MSG,
|
|
114
|
+
skip_message: NOT_APPLICABLE_MSG,
|
|
115
|
+
start_time: currentDate,
|
|
116
|
+
status: inspecjs_1.ExecJSON.ControlResultStatus.Skipped
|
|
117
|
+
}
|
|
118
|
+
];
|
|
119
|
+
case 'INSUFFICIENT_DATA':
|
|
120
|
+
return [
|
|
121
|
+
{
|
|
122
|
+
run_time: 0,
|
|
123
|
+
code_desc: INSUFFICIENT_DATA_MSG,
|
|
124
|
+
skip_message: INSUFFICIENT_DATA_MSG,
|
|
125
|
+
start_time: currentDate,
|
|
126
|
+
status: inspecjs_1.ExecJSON.ControlResultStatus.Skipped
|
|
127
|
+
}
|
|
128
|
+
];
|
|
129
|
+
default:
|
|
130
|
+
return [];
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
return ruleData.push(result);
|
|
135
|
+
}
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
return this.appendResourceNamesToResults(await Promise.all(ruleData), await this.extractResourceNamesFromIds(allRulesResolved));
|
|
139
|
+
}
|
|
140
|
+
async appendResourceNamesToResults(completedControlResults, extractedResourceNames) {
|
|
141
|
+
return completedControlResults.map((completedControlResult) => completedControlResult.map((completedControl) => {
|
|
142
|
+
for (const extractedResourceName in extractedResourceNames) {
|
|
143
|
+
if (completedControl.code_desc.indexOf(JSON.stringify(extractedResourceName)
|
|
144
|
+
.replace(/\"/gi, '')
|
|
145
|
+
.replace(/{/gi, '')
|
|
146
|
+
.replace(/}/gi, '')) !== -1) {
|
|
147
|
+
return {
|
|
148
|
+
...completedControl,
|
|
149
|
+
code_desc: `${completedControl.code_desc}, resource_name: ${extractedResourceNames[extractedResourceName]}`
|
|
150
|
+
};
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
return completedControl;
|
|
154
|
+
}));
|
|
155
|
+
}
|
|
156
|
+
async extractResourceNamesFromIds(evaluationResults) {
|
|
157
|
+
var _a;
|
|
158
|
+
const resourceMap = {};
|
|
159
|
+
const resolvedResourcesMap = {};
|
|
160
|
+
evaluationResults.forEach((result) => {
|
|
161
|
+
const resourceType = lodash_1.default.get(result, 'EvaluationResultIdentifier.EvaluationResultQualifier.ResourceType');
|
|
162
|
+
const resourceId = lodash_1.default.get(result, 'EvaluationResultIdentifier.EvaluationResultQualifier.ResourceId');
|
|
163
|
+
if (!(resourceType in resourceMap)) {
|
|
164
|
+
resourceMap[resourceType] = [resourceId];
|
|
165
|
+
}
|
|
166
|
+
else {
|
|
167
|
+
if (!resourceMap[resourceType].includes(resourceId) &&
|
|
168
|
+
typeof resourceId === 'string') {
|
|
169
|
+
resourceMap[resourceType].push(resourceId);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
});
|
|
173
|
+
for (const resourceType in resourceMap) {
|
|
174
|
+
const resourceIDSlices = this.chunkArray(resourceMap[resourceType], 20);
|
|
175
|
+
for (const slice of resourceIDSlices) {
|
|
176
|
+
await this.delay(150);
|
|
177
|
+
const resources = await this.configService
|
|
178
|
+
.listDiscoveredResources({
|
|
179
|
+
resourceType: resourceType,
|
|
180
|
+
resourceIds: slice
|
|
181
|
+
})
|
|
182
|
+
.promise();
|
|
183
|
+
(_a = resources.resourceIdentifiers) === null || _a === void 0 ? void 0 : _a.forEach((resource) => {
|
|
184
|
+
if (resource.resourceId && resource.resourceName) {
|
|
185
|
+
resolvedResourcesMap[resource.resourceId] = resource.resourceName;
|
|
186
|
+
}
|
|
187
|
+
});
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
return resolvedResourcesMap;
|
|
191
|
+
}
|
|
192
|
+
getCodeDesc(result) {
|
|
193
|
+
let output = '';
|
|
194
|
+
if (result.EvaluationResultIdentifier !== undefined &&
|
|
195
|
+
result.EvaluationResultIdentifier.EvaluationResultQualifier !== undefined) {
|
|
196
|
+
output = JSON.stringify(result.EvaluationResultIdentifier.EvaluationResultQualifier)
|
|
197
|
+
.replace(/\"/gi, '')
|
|
198
|
+
.replace(/{/gi, '')
|
|
199
|
+
.replace(/}/gi, '');
|
|
200
|
+
}
|
|
201
|
+
return output;
|
|
202
|
+
}
|
|
203
|
+
getRunTime(result) {
|
|
204
|
+
let diff = 0;
|
|
205
|
+
if (result.ResultRecordedTime !== undefined &&
|
|
206
|
+
result.ConfigRuleInvokedTime !== undefined) {
|
|
207
|
+
diff =
|
|
208
|
+
(result.ResultRecordedTime.getTime() -
|
|
209
|
+
result.ConfigRuleInvokedTime.getTime()) /
|
|
210
|
+
1000;
|
|
211
|
+
}
|
|
212
|
+
return diff;
|
|
213
|
+
}
|
|
214
|
+
getStatus(result) {
|
|
215
|
+
if (result.ComplianceType === 'COMPLIANT') {
|
|
216
|
+
return inspecjs_1.ExecJSON.ControlResultStatus.Passed;
|
|
217
|
+
}
|
|
218
|
+
else if (result.ComplianceType === 'NON_COMPLIANT') {
|
|
219
|
+
return inspecjs_1.ExecJSON.ControlResultStatus.Failed;
|
|
220
|
+
}
|
|
221
|
+
else {
|
|
222
|
+
return inspecjs_1.ExecJSON.ControlResultStatus.Skipped;
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
getMessage(result, codeDesc, status) {
|
|
226
|
+
if (status === inspecjs_1.ExecJSON.ControlResultStatus.Failed) {
|
|
227
|
+
return `${codeDesc}: ${result.Annotation || 'Rule does not pass rule compliance'}`;
|
|
228
|
+
}
|
|
229
|
+
else {
|
|
230
|
+
return undefined;
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
async fetchAllComplianceInfo(configRules) {
|
|
234
|
+
var _a;
|
|
235
|
+
const complianceResults = [];
|
|
236
|
+
const configRuleSlices = this.chunkArray(configRules, 25);
|
|
237
|
+
for (const slice of configRuleSlices) {
|
|
238
|
+
await this.delay(150);
|
|
239
|
+
const response = await this.configService
|
|
240
|
+
.describeComplianceByConfigRule({
|
|
241
|
+
ConfigRuleNames: slice.map((rule) => rule.ConfigRuleName || '')
|
|
242
|
+
})
|
|
243
|
+
.promise();
|
|
244
|
+
if (response.ComplianceByConfigRules === undefined) {
|
|
245
|
+
throw new Error('No compliance data was returned');
|
|
246
|
+
}
|
|
247
|
+
else {
|
|
248
|
+
(_a = response.ComplianceByConfigRules) === null || _a === void 0 ? void 0 : _a.forEach((compliance) => complianceResults.push(compliance));
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
return complianceResults;
|
|
252
|
+
}
|
|
253
|
+
hdfTags(configRule) {
|
|
254
|
+
var _a;
|
|
255
|
+
let result = {};
|
|
256
|
+
const sourceIdentifier = (_a = configRule.Source) === null || _a === void 0 ? void 0 : _a.SourceIdentifier;
|
|
257
|
+
result = lodash_1.default.set(result, 'nist', []);
|
|
258
|
+
let defaultMatch = [];
|
|
259
|
+
if (sourceIdentifier !== undefined) {
|
|
260
|
+
defaultMatch = AWS_CONFIG_MAPPING.nistFilter([sourceIdentifier]);
|
|
261
|
+
}
|
|
262
|
+
if (Array.isArray(defaultMatch) && defaultMatch.length !== 0) {
|
|
263
|
+
result = lodash_1.default.set(result, 'nist', lodash_1.default.get(result, 'nist').concat(defaultMatch));
|
|
264
|
+
}
|
|
265
|
+
if (Array.isArray(lodash_1.default.get(result, 'nist')) &&
|
|
266
|
+
lodash_1.default.get(result, 'nist').length === 0) {
|
|
267
|
+
result = lodash_1.default.set(result, 'nist', ['unmapped']);
|
|
268
|
+
}
|
|
269
|
+
return result;
|
|
270
|
+
}
|
|
271
|
+
checkText(configRule) {
|
|
272
|
+
var _a;
|
|
273
|
+
let params = [];
|
|
274
|
+
if (configRule.InputParameters !== undefined &&
|
|
275
|
+
configRule.InputParameters !== '{}') {
|
|
276
|
+
params = configRule.InputParameters.replace(/{/gi, '')
|
|
277
|
+
.replace(/}/gi, '')
|
|
278
|
+
.split(',');
|
|
279
|
+
}
|
|
280
|
+
const checkText = [];
|
|
281
|
+
checkText.push(`ARN: ${configRule.ConfigRuleArn || 'N/A'}`);
|
|
282
|
+
checkText.push(`Source Identifier: ${((_a = configRule.Source) === null || _a === void 0 ? void 0 : _a.SourceIdentifier) || 'N/A'}`);
|
|
283
|
+
if (params.length !== 0) {
|
|
284
|
+
checkText.push(`${params.join('<br/>').replace(/\"/gi, '')}`);
|
|
285
|
+
}
|
|
286
|
+
return checkText.join('<br/>');
|
|
287
|
+
}
|
|
288
|
+
hdfDescriptions(configRule) {
|
|
289
|
+
return [
|
|
290
|
+
{
|
|
291
|
+
data: this.checkText(configRule),
|
|
292
|
+
label: 'check'
|
|
293
|
+
}
|
|
294
|
+
];
|
|
295
|
+
}
|
|
296
|
+
getAccountId(arn) {
|
|
297
|
+
const matches = arn.match(/:(\d{12}):config-rule/);
|
|
298
|
+
if (matches === null) {
|
|
299
|
+
return 'no-account-id';
|
|
300
|
+
}
|
|
301
|
+
else {
|
|
302
|
+
return matches[0];
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
async getControls() {
|
|
306
|
+
let index = 0;
|
|
307
|
+
return (await this.issues).map((issue) => {
|
|
308
|
+
const control = {
|
|
309
|
+
id: issue.ConfigRuleId || '',
|
|
310
|
+
title: `${this.getAccountId(issue.ConfigRuleArn || '')} - ${issue.ConfigRuleName}`
|
|
311
|
+
.replace(/:/gi, '')
|
|
312
|
+
.replace(/config-rule/gi, ''),
|
|
313
|
+
desc: issue.Description || null,
|
|
314
|
+
impact: this.getImpact(issue),
|
|
315
|
+
tags: this.hdfTags(issue),
|
|
316
|
+
descriptions: this.hdfDescriptions(issue),
|
|
317
|
+
refs: [],
|
|
318
|
+
source_location: { ref: issue.ConfigRuleArn, line: 1 },
|
|
319
|
+
code: '',
|
|
320
|
+
results: this.results[index]
|
|
321
|
+
};
|
|
322
|
+
index++;
|
|
323
|
+
return control;
|
|
324
|
+
});
|
|
325
|
+
}
|
|
326
|
+
getImpact(issue) {
|
|
327
|
+
if (lodash_1.default.get(issue, 'compliance') === 'NOT_APPLICABLE') {
|
|
328
|
+
return 0;
|
|
329
|
+
}
|
|
330
|
+
else {
|
|
331
|
+
return 0.5;
|
|
332
|
+
}
|
|
333
|
+
}
|
|
334
|
+
async toHdf() {
|
|
335
|
+
const hdf = {
|
|
336
|
+
platform: {
|
|
337
|
+
name: 'Heimdall Tools',
|
|
338
|
+
release: package_json_1.version,
|
|
339
|
+
target_id: ''
|
|
340
|
+
},
|
|
341
|
+
version: package_json_1.version,
|
|
342
|
+
statistics: {
|
|
343
|
+
duration: null
|
|
344
|
+
},
|
|
345
|
+
profiles: [
|
|
346
|
+
{
|
|
347
|
+
name: NAME,
|
|
348
|
+
version: '',
|
|
349
|
+
title: NAME,
|
|
350
|
+
maintainer: null,
|
|
351
|
+
summary: NAME,
|
|
352
|
+
license: null,
|
|
353
|
+
copyright: null,
|
|
354
|
+
copyright_email: null,
|
|
355
|
+
supports: [],
|
|
356
|
+
attributes: [],
|
|
357
|
+
depends: [],
|
|
358
|
+
groups: [],
|
|
359
|
+
status: 'loaded',
|
|
360
|
+
controls: await this.getControls(),
|
|
361
|
+
sha256: ''
|
|
362
|
+
}
|
|
363
|
+
]
|
|
364
|
+
};
|
|
365
|
+
return hdf;
|
|
366
|
+
}
|
|
367
|
+
}
|
|
368
|
+
exports.AwsConfigMapper = AwsConfigMapper;
|
|
369
|
+
//# sourceMappingURL=aws-config-mapper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aws-config-mapper.js","sourceRoot":"","sources":["../../src/aws-config-mapper.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,19 +1,15 @@
|
|
|
1
1
|
import { ExecJSON } from 'inspecjs';
|
|
2
2
|
export interface ILookupPath {
|
|
3
3
|
path?: string;
|
|
4
|
-
transformer?: (value:
|
|
5
|
-
arrayTransformer?: (value: unknown[], file:
|
|
4
|
+
transformer?: (value: any) => unknown;
|
|
5
|
+
arrayTransformer?: (value: unknown[], file: any) => unknown[];
|
|
6
6
|
key?: string;
|
|
7
7
|
}
|
|
8
8
|
export declare type ObjectEntries<T> = {
|
|
9
9
|
[K in keyof T]: readonly [K, T[K]];
|
|
10
10
|
}[keyof T];
|
|
11
11
|
export declare type MappedTransform<T, U extends ILookupPath> = {
|
|
12
|
-
[K in keyof T]: Exclude<T[K], undefined | null> extends Array<any> ? MappedTransform<T[K], U> : T[K] extends Function ? T[K] : T[K] extends object ? MappedTransform<T[K] &
|
|
13
|
-
arrayTransformer?: (value: unknown[], file: Record<string, unknown>) => T[K][];
|
|
14
|
-
}), U> : T[K] | (U & {
|
|
15
|
-
transformer?: (value: unknown) => T[K];
|
|
16
|
-
});
|
|
12
|
+
[K in keyof T]: Exclude<T[K], undefined | null> extends Array<any> ? MappedTransform<T[K], U> : T[K] extends Function ? T[K] : T[K] extends object ? MappedTransform<T[K] & U, U> : T[K] | U;
|
|
17
13
|
};
|
|
18
14
|
export declare type MappedReform<T, U> = {
|
|
19
15
|
[K in keyof T]: Exclude<T[K], undefined | null> extends Array<any> ? MappedReform<T[K], U> : T[K] extends object ? MappedReform<T[K] & U, U> : Exclude<T[K], U>;
|
|
@@ -40,6 +40,7 @@ function parseHtml(input) {
|
|
|
40
40
|
});
|
|
41
41
|
if (typeof input === 'string') {
|
|
42
42
|
myParser.write(input);
|
|
43
|
+
myParser.end();
|
|
43
44
|
}
|
|
44
45
|
return textData.join('');
|
|
45
46
|
}
|
|
@@ -133,18 +134,19 @@ class BaseConverter {
|
|
|
133
134
|
return pathVal;
|
|
134
135
|
}
|
|
135
136
|
if (typeof transformer === 'function') {
|
|
136
|
-
return transformer(file);
|
|
137
|
+
return transformer.bind(this)(file);
|
|
137
138
|
}
|
|
138
139
|
else {
|
|
139
140
|
return this.convertInternal(file, v);
|
|
140
141
|
}
|
|
141
142
|
}
|
|
142
143
|
handleArray(file, v) {
|
|
144
|
+
var _a, _b, _c;
|
|
143
145
|
if (v.length === 0) {
|
|
144
146
|
return [];
|
|
145
147
|
}
|
|
146
148
|
if (v[0].path === undefined) {
|
|
147
|
-
const arrayTransformer = v[0].arrayTransformer;
|
|
149
|
+
const arrayTransformer = (_a = v[0].arrayTransformer) === null || _a === void 0 ? void 0 : _a.bind(this);
|
|
148
150
|
v = v.map((element) => {
|
|
149
151
|
return lodash_1.default.omit(element, ['arrayTransformer']);
|
|
150
152
|
});
|
|
@@ -153,15 +155,23 @@ class BaseConverter {
|
|
|
153
155
|
output.push(this.evaluate(file, element));
|
|
154
156
|
});
|
|
155
157
|
if (arrayTransformer !== undefined) {
|
|
156
|
-
|
|
158
|
+
if (Array.isArray(arrayTransformer)) {
|
|
159
|
+
output = arrayTransformer[0].apply(arrayTransformer[1], [
|
|
160
|
+
v,
|
|
161
|
+
this.data
|
|
162
|
+
]);
|
|
163
|
+
}
|
|
164
|
+
else {
|
|
165
|
+
output = arrayTransformer.apply(null, [output, this.data]);
|
|
166
|
+
}
|
|
157
167
|
}
|
|
158
168
|
return output;
|
|
159
169
|
}
|
|
160
170
|
else {
|
|
161
171
|
const path = v[0].path;
|
|
162
172
|
const key = v[0].key;
|
|
163
|
-
const arrayTransformer = v[0].arrayTransformer;
|
|
164
|
-
const transformer = v[0].transformer;
|
|
173
|
+
const arrayTransformer = (_b = v[0].arrayTransformer) === null || _b === void 0 ? void 0 : _b.bind(this);
|
|
174
|
+
const transformer = (_c = v[0].transformer) === null || _c === void 0 ? void 0 : _c.bind(this);
|
|
165
175
|
if (this.hasPath(file, path)) {
|
|
166
176
|
const pathVal = this.handlePath(file, path);
|
|
167
177
|
if (Array.isArray(pathVal)) {
|
|
@@ -173,12 +183,20 @@ class BaseConverter {
|
|
|
173
183
|
'key'
|
|
174
184
|
]);
|
|
175
185
|
});
|
|
186
|
+
if (arrayTransformer !== undefined) {
|
|
187
|
+
if (Array.isArray(arrayTransformer)) {
|
|
188
|
+
v = arrayTransformer[0].apply(arrayTransformer[1], [
|
|
189
|
+
v,
|
|
190
|
+
this.data
|
|
191
|
+
]);
|
|
192
|
+
}
|
|
193
|
+
else {
|
|
194
|
+
v = arrayTransformer.apply(null, [v, this.data]);
|
|
195
|
+
}
|
|
196
|
+
}
|
|
176
197
|
if (key !== undefined) {
|
|
177
198
|
v = collapseDuplicates(v, key, this.collapseResults);
|
|
178
199
|
}
|
|
179
|
-
if (arrayTransformer !== undefined) {
|
|
180
|
-
v = arrayTransformer(v, this.data);
|
|
181
|
-
}
|
|
182
200
|
return v;
|
|
183
201
|
}
|
|
184
202
|
else {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base-converter.js","sourceRoot":"","sources":["../../src/base-converter.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA,mCAAkC;AAClC,wDAA0C;AAE1C,oDAAuB;
|
|
1
|
+
{"version":3,"file":"base-converter.js","sourceRoot":"","sources":["../../src/base-converter.ts"],"names":[],"mappings":"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"}
|
|
@@ -7,7 +7,6 @@ exports.BurpSuiteMapper = void 0;
|
|
|
7
7
|
const fast_xml_parser_1 = __importDefault(require("fast-xml-parser"));
|
|
8
8
|
const inspecjs_1 = require("inspecjs");
|
|
9
9
|
const lodash_1 = __importDefault(require("lodash"));
|
|
10
|
-
const path_1 = __importDefault(require("path"));
|
|
11
10
|
const package_json_1 = require("../package.json");
|
|
12
11
|
const base_converter_1 = require("./base-converter");
|
|
13
12
|
const CweNistMapping_1 = require("./mappings/CweNistMapping");
|
|
@@ -18,8 +17,7 @@ const IMPACT_MAPPING = new Map([
|
|
|
18
17
|
['information', 0.3]
|
|
19
18
|
]);
|
|
20
19
|
const NAME = 'BurpSuite Pro Scan';
|
|
21
|
-
const
|
|
22
|
-
const CWE_NIST_MAPPING = new CweNistMapping_1.CweNistMapping(CWE_NIST_MAPPING_FILE);
|
|
20
|
+
const CWE_NIST_MAPPING = new CweNistMapping_1.CweNistMapping();
|
|
23
21
|
const DEFAULT_NIST_TAG = ['SA-11', 'RA-5'];
|
|
24
22
|
function formatCodeDesc(issue) {
|
|
25
23
|
const text = [];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"burpsuite-mapper.js","sourceRoot":"","sources":["../../src/burpsuite-mapper.ts"],"names":[],"mappings":";;;;;;AAAA,sEAAqC;AACrC,uCAAkC;AAClC,oDAAuB;AACvB,
|
|
1
|
+
{"version":3,"file":"burpsuite-mapper.js","sourceRoot":"","sources":["../../src/burpsuite-mapper.ts"],"names":[],"mappings":";;;;;;AAAA,sEAAqC;AACrC,uCAAkC;AAClC,oDAAuB;AACvB,kDAAgE;AAChE,qDAM0B;AAC1B,8DAAyD;AAGzD,MAAM,cAAc,GAAwB,IAAI,GAAG,CAAC;IAClD,CAAC,MAAM,EAAE,GAAG,CAAC;IACb,CAAC,QAAQ,EAAE,GAAG,CAAC;IACf,CAAC,KAAK,EAAE,GAAG,CAAC;IACZ,CAAC,aAAa,EAAE,GAAG,CAAC;CACrB,CAAC,CAAC;AACH,MAAM,IAAI,GAAG,oBAAoB,CAAC;AAClC,MAAM,gBAAgB,GAAG,IAAI,+BAAc,EAAE,CAAC;AAC9C,MAAM,gBAAgB,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;AAG3C,SAAS,cAAc,CAAC,KAAc;IACpC,MAAM,IAAI,GAAG,EAAE,CAAC;IAChB,IAAI,gBAAC,CAAC,GAAG,CAAC,KAAK,EAAE,SAAS,CAAC,IAAI,gBAAC,CAAC,GAAG,CAAC,KAAK,EAAE,WAAW,CAAC,EAAE;QACxD,IAAI,CAAC,IAAI,CACP,aAAa,gBAAC,CAAC,GAAG,CAAC,KAAK,EAAE,SAAS,CAAC,UAAU,gBAAC,CAAC,GAAG,CAAC,KAAK,EAAE,WAAW,CAAC,EAAE,CAC1E,CAAC;KACH;SAAM;QACL,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;KAChC;IACD,IAAI,gBAAC,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,CAAC,EAAE;QAC5B,IAAI,CAAC,IAAI,CAAC,aAAa,IAAA,0BAAS,EAAC,gBAAC,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC;KAC/D;SAAM;QACL,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;KACzB;IACD,IAAI,gBAAC,CAAC,GAAG,CAAC,KAAK,EAAE,aAAa,CAAC,EAAE;QAC/B,IAAI,CAAC,IAAI,CAAC,gBAAgB,IAAA,0BAAS,EAAC,gBAAC,CAAC,GAAG,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC,EAAE,CAAC,CAAC;KACrE;IACD,IAAI,gBAAC,CAAC,GAAG,CAAC,KAAK,EAAE,YAAY,CAAC,EAAE;QAC9B,IAAI,CAAC,IAAI,CAAC,eAAe,IAAA,0BAAS,EAAC,gBAAC,CAAC,GAAG,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC,EAAE,CAAC,CAAC;KACnE;SAAM;QACL,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;KAC3B;IACD,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;AAChC,CAAC;AACD,SAAS,UAAU,CAAC,EAAW;IAC7B,IAAI,OAAO,EAAE,KAAK,QAAQ,IAAI,OAAO,EAAE,KAAK,QAAQ,EAAE;QACpD,OAAO,EAAE,CAAC,QAAQ,EAAE,CAAC;KACtB;SAAM;QACL,OAAO,EAAE,CAAC;KACX;AACH,CAAC;AACD,SAAS,WAAW,CAAC,KAAa;IAChC,OAAO,IAAA,0BAAS,EAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;AAClD,CAAC;AACD,SAAS,OAAO,CAAC,KAAa;IAC5B,IAAI,GAAG,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAC3C,GAAG,CAAC,KAAK,EAAE,CAAC;IACZ,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACtC,OAAO,gBAAgB,CAAC,UAAU,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;AAC9E,CAAC;AAED,SAAS,QAAQ,CAAC,GAAW;IAC3B,MAAM,OAAO,GAAG;QACd,mBAAmB,EAAE,EAAE;QACvB,YAAY,EAAE,MAAM;QACpB,gBAAgB,EAAE,KAAK;KACxB,CAAC;IACF,OAAO,yBAAM,CAAC,KAAK,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;AACpC,CAAC;AACD,MAAa,eAAgB,SAAQ,8BAAa;IA2EhD,YAAY,QAAgB;QAC1B,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;QA3E5B,aAAQ,GAAqD;YAC3D,QAAQ,EAAE;gBACR,IAAI,EAAE,gBAAgB;gBACtB,OAAO,EAAE,sBAAoB;gBAC7B,SAAS,EAAE,EAAE;aACd;YACD,OAAO,EAAE,sBAAoB;YAC7B,UAAU,EAAE;gBACV,QAAQ,EAAE,IAAI;aACf;YACD,QAAQ,EAAE;gBACR;oBACE,IAAI,EAAE,IAAI;oBACV,OAAO,EAAE,EAAC,IAAI,EAAE,oBAAoB,EAAC;oBACrC,KAAK,EAAE,IAAI;oBACX,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE,IAAI;oBACb,OAAO,EAAE,IAAI;oBACb,SAAS,EAAE,IAAI;oBACf,eAAe,EAAE,IAAI;oBACrB,QAAQ,EAAE,EAAE;oBACZ,UAAU,EAAE,EAAE;oBACd,OAAO,EAAE,EAAE;oBACX,MAAM,EAAE,EAAE;oBACV,MAAM,EAAE,QAAQ;oBAChB,QAAQ,EAAE;wBACR;4BACE,IAAI,EAAE,cAAc;4BACpB,GAAG,EAAE,IAAI;4BACT,EAAE,EAAE,EAAC,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,UAAU,EAAC;4BAC3C,KAAK,EAAE,EAAC,IAAI,EAAE,MAAM,EAAC;4BACrB,IAAI,EAAE,EAAC,IAAI,EAAE,iBAAiB,EAAE,WAAW,EAAE,0BAAS,EAAC;4BACvD,MAAM,EAAE;gCACN,IAAI,EAAE,UAAU;gCAChB,WAAW,EAAE,IAAA,8BAAa,EAAC,cAAc,CAAC;6BAC3C;4BACD,IAAI,EAAE;gCACJ,IAAI,EAAE;oCACJ,IAAI,EAAE,8BAA8B;oCACpC,WAAW,EAAE,OAAO;iCACrB;gCACD,KAAK,EAAE;oCACL,IAAI,EAAE,8BAA8B;oCACpC,WAAW,EAAE,WAAW;iCACzB;gCACD,UAAU,EAAE,EAAC,IAAI,EAAE,YAAY,EAAC;6BACjC;4BACD,YAAY,EAAE;gCACZ;oCACE,IAAI,EAAE,EAAC,IAAI,EAAE,iBAAiB,EAAE,WAAW,EAAE,0BAAS,EAAC;oCACvD,KAAK,EAAE,OAAO;iCACf;gCACD;oCACE,IAAI,EAAE,EAAC,IAAI,EAAE,uBAAuB,EAAE,WAAW,EAAE,0BAAS,EAAC;oCAC7D,KAAK,EAAE,KAAK;iCACb;6BACF;4BACD,IAAI,EAAE,EAAE;4BACR,eAAe,EAAE,EAAE;4BACnB,IAAI,EAAE,EAAE;4BACR,OAAO,EAAE;gCACP;oCACE,MAAM,EAAE,mBAAQ,CAAC,mBAAmB,CAAC,MAAM;oCAC3C,SAAS,EAAE,EAAC,WAAW,EAAE,cAAc,EAAC;oCACxC,QAAQ,EAAE,CAAC;oCACX,UAAU,EAAE,EAAC,IAAI,EAAE,qBAAqB,EAAC;iCAC1C;6BACF;yBACF;qBACF;oBACD,MAAM,EAAE,EAAE;iBACX;aACF;SACF,CAAC;IAGF,CAAC;IACD,WAAW,CACT,cAAgE;QAEhE,KAAK,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;IACpC,CAAC;CACF;AAnFD,0CAmFC"}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
export interface IOptions {
|
|
2
|
+
input: string;
|
|
3
|
+
awsAccountId: string;
|
|
4
|
+
target: string;
|
|
5
|
+
region: string;
|
|
6
|
+
}
|
|
7
|
+
export interface IExecJSONASFF {
|
|
8
|
+
Findings: IFindingASFF[];
|
|
9
|
+
}
|
|
10
|
+
export interface IFindingASFF {
|
|
11
|
+
SchemaVersion: string;
|
|
12
|
+
Id: string;
|
|
13
|
+
ProductArn: string;
|
|
14
|
+
ProductName?: string;
|
|
15
|
+
CompanyName?: string;
|
|
16
|
+
Region?: string;
|
|
17
|
+
GeneratorId: string;
|
|
18
|
+
AwsAccountId: string;
|
|
19
|
+
Types?: string[] | Record<string, unknown>;
|
|
20
|
+
FirstObservedAt?: string;
|
|
21
|
+
LastObservedAt?: string;
|
|
22
|
+
CreatedAt: string;
|
|
23
|
+
UpdatedAt: string;
|
|
24
|
+
Severity: ISeverityASFF;
|
|
25
|
+
Title: string;
|
|
26
|
+
Description: string;
|
|
27
|
+
Remediation: IRemediationASFF;
|
|
28
|
+
ProductFields: IProductFieldsASFF;
|
|
29
|
+
Resources: IResourcesASFF[];
|
|
30
|
+
Compliance: IComplianceASFF;
|
|
31
|
+
WorkflowState?: string;
|
|
32
|
+
Workflow?: {
|
|
33
|
+
Status: string;
|
|
34
|
+
};
|
|
35
|
+
RecordState?: string;
|
|
36
|
+
FindingProviderFields: IFindingProviderFieldsASFF;
|
|
37
|
+
}
|
|
38
|
+
export interface ISeverityASFF {
|
|
39
|
+
Product?: number;
|
|
40
|
+
Label: string;
|
|
41
|
+
Normalized?: number;
|
|
42
|
+
Original?: string;
|
|
43
|
+
}
|
|
44
|
+
export interface IRemediationASFF {
|
|
45
|
+
Recommendation: {
|
|
46
|
+
Text: string;
|
|
47
|
+
Url?: string;
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
export interface IProductFieldsASFF {
|
|
51
|
+
Check?: string | Record<string, unknown>;
|
|
52
|
+
StandardsGuideArn?: string;
|
|
53
|
+
StandardsGuideSubscriptionArn?: string;
|
|
54
|
+
RuleId?: string;
|
|
55
|
+
RecommendationUrl?: string;
|
|
56
|
+
StandardsControlArn?: string;
|
|
57
|
+
'aws/securityhub/ProductName'?: string;
|
|
58
|
+
'aws/securityhub/CompanyName'?: string;
|
|
59
|
+
'aws/securityhub/annotation'?: string;
|
|
60
|
+
'Resources:0/Id'?: string;
|
|
61
|
+
'aws/securityhub/FindingId'?: string;
|
|
62
|
+
}
|
|
63
|
+
export interface IResourcesASFF {
|
|
64
|
+
Type: string;
|
|
65
|
+
Id: string;
|
|
66
|
+
Partition?: string;
|
|
67
|
+
Region?: string;
|
|
68
|
+
Details?: {
|
|
69
|
+
AwsIamRole: {
|
|
70
|
+
AssumeRolePolicyDocument: string | Record<string, unknown>;
|
|
71
|
+
};
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
export interface IComplianceASFF {
|
|
75
|
+
Status: string;
|
|
76
|
+
StatusReasons?: ({
|
|
77
|
+
ReasonCode: string | null;
|
|
78
|
+
Description: string | null;
|
|
79
|
+
} | null)[];
|
|
80
|
+
RelatedRequirements?: string[] | Record<string, unknown>;
|
|
81
|
+
}
|
|
82
|
+
export interface IFindingProviderFieldsASFF {
|
|
83
|
+
Severity: {
|
|
84
|
+
Label: string;
|
|
85
|
+
Original?: string;
|
|
86
|
+
};
|
|
87
|
+
Types: string[] | Record<string, unknown>;
|
|
88
|
+
}
|