@contrast/contrast 1.0.0 → 1.0.1
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/.prettierignore +2 -0
- package/README.md +120 -47
- package/dist/audit/AnalysisEngine.js +37 -0
- package/dist/audit/catalogueApplication/catalogueApplication.js +36 -0
- package/dist/audit/dotnetAnalysisEngine/index.js +25 -0
- package/dist/audit/dotnetAnalysisEngine/parseLockFileContents.js +35 -0
- package/dist/audit/dotnetAnalysisEngine/parseProjectFileContents.js +15 -0
- package/dist/audit/dotnetAnalysisEngine/readLockFileContents.js +18 -0
- package/dist/audit/dotnetAnalysisEngine/readProjectFileContents.js +14 -0
- package/dist/audit/dotnetAnalysisEngine/sanitizer.js +9 -0
- package/dist/audit/goAnalysisEngine/index.js +17 -0
- package/dist/audit/goAnalysisEngine/parseProjectFileContents.js +164 -0
- package/dist/audit/goAnalysisEngine/readProjectFileContents.js +21 -0
- package/dist/audit/goAnalysisEngine/sanitizer.js +5 -0
- package/dist/audit/javaAnalysisEngine/index.js +34 -0
- package/dist/audit/javaAnalysisEngine/parseMavenProjectFileContents.js +153 -0
- package/dist/audit/javaAnalysisEngine/parseProjectFileContents.js +353 -0
- package/dist/audit/javaAnalysisEngine/readProjectFileContents.js +98 -0
- package/dist/audit/javaAnalysisEngine/sanitizer.js +5 -0
- package/dist/audit/languageAnalysisEngine/checkForMultipleIdentifiedLanguages.js +24 -0
- package/dist/audit/languageAnalysisEngine/checkForMultipleIdentifiedProjectFiles.js +24 -0
- package/dist/audit/languageAnalysisEngine/checkIdentifiedLanguageHasLockFile.js +35 -0
- package/dist/audit/languageAnalysisEngine/checkIdentifiedLanguageHasProjectFile.js +23 -0
- package/dist/audit/languageAnalysisEngine/commonApi.js +18 -0
- package/dist/audit/languageAnalysisEngine/constants.js +20 -0
- package/dist/audit/languageAnalysisEngine/filterProjectPath.js +20 -0
- package/dist/audit/languageAnalysisEngine/getIdentifiedLanguageInfo.js +25 -0
- package/dist/audit/languageAnalysisEngine/getProjectRootFilenames.js +39 -0
- package/dist/audit/languageAnalysisEngine/index.js +39 -0
- package/dist/audit/languageAnalysisEngine/langugageAnalysisFactory.js +70 -0
- package/dist/audit/languageAnalysisEngine/reduceIdentifiedLanguages.js +121 -0
- package/dist/audit/languageAnalysisEngine/report/checkIgnoreDevDep.js +17 -0
- package/dist/audit/languageAnalysisEngine/report/commonReportingFunctions.js +257 -0
- package/dist/audit/languageAnalysisEngine/report/newReportingFeature.js +81 -0
- package/dist/audit/languageAnalysisEngine/report/reportingFeature.js +133 -0
- package/dist/audit/languageAnalysisEngine/sendSnapshot.js +41 -0
- package/dist/audit/languageAnalysisEngine/util/capabilities.js +11 -0
- package/dist/audit/languageAnalysisEngine/util/generalAPI.js +39 -0
- package/dist/audit/languageAnalysisEngine/util/requestUtils.js +14 -0
- package/dist/audit/nodeAnalysisEngine/handleNPMLockFileV2.js +40 -0
- package/dist/audit/nodeAnalysisEngine/index.js +31 -0
- package/dist/audit/nodeAnalysisEngine/parseNPMLockFileContents.js +18 -0
- package/dist/audit/nodeAnalysisEngine/parseYarn2LockFileContents.js +51 -0
- package/dist/audit/nodeAnalysisEngine/parseYarnLockFileContents.js +18 -0
- package/dist/audit/nodeAnalysisEngine/readNPMLockFileContents.js +17 -0
- package/dist/audit/nodeAnalysisEngine/readProjectFileContents.js +14 -0
- package/dist/audit/nodeAnalysisEngine/readYarnLockFileContents.js +24 -0
- package/dist/audit/nodeAnalysisEngine/sanitizer.js +9 -0
- package/dist/audit/phpAnalysisEngine/index.js +23 -0
- package/dist/audit/phpAnalysisEngine/parseLockFileContents.js +52 -0
- package/dist/audit/phpAnalysisEngine/readLockFileContents.js +13 -0
- package/dist/audit/phpAnalysisEngine/readProjectFileContents.js +16 -0
- package/dist/audit/phpAnalysisEngine/sanitizer.js +5 -0
- package/dist/audit/pythonAnalysisEngine/index.js +25 -0
- package/dist/audit/pythonAnalysisEngine/parsePipfileLockContents.js +17 -0
- package/dist/audit/pythonAnalysisEngine/parseProjectFileContents.js +21 -0
- package/dist/audit/pythonAnalysisEngine/readPipfileLockFileContents.js +13 -0
- package/dist/audit/pythonAnalysisEngine/readPythonProjectFileContents.js +14 -0
- package/dist/audit/pythonAnalysisEngine/sanitizer.js +7 -0
- package/dist/audit/rubyAnalysisEngine/index.js +25 -0
- package/dist/audit/rubyAnalysisEngine/parseGemfileLockContents.js +176 -0
- package/dist/audit/rubyAnalysisEngine/parsedGemfile.js +22 -0
- package/dist/audit/rubyAnalysisEngine/readGemfileContents.js +14 -0
- package/dist/audit/rubyAnalysisEngine/readGemfileLockContents.js +14 -0
- package/dist/audit/rubyAnalysisEngine/sanitizer.js +6 -0
- package/dist/commands/audit/auditConfig.js +25 -0
- package/dist/commands/audit/auditController.js +31 -0
- package/dist/commands/audit/help.js +52 -0
- package/dist/commands/audit/processAudit.js +18 -0
- package/dist/commands/auth/auth.js +1 -1
- package/dist/commands/scan/processScan.js +19 -5
- package/dist/common/HTTPClient.js +101 -13
- package/dist/common/errorHandling.js +49 -1
- package/dist/common/findLatestCLIVersion.js +23 -0
- package/dist/constants/constants.js +1 -1
- package/dist/constants/lambda.js +32 -4
- package/dist/constants/locales.js +39 -16
- package/dist/constants.js +148 -20
- package/dist/index.js +7 -1
- package/dist/lambda/aws.js +14 -11
- package/dist/lambda/help.js +4 -0
- package/dist/lambda/lambda.js +50 -27
- package/dist/lambda/lambdaUtils.js +72 -0
- package/dist/lambda/logUtils.js +11 -1
- package/dist/lambda/scanDetailCompletion.js +4 -4
- package/dist/lambda/scanRequest.js +11 -5
- package/dist/lambda/utils.js +110 -53
- package/dist/scan/autoDetection.js +0 -32
- package/dist/scan/fileUtils.js +1 -1
- package/dist/scan/help.js +12 -40
- package/dist/scan/populateProjectIdAndProjectName.js +4 -0
- package/dist/scan/saveResults.js +15 -0
- package/dist/scan/scan.js +77 -42
- package/dist/scan/scanConfig.js +20 -0
- package/dist/scan/scanController.js +13 -15
- package/dist/scan/scanResults.js +18 -16
- package/dist/utils/commonApi.js +3 -3
- package/dist/utils/fileUtils.js +31 -0
- package/dist/utils/paramsUtil/commandlineParams.js +1 -20
- package/dist/utils/paramsUtil/genericCommandLineParams.js +12 -0
- package/dist/utils/paramsUtil/paramHandler.js +3 -6
- package/dist/utils/parsedCLIOptions.js +14 -8
- package/package.json +26 -21
- package/src/audit/AnalysisEngine.js +103 -0
- package/src/audit/catalogueApplication/catalogueApplication.js +42 -0
- package/src/audit/dotnetAnalysisEngine/index.js +26 -0
- package/src/audit/dotnetAnalysisEngine/parseLockFileContents.js +47 -0
- package/src/audit/dotnetAnalysisEngine/parseProjectFileContents.js +29 -0
- package/src/audit/dotnetAnalysisEngine/readLockFileContents.js +30 -0
- package/src/audit/dotnetAnalysisEngine/readProjectFileContents.js +26 -0
- package/src/audit/dotnetAnalysisEngine/sanitizer.js +11 -0
- package/src/audit/goAnalysisEngine/index.js +18 -0
- package/src/audit/goAnalysisEngine/parseProjectFileContents.js +209 -0
- package/src/audit/goAnalysisEngine/readProjectFileContents.js +31 -0
- package/src/audit/goAnalysisEngine/sanitizer.js +7 -0
- package/src/audit/javaAnalysisEngine/index.js +41 -0
- package/src/audit/javaAnalysisEngine/parseMavenProjectFileContents.js +222 -0
- package/src/audit/javaAnalysisEngine/parseProjectFileContents.js +420 -0
- package/src/audit/javaAnalysisEngine/readProjectFileContents.js +141 -0
- package/src/audit/javaAnalysisEngine/sanitizer.js +6 -0
- package/src/audit/languageAnalysisEngine/checkForMultipleIdentifiedLanguages.js +35 -0
- package/src/audit/languageAnalysisEngine/checkForMultipleIdentifiedProjectFiles.js +41 -0
- package/src/audit/languageAnalysisEngine/checkIdentifiedLanguageHasLockFile.js +54 -0
- package/src/audit/languageAnalysisEngine/checkIdentifiedLanguageHasProjectFile.js +32 -0
- package/src/audit/languageAnalysisEngine/commonApi.js +20 -0
- package/src/audit/languageAnalysisEngine/constants.js +23 -0
- package/src/audit/languageAnalysisEngine/filterProjectPath.js +21 -0
- package/src/audit/languageAnalysisEngine/getIdentifiedLanguageInfo.js +41 -0
- package/src/audit/languageAnalysisEngine/getProjectRootFilenames.js +72 -0
- package/src/audit/languageAnalysisEngine/index.js +45 -0
- package/src/audit/languageAnalysisEngine/langugageAnalysisFactory.js +94 -0
- package/src/audit/languageAnalysisEngine/reduceIdentifiedLanguages.js +177 -0
- package/src/audit/languageAnalysisEngine/report/checkIgnoreDevDep.js +27 -0
- package/src/audit/languageAnalysisEngine/report/commonReportingFunctions.js +303 -0
- package/src/audit/languageAnalysisEngine/report/newReportingFeature.js +124 -0
- package/src/audit/languageAnalysisEngine/report/reportingFeature.js +190 -0
- package/src/audit/languageAnalysisEngine/sendSnapshot.js +51 -0
- package/src/audit/languageAnalysisEngine/util/capabilities.js +12 -0
- package/src/audit/languageAnalysisEngine/util/generalAPI.js +43 -0
- package/src/audit/languageAnalysisEngine/util/requestUtils.js +17 -0
- package/src/audit/nodeAnalysisEngine/handleNPMLockFileV2.js +49 -0
- package/src/audit/nodeAnalysisEngine/index.js +35 -0
- package/src/audit/nodeAnalysisEngine/parseNPMLockFileContents.js +20 -0
- package/src/audit/nodeAnalysisEngine/parseYarn2LockFileContents.js +63 -0
- package/src/audit/nodeAnalysisEngine/parseYarnLockFileContents.js +26 -0
- package/src/audit/nodeAnalysisEngine/readNPMLockFileContents.js +23 -0
- package/src/audit/nodeAnalysisEngine/readProjectFileContents.js +27 -0
- package/src/audit/nodeAnalysisEngine/readYarnLockFileContents.js +36 -0
- package/src/audit/nodeAnalysisEngine/sanitizer.js +11 -0
- package/src/audit/phpAnalysisEngine/index.js +27 -0
- package/src/audit/phpAnalysisEngine/parseLockFileContents.js +60 -0
- package/src/audit/phpAnalysisEngine/readLockFileContents.js +14 -0
- package/src/audit/phpAnalysisEngine/readProjectFileContents.js +25 -0
- package/src/audit/phpAnalysisEngine/sanitizer.js +4 -0
- package/src/audit/pythonAnalysisEngine/index.js +55 -0
- package/src/audit/pythonAnalysisEngine/parsePipfileLockContents.js +23 -0
- package/src/audit/pythonAnalysisEngine/parseProjectFileContents.js +33 -0
- package/src/audit/pythonAnalysisEngine/readPipfileLockFileContents.js +16 -0
- package/src/audit/pythonAnalysisEngine/readPythonProjectFileContents.js +22 -0
- package/src/audit/pythonAnalysisEngine/sanitizer.js +9 -0
- package/src/audit/rubyAnalysisEngine/index.js +30 -0
- package/src/audit/rubyAnalysisEngine/parseGemfileLockContents.js +215 -0
- package/src/audit/rubyAnalysisEngine/parsedGemfile.js +39 -0
- package/src/audit/rubyAnalysisEngine/readGemfileContents.js +18 -0
- package/src/audit/rubyAnalysisEngine/readGemfileLockContents.js +17 -0
- package/src/audit/rubyAnalysisEngine/sanitizer.js +8 -0
- package/src/commands/audit/auditConfig.ts +30 -0
- package/src/commands/audit/auditController.ts +31 -0
- package/src/commands/audit/help.ts +48 -0
- package/src/commands/audit/processAudit.ts +19 -0
- package/src/commands/auth/auth.js +1 -1
- package/src/commands/scan/processScan.js +20 -5
- package/src/common/HTTPClient.js +136 -14
- package/src/common/errorHandling.ts +56 -1
- package/src/common/findLatestCLIVersion.ts +27 -0
- package/src/constants/constants.js +1 -1
- package/src/constants/lambda.js +45 -4
- package/src/constants/locales.js +48 -20
- package/src/constants.js +168 -22
- package/src/index.ts +9 -2
- package/src/lambda/aws.ts +13 -12
- package/src/lambda/help.ts +4 -0
- package/src/lambda/lambda.ts +53 -34
- package/src/lambda/lambdaUtils.ts +111 -0
- package/src/lambda/logUtils.ts +19 -1
- package/src/lambda/scanDetailCompletion.ts +4 -4
- package/src/lambda/scanRequest.ts +13 -11
- package/src/lambda/utils.ts +149 -81
- package/src/scan/autoDetection.js +0 -29
- package/src/scan/fileUtils.js +1 -1
- package/src/scan/help.js +12 -45
- package/src/scan/populateProjectIdAndProjectName.js +4 -0
- package/src/scan/saveResults.js +15 -0
- package/src/scan/scan.js +95 -59
- package/src/scan/scanConfig.js +29 -0
- package/src/scan/scanController.js +13 -13
- package/src/scan/scanResults.js +21 -19
- package/src/utils/commonApi.js +2 -3
- package/src/utils/paramsUtil/commandlineParams.js +1 -26
- package/src/utils/paramsUtil/paramHandler.js +3 -7
- package/src/utils/parsedCLIOptions.js +11 -9
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const AnalysisEngine = require('./../AnalysisEngine');
|
|
3
|
+
const readPythonProjectFileContents = require('./readPythonProjectFileContents');
|
|
4
|
+
const readPipfileLockFileContents = require('./readPipfileLockFileContents');
|
|
5
|
+
const parseProjectFileContents = require('./parseProjectFileContents');
|
|
6
|
+
const parsePipfileLockContents = require('./parsePipfileLockContents');
|
|
7
|
+
const sanitizer = require('./sanitizer');
|
|
8
|
+
const i18n = require('i18n');
|
|
9
|
+
module.exports = exports = (language, config, callback) => {
|
|
10
|
+
const ae = new AnalysisEngine({ language, config, python: {} });
|
|
11
|
+
ae.use([
|
|
12
|
+
readPythonProjectFileContents,
|
|
13
|
+
parseProjectFileContents,
|
|
14
|
+
readPipfileLockFileContents,
|
|
15
|
+
parsePipfileLockContents,
|
|
16
|
+
sanitizer
|
|
17
|
+
]);
|
|
18
|
+
ae.analyze((err, analysis) => {
|
|
19
|
+
if (err) {
|
|
20
|
+
callback(new Error(i18n.__('pythonAnalysisEngineError') + `${err.message}`));
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
callback(null, analysis);
|
|
24
|
+
});
|
|
25
|
+
};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const i18n = require('i18n');
|
|
3
|
+
module.exports = exports = ({ language: { lockFilePath }, python }, next) => {
|
|
4
|
+
if (python.rawLockFileContents === undefined) {
|
|
5
|
+
return next();
|
|
6
|
+
}
|
|
7
|
+
try {
|
|
8
|
+
let parsedPipLock = JSON.parse(python.rawLockFileContents);
|
|
9
|
+
parsedPipLock['defaults'] = parsedPipLock['default'];
|
|
10
|
+
python.pipfileLock = parsedPipLock;
|
|
11
|
+
}
|
|
12
|
+
catch (err) {
|
|
13
|
+
next(new Error(i18n.__('pythonAnalysisEnginePipError', lockFilePath ? lockFilePath : 'undefined') + `${err.message}`));
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
next();
|
|
17
|
+
};
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const multiReplace = require('string-multiple-replace');
|
|
3
|
+
const i18n = require('i18n');
|
|
4
|
+
module.exports = exports = ({ python }, next) => {
|
|
5
|
+
const { rawProjectFileContents } = python;
|
|
6
|
+
try {
|
|
7
|
+
const matcherObj = { '"': '' };
|
|
8
|
+
const sequencer = ['"'];
|
|
9
|
+
const parsedPipfile = multiReplace(rawProjectFileContents, matcherObj, sequencer);
|
|
10
|
+
const pythonArray = parsedPipfile.split('\n');
|
|
11
|
+
python.pipfilDependanceies = pythonArray.filter(element => {
|
|
12
|
+
return element != '' && !element.includes('#');
|
|
13
|
+
});
|
|
14
|
+
next();
|
|
15
|
+
}
|
|
16
|
+
catch (err) {
|
|
17
|
+
next(new Error(i18n.__('pythonAnalysisParseProjectFileError', rawProjectFileContents) +
|
|
18
|
+
`${err.message}`));
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const fs = require('fs');
|
|
3
|
+
const i18n = require('i18n');
|
|
4
|
+
module.exports = exports = ({ language: { lockFilePath }, python }, next) => {
|
|
5
|
+
try {
|
|
6
|
+
python.rawLockFileContents = fs.readFileSync(lockFilePath);
|
|
7
|
+
}
|
|
8
|
+
catch (err) {
|
|
9
|
+
next(new Error(i18n.__('pythonAnalysisReadPipFileError', lockFilePath) +
|
|
10
|
+
`${err.message}`));
|
|
11
|
+
}
|
|
12
|
+
next();
|
|
13
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const fs = require('fs');
|
|
3
|
+
const i18n = require('i18n');
|
|
4
|
+
module.exports = exports = ({ language: { projectFilePath }, python }, next) => {
|
|
5
|
+
try {
|
|
6
|
+
python.rawProjectFileContents = fs.readFileSync(projectFilePath, 'utf8');
|
|
7
|
+
next();
|
|
8
|
+
}
|
|
9
|
+
catch (err) {
|
|
10
|
+
next(new Error(i18n.__('pythonAnalysisReadPythonProjectFileError', projectFilePath) +
|
|
11
|
+
`${err.message}`));
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const AnalysisEngine = require('./../AnalysisEngine');
|
|
3
|
+
const readGemfileContents = require('./readGemfileContents');
|
|
4
|
+
const readGemfileLockContents = require('./readGemfileLockContents');
|
|
5
|
+
const parsedGemfile = require('./parsedGemfile');
|
|
6
|
+
const parseGemfileLockFileContents = require('./parseGemfileLockContents');
|
|
7
|
+
const sanitizer = require('./sanitizer');
|
|
8
|
+
const i18n = require('i18n');
|
|
9
|
+
module.exports = exports = (language, config, callback) => {
|
|
10
|
+
const ae = new AnalysisEngine({ language, config, ruby: {} });
|
|
11
|
+
ae.use([
|
|
12
|
+
readGemfileContents,
|
|
13
|
+
parsedGemfile,
|
|
14
|
+
readGemfileLockContents,
|
|
15
|
+
parseGemfileLockFileContents,
|
|
16
|
+
sanitizer
|
|
17
|
+
]);
|
|
18
|
+
ae.analyze((err, analysis) => {
|
|
19
|
+
if (err) {
|
|
20
|
+
callback(new Error(i18n.__('rubyAnalysisEngineError') + `${err.message}`));
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
callback(null, analysis);
|
|
24
|
+
});
|
|
25
|
+
};
|
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const whitespaceRegx = /^(\s*)/;
|
|
3
|
+
let index = 0;
|
|
4
|
+
const depReg = /^\s*([A-Za-z0-9.!@#$%\-^&*_+]*)\s*(\((.*?)\))/;
|
|
5
|
+
const i18n = require('i18n');
|
|
6
|
+
const GEMFILE_KEY_VALUE = /^\s*([^:(]*)\s*\:*\s*(.*)/;
|
|
7
|
+
let rubyObj = {};
|
|
8
|
+
rubyObj.dependencies = {};
|
|
9
|
+
module.exports = exports = ({ ruby }, next) => {
|
|
10
|
+
const { rawLockFileContents } = ruby;
|
|
11
|
+
let lines = rawLockFileContents.split('\n');
|
|
12
|
+
try {
|
|
13
|
+
ruby.gemfileLock = {};
|
|
14
|
+
getDirectDepencies(lines, ruby.gemfileLock);
|
|
15
|
+
getRubyVersion(lines, ruby.gemfileLock);
|
|
16
|
+
getSourceArr(lines, ruby.gemfileLock);
|
|
17
|
+
next();
|
|
18
|
+
}
|
|
19
|
+
catch (err) {
|
|
20
|
+
next(new Error(i18n.__('rubyAnalysisEngineParsedGemLockFileError') + `${err.message}`));
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
const populateSourceType = (line, rubyObj) => {
|
|
24
|
+
return (rubyObj.sourceType = line);
|
|
25
|
+
};
|
|
26
|
+
const nonDependencyKeys = (line, rubyObj) => {
|
|
27
|
+
let parts = GEMFILE_KEY_VALUE.exec(line);
|
|
28
|
+
let key = parts[1].trim();
|
|
29
|
+
let value = parts[2] || '';
|
|
30
|
+
return (rubyObj[key] = value);
|
|
31
|
+
};
|
|
32
|
+
const populateResolveAndPlatform = (dependency, rubyObj) => {
|
|
33
|
+
const depArr = dependency.split('-');
|
|
34
|
+
rubyObj.resolved = depArr[0];
|
|
35
|
+
rubyObj.platform = depArr.length > 1 ? depArr[1] : 'UNSPECIFIED';
|
|
36
|
+
return rubyObj;
|
|
37
|
+
};
|
|
38
|
+
const isUpperCase = str => {
|
|
39
|
+
return str === str.toUpperCase();
|
|
40
|
+
};
|
|
41
|
+
const getDirectDepencies = (lines, ruby) => {
|
|
42
|
+
let depIndex = 0;
|
|
43
|
+
for (let i = 0; i < lines.length; i++) {
|
|
44
|
+
if (lines[i] == 'DEPENDENCIES') {
|
|
45
|
+
depIndex = i;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
const getDepArray = lines.slice(depIndex);
|
|
49
|
+
ruby.dependencies = {};
|
|
50
|
+
for (let j = 1; j < getDepArray.length; j++) {
|
|
51
|
+
const element = getDepArray[j];
|
|
52
|
+
if (!isUpperCase(element)) {
|
|
53
|
+
const isDependencyWithVersion = depReg.test(element);
|
|
54
|
+
if (isDependencyWithVersion) {
|
|
55
|
+
const dependency = depReg.exec(element);
|
|
56
|
+
let name = dependency[1];
|
|
57
|
+
name = name.replace('!', '');
|
|
58
|
+
ruby.dependencies[name.trim()] = dependency[3];
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
let name = element;
|
|
62
|
+
name = name.replace('!', ' ');
|
|
63
|
+
ruby.dependencies[name.trim()] = 'UNSPECIFIED';
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
const getRubyVersion = (lines, ruby) => {
|
|
72
|
+
let rubVersionIndex = 0;
|
|
73
|
+
for (let i = 0; i < lines.length; i++) {
|
|
74
|
+
if (lines[i] == 'RUBY VERSION') {
|
|
75
|
+
rubVersionIndex = i;
|
|
76
|
+
break;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
if (rubVersionIndex !== 0) {
|
|
80
|
+
const getRubyVersionArray = lines.slice(rubVersionIndex);
|
|
81
|
+
ruby.runtimeDetails = {};
|
|
82
|
+
for (let j = 1; j < getRubyVersionArray.length; j++) {
|
|
83
|
+
let element = getRubyVersionArray[j];
|
|
84
|
+
if (!isUpperCase(element)) {
|
|
85
|
+
element = element.trim();
|
|
86
|
+
if (/^([ruby\s0-9.*]+)/.test(element)) {
|
|
87
|
+
let splitElement = element.split(' ');
|
|
88
|
+
ruby.runtimeDetails['version'] = splitElement[1];
|
|
89
|
+
}
|
|
90
|
+
if (/^([p0-9]+)/.test(element)) {
|
|
91
|
+
ruby.runtimeDetails['patchLevel'] = element.substring(1);
|
|
92
|
+
}
|
|
93
|
+
if (element.includes('engine')) {
|
|
94
|
+
let splitElement = element.split(' ');
|
|
95
|
+
ruby.runtimeDetails[splitElement[0]] = splitElement[1];
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
const formatSourceArr = sourceArr => {
|
|
105
|
+
return sourceArr.map(element => {
|
|
106
|
+
if (element.sourceType === 'GIT') {
|
|
107
|
+
delete element.specs;
|
|
108
|
+
}
|
|
109
|
+
if (element.sourceType === 'GEM') {
|
|
110
|
+
delete element.branch;
|
|
111
|
+
delete element.revision;
|
|
112
|
+
delete element.depthLevel;
|
|
113
|
+
delete element.specs;
|
|
114
|
+
}
|
|
115
|
+
if (element.sourceType === 'PATH') {
|
|
116
|
+
delete element.branch;
|
|
117
|
+
delete element.revision;
|
|
118
|
+
delete element.depthLevel;
|
|
119
|
+
delete element.specs;
|
|
120
|
+
delete element.platform;
|
|
121
|
+
}
|
|
122
|
+
return element;
|
|
123
|
+
});
|
|
124
|
+
};
|
|
125
|
+
const getSourceArr = (lines, ruby) => {
|
|
126
|
+
let line = 0;
|
|
127
|
+
let source = [];
|
|
128
|
+
while ((line = lines[index++]) !== undefined) {
|
|
129
|
+
let currentWS = whitespaceRegx.exec(line)[1].length;
|
|
130
|
+
if (!line.includes(' bundler (')) {
|
|
131
|
+
if (currentWS === 0 && !line.includes(':') && line != '') {
|
|
132
|
+
populateSourceType(line, rubyObj);
|
|
133
|
+
}
|
|
134
|
+
if (currentWS !== 0 && line.includes(':')) {
|
|
135
|
+
nonDependencyKeys(line, rubyObj);
|
|
136
|
+
}
|
|
137
|
+
if (currentWS > 2) {
|
|
138
|
+
const isDependencyWithVersion = depReg.test(line);
|
|
139
|
+
let nexlineWS = whitespaceRegx.exec(lines[index])[1].length;
|
|
140
|
+
if (currentWS === 6) {
|
|
141
|
+
const dependency = depReg.exec(line);
|
|
142
|
+
if (isDependencyWithVersion) {
|
|
143
|
+
if (rubyObj.name !== dependency[1]) {
|
|
144
|
+
rubyObj.dependencies[dependency[1]] = dependency[3];
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
else {
|
|
148
|
+
rubyObj.dependencies[line.trim()] = 'UNSPECIFIED';
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
if (currentWS === 4 && rubyObj.depthLevel === undefined) {
|
|
152
|
+
const dependency = depReg.exec(line);
|
|
153
|
+
rubyObj.name = dependency[1];
|
|
154
|
+
rubyObj.depthLevel = currentWS;
|
|
155
|
+
populateResolveAndPlatform(dependency[3], rubyObj);
|
|
156
|
+
}
|
|
157
|
+
if (currentWS === 4 && rubyObj.depthLevel) {
|
|
158
|
+
const dependency = depReg.exec(line);
|
|
159
|
+
rubyObj.name = dependency[1];
|
|
160
|
+
rubyObj.depthLevel = currentWS;
|
|
161
|
+
populateResolveAndPlatform(dependency[3], rubyObj);
|
|
162
|
+
}
|
|
163
|
+
if ((currentWS === 4 && nexlineWS === 4) ||
|
|
164
|
+
(currentWS === 6 && nexlineWS === 4) ||
|
|
165
|
+
nexlineWS == '') {
|
|
166
|
+
let newObj = {};
|
|
167
|
+
newObj = JSON.parse(JSON.stringify(rubyObj));
|
|
168
|
+
source.push(newObj);
|
|
169
|
+
rubyObj.dependencies = {};
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
ruby.sources = formatSourceArr(source);
|
|
175
|
+
};
|
|
176
|
+
exports.getSourceArr = getSourceArr;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const i18n = require('i18n');
|
|
3
|
+
module.exports = exports = ({ ruby }, next) => {
|
|
4
|
+
const { rawProjectFileContents } = ruby;
|
|
5
|
+
try {
|
|
6
|
+
const rubyArray = rawProjectFileContents.split('\n');
|
|
7
|
+
let filteredRubyDep = rubyArray.filter(element => {
|
|
8
|
+
return (!element.includes('#') &&
|
|
9
|
+
element.includes('gem') &&
|
|
10
|
+
!element.includes('source'));
|
|
11
|
+
});
|
|
12
|
+
for (let i = 0; i < filteredRubyDep.length; i++) {
|
|
13
|
+
filteredRubyDep[i] = filteredRubyDep[i].trim();
|
|
14
|
+
}
|
|
15
|
+
ruby.gemfilesDependanceies = filteredRubyDep;
|
|
16
|
+
next();
|
|
17
|
+
}
|
|
18
|
+
catch (err) {
|
|
19
|
+
next(new Error(i18n.__('rubyAnalysisEngineParsedGemFileError', rawProjectFileContents) + `${err.message}`));
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const fs = require('fs');
|
|
3
|
+
const i18n = require('i18n');
|
|
4
|
+
module.exports = exports = ({ language: { projectFilePath }, ruby }, next) => {
|
|
5
|
+
try {
|
|
6
|
+
ruby.rawProjectFileContents = fs.readFileSync(projectFilePath, 'utf8');
|
|
7
|
+
next();
|
|
8
|
+
}
|
|
9
|
+
catch (err) {
|
|
10
|
+
next(new Error(i18n.__('rubyAnalysisEngineReadGemFileError', projectFilePath) +
|
|
11
|
+
`${err.message}`));
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const fs = require('fs');
|
|
3
|
+
const i18n = require('i18n');
|
|
4
|
+
module.exports = exports = ({ language: { lockFilePath }, ruby }, next) => {
|
|
5
|
+
try {
|
|
6
|
+
ruby.rawLockFileContents = fs.readFileSync(lockFilePath, 'utf8');
|
|
7
|
+
next();
|
|
8
|
+
}
|
|
9
|
+
catch (err) {
|
|
10
|
+
next(new Error(i18n.__('rubyAnalysisEngineReadGemLockFileError', lockFilePath) +
|
|
11
|
+
`${err.message}`));
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
};
|
|
@@ -0,0 +1,25 @@
|
|
|
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.getAuditConfig = void 0;
|
|
7
|
+
const paramHandler_1 = __importDefault(require("../../utils/paramsUtil/paramHandler"));
|
|
8
|
+
const constants_1 = __importDefault(require("../../constants"));
|
|
9
|
+
const parsedCLIOptions_1 = __importDefault(require("../../utils/parsedCLIOptions"));
|
|
10
|
+
const constants_2 = __importDefault(require("../../audit/languageAnalysisEngine/constants"));
|
|
11
|
+
const { supportedLanguages: { NODE, JAVASCRIPT } } = constants_2.default;
|
|
12
|
+
const getAuditConfig = (argv) => {
|
|
13
|
+
const auditParameters = parsedCLIOptions_1.default.getCommandLineArgsCustom(argv, constants_1.default.commandLineDefinitions.auditOptionDefinitions);
|
|
14
|
+
const paramsAuth = paramHandler_1.default.getAuth(auditParameters);
|
|
15
|
+
if (auditParameters.language === undefined ||
|
|
16
|
+
auditParameters.language === null) {
|
|
17
|
+
console.log('error, --language parameter is required');
|
|
18
|
+
process.exit(1);
|
|
19
|
+
}
|
|
20
|
+
else if (auditParameters.language.toUpperCase() === JAVASCRIPT) {
|
|
21
|
+
auditParameters.language = NODE.toLowerCase();
|
|
22
|
+
}
|
|
23
|
+
return { ...paramsAuth, ...auditParameters };
|
|
24
|
+
};
|
|
25
|
+
exports.getAuditConfig = getAuditConfig;
|
|
@@ -0,0 +1,31 @@
|
|
|
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.startAudit = void 0;
|
|
7
|
+
const catalogueApplication_1 = require("../../audit/catalogueApplication/catalogueApplication");
|
|
8
|
+
const commonApi_1 = __importDefault(require("../../audit/languageAnalysisEngine/commonApi"));
|
|
9
|
+
const identifyLanguageAE = require('./../../audit/languageAnalysisEngine');
|
|
10
|
+
const languageFactory = require('./../../audit/languageAnalysisEngine/langugageAnalysisFactory');
|
|
11
|
+
const dealWithNoAppId = async (config) => {
|
|
12
|
+
let appID;
|
|
13
|
+
try {
|
|
14
|
+
appID = await commonApi_1.default.returnAppId(config);
|
|
15
|
+
if (!appID && config.applicationName) {
|
|
16
|
+
return await (0, catalogueApplication_1.catalogueApplication)(config);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
catch (e) {
|
|
20
|
+
console.log(e);
|
|
21
|
+
}
|
|
22
|
+
console.log(appID);
|
|
23
|
+
return appID;
|
|
24
|
+
};
|
|
25
|
+
const startAudit = async (config) => {
|
|
26
|
+
if (!config.applicationId) {
|
|
27
|
+
config.applicationId = await dealWithNoAppId(config);
|
|
28
|
+
}
|
|
29
|
+
identifyLanguageAE(config.projectPath, languageFactory, config.applicationId, config);
|
|
30
|
+
};
|
|
31
|
+
exports.startAudit = startAudit;
|
|
@@ -0,0 +1,52 @@
|
|
|
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.auditUsageGuide = void 0;
|
|
7
|
+
const command_line_usage_1 = __importDefault(require("command-line-usage"));
|
|
8
|
+
const i18n_1 = __importDefault(require("i18n"));
|
|
9
|
+
const constants_1 = __importDefault(require("../../constants"));
|
|
10
|
+
const auditUsageGuide = (0, command_line_usage_1.default)([
|
|
11
|
+
{
|
|
12
|
+
header: i18n_1.default.__('auditHeader'),
|
|
13
|
+
content: [i18n_1.default.__('auditHeaderMessage')]
|
|
14
|
+
},
|
|
15
|
+
{
|
|
16
|
+
header: i18n_1.default.__('constantsPrerequisitesHeader'),
|
|
17
|
+
content: [
|
|
18
|
+
'{bold ' +
|
|
19
|
+
i18n_1.default.__('constantsAuditPrerequisitesContentSupportedLanguages') +
|
|
20
|
+
'}',
|
|
21
|
+
'{bold ' +
|
|
22
|
+
i18n_1.default.__('constantsAuditPrerequisitesContentJava') +
|
|
23
|
+
'}' +
|
|
24
|
+
i18n_1.default.__('constantsAuditPrerequisitesContentMessage'),
|
|
25
|
+
'',
|
|
26
|
+
'{italic ' + i18n_1.default.__('constantsJavaNote') + '}',
|
|
27
|
+
'{italic ' + i18n_1.default.__('constantsJavaNoteGradle') + '}',
|
|
28
|
+
'',
|
|
29
|
+
'{bold ' +
|
|
30
|
+
i18n_1.default.__('constantsAuditPrerequisitesContentDotNet') +
|
|
31
|
+
'}' +
|
|
32
|
+
i18n_1.default.__('constantsAuditPrerequisitesContentDotNetMessage'),
|
|
33
|
+
'{bold ' +
|
|
34
|
+
i18n_1.default.__('constantsAuditPrerequisitesContentLanguageNode') +
|
|
35
|
+
'}' +
|
|
36
|
+
i18n_1.default.__('constantsAuditPrerequisitesContentLanguageNodeMessage'),
|
|
37
|
+
'{bold ' +
|
|
38
|
+
i18n_1.default.__('constantsAuditPrerequisitesContentLanguageRuby') +
|
|
39
|
+
'}' +
|
|
40
|
+
i18n_1.default.__('constantsAuditPrerequisitesContentLanguageRubyMessage'),
|
|
41
|
+
'{bold ' +
|
|
42
|
+
i18n_1.default.__('constantsAuditPrerequisitesContentLanguagePython') +
|
|
43
|
+
'}' +
|
|
44
|
+
i18n_1.default.__('constantsAuditPrerequisitesContentLanguagePythonMessage')
|
|
45
|
+
]
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
header: i18n_1.default.__('constantsAuditOptions'),
|
|
49
|
+
optionList: constants_1.default.commandLineDefinitions.auditOptionDefinitions
|
|
50
|
+
}
|
|
51
|
+
]);
|
|
52
|
+
exports.auditUsageGuide = auditUsageGuide;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.processAudit = void 0;
|
|
4
|
+
const auditController_1 = require("./auditController");
|
|
5
|
+
const auditConfig_1 = require("./auditConfig");
|
|
6
|
+
const help_1 = require("./help");
|
|
7
|
+
const processAudit = async (argv) => {
|
|
8
|
+
if (argv.indexOf('--help') != -1) {
|
|
9
|
+
printHelpMessage();
|
|
10
|
+
process.exit(1);
|
|
11
|
+
}
|
|
12
|
+
const config = (0, auditConfig_1.getAuditConfig)(argv);
|
|
13
|
+
const auditResults = await (0, auditController_1.startAudit)(config);
|
|
14
|
+
};
|
|
15
|
+
exports.processAudit = processAudit;
|
|
16
|
+
const printHelpMessage = () => {
|
|
17
|
+
console.log(help_1.auditUsageGuide);
|
|
18
|
+
};
|
|
@@ -34,7 +34,7 @@ const isAuthComplete = async (token, timeout, config) => {
|
|
|
34
34
|
let result = await pollAuthResult(token, client);
|
|
35
35
|
if (result.statusCode === 200) {
|
|
36
36
|
succeedSpinner(authSpinner, i18n.__('authSuccessMessage'));
|
|
37
|
-
console.log(i18n.__('
|
|
37
|
+
console.log(i18n.__('runAuthSuccessMessage'));
|
|
38
38
|
return result.body;
|
|
39
39
|
}
|
|
40
40
|
let endTime = new Date() - startTime;
|
|
@@ -1,18 +1,32 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
const { startScan } = require('../../scan/scanController');
|
|
3
|
-
const paramHandler = require('../../utils/paramsUtil/paramHandler');
|
|
4
3
|
const { formatScanOutput } = require('../../scan/scan');
|
|
5
4
|
const { scanUsageGuide } = require('../../scan/help');
|
|
6
|
-
const
|
|
7
|
-
|
|
8
|
-
|
|
5
|
+
const scanConfig = require('../../scan/scanConfig');
|
|
6
|
+
const saveResults = require('../../scan/saveResults');
|
|
7
|
+
const commonApi = require('../../utils/commonApi');
|
|
8
|
+
const i18n = require('i18n');
|
|
9
|
+
const processScan = async (argvMain) => {
|
|
10
|
+
if (argvMain.indexOf('--help') !== -1) {
|
|
9
11
|
printHelpMessage();
|
|
10
12
|
process.exit(1);
|
|
11
13
|
}
|
|
12
|
-
let
|
|
14
|
+
let config = scanConfig.getScanConfig(argvMain);
|
|
15
|
+
let scanResults = await startScan(config);
|
|
13
16
|
if (scanResults) {
|
|
14
17
|
formatScanOutput(scanResults?.projectOverview, scanResults?.scanResultsInstances);
|
|
15
18
|
}
|
|
19
|
+
if (config.save) {
|
|
20
|
+
if (config.save.toLowerCase() === 'sarif') {
|
|
21
|
+
const scanId = scanResults.scanDetail.id;
|
|
22
|
+
const client = commonApi.getHttpClient(config);
|
|
23
|
+
const rawResults = await client.getSpecificScanResultSarif(config, scanId);
|
|
24
|
+
saveResults.writeResultsToFile(rawResults?.body);
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
console.log(i18n.__('scanNoFiletypeSpecifiedForSave'));
|
|
28
|
+
}
|
|
29
|
+
}
|
|
16
30
|
};
|
|
17
31
|
const printHelpMessage = () => {
|
|
18
32
|
console.log(scanUsageGuide);
|