scanoss 0.2.18 → 0.2.21

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.
Files changed (154) hide show
  1. package/build/main/bin/cli-bin.js +4 -2
  2. package/build/main/commands/dep.js +19 -7
  3. package/build/main/commands/helpers.d.ts +1 -0
  4. package/build/main/commands/helpers.js +22 -0
  5. package/build/main/commands/scan.js +3 -15
  6. package/build/main/index.d.ts +2 -1
  7. package/build/main/index.js +3 -2
  8. package/build/main/lib/dependencies/DependencyScanner.d.ts +10 -0
  9. package/build/main/lib/dependencies/DependencyScanner.js +66 -0
  10. package/build/main/lib/dependencies/DependencyScannerCfg.d.ts +4 -0
  11. package/build/main/lib/dependencies/DependencyScannerCfg.js +11 -0
  12. package/build/main/lib/dependencies/DependencyTypes.d.ts +10 -8
  13. package/build/main/lib/dependencies/LocalDependency/DependencyTypes.d.ts +16 -0
  14. package/build/main/lib/dependencies/LocalDependency/DependencyTypes.js +3 -0
  15. package/build/main/lib/dependencies/LocalDependency/LocalDependency.d.ts +6 -0
  16. package/build/main/lib/dependencies/LocalDependency/LocalDependency.js +51 -0
  17. package/build/main/lib/dependencies/LocalDependency/parsers/golangParser.d.ts +2 -0
  18. package/build/main/lib/dependencies/LocalDependency/parsers/golangParser.js +63 -0
  19. package/build/main/lib/dependencies/LocalDependency/parsers/mavenParser.d.ts +2 -0
  20. package/build/main/lib/dependencies/LocalDependency/parsers/mavenParser.js +57 -0
  21. package/build/main/lib/dependencies/{parsers → LocalDependency/parsers}/npmParser.d.ts +3 -3
  22. package/build/main/lib/dependencies/LocalDependency/parsers/npmParser.js +50 -0
  23. package/build/main/lib/dependencies/LocalDependency/parsers/pyParser.d.ts +2 -0
  24. package/build/main/lib/dependencies/LocalDependency/parsers/pyParser.js +61 -0
  25. package/build/main/lib/dependencies/{parsers → LocalDependency/parsers}/rubyParser.d.ts +3 -3
  26. package/build/main/lib/dependencies/LocalDependency/parsers/rubyParser.js +133 -0
  27. package/build/main/lib/dependencies/{parsers → LocalDependency/parsers}/utils.d.ts +0 -0
  28. package/build/main/lib/dependencies/{parsers → LocalDependency/parsers}/utils.js +1 -1
  29. package/build/main/lib/grpc/GrpcDependencyService.d.ts +11 -0
  30. package/build/main/lib/grpc/GrpcDependencyService.js +88 -0
  31. package/build/main/lib/{dependencies/parsers/golangParser.d.ts → grpc/scanoss/api/common/v2/scanoss-common_grpc_pb.d.ts} +0 -0
  32. package/build/main/lib/grpc/scanoss/api/common/v2/scanoss-common_grpc_pb.js +2 -0
  33. package/build/main/lib/grpc/scanoss/api/common/v2/scanoss-common_pb.d.ts +1 -0
  34. package/build/main/lib/grpc/scanoss/api/common/v2/scanoss-common_pb.js +404 -0
  35. package/build/main/lib/grpc/scanoss/api/dependencies/v2/scanoss-dependencies_grpc_pb.d.ts +42 -0
  36. package/build/main/lib/grpc/scanoss/api/dependencies/v2/scanoss-dependencies_grpc_pb.js +98 -0
  37. package/build/main/lib/grpc/scanoss/api/dependencies/v2/scanoss-dependencies_pb.d.ts +1 -0
  38. package/build/main/lib/grpc/scanoss/api/dependencies/v2/scanoss-dependencies_pb.js +1197 -0
  39. package/build/main/lib/grpc/scanoss/api/scanning/v2/scanoss-scanning_grpc_pb.d.ts +21 -0
  40. package/build/main/lib/grpc/scanoss/api/scanning/v2/scanoss-scanning_grpc_pb.js +66 -0
  41. package/build/main/lib/grpc/scanoss/api/scanning/v2/scanoss-scanning_pb.d.ts +1 -0
  42. package/build/main/lib/grpc/scanoss/api/scanning/v2/scanoss-scanning_pb.js +14 -0
  43. package/build/main/lib/scanner/Scanner.js +1 -1
  44. package/build/module/bin/cli-bin.js +4 -2
  45. package/build/module/commands/dep.js +19 -7
  46. package/build/module/commands/helpers.d.ts +1 -0
  47. package/build/module/commands/helpers.js +15 -0
  48. package/build/module/commands/scan.js +2 -14
  49. package/build/module/index.d.ts +2 -1
  50. package/build/module/index.js +3 -2
  51. package/build/module/lib/dependencies/DependencyScanner.d.ts +10 -0
  52. package/build/module/lib/dependencies/DependencyScanner.js +64 -0
  53. package/build/module/lib/dependencies/DependencyScannerCfg.d.ts +4 -0
  54. package/build/module/lib/dependencies/DependencyScannerCfg.js +5 -0
  55. package/build/module/lib/dependencies/DependencyTypes.d.ts +10 -8
  56. package/build/module/lib/dependencies/LocalDependency/DependencyTypes.d.ts +16 -0
  57. package/build/module/lib/dependencies/LocalDependency/DependencyTypes.js +2 -0
  58. package/build/module/lib/dependencies/LocalDependency/LocalDependency.d.ts +6 -0
  59. package/build/module/lib/dependencies/LocalDependency/LocalDependency.js +45 -0
  60. package/build/module/lib/dependencies/LocalDependency/parsers/golangParser.d.ts +2 -0
  61. package/build/module/lib/dependencies/LocalDependency/parsers/golangParser.js +55 -0
  62. package/build/module/lib/dependencies/LocalDependency/parsers/mavenParser.d.ts +2 -0
  63. package/build/module/lib/dependencies/LocalDependency/parsers/mavenParser.js +50 -0
  64. package/build/module/lib/dependencies/{parsers → LocalDependency/parsers}/npmParser.d.ts +3 -3
  65. package/build/module/lib/dependencies/LocalDependency/parsers/npmParser.js +42 -0
  66. package/build/module/lib/dependencies/LocalDependency/parsers/pyParser.d.ts +2 -0
  67. package/build/module/lib/dependencies/LocalDependency/parsers/pyParser.js +53 -0
  68. package/build/module/lib/dependencies/{parsers → LocalDependency/parsers}/rubyParser.d.ts +3 -3
  69. package/build/module/lib/dependencies/LocalDependency/parsers/rubyParser.js +130 -0
  70. package/build/module/lib/dependencies/{parsers → LocalDependency/parsers}/utils.d.ts +0 -0
  71. package/build/module/lib/dependencies/LocalDependency/parsers/utils.js +15 -0
  72. package/build/module/lib/grpc/GrpcDependencyService.d.ts +11 -0
  73. package/build/module/lib/grpc/GrpcDependencyService.js +67 -0
  74. package/build/module/lib/{dependencies/parsers/golangParser.d.ts → grpc/scanoss/api/common/v2/scanoss-common_grpc_pb.d.ts} +0 -0
  75. package/build/module/lib/grpc/scanoss/api/common/v2/scanoss-common_grpc_pb.js +2 -0
  76. package/build/module/lib/grpc/scanoss/api/common/v2/scanoss-common_pb.d.ts +1 -0
  77. package/build/module/lib/grpc/scanoss/api/common/v2/scanoss-common_pb.js +404 -0
  78. package/build/module/lib/grpc/scanoss/api/dependencies/v2/scanoss-dependencies_grpc_pb.d.ts +42 -0
  79. package/build/module/lib/grpc/scanoss/api/dependencies/v2/scanoss-dependencies_grpc_pb.js +98 -0
  80. package/build/module/lib/grpc/scanoss/api/dependencies/v2/scanoss-dependencies_pb.d.ts +1 -0
  81. package/build/module/lib/grpc/scanoss/api/dependencies/v2/scanoss-dependencies_pb.js +1197 -0
  82. package/build/module/lib/grpc/scanoss/api/scanning/v2/scanoss-scanning_grpc_pb.d.ts +21 -0
  83. package/build/module/lib/grpc/scanoss/api/scanning/v2/scanoss-scanning_grpc_pb.js +66 -0
  84. package/build/module/lib/grpc/scanoss/api/scanning/v2/scanoss-scanning_pb.d.ts +1 -0
  85. package/build/module/lib/grpc/scanoss/api/scanning/v2/scanoss-scanning_pb.js +14 -0
  86. package/build/module/lib/scanner/Scanner.js +1 -1
  87. package/build/tsconfig.module.tsbuildinfo +1 -1
  88. package/build/tsconfig.tsbuildinfo +1 -1
  89. package/package.json +3 -1
  90. package/src/bin/cli-bin.ts +4 -1
  91. package/src/commands/dep.ts +18 -6
  92. package/src/commands/helpers.ts +14 -0
  93. package/src/commands/scan.ts +3 -12
  94. package/src/index.ts +5 -1
  95. package/src/lib/dependencies/DependencyScanner.ts +77 -0
  96. package/src/lib/dependencies/DependencyScannerCfg.ts +7 -0
  97. package/src/lib/dependencies/DependencyTypes.ts +16 -14
  98. package/src/lib/dependencies/LocalDependency/DependencyTypes.ts +21 -0
  99. package/src/lib/dependencies/LocalDependency/LocalDependency.ts +48 -0
  100. package/src/lib/dependencies/LocalDependency/parsers/golangParser.ts +78 -0
  101. package/src/lib/dependencies/{parsers → LocalDependency/parsers}/mavenParser.ts +10 -6
  102. package/src/lib/dependencies/{parsers → LocalDependency/parsers}/npmParser.ts +14 -8
  103. package/src/lib/dependencies/LocalDependency/parsers/pyParser.ts +55 -0
  104. package/src/lib/dependencies/{parsers → LocalDependency/parsers}/rubyParser.ts +21 -29
  105. package/src/lib/dependencies/{parsers → LocalDependency/parsers}/utils.ts +0 -1
  106. package/src/lib/grpc/GrpcDependencyService.ts +73 -0
  107. package/src/lib/grpc/scanoss/api/common/v2/scanoss-common_grpc_pb.d.ts +1 -0
  108. package/src/lib/grpc/scanoss/api/common/v2/scanoss-common_grpc_pb.js +1 -0
  109. package/src/lib/grpc/scanoss/api/common/v2/scanoss-common_pb.d.ts +79 -0
  110. package/src/lib/grpc/scanoss/api/common/v2/scanoss-common_pb.js +482 -0
  111. package/src/lib/grpc/scanoss/api/dependencies/v2/scanoss-dependencies_grpc_pb.d.ts +30 -0
  112. package/src/lib/grpc/scanoss/api/dependencies/v2/scanoss-dependencies_grpc_pb.js +109 -0
  113. package/src/lib/grpc/scanoss/api/dependencies/v2/scanoss-dependencies_pb.d.ts +206 -0
  114. package/src/lib/grpc/scanoss/api/dependencies/v2/scanoss-dependencies_pb.js +1489 -0
  115. package/src/lib/grpc/scanoss/api/scanning/v2/scanoss-scanning_grpc_pb.d.ts +25 -0
  116. package/src/lib/grpc/scanoss/api/scanning/v2/scanoss-scanning_grpc_pb.js +73 -0
  117. package/src/lib/grpc/scanoss/api/scanning/v2/scanoss-scanning_pb.d.ts +6 -0
  118. package/src/lib/grpc/scanoss/api/scanning/v2/scanoss-scanning_pb.js +15 -0
  119. package/src/lib/scanner/Scanner.ts +2 -1
  120. package/tsconfig.json +5 -22
  121. package/yarn.lock +5252 -5213
  122. package/build/main/lib/dependencies/Dependency.d.ts +0 -9
  123. package/build/main/lib/dependencies/Dependency.js +0 -52
  124. package/build/main/lib/dependencies/PurlGenerator.d.ts +0 -2
  125. package/build/main/lib/dependencies/PurlGenerator.js +0 -44
  126. package/build/main/lib/dependencies/parsers/golangParser.js +0 -3
  127. package/build/main/lib/dependencies/parsers/mavenParser.d.ts +0 -2
  128. package/build/main/lib/dependencies/parsers/mavenParser.js +0 -54
  129. package/build/main/lib/dependencies/parsers/npmParser.js +0 -46
  130. package/build/main/lib/dependencies/parsers/pyParser.d.ts +0 -2
  131. package/build/main/lib/dependencies/parsers/pyParser.js +0 -51
  132. package/build/main/lib/dependencies/parsers/rubyParser.js +0 -135
  133. package/build/main/lib/dependencies/parsers/types.d.ts +0 -15
  134. package/build/main/lib/dependencies/parsers/types.js +0 -33
  135. package/build/module/lib/dependencies/Dependency.d.ts +0 -9
  136. package/build/module/lib/dependencies/Dependency.js +0 -47
  137. package/build/module/lib/dependencies/PurlGenerator.d.ts +0 -2
  138. package/build/module/lib/dependencies/PurlGenerator.js +0 -37
  139. package/build/module/lib/dependencies/parsers/golangParser.js +0 -3
  140. package/build/module/lib/dependencies/parsers/mavenParser.d.ts +0 -2
  141. package/build/module/lib/dependencies/parsers/mavenParser.js +0 -47
  142. package/build/module/lib/dependencies/parsers/npmParser.js +0 -38
  143. package/build/module/lib/dependencies/parsers/pyParser.d.ts +0 -2
  144. package/build/module/lib/dependencies/parsers/pyParser.js +0 -44
  145. package/build/module/lib/dependencies/parsers/rubyParser.js +0 -132
  146. package/build/module/lib/dependencies/parsers/types.d.ts +0 -15
  147. package/build/module/lib/dependencies/parsers/types.js +0 -32
  148. package/build/module/lib/dependencies/parsers/utils.js +0 -15
  149. package/package-lock.json +0 -18589
  150. package/src/lib/dependencies/Dependency.ts +0 -60
  151. package/src/lib/dependencies/PurlGenerator.ts +0 -44
  152. package/src/lib/dependencies/parsers/golangParser.ts +0 -4
  153. package/src/lib/dependencies/parsers/pyParser.ts +0 -46
  154. package/src/lib/dependencies/parsers/types.ts +0 -50
@@ -1,60 +0,0 @@
1
- import os from "os";
2
- import fs from "fs";
3
-
4
- import { IDependencyResponse, IFile, IDependency } from "./DependencyTypes";
5
- import { FileListDependency } from "./parsers/types";
6
- import { generateDependenciesPurls } from "./PurlGenerator";
7
- import { PackageURL } from "packageurl-js";
8
-
9
- export class Dependency {
10
-
11
- private workDirectory: string;
12
-
13
- private resultFilePath: string;
14
-
15
- constructor () {
16
- this.setWorkDirectory(`${os.tmpdir()}/depscanner-${new Date().getTime()}`);
17
- }
18
-
19
- public async scan (fileList: Array<string>): Promise<IDependencyResponse> {
20
- const toGrpc = await generateDependenciesPurls(fileList);
21
- // Here we should call to the grpc server
22
- return this.adapterToDependencyResponse(toGrpc);
23
- }
24
-
25
- public setWorkDirectory(workDirectory: string) {
26
- this.workDirectory = workDirectory;
27
- this.resultFilePath = `${this.workDirectory}/dependencies.json`;
28
-
29
- if (!fs.existsSync(this.workDirectory)) fs.mkdirSync(this.workDirectory);
30
- }
31
-
32
- private adapterToDependencyResponse (dependencies: FileListDependency): IDependencyResponse {
33
- const results = <IDependencyResponse>{files: []};
34
-
35
- for (const dependency of dependencies.files){
36
- let depArr: Array<IDependency> = [];
37
- for (const purl of dependency.purls) {
38
- const pkg = PackageURL.fromString(purl.purl);
39
-
40
- depArr.push({
41
- component: null,
42
- purl: purl.purl,
43
- version: pkg.version,
44
- licenses: [{name: null}]
45
- });
46
- }
47
-
48
- let fileArr = <IFile>{};
49
- fileArr = ({
50
- file: dependency.file,
51
- id: "dependency",
52
- status: "pending",
53
- dependencies: depArr
54
- });
55
-
56
- results.files.push(fileArr);
57
- }
58
- return results
59
- }
60
- }
@@ -1,44 +0,0 @@
1
- import fs from 'fs';
2
- import path from 'path';
3
- import { FileListDependency, ParserDefinitions } from './parsers/types';
4
-
5
-
6
- import { pomParser } from './parsers/mavenParser';
7
- import { packagelockParser, packageParser } from './parsers/npmParser';
8
- import { requirementsParser } from './parsers/pyParser';
9
- import { gemfilelockParser, gemfileParser } from './parsers/rubyParser';
10
-
11
-
12
-
13
- /*
14
- This is a hash map that connect a filename with it's own parser function
15
- Any parser function must return a FileDependency object (See type.ts file in src/parser
16
- */
17
- const Parser: ParserDefinitions = {
18
- 'requirements.txt': requirementsParser,
19
- 'pom.xml': pomParser,
20
- 'package.json': packageParser,
21
- 'package-lock.json': packagelockParser,
22
- 'Gemfile': gemfileParser,
23
- 'Gemfile.lock': gemfilelockParser
24
- };
25
-
26
-
27
- export async function generateDependenciesPurls(files: Array<string>): Promise<FileListDependency> {
28
- let results: FileListDependency = {files: []};
29
- for (const filePath of files) {
30
- const fileName = path.basename(filePath);
31
- if(Parser[fileName] != null) {
32
- try {
33
- const fileContent = await fs.promises.readFile(filePath, 'utf8');
34
- const dependency = Parser[fileName](fileContent, filePath);
35
- if(dependency.purls.length != 0)
36
- results.files.push(dependency);
37
- } catch (error) {
38
- console.error(`Error parsing file: ${filePath}\n`,error);
39
- }
40
- }
41
- }
42
- return results;
43
- }
44
-
@@ -1,4 +0,0 @@
1
-
2
-
3
- // Reference https://go.dev/ref/mod#go-mod-file
4
- //
@@ -1,46 +0,0 @@
1
- import path from "path";
2
- import { PackageURL } from "packageurl-js";
3
- import { FileDependency } from "./types";
4
- import { isValidPath, isValidUrl } from './utils';
5
-
6
- const PURL_TYPE = 'pypi';
7
-
8
- // Parse a requirements.txt file from python projects
9
- // See reference on: https://pip.pypa.io/en/stable/reference/requirements-file-format/
10
- const MANIFEST_FILE = 'requirements.txt';
11
- export function requirementsParser(fileContent: string, filePath: string): FileDependency {
12
-
13
- // If the file is not a python manifest file, return an empty results
14
- const results: FileDependency = {file: filePath, purls: []};
15
- if(path.basename(filePath) != MANIFEST_FILE)
16
- return results;
17
-
18
-
19
- const lines: Array<string> = fileContent.split('\n');
20
- let compName: string = '';
21
- let compVer: string = '';
22
-
23
- for (let line of lines) {
24
- line = line.trim();
25
- if (!line.startsWith('#') && line.length>0) { // Avoid comments and new lines
26
- if(isValidUrl(line)) {
27
- // For reference about the regex see https://www.rfc-editor.org/rfc/rfc3986#appendix-B
28
- const res = line.match(/^(([^:\/?#]+):)?(\/\/([^\/?#]*))?([^?#]*)(\?([^#]*))?(#(.*))?/);
29
- continue;
30
- }
31
- else if(isValidPath(line)) {continue;}
32
- else if(line.startsWith('-r')) {continue;} // recursive dependencies (NOT SUPPORTED YET)
33
- else {
34
- // Line contains a package name and/or version.
35
- const res = line.match(/^([-\w]+)\s*(?:[>=~!]*)\s*([\d\.]*)/); //Extract name and version
36
- if (res) {
37
- compName = res.length > 1 ? res[1] : ' ';
38
- compVer = undefined;
39
- }
40
- }
41
- const purlString = new PackageURL(PURL_TYPE, undefined, compName, compVer, undefined, undefined).toString();
42
- results.purls.push({purl: purlString});
43
- }
44
- }
45
- return results;
46
- }
@@ -1,50 +0,0 @@
1
- export interface Purl {
2
- purl: string;
3
- }
4
-
5
- export interface FileDependency {
6
- file: string;
7
- purls: Array<Purl>;
8
- }
9
-
10
- export interface FileListDependency {
11
- files: Array<FileDependency>;
12
- }
13
-
14
- type ParserFuncType = (fileContent: string, filePath: string) => FileDependency;
15
-
16
- export interface ParserDefinitions {
17
- [key: string]: ParserFuncType;
18
- }
19
-
20
-
21
- /*
22
- EXAMPLE
23
- {
24
- "files": [
25
- {
26
- "file": "./test/data/requirements.txt",
27
- "purls": [
28
- {
29
- "purl": "pkg:pypi/requests"
30
- },
31
- {
32
- "purl": "pkg:pypi/crc32c@2.2"
33
- },
34
- {
35
- "purl": "pkg:pypi/binaryornot"
36
- },
37
- {
38
- "purl": "pkg:pypi/progress"
39
- },
40
- {
41
- "purl": "pkg:pypi/grpcio"
42
- },
43
- {
44
- "purl": "pkg:pypi/protobuf"
45
- }
46
- ]
47
- }
48
- ]
49
- }
50
- */