scanoss 0.2.28 → 0.3.0

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 (128) hide show
  1. package/.github/workflows/reuse.yml +15 -0
  2. package/.github/workflows/scanoss.yml +24 -0
  3. package/.gitignore +0 -1
  4. package/.idea/workspace.xml +296 -6
  5. package/.nyc_output/a25d3ac4-ee71-4c5e-926e-3a17714555cd.json +1 -0
  6. package/.nyc_output/processinfo/a25d3ac4-ee71-4c5e-926e-3a17714555cd.json +1 -0
  7. package/.nyc_output/processinfo/index.json +1 -0
  8. package/.reuse/dep5 +16 -0
  9. package/LICENSES/CC0-1.0.txt +121 -0
  10. package/LICENSES/MIT.txt +9 -0
  11. package/README.md +9 -0
  12. package/build/main/bin/cli-bin.js +4 -3
  13. package/build/main/commands/dep.js +1 -2
  14. package/build/main/commands/fingerprint.js +17 -9
  15. package/build/main/commands/helpers.js +1 -2
  16. package/build/main/commands/scan.js +3 -2
  17. package/build/main/index.js +1 -2
  18. package/build/main/lib/dependencies/DependencyScanner.d.ts +1 -1
  19. package/build/main/lib/dependencies/DependencyScanner.js +23 -12
  20. package/build/main/lib/dependencies/DependencyScannerCfg.js +1 -2
  21. package/build/main/lib/dependencies/DependencyTypes.js +0 -1
  22. package/build/main/lib/dependencies/LocalDependency/DependencyTypes.js +0 -1
  23. package/build/main/lib/dependencies/LocalDependency/LocalDependency.js +3 -2
  24. package/build/main/lib/dependencies/LocalDependency/parsers/golangParser.d.ts +1 -0
  25. package/build/main/lib/dependencies/LocalDependency/parsers/golangParser.js +50 -16
  26. package/build/main/lib/dependencies/LocalDependency/parsers/mavenParser.js +1 -2
  27. package/build/main/lib/dependencies/LocalDependency/parsers/npmParser.d.ts +10 -0
  28. package/build/main/lib/dependencies/LocalDependency/parsers/npmParser.js +146 -10
  29. package/build/main/lib/dependencies/LocalDependency/parsers/pyParser.js +1 -2
  30. package/build/main/lib/dependencies/LocalDependency/parsers/rubyParser.js +1 -2
  31. package/build/main/lib/dependencies/LocalDependency/parsers/utils.js +1 -2
  32. package/build/main/lib/filters/defaultFilter.js +1 -2
  33. package/build/main/lib/filters/filtering.js +1 -2
  34. package/build/main/lib/grpc/GrpcDependencyService.js +1 -2
  35. package/build/main/lib/grpc/scanoss/api/components/v2/scanoss-components_grpc_pb.d.ts +62 -0
  36. package/build/main/lib/grpc/scanoss/api/components/v2/scanoss-components_grpc_pb.js +128 -0
  37. package/build/main/lib/grpc/scanoss/api/components/v2/scanoss-components_pb.d.ts +1 -0
  38. package/build/main/lib/grpc/scanoss/api/components/v2/scanoss-components_pb.js +1403 -0
  39. package/build/main/lib/scanner/Dispatcher/DispatchableItem.js +1 -2
  40. package/build/main/lib/scanner/Dispatcher/Dispatcher.js +1 -2
  41. package/build/main/lib/scanner/Dispatcher/DispatcherResponse.js +1 -2
  42. package/build/main/lib/scanner/Dispatcher/GlobalControllerAborter.js +1 -2
  43. package/build/main/lib/scanner/Scannable/ScannableItem.js +1 -2
  44. package/build/main/lib/scanner/Scanner.js +1 -2
  45. package/build/main/lib/scanner/ScannerCfg.js +2 -3
  46. package/build/main/lib/scanner/ScannerTypes.d.ts +1 -0
  47. package/build/main/lib/scanner/ScannerTypes.js +2 -2
  48. package/build/main/lib/scanner/WfpProvider/FingerprintPackage.js +1 -2
  49. package/build/main/lib/scanner/WfpProvider/WfpCalculator/WfpCalculator.js +175 -18
  50. package/build/main/lib/scanner/WfpProvider/WfpCalculator/Winnower.d.ts +3 -0
  51. package/build/main/lib/scanner/WfpProvider/WfpCalculator/Winnower.js +211 -0
  52. package/build/main/lib/scanner/WfpProvider/WfpProvider.js +1 -2
  53. package/build/main/lib/scanner/WfpProvider/WfpSplitter/WfpSplitter.js +1 -2
  54. package/build/main/lib/tree/File.js +1 -2
  55. package/build/main/lib/tree/Folder.js +1 -2
  56. package/build/main/lib/tree/Node.js +1 -2
  57. package/build/main/lib/tree/Tree.js +1 -2
  58. package/build/module/bin/cli-bin.js +4 -2
  59. package/build/module/commands/fingerprint.js +22 -13
  60. package/build/module/commands/scan.js +4 -2
  61. package/build/module/lib/dependencies/DependencyScanner.d.ts +1 -1
  62. package/build/module/lib/dependencies/DependencyScanner.js +23 -11
  63. package/build/module/lib/dependencies/LocalDependency/LocalDependency.js +5 -3
  64. package/build/module/lib/dependencies/LocalDependency/parsers/golangParser.d.ts +1 -0
  65. package/build/module/lib/dependencies/LocalDependency/parsers/golangParser.js +47 -14
  66. package/build/module/lib/dependencies/LocalDependency/parsers/npmParser.d.ts +10 -0
  67. package/build/module/lib/dependencies/LocalDependency/parsers/npmParser.js +140 -8
  68. package/build/module/lib/grpc/scanoss/api/components/v2/scanoss-components_grpc_pb.d.ts +62 -0
  69. package/build/module/lib/grpc/scanoss/api/components/v2/scanoss-components_grpc_pb.js +128 -0
  70. package/build/module/lib/grpc/scanoss/api/components/v2/scanoss-components_pb.d.ts +1 -0
  71. package/build/module/lib/grpc/scanoss/api/components/v2/scanoss-components_pb.js +1403 -0
  72. package/build/module/lib/scanner/ScannerCfg.js +2 -2
  73. package/build/module/lib/scanner/ScannerTypes.d.ts +1 -0
  74. package/build/module/lib/scanner/ScannerTypes.js +2 -1
  75. package/build/module/lib/scanner/WfpProvider/WfpCalculator/WfpCalculator.js +175 -17
  76. package/build/module/lib/scanner/WfpProvider/WfpCalculator/Winnower.d.ts +3 -0
  77. package/build/module/lib/scanner/WfpProvider/WfpCalculator/Winnower.js +211 -0
  78. package/build/tsconfig.module.tsbuildinfo +1 -1
  79. package/build/tsconfig.tsbuildinfo +1 -1
  80. package/package.json +6 -17
  81. package/src/bin/cli-bin.ts +3 -1
  82. package/src/commands/fingerprint.ts +23 -14
  83. package/src/commands/scan.ts +10 -2
  84. package/src/lib/dependencies/DependencyScanner.ts +20 -12
  85. package/src/lib/dependencies/LocalDependency/LocalDependency.ts +8 -2
  86. package/src/lib/dependencies/LocalDependency/parsers/golangParser.ts +67 -15
  87. package/src/lib/dependencies/LocalDependency/parsers/npmParser.ts +182 -7
  88. package/src/lib/scanner/ScannerCfg.ts +2 -1
  89. package/src/lib/scanner/ScannerTypes.ts +1 -0
  90. package/src/lib/scanner/WfpProvider/FingerprintPackage.ts +1 -1
  91. package/src/lib/scanner/WfpProvider/WfpCalculator/WfpCalculator.ts +174 -17
  92. package/tests/WfpCalculator.spec.ts +103 -0
  93. package/{test/dependencies/data → tests/data/dependencies}/Gemfile/1/Gemfile +0 -0
  94. package/{test/dependencies/data → tests/data/dependencies}/Gemfile/1/Gemfile~ +0 -0
  95. package/{test/dependencies/data → tests/data/dependencies}/Gemfile/2/Gemfile +0 -0
  96. package/{test/dependencies/data → tests/data/dependencies}/Gemfile/2/Gemfile~ +0 -0
  97. package/{test/dependencies/data → tests/data/dependencies}/Gemfile/3/Gemfile +0 -0
  98. package/{test/dependencies/data → tests/data/dependencies}/Gemfile/3/Gemfile~ +0 -0
  99. package/{test/dependencies/data → tests/data/dependencies}/Gemfile/4/Gemfile +0 -0
  100. package/{test/dependencies/data → tests/data/dependencies}/Gemfile/4/Gemfile~ +0 -0
  101. package/{test/dependencies/data → tests/data/dependencies}/Gemfile.lock/1/Gemfile.lock +0 -0
  102. package/{test/dependencies/data → tests/data/dependencies}/Gemfile.lock/2/Gemfile.lock +0 -0
  103. package/{test/dependencies/data → tests/data/dependencies}/Gemfile.lock/2/Gemfile.lock~ +0 -0
  104. package/tests/data/dependencies/go.sum/1/go.sum +119 -0
  105. package/tests/data/dependencies/go.sum/depJSON.sh +23 -0
  106. package/tests/data/dependencies/package-lock/1/package-lock.json +715 -0
  107. package/tests/data/dependencies/package-lock/2/package-lock.json +32069 -0
  108. package/tests/data/dependencies/package-lock/3/package-lock.json +9013 -0
  109. package/{test/dependencies/data → tests/data/dependencies}/pom.xml/1/pom.xml +0 -0
  110. package/tests/data/dependencies/yarn-lock/generate_expected_output.sh +4 -0
  111. package/tests/data/dependencies/yarn-lock/v1/yarn.lock +50 -0
  112. package/tests/data/dependencies/yarn-lock/v1/yarn.lock-expected +13 -0
  113. package/tests/data/dependencies/yarn-lock/v1-complex/yarn.lock +27 -0
  114. package/tests/data/dependencies/yarn-lock/v1-complex/yarn.lock-expected +8 -0
  115. package/tests/data/dependencies/yarn-lock/v1-complex2/yarn.lock +220 -0
  116. package/tests/data/dependencies/yarn-lock/v2/yarn.lock +31 -0
  117. package/tests/data/dependencies/yarn-lock/v2/yarn.lock-expected +57 -0
  118. package/tests/data/dependencies/yarn-lock/v2-local/yarn.lock +11 -0
  119. package/tests/data/dependencies/yarn-lock/v2-local/yarn.lock-expected +27204 -0
  120. package/tests/data/scanner/file1.c +41 -0
  121. package/tests/data/scanner/file2.go +87 -0
  122. package/tests/dependencies/golangParser.goModParser.specs.ts +146 -0
  123. package/tests/dependencies/npmParser.spec.ts +133 -0
  124. package/tsconfig.json +4 -3
  125. package/yarn.lock +4596 -5321
  126. package/examples/defaultFilter.json +0 -203
  127. package/package-lock.json +0 -18588
  128. package/src/lib/scanner/Winnower/WinnowerExtractor.ts +0 -37
@@ -12,10 +12,10 @@ export class ScannerCfg {
12
12
  WFP_FILE_MAX_SIZE = 64 * 1000;
13
13
  MAX_RETRIES_FOR_RECOVERABLES_ERRORS = 5;
14
14
  ABORT_ON_MAX_RETRIES = true;
15
- // Persist results after [ X ] number of server responses.
15
+ // Persist results after [ X ] server responses
16
16
  MAX_RESPONSES_IN_BUFFER = 300;
17
17
  DISPATCHER_QUEUE_SIZE_MAX_LIMIT = 300;
18
18
  DISPATCHER_QUEUE_SIZE_MIN_LIMIT = 200;
19
19
  }
20
20
  ;
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2Nhbm5lckNmZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvc2Nhbm5lci9TY2FubmVyQ2ZnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sT0FBTyxVQUFVO0lBQ3JCLG1CQUFtQjtJQUNuQixnQkFBZ0IsR0FBRyxZQUFZLENBQUE7SUFFL0IsVUFBVTtJQUNWLE9BQU8sR0FBRyxtQ0FBbUMsQ0FBQztJQUU5QyxPQUFPLEdBQUcsRUFBRSxDQUFDO0lBRWIsdUJBQXVCO0lBQ3ZCLGlCQUFpQixHQUFHLEVBQUUsQ0FBQztJQUV2QiwrQkFBK0I7SUFDL0IsT0FBTyxHQUFHLEtBQUssQ0FBQztJQUVoQixzQ0FBc0M7SUFDdEMsaUJBQWlCLEdBQUcsRUFBRSxHQUFHLElBQUksQ0FBQztJQUU5QixtQ0FBbUMsR0FBRyxDQUFDLENBQUM7SUFFeEMsb0JBQW9CLEdBQUcsSUFBSSxDQUFDO0lBRTVCLDBEQUEwRDtJQUMxRCx1QkFBdUIsR0FBRyxHQUFHLENBQUM7SUFFOUIsK0JBQStCLEdBQUcsR0FBRyxDQUFDO0lBRXRDLCtCQUErQixHQUFHLEdBQUcsQ0FBQztDQUN2QztBQUFBLENBQUMifQ==
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2Nhbm5lckNmZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvc2Nhbm5lci9TY2FubmVyQ2ZnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sT0FBTyxVQUFVO0lBQ3JCLG1CQUFtQjtJQUNuQixnQkFBZ0IsR0FBRyxZQUFZLENBQUE7SUFFL0IsVUFBVTtJQUNWLE9BQU8sR0FBRyxtQ0FBbUMsQ0FBQztJQUU5QyxPQUFPLEdBQUcsRUFBRSxDQUFDO0lBRWIsdUJBQXVCO0lBQ3ZCLGlCQUFpQixHQUFHLEVBQUUsQ0FBQztJQUV2QiwrQkFBK0I7SUFDL0IsT0FBTyxHQUFHLEtBQUssQ0FBQztJQUVoQixzQ0FBc0M7SUFDdEMsaUJBQWlCLEdBQUcsRUFBRSxHQUFHLElBQUksQ0FBQztJQUU5QixtQ0FBbUMsR0FBRyxDQUFDLENBQUM7SUFFeEMsb0JBQW9CLEdBQUcsSUFBSSxDQUFDO0lBRTVCLCtDQUErQztJQUMvQyx1QkFBdUIsR0FBRyxHQUFHLENBQUM7SUFFOUIsK0JBQStCLEdBQUcsR0FBRyxDQUFDO0lBRXRDLCtCQUErQixHQUFHLEdBQUcsQ0FBQztDQUV2QztBQUFBLENBQUMifQ==
@@ -22,6 +22,7 @@ export declare enum ScannerEvents {
22
22
  }
23
23
  export declare enum WinnowingMode {
24
24
  FULL_WINNOWING = "FULL_WINNOWING",
25
+ FULL_WINNOWING_HPSM = "FULL_WINNOWING_HPSM",
25
26
  WINNOWING_ONLY_MD5 = "WINNOWING_ONLY_MD5"
26
27
  }
27
28
  export declare enum SbomMode {
@@ -25,6 +25,7 @@ export var ScannerEvents;
25
25
  export var WinnowingMode;
26
26
  (function (WinnowingMode) {
27
27
  WinnowingMode["FULL_WINNOWING"] = "FULL_WINNOWING";
28
+ WinnowingMode["FULL_WINNOWING_HPSM"] = "FULL_WINNOWING_HPSM";
28
29
  WinnowingMode["WINNOWING_ONLY_MD5"] = "WINNOWING_ONLY_MD5";
29
30
  })(WinnowingMode || (WinnowingMode = {}));
30
31
  ;
@@ -34,4 +35,4 @@ export var SbomMode;
34
35
  SbomMode["SBOM_IDENTIFY"] = "identify";
35
36
  })(SbomMode || (SbomMode = {}));
36
37
  ;
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2Nhbm5lclR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9zY2FubmVyL1NjYW5uZXJUeXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxhQTRCWDtBQTVCRCxXQUFZLGFBQWE7SUFDdkIsMERBQXlDLENBQUE7SUFDekMsZ0VBQStDLENBQUE7SUFDL0MsMERBQXlDLENBQUE7SUFDekMsOENBQTZCLENBQUE7SUFFN0IsZ0VBQStDLENBQUE7SUFDL0MsNERBQTJDLENBQUE7SUFDM0MsNERBQTJDLENBQUE7SUFDM0MsZ0ZBQStELENBQUE7SUFDL0QsMEVBQXlELENBQUE7SUFDekQsb0ZBQW1FLENBQUE7SUFDbkUsa0RBQWlDLENBQUE7SUFFakMsZ0VBQStDLENBQUE7SUFFL0Msd0RBQXVDLENBQUE7SUFDdkMsd0RBQXVDLENBQUE7SUFFdkMsd0RBQXVDLENBQUE7SUFDdkMsb0RBQW1DLENBQUE7SUFFbkMsd0NBQXVCLENBQUE7SUFDdkIsc0RBQXFDLENBQUE7SUFFckMsNENBQTJCLENBQUE7SUFFM0IsZ0NBQWUsQ0FBQTtBQUNqQixDQUFDLEVBNUJXLGFBQWEsS0FBYixhQUFhLFFBNEJ4QjtBQUFBLENBQUM7QUFFRixNQUFNLENBQU4sSUFBWSxhQUdYO0FBSEQsV0FBWSxhQUFhO0lBQ3ZCLGtEQUFpQyxDQUFBO0lBQ2pDLDBEQUF5QyxDQUFBO0FBQzNDLENBQUMsRUFIVyxhQUFhLEtBQWIsYUFBYSxRQUd4QjtBQUFBLENBQUM7QUFFRixNQUFNLENBQU4sSUFBWSxRQUdYO0FBSEQsV0FBWSxRQUFRO0lBQ2xCLHFDQUF5QixDQUFBO0lBQ3pCLHNDQUEwQixDQUFBO0FBQzVCLENBQUMsRUFIVyxRQUFRLEtBQVIsUUFBUSxRQUduQjtBQVVBLENBQUMifQ==
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2Nhbm5lclR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9zY2FubmVyL1NjYW5uZXJUeXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxhQTRCWDtBQTVCRCxXQUFZLGFBQWE7SUFDdkIsMERBQXlDLENBQUE7SUFDekMsZ0VBQStDLENBQUE7SUFDL0MsMERBQXlDLENBQUE7SUFDekMsOENBQTZCLENBQUE7SUFFN0IsZ0VBQStDLENBQUE7SUFDL0MsNERBQTJDLENBQUE7SUFDM0MsNERBQTJDLENBQUE7SUFDM0MsZ0ZBQStELENBQUE7SUFDL0QsMEVBQXlELENBQUE7SUFDekQsb0ZBQW1FLENBQUE7SUFDbkUsa0RBQWlDLENBQUE7SUFFakMsZ0VBQStDLENBQUE7SUFFL0Msd0RBQXVDLENBQUE7SUFDdkMsd0RBQXVDLENBQUE7SUFFdkMsd0RBQXVDLENBQUE7SUFDdkMsb0RBQW1DLENBQUE7SUFFbkMsd0NBQXVCLENBQUE7SUFDdkIsc0RBQXFDLENBQUE7SUFFckMsNENBQTJCLENBQUE7SUFFM0IsZ0NBQWUsQ0FBQTtBQUNqQixDQUFDLEVBNUJXLGFBQWEsS0FBYixhQUFhLFFBNEJ4QjtBQUFBLENBQUM7QUFFRixNQUFNLENBQU4sSUFBWSxhQUlYO0FBSkQsV0FBWSxhQUFhO0lBQ3ZCLGtEQUFpQyxDQUFBO0lBQ2pDLDREQUEyQyxDQUFBO0lBQzNDLDBEQUF5QyxDQUFBO0FBQzNDLENBQUMsRUFKVyxhQUFhLEtBQWIsYUFBYSxRQUl4QjtBQUFBLENBQUM7QUFFRixNQUFNLENBQU4sSUFBWSxRQUdYO0FBSEQsV0FBWSxRQUFRO0lBQ2xCLHFDQUF5QixDQUFBO0lBQ3pCLHNDQUEwQixDQUFBO0FBQzVCLENBQUMsRUFIVyxRQUFRLEtBQVIsUUFBUSxRQUduQjtBQVVBLENBQUMifQ==
@@ -16,7 +16,13 @@ parentPort.on('message', async (scannableItem) => {
16
16
  scannableItem.contentSource,
17
17
  scannableItem.maxSizeWfp
18
18
  );
19
- } else {
19
+ } else if (scannableItem.winnowingMode === "FULL_WINNOWING_HPSM") {
20
+ fingerprint = wfp_hpsm_for_content(
21
+ scannableItem.content,
22
+ scannableItem.contentSource,
23
+ scannableItem.maxSizeWfp
24
+ );
25
+ } else if (scannableItem.winnowingMode === "WINNOWING_ONLY_MD5") {
20
26
  fingerprint = wfp_only_md5(
21
27
  scannableItem.content,
22
28
  scannableItem.contentSource
@@ -24,13 +30,15 @@ parentPort.on('message', async (scannableItem) => {
24
30
  }
25
31
 
26
32
  scannableItem.fingerprint = fingerprint;
27
-
28
33
  parentPort.postMessage(scannableItem);
29
- });
30
34
 
35
+ });
31
36
 
32
- const crypto = require('crypto');
37
+ /**
38
+ * Winnowing and HPSM algorithm begins
39
+ */
33
40
 
41
+ const crypto = require('crypto');
34
42
  const isWin = process.platform === 'win32';
35
43
  const pathSeparator = isWin ? String.fromCharCode(92) : '/';
36
44
 
@@ -70,18 +78,6 @@ function min_hex_array(array) {
70
78
  return min;
71
79
  }
72
80
 
73
- function wfp_for_content(content, contentSource, maxSize) {
74
- let wfp = wfp_only_md5(content, contentSource);
75
- wfp += calc_wfp(content, maxSize);
76
- return wfp;
77
- }
78
-
79
- function wfp_only_md5(contents, contentSource) {
80
- const file_md5 = crypto.createHash('md5').update(contents).digest('hex');
81
- let wfp = 'file=' + String(file_md5) + ',' + String(contents.length) + ',' + String(contentSource)+ String.fromCharCode(10);
82
- return wfp;
83
- }
84
-
85
81
  function calc_wfp(contents, maxSize) {
86
82
  let gram = '';
87
83
  const window = [];
@@ -224,6 +220,168 @@ function crc32c_hex(str) {
224
220
  return crc32c(str).toString(16).padStart(8, '0');
225
221
  }
226
222
 
223
+ function truncate_string(input, maxSize){
224
+ return input.slice(0, maxSize)
225
+ }
226
+
227
+ function toHexString(byteArray) {
228
+ return Array.from(byteArray, function(byte) {
229
+ return ('0' + (byte & 0xFF).toString(16)).slice(-2);
230
+ }).join('')
231
+ }
232
+
233
+ function calc_hpsm(content) {
234
+ let list_normalized = []; //Array of numbers
235
+ let crc_lines = []; //Array of numbers that represent the crc8_maxim for each line of the file
236
+
237
+ let last_line = 0;
238
+ crc8_MAXIM_DOW_GenerateTable();
239
+
240
+ for(let i = 0; i<content.length; i++) {
241
+ const c = content[i];
242
+ if (c == ASCII_LF) { //When there is a new line
243
+ if (list_normalized.length) {
244
+ crc_lines.push(crc8_MAXIM_DOW_Buffer(list_normalized))
245
+ list_normalized=[];
246
+ } else if(last_line+1 == i) {
247
+ crc_lines.push(0xFF);
248
+ } else if (i-last_line > 1) {
249
+ crc_lines.push(0x00)
250
+ }
251
+ last_line = i;
252
+ } else {
253
+ const c_normalized = normalize(c);
254
+ if (c_normalized != 0) list_normalized.push(c_normalized)
255
+ }
256
+ }
257
+ return "hpsm=" + toHexString(crc_lines)
258
+ }
259
+
260
+
261
+ /**
262
+ * Create a wfp_hpsm package joining wfp (with md5 line) and a hpsm.
263
+ *
264
+ * Example:
265
+ * wfp = file=508cb9dfbe1c7dca5ed24f124473f33d,300,asd.c
266
+ * 11=b19bdbfa
267
+ *
268
+ * hpsm = hpsm=1909ff06ff688630ff45a92b52f47eff3500ffff
269
+ *
270
+ * wfp_hpsm = file=508cb9dfbe1c7dca5ed24f124473f33d,300,asd.c
271
+ * hpsm=1909ff06ff688630ff45a92b52f47eff3500ffff
272
+ * 11=b19bdbfa
273
+ *
274
+ * @param {string} wfp Complete wfp string (with md5 line)
275
+ * @param {string} hpsm
276
+ * @returns {string}
277
+ */
278
+ function join_wfp_hpsm(wfp, hpsm) {
279
+ let header = wfp.match(/file=.*/);
280
+ header += String.fromCharCode(10);
281
+ header += hpsm;
282
+ wfp = wfp.replace(/file=.*/, "")
283
+ return header + wfp;
284
+ }
285
+
286
+ /**
287
+ *
288
+ * @param {Buffer} content
289
+ * @param {string} contentSource
290
+ * @param {number} maxSize
291
+ * @returns {string}
292
+ */
293
+ function wfp_hpsm_for_content(content, contentSource, maxSize) {
294
+ let wfp = wfp_for_content(content, contentSource, maxSize)
295
+ let hpsm = calc_hpsm(content) //Returns a string
296
+ let wfp_hpsm_joined = join_wfp_hpsm(wfp, hpsm)
297
+ return truncate_string(wfp_hpsm_joined, maxSize)
298
+ }
299
+
300
+ function wfp_for_content(content, contentSource, maxSize) {
301
+ let wfp = wfp_only_md5(content, contentSource);
302
+ wfp += calc_wfp(content, maxSize);
303
+ return wfp;
304
+ }
305
+
306
+ function wfp_only_md5(contents, contentSource) {
307
+ const file_md5 = crypto.createHash('md5').update(contents).digest('hex');
308
+ let wfp = 'file=' + String(file_md5) + ',' + String(contents.length) + ',' + String(contentSource)+ String.fromCharCode(10);
309
+ return wfp;
310
+ }
311
+
312
+ /**
313
+ * CRC8_MAXIM algorithm begins
314
+ */
315
+
316
+
317
+ //=============================================================================
318
+ // Implementation of CRC-8/MAXIM-DOW,CRC-8/MAXIM,DOW-CRC.
319
+ // Notes: Code ported from C Auto-generated by http://crc.drque.net/
320
+ //=============================================================================
321
+
322
+ //Table size
323
+ const CRC8_MAXIM_DOW_TABLE_SIZE = 0x100
324
+ const CRC8_MAXIM_DOW_POLYNOMIAL = 0x8C // 0x31 reflected
325
+ const CRC8_MAXIM_DOW_INITIAL = 0x00 // 0x00 reflected
326
+ const CRC8_MAXIM_DOW_FINAL = 0x00 // 0x00 reflected
327
+
328
+ let crc8_MAXIM_DOW_Table = []
329
+
330
+ /**
331
+ * Compute CRC of byte without lookup tables.
332
+ *
333
+ * @param {number} crc Current CRC or initial value
334
+ * @param {number} byte New byte to accumulate.
335
+ * @returns {number} Updated CRC.
336
+ */
337
+ function crc8_MAXIM_DOW_ByteNoTable(crc, byte) {
338
+ crc ^= byte;
339
+ for (let count = 0; count<8; count++) {
340
+ const isSet = (crc & 0x01)
341
+ crc >>= 1;
342
+ if (isSet) crc ^= CRC8_MAXIM_DOW_POLYNOMIAL
343
+ }
344
+ return crc
345
+ }
346
+
347
+ /**
348
+ * Create the lookup table.
349
+ * Note: Must be called before any table based CRC calculations can be done.
350
+ */
351
+ function crc8_MAXIM_DOW_GenerateTable() {
352
+ for(let i = 0; i<CRC8_MAXIM_DOW_TABLE_SIZE; i++) {
353
+ crc8_MAXIM_DOW_Table.push(crc8_MAXIM_DOW_ByteNoTable(0, i))
354
+ }
355
+ }
356
+
357
+ /**
358
+ * Update CRC by byte.
359
+ *
360
+ * @param {number} crc Initial CRC.
361
+ * @param {number} byte New byte to accumulate.
362
+ * @returns {number} Updated CRC.
363
+ */
364
+ function crc8_MAXIM_DOW_Byte( crc, byte )
365
+ {
366
+ const index = byte ^ crc;
367
+ return crc8_MAXIM_DOW_Table[ index ] ^ ( crc >> 8 );
368
+ }
369
+
370
+ /**
371
+ * Compute CRC of buffer.
372
+ * Note: crc8_MAXIM_DOW_GenerateTable() must be called before use this function
373
+ *
374
+ * @param {Buffer} buffer Buffer with bytes to calculate CRC.
375
+ * @returns {number} CRC
376
+ */
377
+ function crc8_MAXIM_DOW_Buffer(buffer) {
378
+ let crc = CRC8_MAXIM_DOW_INITIAL;
379
+ for (let index = 0; index < buffer.length ; index ++) {
380
+ crc = crc8_MAXIM_DOW_Byte(crc, buffer[index])
381
+ }
382
+ crc ^= CRC8_MAXIM_DOW_FINAL;
383
+ return crc;
384
+ }
227
385
  `;
228
386
  export class WfpCalculator extends WfpProvider {
229
387
  fileList;
@@ -327,4 +485,4 @@ export class WfpCalculator extends WfpProvider {
327
485
  this.init();
328
486
  }
329
487
  }
330
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiV2ZwQ2FsY3VsYXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvc2Nhbm5lci9XZnBQcm92aWRlci9XZnBDYWxjdWxhdG9yL1dmcENhbGN1bGF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sSUFBSSxDQUFDO0FBQ3BCLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUV4QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDOUQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRzlDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzNELE9BQU8sRUFBcUIsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFHaEUsTUFBTSxZQUFZLEdBQUc7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Q0E0TnBCLENBQUM7QUFFRixNQUFNLE9BQU8sYUFBYyxTQUFRLFdBQVc7SUFDcEMsUUFBUSxDQUFNO0lBRWQsYUFBYSxDQUFTO0lBRXRCLFFBQVEsQ0FBVTtJQUUxQixZQUFZLFVBQVUsR0FBRyxJQUFJLFVBQVUsRUFBRTtRQUN2QyxLQUFLLEVBQUUsQ0FBQztRQUNSLElBQUksQ0FBQyxVQUFVLEdBQUcsVUFBVSxDQUFDO0lBQy9CLENBQUM7SUFFRCxJQUFJO1FBQ0YsS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ2IsSUFBSSxD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
488
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiV2ZwQ2FsY3VsYXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvc2Nhbm5lci9XZnBQcm92aWRlci9XZnBDYWxjdWxhdG9yL1dmcENhbGN1bGF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sSUFBSSxDQUFDO0FBQ3BCLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUV4QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDOUQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRzlDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzNELE9BQU8sRUFBcUIsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFaEUsTUFBTSxZQUFZLEdBQUc7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztDQTBYcEIsQ0FBQztBQUVGLE1BQU0sT0FBTyxhQUFjLFNBQVEsV0FBVztJQUNwQyxRQUFRLENBQU07SUFFZCxhQUFhLENBQVM7SUFFdEIsUUFBUSxD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
@@ -0,0 +1,3 @@
1
+ export function wfp_hpsm_for_content(content: any, contentSource: any, maxSize: any): string;
2
+ export function wfp_for_content(content: any, contentSource: any, maxSize: any): string;
3
+ export function wfp_only_md5(contents: any, contentSource: any): string;
@@ -0,0 +1,211 @@
1
+ const crypto = require('crypto');
2
+ const isWin = process.platform === 'win32';
3
+ const pathSeparator = isWin ? String.fromCharCode(92) : '/';
4
+ // Winnowing configuration. DO NOT CHANGE.
5
+ const GRAM = 30;
6
+ const WINDOW = 64;
7
+ // ASCII characters
8
+ const ASCII_0 = 48;
9
+ const ASCII_9 = 57;
10
+ const ASCII_A = 65;
11
+ const ASCII_Z = 90;
12
+ const ASCII_a = 97;
13
+ const ASCII_z = 122;
14
+ const ASCII_LF = 10;
15
+ function normalize(byte) {
16
+ if (byte < ASCII_0 || byte > ASCII_z) {
17
+ return 0;
18
+ }
19
+ if (byte <= ASCII_9 || byte >= ASCII_a) {
20
+ return byte;
21
+ }
22
+ if (byte >= ASCII_A && byte <= ASCII_Z) {
23
+ return byte + 32;
24
+ }
25
+ return 0;
26
+ }
27
+ function min_hex_array(array) {
28
+ let min = 'ffffffff';
29
+ for (let i = 0; i < array.length; i++) {
30
+ if (array[i] < min) {
31
+ min = array[i];
32
+ }
33
+ }
34
+ return min;
35
+ }
36
+ function calc_wfp(contents, maxSize) {
37
+ let gram = '';
38
+ const window = [];
39
+ let normalized = 0;
40
+ let line = 1;
41
+ let min_hash = 'ffffffff';
42
+ let last_hash = 'ffffffff';
43
+ let last_line = 0;
44
+ let output = '';
45
+ let gram_crc32 = 0;
46
+ let wfp = '';
47
+ for (let i = 0; i < contents.length; i++) {
48
+ if (wfp.length > maxSize)
49
+ return wfp;
50
+ const byte = contents[i];
51
+ if (byte == ASCII_LF) {
52
+ line += 1;
53
+ normalized = 0;
54
+ }
55
+ else {
56
+ normalized = normalize(byte);
57
+ }
58
+ // Is this an useful byte?
59
+ if (normalized) {
60
+ gram += String.fromCharCode(normalized);
61
+ if (gram.length >= GRAM) {
62
+ gram_crc32 = crc32c_hex(gram);
63
+ window.push(gram_crc32);
64
+ if (window.length >= WINDOW) {
65
+ min_hash = min_hex_array(window);
66
+ if (min_hash !== last_hash) {
67
+ // Hashing the hash will result in a better balanced output data set
68
+ // as it will counter the winnowing effect which selects the "minimum"
69
+ // hash in each window
70
+ const min_hash_bytes_le = parseHexString(toLittleEndianCRCHex(min_hash));
71
+ const crc_hex = crc32c_for_bytes_hex(min_hash_bytes_le);
72
+ if (last_line != line) {
73
+ if (output.length > 0) {
74
+ wfp += String(output) + String.fromCharCode(10);
75
+ }
76
+ output = String(line) + '=' + String(crc_hex);
77
+ }
78
+ else {
79
+ output += ',' + String(crc_hex);
80
+ }
81
+ last_line = line;
82
+ last_hash = min_hash;
83
+ }
84
+ window.shift();
85
+ }
86
+ gram = gram.slice(1);
87
+ }
88
+ }
89
+ }
90
+ if (output.length > 0) {
91
+ wfp += String(output) + String.fromCharCode(10);
92
+ }
93
+ return wfp;
94
+ }
95
+ function parseHexString(str) {
96
+ const result = [];
97
+ while (str.length >= 2) {
98
+ result.push(parseInt(str.substring(0, 2), 16));
99
+ str = str.substring(2, str.length);
100
+ }
101
+ return result;
102
+ }
103
+ /**
104
+ *
105
+ * @param {string} hex
106
+ */
107
+ function toLittleEndianCRCHex(hex) {
108
+ return (hex.charAt(6) +
109
+ hex.charAt(7) +
110
+ hex.charAt(4) +
111
+ hex.charAt(5) +
112
+ hex.charAt(2) +
113
+ hex.charAt(3) +
114
+ hex.charAt(0) +
115
+ hex.charAt(1));
116
+ }
117
+ let CRC_TABLE = [];
118
+ function makeCRCTable() {
119
+ let c;
120
+ const crcTable = [];
121
+ for (let n = 0; n < 256; n++) {
122
+ c = n;
123
+ for (let k = 0; k < 8; k++) {
124
+ c = c & 1 ? 0x82f63b78 ^ (c >>> 1) : c >>> 1;
125
+ }
126
+ crcTable[n] = c;
127
+ }
128
+ return crcTable;
129
+ }
130
+ function crc32c(str) {
131
+ if (CRC_TABLE.length == 0) {
132
+ CRC_TABLE = makeCRCTable();
133
+ }
134
+ let crc = 0 ^ -1;
135
+ for (let i = 0; i < str.length; i++) {
136
+ crc = (crc >>> 8) ^ CRC_TABLE[(crc ^ str.charCodeAt(i)) & 0xff];
137
+ }
138
+ return (crc ^ -1) >>> 0;
139
+ }
140
+ function crc32c_for_bytes(bytes) {
141
+ if (CRC_TABLE.length == 0) {
142
+ CRC_TABLE = makeCRCTable();
143
+ }
144
+ let crc = 0 ^ -1;
145
+ for (let i = 0; i < bytes.length; i++) {
146
+ crc = (crc >>> 8) ^ CRC_TABLE[(crc ^ bytes[i]) & 0xff];
147
+ }
148
+ return (crc ^ -1) >>> 0;
149
+ }
150
+ function crc32c_for_bytes_hex(bytes) {
151
+ return crc32c_for_bytes(bytes).toString(16).padStart(8, '0');
152
+ }
153
+ function crc32c_hex(str) {
154
+ return crc32c(str).toString(16).padStart(8, '0');
155
+ }
156
+ function truncate_string(input, maxSize) {
157
+ return "";
158
+ }
159
+ function calc_hpsm(content) {
160
+ for (let i = 0; i < content.length; i++) {
161
+ let a = 0;
162
+ }
163
+ return "";
164
+ }
165
+ /*
166
+ Receives a wfp with the md5 line, a hpsm and joins both.
167
+
168
+ Example:
169
+ wfp = `file=508cb9dfbe1c7dca5ed24f124473f33d,300,asd.c
170
+ 11=b19bdbfa
171
+ 13=8fd738fa,b6f47c1e
172
+ `
173
+ hpsm = `hpsm=1909ff06ff688630ff45a92b52f47eff3500ffff`
174
+
175
+ wfp_hpsm = `file=508cb9dfbe1c7dca5ed24f124473f33d,300,asd.c
176
+ hpsm=1909ff06ff688630ff45a92b52f47eff3500ffff
177
+ 11=b19bdbfa
178
+ 13=8fd738fa,b6f47c1e`
179
+ */
180
+ function join_wfp_hpsm(wfp, hpsm) {
181
+ return "";
182
+ }
183
+ function wfp_hpsm_for_content(content, contentSource, maxSize) {
184
+ let wfp = wfp_for_content(content, contentSource, maxSize);
185
+ let hpsm = calc_hpsm(content);
186
+ if (hpsm.length >= maxSize) {
187
+ //If the hpsm is longer than maxSize?
188
+ }
189
+ let wfp_hpsm_joined = join_wfp_hpsm(wfp, hpsm);
190
+ // if the joined package is longer than maxSize truncate wfps lines
191
+ if (wfp_hpsm_joined.length > maxSize) {
192
+ }
193
+ let output = "";
194
+ return truncate_string(output, maxSize);
195
+ }
196
+ function wfp_for_content(content, contentSource, maxSize) {
197
+ let wfp = wfp_only_md5(content, contentSource);
198
+ wfp += calc_wfp(content, maxSize);
199
+ return wfp;
200
+ }
201
+ function wfp_only_md5(contents, contentSource) {
202
+ const file_md5 = crypto.createHash('md5').update(contents).digest('hex');
203
+ let wfp = 'file=' + String(file_md5) + ',' + String(contents.length) + ',' + String(contentSource) + String.fromCharCode(10);
204
+ return wfp;
205
+ }
206
+ module.exports = {
207
+ wfp_hpsm_for_content,
208
+ wfp_for_content,
209
+ wfp_only_md5,
210
+ };
211
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Winnower.js","sourceRoot":"","sources":["../../../../../../src/lib/scanner/WfpProvider/WfpCalculator/Winnower.js"],"names":[],"mappings":"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"}