@fyuld/snitch 1.6.1 → 2.1.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 (208) hide show
  1. package/.snitchconfig.json +25 -135
  2. package/dist/SnitchConfigManager.d.ts +9 -0
  3. package/dist/SnitchConfigManager.d.ts.map +1 -0
  4. package/dist/SnitchConfigManager.js +112 -0
  5. package/dist/SnitchConfigManager.js.map +1 -0
  6. package/dist/commands/firstRun.d.ts +2 -0
  7. package/dist/commands/firstRun.d.ts.map +1 -0
  8. package/dist/commands/firstRun.js +10 -0
  9. package/dist/commands/firstRun.js.map +1 -0
  10. package/dist/commands/init/defaultConfigInit.d.ts +2 -0
  11. package/dist/commands/init/defaultConfigInit.d.ts.map +1 -0
  12. package/dist/commands/init/defaultConfigInit.js +53 -0
  13. package/dist/commands/init/defaultConfigInit.js.map +1 -0
  14. package/dist/commands/init/downloadedConfigInit.d.ts +3 -0
  15. package/dist/commands/init/downloadedConfigInit.d.ts.map +1 -0
  16. package/dist/commands/init/downloadedConfigInit.js +80 -0
  17. package/dist/commands/init/downloadedConfigInit.js.map +1 -0
  18. package/dist/commands/init.d.ts +1 -1
  19. package/dist/commands/init.d.ts.map +1 -1
  20. package/dist/commands/init.js +11 -12
  21. package/dist/commands/init.js.map +1 -1
  22. package/dist/commands/prepare.d.ts +2 -0
  23. package/dist/commands/prepare.d.ts.map +1 -0
  24. package/dist/commands/prepare.js +61 -0
  25. package/dist/commands/prepare.js.map +1 -0
  26. package/dist/common/fs.d.ts +1 -0
  27. package/dist/common/fs.d.ts.map +1 -0
  28. package/dist/common/fs.js +2 -0
  29. package/dist/common/fs.js.map +1 -0
  30. package/dist/common/index.d.ts +2 -0
  31. package/dist/common/index.d.ts.map +1 -0
  32. package/dist/common/index.js +18 -0
  33. package/dist/common/index.js.map +1 -0
  34. package/dist/common/json.d.ts +21 -0
  35. package/dist/common/json.d.ts.map +1 -0
  36. package/dist/common/json.js +41 -0
  37. package/dist/common/json.js.map +1 -0
  38. package/dist/common/strings.d.ts +8 -0
  39. package/dist/common/strings.d.ts.map +1 -0
  40. package/dist/common/strings.js +15 -0
  41. package/dist/common/strings.js.map +1 -0
  42. package/dist/config/policy-loader.d.ts +4 -0
  43. package/dist/config/policy-loader.d.ts.map +1 -0
  44. package/dist/config/policy-loader.js +21 -0
  45. package/dist/config/policy-loader.js.map +1 -0
  46. package/dist/datamodel/commands.d.ts +25 -0
  47. package/dist/datamodel/commands.d.ts.map +1 -0
  48. package/dist/datamodel/commands.js +31 -0
  49. package/dist/datamodel/commands.js.map +1 -0
  50. package/dist/datamodel/common.d.ts +11 -0
  51. package/dist/datamodel/common.d.ts.map +1 -0
  52. package/dist/datamodel/common.js +3 -0
  53. package/dist/datamodel/common.js.map +1 -0
  54. package/dist/datamodel/errors.d.ts +16 -0
  55. package/dist/datamodel/errors.d.ts.map +1 -0
  56. package/dist/datamodel/errors.js +51 -0
  57. package/dist/datamodel/errors.js.map +1 -0
  58. package/dist/datamodel/index.d.ts +9 -0
  59. package/dist/datamodel/index.d.ts.map +1 -0
  60. package/dist/datamodel/index.js +25 -0
  61. package/dist/datamodel/index.js.map +1 -0
  62. package/dist/datamodel/internal-configs.d.ts +14 -0
  63. package/dist/datamodel/internal-configs.d.ts.map +1 -0
  64. package/dist/datamodel/internal-configs.js +3 -0
  65. package/dist/datamodel/internal-configs.js.map +1 -0
  66. package/dist/datamodel/public-configs.d.ts +27 -0
  67. package/dist/datamodel/public-configs.d.ts.map +1 -0
  68. package/dist/datamodel/public-configs.js +3 -0
  69. package/dist/datamodel/public-configs.js.map +1 -0
  70. package/dist/datamodel/snitch-configuration.d.ts +16 -0
  71. package/dist/datamodel/snitch-configuration.d.ts.map +1 -0
  72. package/dist/datamodel/snitch-configuration.js +32 -0
  73. package/dist/datamodel/snitch-configuration.js.map +1 -0
  74. package/dist/datamodel/typeguards.d.ts +3 -0
  75. package/dist/datamodel/typeguards.d.ts.map +1 -0
  76. package/dist/datamodel/typeguards.js +7 -0
  77. package/dist/datamodel/typeguards.js.map +1 -0
  78. package/dist/datamodel/typescript-specific.d.ts +7 -0
  79. package/dist/datamodel/typescript-specific.d.ts.map +1 -0
  80. package/dist/datamodel/typescript-specific.js +11 -0
  81. package/dist/datamodel/typescript-specific.js.map +1 -0
  82. package/dist/index.d.ts +2 -8
  83. package/dist/index.d.ts.map +1 -1
  84. package/dist/index.js +5 -17
  85. package/dist/index.js.map +1 -1
  86. package/dist/reporting/violation-reporter.d.ts +4 -0
  87. package/dist/reporting/violation-reporter.d.ts.map +1 -0
  88. package/dist/reporting/violation-reporter.js +45 -0
  89. package/dist/reporting/violation-reporter.js.map +1 -0
  90. package/dist/rules/policies/code-should-have-declarations.d.ts +3 -0
  91. package/dist/rules/policies/code-should-have-declarations.d.ts.map +1 -0
  92. package/dist/rules/policies/code-should-have-declarations.js +15 -0
  93. package/dist/rules/policies/code-should-have-declarations.js.map +1 -0
  94. package/dist/rules/policies/keep-tests-clean.d.ts +3 -0
  95. package/dist/rules/policies/keep-tests-clean.d.ts.map +1 -0
  96. package/dist/rules/policies/keep-tests-clean.js +21 -0
  97. package/dist/rules/policies/keep-tests-clean.js.map +1 -0
  98. package/dist/rules/policies/no-vars.d.ts +3 -0
  99. package/dist/rules/policies/no-vars.d.ts.map +1 -0
  100. package/dist/rules/policies/no-vars.js +19 -0
  101. package/dist/rules/policies/no-vars.js.map +1 -0
  102. package/dist/rules/policy-executor.d.ts +5 -0
  103. package/dist/rules/policy-executor.d.ts.map +1 -0
  104. package/dist/rules/policy-executor.js +10 -0
  105. package/dist/rules/policy-executor.js.map +1 -0
  106. package/dist/rules/policy.d.ts +7 -0
  107. package/dist/rules/policy.d.ts.map +1 -0
  108. package/dist/rules/policy.js +3 -0
  109. package/dist/rules/policy.js.map +1 -0
  110. package/dist/rules/provider-executor.d.ts +5 -0
  111. package/dist/rules/provider-executor.d.ts.map +1 -0
  112. package/dist/rules/provider-executor.js +105 -0
  113. package/dist/rules/provider-executor.js.map +1 -0
  114. package/dist/rules/provider.d.ts +26 -0
  115. package/dist/rules/provider.d.ts.map +1 -0
  116. package/dist/rules/provider.js +3 -0
  117. package/dist/rules/provider.js.map +1 -0
  118. package/dist/rules/providers/filter-by-declaration-type-provider.d.ts +8 -0
  119. package/dist/rules/providers/filter-by-declaration-type-provider.d.ts.map +1 -0
  120. package/dist/rules/providers/filter-by-declaration-type-provider.js +15 -0
  121. package/dist/rules/providers/filter-by-declaration-type-provider.js.map +1 -0
  122. package/dist/rules/providers/filter-by-file-provider.d.ts +8 -0
  123. package/dist/rules/providers/filter-by-file-provider.d.ts.map +1 -0
  124. package/dist/rules/providers/filter-by-file-provider.js +16 -0
  125. package/dist/rules/providers/filter-by-file-provider.js.map +1 -0
  126. package/dist/rules/providers/filter-exclude-function-names-provider.d.ts +8 -0
  127. package/dist/rules/providers/filter-exclude-function-names-provider.d.ts.map +1 -0
  128. package/dist/rules/providers/filter-exclude-function-names-provider.js +15 -0
  129. package/dist/rules/providers/filter-exclude-function-names-provider.js.map +1 -0
  130. package/dist/rules/providers/filter-has-literal-arguments-provider.d.ts +8 -0
  131. package/dist/rules/providers/filter-has-literal-arguments-provider.d.ts.map +1 -0
  132. package/dist/rules/providers/filter-has-literal-arguments-provider.js +26 -0
  133. package/dist/rules/providers/filter-has-literal-arguments-provider.js.map +1 -0
  134. package/dist/rules/providers/identity-provider.d.ts +8 -0
  135. package/dist/rules/providers/identity-provider.d.ts.map +1 -0
  136. package/dist/rules/providers/identity-provider.js +30 -0
  137. package/dist/rules/providers/identity-provider.js.map +1 -0
  138. package/dist/rules/violation-rule.d.ts +7 -0
  139. package/dist/rules/violation-rule.d.ts.map +1 -0
  140. package/dist/rules/violation-rule.js +3 -0
  141. package/dist/rules/violation-rule.js.map +1 -0
  142. package/dist/rules/violation.d.ts +12 -0
  143. package/dist/rules/violation.d.ts.map +1 -0
  144. package/dist/rules/violation.js +3 -0
  145. package/dist/rules/violation.js.map +1 -0
  146. package/dist/snitch.js +114 -44
  147. package/dist/snitch.js.map +1 -1
  148. package/dist/utils/AstAnalysis.d.ts +28 -0
  149. package/dist/utils/AstAnalysis.d.ts.map +1 -0
  150. package/dist/utils/AstAnalysis.js +117 -0
  151. package/dist/utils/AstAnalysis.js.map +1 -0
  152. package/dist/utils/args.d.ts +6 -0
  153. package/dist/utils/args.d.ts.map +1 -0
  154. package/dist/utils/args.js +23 -0
  155. package/dist/utils/args.js.map +1 -0
  156. package/dist/utils/ast-parser.d.ts +68 -0
  157. package/dist/utils/ast-parser.d.ts.map +1 -0
  158. package/dist/utils/ast-parser.js +364 -0
  159. package/dist/utils/ast-parser.js.map +1 -0
  160. package/dist/utils/fs.d.ts +8 -0
  161. package/dist/utils/fs.d.ts.map +1 -0
  162. package/dist/utils/fs.js +93 -0
  163. package/dist/utils/fs.js.map +1 -0
  164. package/dist/utils/pattern-scanner.d.ts +5 -21
  165. package/dist/utils/pattern-scanner.d.ts.map +1 -1
  166. package/dist/utils/pattern-scanner.js +13 -17
  167. package/dist/utils/pattern-scanner.js.map +1 -1
  168. package/dist/utils/ts-parser.d.ts.map +1 -1
  169. package/dist/utils/ts-parser.js +5 -12
  170. package/dist/utils/ts-parser.js.map +1 -1
  171. package/package.json +15 -6
  172. package/snitchconfig.schema.json +107 -51
  173. package/dist/commands/badimports.d.ts +0 -2
  174. package/dist/commands/badimports.d.ts.map +0 -1
  175. package/dist/commands/badimports.js +0 -8
  176. package/dist/commands/badimports.js.map +0 -1
  177. package/dist/commands/dirtydefaults.d.ts +0 -2
  178. package/dist/commands/dirtydefaults.d.ts.map +0 -1
  179. package/dist/commands/dirtydefaults.js +0 -8
  180. package/dist/commands/dirtydefaults.js.map +0 -1
  181. package/dist/commands/dm.d.ts +0 -2
  182. package/dist/commands/dm.d.ts.map +0 -1
  183. package/dist/commands/dm.js +0 -100
  184. package/dist/commands/dm.js.map +0 -1
  185. package/dist/commands/enumerate.d.ts +0 -2
  186. package/dist/commands/enumerate.d.ts.map +0 -1
  187. package/dist/commands/enumerate.js +0 -8
  188. package/dist/commands/enumerate.js.map +0 -1
  189. package/dist/commands/expectmagic.d.ts +0 -2
  190. package/dist/commands/expectmagic.d.ts.map +0 -1
  191. package/dist/commands/expectmagic.js +0 -8
  192. package/dist/commands/expectmagic.js.map +0 -1
  193. package/dist/commands/fixtures.d.ts +0 -2
  194. package/dist/commands/fixtures.d.ts.map +0 -1
  195. package/dist/commands/fixtures.js +0 -8
  196. package/dist/commands/fixtures.js.map +0 -1
  197. package/dist/commands/scan.d.ts +0 -2
  198. package/dist/commands/scan.d.ts.map +0 -1
  199. package/dist/commands/scan.js +0 -108
  200. package/dist/commands/scan.js.map +0 -1
  201. package/dist/commands/vocab.d.ts +0 -2
  202. package/dist/commands/vocab.d.ts.map +0 -1
  203. package/dist/commands/vocab.js +0 -166
  204. package/dist/commands/vocab.js.map +0 -1
  205. package/dist/datamodel.d.ts +0 -18
  206. package/dist/datamodel.d.ts.map +0 -1
  207. package/dist/datamodel.js +0 -23
  208. package/dist/datamodel.js.map +0 -1
@@ -0,0 +1,4 @@
1
+ import { ViolationReport } from '../rules/violation';
2
+ export declare function reportViolations(violations: ViolationReport[]): void;
3
+ export declare function getViolationSummary(violations: ViolationReport[]): string;
4
+ //# sourceMappingURL=violation-reporter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"violation-reporter.d.ts","sourceRoot":"","sources":["../../src/reporting/violation-reporter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AAEpD,wBAAgB,gBAAgB,CAAC,UAAU,EAAE,eAAe,EAAE,GAAG,IAAI,CA0CpE;AAED,wBAAgB,mBAAmB,CAAC,UAAU,EAAE,eAAe,EAAE,GAAG,MAAM,CAIzE"}
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.reportViolations = reportViolations;
4
+ exports.getViolationSummary = getViolationSummary;
5
+ function reportViolations(violations) {
6
+ if (violations.length === 0) {
7
+ console.log('\n✓ No violations found\n');
8
+ return;
9
+ }
10
+ // Group violations by file
11
+ const byFile = new Map();
12
+ for (const violation of violations) {
13
+ if (!byFile.has(violation.file)) {
14
+ byFile.set(violation.file, []);
15
+ }
16
+ byFile.get(violation.file).push(violation);
17
+ }
18
+ // Print violations grouped by file
19
+ console.log('\n✗ Violations found:\n');
20
+ for (const [file, fileViolations] of byFile) {
21
+ console.log(`${file}`);
22
+ for (const violation of fileViolations) {
23
+ const lineInfo = violation.line ? `:${violation.line}` : '';
24
+ console.log(` ${lineInfo} [${violation.policyName}] ${violation.message}`);
25
+ console.log(` Culprit: ${violation.cause.culprit}`);
26
+ if (violation.cause.snippet) {
27
+ console.log(` Snippet:\n${violation.cause.snippet
28
+ .split('\n')
29
+ .map((l) => ` ${l}`)
30
+ .join('\n')}`);
31
+ }
32
+ }
33
+ console.log('');
34
+ }
35
+ // Summary
36
+ const fileCount = byFile.size;
37
+ const violationCount = violations.length;
38
+ console.log(`Found ${violationCount} violation${violationCount === 1 ? '' : 's'} across ${fileCount} file${fileCount === 1 ? '' : 's'}\n`);
39
+ }
40
+ function getViolationSummary(violations) {
41
+ const fileCount = new Set(violations.map((v) => v.file)).size;
42
+ const violationCount = violations.length;
43
+ return `Found ${violationCount} violation${violationCount === 1 ? '' : 's'} across ${fileCount} file${fileCount === 1 ? '' : 's'}`;
44
+ }
45
+ //# sourceMappingURL=violation-reporter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"violation-reporter.js","sourceRoot":"","sources":["../../src/reporting/violation-reporter.ts"],"names":[],"mappings":";;AAEA,4CA0CC;AAED,kDAIC;AAhDD,SAAgB,gBAAgB,CAAC,UAA6B;IAC5D,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC5B,OAAO,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAA;QACxC,OAAM;IACR,CAAC;IAED,2BAA2B;IAC3B,MAAM,MAAM,GAAG,IAAI,GAAG,EAA6B,CAAA;IACnD,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE,CAAC;QACnC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC;YAChC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE,CAAC,CAAA;QAChC,CAAC;QACD,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,CAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;IAC7C,CAAC;IAED,mCAAmC;IACnC,OAAO,CAAC,GAAG,CAAC,yBAAyB,CAAC,CAAA;IAEtC,KAAK,MAAM,CAAC,IAAI,EAAE,cAAc,CAAC,IAAI,MAAM,EAAE,CAAC;QAC5C,OAAO,CAAC,GAAG,CAAC,GAAG,IAAI,EAAE,CAAC,CAAA;QACtB,KAAK,MAAM,SAAS,IAAI,cAAc,EAAE,CAAC;YACvC,MAAM,QAAQ,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAA;YAC3D,OAAO,CAAC,GAAG,CAAC,KAAK,QAAQ,KAAK,SAAS,CAAC,UAAU,KAAK,SAAS,CAAC,OAAO,EAAE,CAAC,CAAA;YAC3E,OAAO,CAAC,GAAG,CAAC,gBAAgB,SAAS,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAA;YACtD,IAAI,SAAS,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;gBAC5B,OAAO,CAAC,GAAG,CACT,iBAAiB,SAAS,CAAC,KAAK,CAAC,OAAO;qBACrC,KAAK,CAAC,IAAI,CAAC;qBACX,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC;qBACxB,IAAI,CAAC,IAAI,CAAC,EAAE,CAChB,CAAA;YACH,CAAC;QACH,CAAC;QACD,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;IACjB,CAAC;IAED,UAAU;IACV,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,CAAA;IAC7B,MAAM,cAAc,GAAG,UAAU,CAAC,MAAM,CAAA;IACxC,OAAO,CAAC,GAAG,CACT,SAAS,cAAc,aAAa,cAAc,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,WAAW,SAAS,QAAQ,SAAS,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,CAC9H,CAAA;AACH,CAAC;AAED,SAAgB,mBAAmB,CAAC,UAA6B;IAC/D,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAA;IAC7D,MAAM,cAAc,GAAG,UAAU,CAAC,MAAM,CAAA;IACxC,OAAO,SAAS,cAAc,aAAa,cAAc,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,WAAW,SAAS,QAAQ,SAAS,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,EAAE,CAAA;AACpI,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Policy } from '../policy';
2
+ export declare const codeShouldHaveDeclarationsPolicy: Policy;
3
+ //# sourceMappingURL=code-should-have-declarations.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"code-should-have-declarations.d.ts","sourceRoot":"","sources":["../../../src/rules/policies/code-should-have-declarations.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAA;AAElC,eAAO,MAAM,gCAAgC,EAAE,MAU9C,CAAA"}
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.codeShouldHaveDeclarationsPolicy = void 0;
4
+ exports.codeShouldHaveDeclarationsPolicy = {
5
+ id: 'code-should-have-declarations',
6
+ title: 'Code Should Have Declarations',
7
+ violations: [
8
+ {
9
+ message: 'No declarations found in code',
10
+ cause: 'empty file or no type/function/variable declarations',
11
+ providers: [{ type: 'identity', source: 'declarations' }],
12
+ },
13
+ ],
14
+ };
15
+ //# sourceMappingURL=code-should-have-declarations.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"code-should-have-declarations.js","sourceRoot":"","sources":["../../../src/rules/policies/code-should-have-declarations.ts"],"names":[],"mappings":";;;AAEa,QAAA,gCAAgC,GAAW;IACtD,EAAE,EAAE,+BAA+B;IACnC,KAAK,EAAE,+BAA+B;IACtC,UAAU,EAAE;QACV;YACE,OAAO,EAAE,+BAA+B;YACxC,KAAK,EAAE,sDAAsD;YAC7D,SAAS,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,cAAc,EAAE,CAAC;SAC1D;KACF;CACF,CAAA"}
@@ -0,0 +1,3 @@
1
+ import { Policy } from '../policy';
2
+ export declare const keepTestsCleanPolicy: Policy;
3
+ //# sourceMappingURL=keep-tests-clean.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"keep-tests-clean.d.ts","sourceRoot":"","sources":["../../../src/rules/policies/keep-tests-clean.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAA;AAGlC,eAAO,MAAM,oBAAoB,EAAE,MAelC,CAAA"}
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.keepTestsCleanPolicy = void 0;
4
+ const ast_parser_1 = require("../../utils/ast-parser");
5
+ exports.keepTestsCleanPolicy = {
6
+ id: 'keep-tests-clean',
7
+ title: 'Keep Tests Clean',
8
+ violations: [
9
+ {
10
+ message: 'Found literal in function call: {functionName}',
11
+ cause: '{literalValue}',
12
+ providers: [
13
+ { type: 'identity', source: 'functionInvocations' },
14
+ { type: 'filter-by-file', patterns: ['test/**/*.ts', '**/*.test.ts', '**/*.spec.ts'] },
15
+ { type: 'filter-exclude-function-names', names: ['test', 'given', 'when', 'then', 'describe', 'it'] },
16
+ { type: 'filter-has-literal-arguments', literalKinds: [ast_parser_1.LiteralKind.String, ast_parser_1.LiteralKind.Number] },
17
+ ],
18
+ },
19
+ ],
20
+ };
21
+ //# sourceMappingURL=keep-tests-clean.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"keep-tests-clean.js","sourceRoot":"","sources":["../../../src/rules/policies/keep-tests-clean.ts"],"names":[],"mappings":";;;AACA,uDAAoD;AAEvC,QAAA,oBAAoB,GAAW;IAC1C,EAAE,EAAE,kBAAkB;IACtB,KAAK,EAAE,kBAAkB;IACzB,UAAU,EAAE;QACV;YACE,OAAO,EAAE,gDAAgD;YACzD,KAAK,EAAE,gBAAgB;YACvB,SAAS,EAAE;gBACT,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,qBAAqB,EAAE;gBACnD,EAAE,IAAI,EAAE,gBAAgB,EAAE,QAAQ,EAAE,CAAC,cAAc,EAAE,cAAc,EAAE,cAAc,CAAC,EAAE;gBACtF,EAAE,IAAI,EAAE,+BAA+B,EAAE,KAAK,EAAE,CAAC,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,IAAI,CAAC,EAAE;gBACrG,EAAE,IAAI,EAAE,8BAA8B,EAAE,YAAY,EAAE,CAAC,wBAAW,CAAC,MAAM,EAAE,wBAAW,CAAC,MAAM,CAAC,EAAE;aACjG;SACF;KACF;CACF,CAAA"}
@@ -0,0 +1,3 @@
1
+ import { Policy } from '../policy';
2
+ export declare const noVarsPolicy: Policy;
3
+ //# sourceMappingURL=no-vars.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-vars.d.ts","sourceRoot":"","sources":["../../../src/rules/policies/no-vars.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAA;AAElC,eAAO,MAAM,YAAY,EAAE,MAa1B,CAAA"}
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.noVarsPolicy = void 0;
4
+ const ast_parser_1 = require("../../utils/ast-parser");
5
+ exports.noVarsPolicy = {
6
+ id: 'no-vars',
7
+ title: 'No Var Declarations',
8
+ violations: [
9
+ {
10
+ message: 'Found var declaration: {declarationName}',
11
+ cause: '{definition}',
12
+ providers: [
13
+ { type: 'identity', source: 'declarations' },
14
+ { type: 'filter-by-declaration-type', declarationTypes: [ast_parser_1.DeclarationType.Var] },
15
+ ],
16
+ },
17
+ ],
18
+ };
19
+ //# sourceMappingURL=no-vars.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"no-vars.js","sourceRoot":"","sources":["../../../src/rules/policies/no-vars.ts"],"names":[],"mappings":";;;AAAA,uDAAwD;AAG3C,QAAA,YAAY,GAAW;IAClC,EAAE,EAAE,SAAS;IACb,KAAK,EAAE,qBAAqB;IAC5B,UAAU,EAAE;QACV;YACE,OAAO,EAAE,0CAA0C;YACnD,KAAK,EAAE,cAAc;YACrB,SAAS,EAAE;gBACT,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,cAAc,EAAE;gBAC5C,EAAE,IAAI,EAAE,4BAA4B,EAAE,gBAAgB,EAAE,CAAC,4BAAe,CAAC,GAAG,CAAC,EAAE;aAChF;SACF;KACF;CACF,CAAA"}
@@ -0,0 +1,5 @@
1
+ import { AstAnalysis } from '../utils/AstAnalysis';
2
+ import { Policy } from './policy';
3
+ import { ViolationReport } from './violation';
4
+ export declare function executePolicy(analysis: AstAnalysis, policy: Policy): Promise<ViolationReport[]>;
5
+ //# sourceMappingURL=policy-executor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"policy-executor.d.ts","sourceRoot":"","sources":["../../src/rules/policy-executor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAA;AAClD,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAA;AACjC,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAA;AAG7C,wBAAsB,aAAa,CAAC,QAAQ,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC,CAMrG"}
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.executePolicy = executePolicy;
4
+ const provider_executor_1 = require("./provider-executor");
5
+ async function executePolicy(analysis, policy) {
6
+ const violationsPerRule = await Promise.all(policy.violations.map((violationRule) => (0, provider_executor_1.executeViolationRule)(analysis, violationRule, policy.id)));
7
+ const allViolations = violationsPerRule.flat();
8
+ return allViolations;
9
+ }
10
+ //# sourceMappingURL=policy-executor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"policy-executor.js","sourceRoot":"","sources":["../../src/rules/policy-executor.ts"],"names":[],"mappings":";;AAKA,sCAMC;AARD,2DAA0D;AAEnD,KAAK,UAAU,aAAa,CAAC,QAAqB,EAAE,MAAc;IACvE,MAAM,iBAAiB,GAAG,MAAM,OAAO,CAAC,GAAG,CACzC,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,aAAa,EAAE,EAAE,CAAC,IAAA,wCAAoB,EAAC,QAAQ,EAAE,aAAa,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,CACnG,CAAA;IACD,MAAM,aAAa,GAAG,iBAAiB,CAAC,IAAI,EAAE,CAAA;IAC9C,OAAO,aAAa,CAAA;AACtB,CAAC"}
@@ -0,0 +1,7 @@
1
+ import { ViolationRule } from './violation-rule';
2
+ export type Policy = {
3
+ id: string;
4
+ title: string;
5
+ violations: ViolationRule[];
6
+ };
7
+ //# sourceMappingURL=policy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"policy.d.ts","sourceRoot":"","sources":["../../src/rules/policy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAA;AAEhD,MAAM,MAAM,MAAM,GAAG;IACnB,EAAE,EAAE,MAAM,CAAA;IACV,KAAK,EAAE,MAAM,CAAA;IACb,UAAU,EAAE,aAAa,EAAE,CAAA;CAC5B,CAAA"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=policy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"policy.js","sourceRoot":"","sources":["../../src/rules/policy.ts"],"names":[],"mappings":""}
@@ -0,0 +1,5 @@
1
+ import { AstAnalysis } from '../utils/AstAnalysis';
2
+ import { ViolationReport } from './violation';
3
+ import { ViolationRule } from './violation-rule';
4
+ export declare function executeViolationRule(analysis: AstAnalysis, violationRule: ViolationRule, policyId: string): Promise<ViolationReport[]>;
5
+ //# sourceMappingURL=provider-executor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"provider-executor.d.ts","sourceRoot":"","sources":["../../src/rules/provider-executor.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAA;AAElD,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAA;AAC7C,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAA;AAOhD,wBAAsB,oBAAoB,CACxC,QAAQ,EAAE,WAAW,EACrB,aAAa,EAAE,aAAa,EAC5B,QAAQ,EAAE,MAAM,GACf,OAAO,CAAC,eAAe,EAAE,CAAC,CAQ5B"}
@@ -0,0 +1,105 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.executeViolationRule = executeViolationRule;
4
+ const ast_parser_1 = require("../utils/ast-parser");
5
+ const identity_provider_1 = require("./providers/identity-provider");
6
+ const filter_by_file_provider_1 = require("./providers/filter-by-file-provider");
7
+ const filter_exclude_function_names_provider_1 = require("./providers/filter-exclude-function-names-provider");
8
+ const filter_has_literal_arguments_provider_1 = require("./providers/filter-has-literal-arguments-provider");
9
+ const filter_by_declaration_type_provider_1 = require("./providers/filter-by-declaration-type-provider");
10
+ async function executeViolationRule(analysis, violationRule, policyId) {
11
+ let currentData = analysis;
12
+ for (const providerConfig of violationRule.providers) {
13
+ currentData = await processProvider(currentData, providerConfig);
14
+ }
15
+ return convertToViolationReports(currentData, violationRule, policyId);
16
+ }
17
+ async function processProvider(data, config) {
18
+ if (config.type === 'identity') {
19
+ const provider = new identity_provider_1.IdentityProvider(config);
20
+ return await provider.process(data);
21
+ }
22
+ if (config.type === 'filter-by-file') {
23
+ const provider = new filter_by_file_provider_1.FilterByFileProvider(config);
24
+ return await provider.process(data);
25
+ }
26
+ if (config.type === 'filter-exclude-function-names') {
27
+ const provider = new filter_exclude_function_names_provider_1.FilterExcludeFunctionNamesProvider(config);
28
+ return await provider.process(data);
29
+ }
30
+ if (config.type === 'filter-has-literal-arguments') {
31
+ const provider = new filter_has_literal_arguments_provider_1.FilterHasLiteralArgumentsProvider(config);
32
+ return await provider.process(data);
33
+ }
34
+ if (config.type === 'filter-by-declaration-type') {
35
+ const provider = new filter_by_declaration_type_provider_1.FilterByDeclarationTypeProvider(config);
36
+ return await provider.process(data);
37
+ }
38
+ throw new Error(`Unknown provider type: ${config.type}`);
39
+ }
40
+ function convertToViolationReports(data, violationRule, policyId) {
41
+ if (policyId === 'code-should-have-declarations') {
42
+ if (data.length === 0) {
43
+ return [
44
+ {
45
+ policyName: policyId,
46
+ detectorName: 'provider-pipeline',
47
+ message: violationRule.message,
48
+ cause: {
49
+ culprit: violationRule.cause,
50
+ snippet: '',
51
+ },
52
+ file: 'n/a',
53
+ },
54
+ ];
55
+ }
56
+ return [];
57
+ }
58
+ return data.map((item) => {
59
+ const message = applyTemplate(violationRule.message, item);
60
+ const culprit = applyTemplate(violationRule.cause, item);
61
+ const snippet = item.snippet || '';
62
+ return {
63
+ policyName: policyId,
64
+ detectorName: 'provider-pipeline',
65
+ message,
66
+ cause: {
67
+ culprit,
68
+ snippet,
69
+ },
70
+ file: item.file,
71
+ line: item.line,
72
+ };
73
+ });
74
+ }
75
+ function applyTemplate(template, item) {
76
+ let result = template;
77
+ if (isFunctionInvocation(item)) {
78
+ result = result.replace(/{functionName}/g, item.functionName);
79
+ const literalArgs = item.arguments.filter((arg) => arg.kind === ast_parser_1.ArgumentKind.PrimitiveLiteral ||
80
+ arg.kind === ast_parser_1.ArgumentKind.ObjectLiteral ||
81
+ arg.kind === ast_parser_1.ArgumentKind.ArrayLiteral);
82
+ if (literalArgs.length > 0) {
83
+ const firstLiteralArg = literalArgs[0];
84
+ result = result.replace(/{literalValue}/g, firstLiteralArg.literal.value);
85
+ }
86
+ }
87
+ if (isLiteral(item)) {
88
+ result = result.replace(/{literalValue}/g, item.value);
89
+ }
90
+ if (isDeclaration(item)) {
91
+ result = result.replace(/{declarationName}/g, item.name);
92
+ result = result.replace(/{definition}/g, item.definition || item.name);
93
+ }
94
+ return result;
95
+ }
96
+ function isFunctionInvocation(item) {
97
+ return 'functionName' in item && 'arguments' in item;
98
+ }
99
+ function isLiteral(item) {
100
+ return 'kind' in item && 'value' in item && 'isPrimitive' in item;
101
+ }
102
+ function isDeclaration(item) {
103
+ return 'name' in item && 'type' in item && 'isExported' in item;
104
+ }
105
+ //# sourceMappingURL=provider-executor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"provider-executor.js","sourceRoot":"","sources":["../../src/rules/provider-executor.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,26 @@
1
+ import { LiteralKind, DeclarationType } from '../utils/ast-parser';
2
+ export type IdentityProviderConfig = {
3
+ type: 'identity';
4
+ source: 'functionInvocations' | 'literals' | 'declarations' | 'typeDeclarations' | 'topLevelFunctions' | 'exports' | 'sequentialGroups';
5
+ };
6
+ export type FilterByFileProviderConfig = {
7
+ type: 'filter-by-file';
8
+ patterns: string[];
9
+ };
10
+ export type FilterExcludeFunctionNamesProviderConfig = {
11
+ type: 'filter-exclude-function-names';
12
+ names: string[];
13
+ };
14
+ export type FilterHasLiteralArgumentsProviderConfig = {
15
+ type: 'filter-has-literal-arguments';
16
+ literalKinds: LiteralKind[];
17
+ };
18
+ export type FilterByDeclarationTypeProviderConfig = {
19
+ type: 'filter-by-declaration-type';
20
+ declarationTypes: DeclarationType[];
21
+ };
22
+ export type ProviderConfig = IdentityProviderConfig | FilterByFileProviderConfig | FilterExcludeFunctionNamesProviderConfig | FilterHasLiteralArgumentsProviderConfig | FilterByDeclarationTypeProviderConfig;
23
+ export type Provider<TInput, TOutput> = {
24
+ process(data: TInput): Promise<TOutput>;
25
+ };
26
+ //# sourceMappingURL=provider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../../src/rules/provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAElE,MAAM,MAAM,sBAAsB,GAAG;IACnC,IAAI,EAAE,UAAU,CAAA;IAChB,MAAM,EACF,qBAAqB,GACrB,UAAU,GACV,cAAc,GACd,kBAAkB,GAClB,mBAAmB,GACnB,SAAS,GACT,kBAAkB,CAAA;CACvB,CAAA;AAED,MAAM,MAAM,0BAA0B,GAAG;IACvC,IAAI,EAAE,gBAAgB,CAAA;IACtB,QAAQ,EAAE,MAAM,EAAE,CAAA;CACnB,CAAA;AAED,MAAM,MAAM,wCAAwC,GAAG;IACrD,IAAI,EAAE,+BAA+B,CAAA;IACrC,KAAK,EAAE,MAAM,EAAE,CAAA;CAChB,CAAA;AAED,MAAM,MAAM,uCAAuC,GAAG;IACpD,IAAI,EAAE,8BAA8B,CAAA;IACpC,YAAY,EAAE,WAAW,EAAE,CAAA;CAC5B,CAAA;AAED,MAAM,MAAM,qCAAqC,GAAG;IAClD,IAAI,EAAE,4BAA4B,CAAA;IAClC,gBAAgB,EAAE,eAAe,EAAE,CAAA;CACpC,CAAA;AAED,MAAM,MAAM,cAAc,GACtB,sBAAsB,GACtB,0BAA0B,GAC1B,wCAAwC,GACxC,uCAAuC,GACvC,qCAAqC,CAAA;AAEzC,MAAM,MAAM,QAAQ,CAAC,MAAM,EAAE,OAAO,IAAI;IACtC,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAA;CACxC,CAAA"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=provider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"provider.js","sourceRoot":"","sources":["../../src/rules/provider.ts"],"names":[],"mappings":""}
@@ -0,0 +1,8 @@
1
+ import { DeclarationWithExport } from '../../utils/ast-parser';
2
+ import { Provider, FilterByDeclarationTypeProviderConfig } from '../provider';
3
+ export declare class FilterByDeclarationTypeProvider implements Provider<DeclarationWithExport[], DeclarationWithExport[]> {
4
+ private config;
5
+ constructor(config: FilterByDeclarationTypeProviderConfig);
6
+ process(data: DeclarationWithExport[]): Promise<DeclarationWithExport[]>;
7
+ }
8
+ //# sourceMappingURL=filter-by-declaration-type-provider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filter-by-declaration-type-provider.d.ts","sourceRoot":"","sources":["../../../src/rules/providers/filter-by-declaration-type-provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAA;AAC9D,OAAO,EAAE,QAAQ,EAAE,qCAAqC,EAAE,MAAM,aAAa,CAAA;AAE7E,qBAAa,+BAAgC,YAAW,QAAQ,CAAC,qBAAqB,EAAE,EAAE,qBAAqB,EAAE,CAAC;IACpG,OAAO,CAAC,MAAM;gBAAN,MAAM,EAAE,qCAAqC;IAE3D,OAAO,CAAC,IAAI,EAAE,qBAAqB,EAAE,GAAG,OAAO,CAAC,qBAAqB,EAAE,CAAC;CAK/E"}
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FilterByDeclarationTypeProvider = void 0;
4
+ class FilterByDeclarationTypeProvider {
5
+ constructor(config) {
6
+ this.config = config;
7
+ }
8
+ async process(data) {
9
+ return data.filter((declaration) => {
10
+ return this.config.declarationTypes.includes(declaration.type);
11
+ });
12
+ }
13
+ }
14
+ exports.FilterByDeclarationTypeProvider = FilterByDeclarationTypeProvider;
15
+ //# sourceMappingURL=filter-by-declaration-type-provider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filter-by-declaration-type-provider.js","sourceRoot":"","sources":["../../../src/rules/providers/filter-by-declaration-type-provider.ts"],"names":[],"mappings":";;;AAGA,MAAa,+BAA+B;IAC1C,YAAoB,MAA6C;QAA7C,WAAM,GAAN,MAAM,CAAuC;IAAG,CAAC;IAErE,KAAK,CAAC,OAAO,CAAC,IAA6B;QACzC,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,EAAE;YACjC,OAAO,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;QAChE,CAAC,CAAC,CAAA;IACJ,CAAC;CACF;AARD,0EAQC"}
@@ -0,0 +1,8 @@
1
+ import { FunctionInvocation, Literal, DeclarationWithExport } from '../../utils/ast-parser';
2
+ import { Provider, FilterByFileProviderConfig } from '../provider';
3
+ export declare class FilterByFileProvider implements Provider<(FunctionInvocation | Literal | DeclarationWithExport)[], (FunctionInvocation | Literal | DeclarationWithExport)[]> {
4
+ private config;
5
+ constructor(config: FilterByFileProviderConfig);
6
+ process(data: (FunctionInvocation | Literal | DeclarationWithExport)[]): Promise<(FunctionInvocation | Literal | DeclarationWithExport)[]>;
7
+ }
8
+ //# sourceMappingURL=filter-by-file-provider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filter-by-file-provider.d.ts","sourceRoot":"","sources":["../../../src/rules/providers/filter-by-file-provider.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAA;AAC3F,OAAO,EAAE,QAAQ,EAAE,0BAA0B,EAAE,MAAM,aAAa,CAAA;AAIlE,qBAAa,oBACX,YACE,QAAQ,CACN,CAAC,kBAAkB,GAAG,OAAO,GAAG,qBAAqB,CAAC,EAAE,EACxD,CAAC,kBAAkB,GAAG,OAAO,GAAG,qBAAqB,CAAC,EAAE,CACzD;IAES,OAAO,CAAC,MAAM;gBAAN,MAAM,EAAE,0BAA0B;IAEhD,OAAO,CACX,IAAI,EAAE,CAAC,kBAAkB,GAAG,OAAO,GAAG,qBAAqB,CAAC,EAAE,GAC7D,OAAO,CAAC,CAAC,kBAAkB,GAAG,OAAO,GAAG,qBAAqB,CAAC,EAAE,CAAC;CAKrE"}
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FilterByFileProvider = void 0;
4
+ const minimatch_1 = require("minimatch");
5
+ class FilterByFileProvider {
6
+ constructor(config) {
7
+ this.config = config;
8
+ }
9
+ async process(data) {
10
+ return data.filter((item) => {
11
+ return this.config.patterns.some((pattern) => (0, minimatch_1.minimatch)(item.file, pattern));
12
+ });
13
+ }
14
+ }
15
+ exports.FilterByFileProvider = FilterByFileProvider;
16
+ //# sourceMappingURL=filter-by-file-provider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filter-by-file-provider.js","sourceRoot":"","sources":["../../../src/rules/providers/filter-by-file-provider.ts"],"names":[],"mappings":";;;AAAA,yCAAqC;AAMrC,MAAa,oBAAoB;IAO/B,YAAoB,MAAkC;QAAlC,WAAM,GAAN,MAAM,CAA4B;IAAG,CAAC;IAE1D,KAAK,CAAC,OAAO,CACX,IAA8D;QAE9D,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,IAAe,EAAE,EAAE;YACrC,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,IAAA,qBAAS,EAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAA;QAC9E,CAAC,CAAC,CAAA;IACJ,CAAC;CACF;AAhBD,oDAgBC"}
@@ -0,0 +1,8 @@
1
+ import { FunctionInvocation } from '../../utils/ast-parser';
2
+ import { Provider, FilterExcludeFunctionNamesProviderConfig } from '../provider';
3
+ export declare class FilterExcludeFunctionNamesProvider implements Provider<FunctionInvocation[], FunctionInvocation[]> {
4
+ private config;
5
+ constructor(config: FilterExcludeFunctionNamesProviderConfig);
6
+ process(data: FunctionInvocation[]): Promise<FunctionInvocation[]>;
7
+ }
8
+ //# sourceMappingURL=filter-exclude-function-names-provider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filter-exclude-function-names-provider.d.ts","sourceRoot":"","sources":["../../../src/rules/providers/filter-exclude-function-names-provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAA;AAC3D,OAAO,EAAE,QAAQ,EAAE,wCAAwC,EAAE,MAAM,aAAa,CAAA;AAEhF,qBAAa,kCAAmC,YAAW,QAAQ,CAAC,kBAAkB,EAAE,EAAE,kBAAkB,EAAE,CAAC;IACjG,OAAO,CAAC,MAAM;gBAAN,MAAM,EAAE,wCAAwC;IAE9D,OAAO,CAAC,IAAI,EAAE,kBAAkB,EAAE,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC;CAKzE"}
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FilterExcludeFunctionNamesProvider = void 0;
4
+ class FilterExcludeFunctionNamesProvider {
5
+ constructor(config) {
6
+ this.config = config;
7
+ }
8
+ async process(data) {
9
+ return data.filter((invocation) => {
10
+ return !this.config.names.includes(invocation.functionName);
11
+ });
12
+ }
13
+ }
14
+ exports.FilterExcludeFunctionNamesProvider = FilterExcludeFunctionNamesProvider;
15
+ //# sourceMappingURL=filter-exclude-function-names-provider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filter-exclude-function-names-provider.js","sourceRoot":"","sources":["../../../src/rules/providers/filter-exclude-function-names-provider.ts"],"names":[],"mappings":";;;AAGA,MAAa,kCAAkC;IAC7C,YAAoB,MAAgD;QAAhD,WAAM,GAAN,MAAM,CAA0C;IAAG,CAAC;IAExE,KAAK,CAAC,OAAO,CAAC,IAA0B;QACtC,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,UAAU,EAAE,EAAE;YAChC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,YAAY,CAAC,CAAA;QAC7D,CAAC,CAAC,CAAA;IACJ,CAAC;CACF;AARD,gFAQC"}
@@ -0,0 +1,8 @@
1
+ import { FunctionInvocation } from '../../utils/ast-parser';
2
+ import { Provider, FilterHasLiteralArgumentsProviderConfig } from '../provider';
3
+ export declare class FilterHasLiteralArgumentsProvider implements Provider<FunctionInvocation[], FunctionInvocation[]> {
4
+ private config;
5
+ constructor(config: FilterHasLiteralArgumentsProviderConfig);
6
+ process(data: FunctionInvocation[]): Promise<FunctionInvocation[]>;
7
+ }
8
+ //# sourceMappingURL=filter-has-literal-arguments-provider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filter-has-literal-arguments-provider.d.ts","sourceRoot":"","sources":["../../../src/rules/providers/filter-has-literal-arguments-provider.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,EAInB,MAAM,wBAAwB,CAAA;AAC/B,OAAO,EAAE,QAAQ,EAAE,uCAAuC,EAAE,MAAM,aAAa,CAAA;AAE/E,qBAAa,iCAAkC,YAAW,QAAQ,CAAC,kBAAkB,EAAE,EAAE,kBAAkB,EAAE,CAAC;IAChG,OAAO,CAAC,MAAM;gBAAN,MAAM,EAAE,uCAAuC;IAE7D,OAAO,CAAC,IAAI,EAAE,kBAAkB,EAAE,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC;CAezE"}
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FilterHasLiteralArgumentsProvider = void 0;
4
+ const ast_parser_1 = require("../../utils/ast-parser");
5
+ class FilterHasLiteralArgumentsProvider {
6
+ constructor(config) {
7
+ this.config = config;
8
+ }
9
+ async process(data) {
10
+ return data.filter((invocation) => {
11
+ return invocation.arguments.some((arg) => {
12
+ if (arg.kind === ast_parser_1.ArgumentKind.PrimitiveLiteral) {
13
+ const primArg = arg;
14
+ return this.config.literalKinds.includes(primArg.literal.kind);
15
+ }
16
+ if (arg.kind === ast_parser_1.ArgumentKind.ObjectLiteral || arg.kind === ast_parser_1.ArgumentKind.ArrayLiteral) {
17
+ const complexArg = arg;
18
+ return this.config.literalKinds.includes(complexArg.literal.kind);
19
+ }
20
+ return false;
21
+ });
22
+ });
23
+ }
24
+ }
25
+ exports.FilterHasLiteralArgumentsProvider = FilterHasLiteralArgumentsProvider;
26
+ //# sourceMappingURL=filter-has-literal-arguments-provider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filter-has-literal-arguments-provider.js","sourceRoot":"","sources":["../../../src/rules/providers/filter-has-literal-arguments-provider.ts"],"names":[],"mappings":";;;AAAA,uDAK+B;AAG/B,MAAa,iCAAiC;IAC5C,YAAoB,MAA+C;QAA/C,WAAM,GAAN,MAAM,CAAyC;IAAG,CAAC;IAEvE,KAAK,CAAC,OAAO,CAAC,IAA0B;QACtC,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,UAAU,EAAE,EAAE;YAChC,OAAO,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE;gBACvC,IAAI,GAAG,CAAC,IAAI,KAAK,yBAAY,CAAC,gBAAgB,EAAE,CAAC;oBAC/C,MAAM,OAAO,GAAG,GAA+B,CAAA;oBAC/C,OAAO,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;gBAChE,CAAC;gBACD,IAAI,GAAG,CAAC,IAAI,KAAK,yBAAY,CAAC,aAAa,IAAI,GAAG,CAAC,IAAI,KAAK,yBAAY,CAAC,YAAY,EAAE,CAAC;oBACtF,MAAM,UAAU,GAAG,GAA6B,CAAA;oBAChD,OAAO,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,QAAQ,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;gBACnE,CAAC;gBACD,OAAO,KAAK,CAAA;YACd,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;IACJ,CAAC;CACF;AAlBD,8EAkBC"}
@@ -0,0 +1,8 @@
1
+ import { AstAnalysis } from '../../utils/AstAnalysis';
2
+ import { Provider, IdentityProviderConfig } from '../provider';
3
+ export declare class IdentityProvider implements Provider<AstAnalysis, any> {
4
+ private config;
5
+ constructor(config: IdentityProviderConfig);
6
+ process(analysis: AstAnalysis): Promise<any>;
7
+ }
8
+ //# sourceMappingURL=identity-provider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"identity-provider.d.ts","sourceRoot":"","sources":["../../../src/rules/providers/identity-provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AACrD,OAAO,EAAE,QAAQ,EAAE,sBAAsB,EAAE,MAAM,aAAa,CAAA;AAE9D,qBAAa,gBAAiB,YAAW,QAAQ,CAAC,WAAW,EAAE,GAAG,CAAC;IACrD,OAAO,CAAC,MAAM;gBAAN,MAAM,EAAE,sBAAsB;IAE5C,OAAO,CAAC,QAAQ,EAAE,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC;CAoBnD"}
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.IdentityProvider = void 0;
4
+ class IdentityProvider {
5
+ constructor(config) {
6
+ this.config = config;
7
+ }
8
+ async process(analysis) {
9
+ switch (this.config.source) {
10
+ case 'declarations':
11
+ return await analysis.getDeclarations();
12
+ case 'literals':
13
+ return await analysis.getLiterals();
14
+ case 'functionInvocations':
15
+ return await analysis.getFunctionInvocations();
16
+ case 'typeDeclarations':
17
+ return await analysis.getTypeDeclarations();
18
+ case 'topLevelFunctions':
19
+ return await analysis.getTopLevelFunctions();
20
+ case 'exports':
21
+ return await analysis.getExports();
22
+ case 'sequentialGroups':
23
+ return await analysis.getSequentialGroups();
24
+ default:
25
+ throw new Error(`Unknown source: ${this.config.source}`);
26
+ }
27
+ }
28
+ }
29
+ exports.IdentityProvider = IdentityProvider;
30
+ //# sourceMappingURL=identity-provider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"identity-provider.js","sourceRoot":"","sources":["../../../src/rules/providers/identity-provider.ts"],"names":[],"mappings":";;;AAGA,MAAa,gBAAgB;IAC3B,YAAoB,MAA8B;QAA9B,WAAM,GAAN,MAAM,CAAwB;IAAG,CAAC;IAEtD,KAAK,CAAC,OAAO,CAAC,QAAqB;QACjC,QAAQ,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;YAC3B,KAAK,cAAc;gBACjB,OAAO,MAAM,QAAQ,CAAC,eAAe,EAAE,CAAA;YACzC,KAAK,UAAU;gBACb,OAAO,MAAM,QAAQ,CAAC,WAAW,EAAE,CAAA;YACrC,KAAK,qBAAqB;gBACxB,OAAO,MAAM,QAAQ,CAAC,sBAAsB,EAAE,CAAA;YAChD,KAAK,kBAAkB;gBACrB,OAAO,MAAM,QAAQ,CAAC,mBAAmB,EAAE,CAAA;YAC7C,KAAK,mBAAmB;gBACtB,OAAO,MAAM,QAAQ,CAAC,oBAAoB,EAAE,CAAA;YAC9C,KAAK,SAAS;gBACZ,OAAO,MAAM,QAAQ,CAAC,UAAU,EAAE,CAAA;YACpC,KAAK,kBAAkB;gBACrB,OAAO,MAAM,QAAQ,CAAC,mBAAmB,EAAE,CAAA;YAC7C;gBACE,MAAM,IAAI,KAAK,CAAC,mBAAmB,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAA;QAC5D,CAAC;IACH,CAAC;CACF;AAvBD,4CAuBC"}
@@ -0,0 +1,7 @@
1
+ import { ProviderConfig } from './provider';
2
+ export type ViolationRule = {
3
+ message: string;
4
+ cause: string;
5
+ providers: ProviderConfig[];
6
+ };
7
+ //# sourceMappingURL=violation-rule.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"violation-rule.d.ts","sourceRoot":"","sources":["../../src/rules/violation-rule.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAA;AAE3C,MAAM,MAAM,aAAa,GAAG;IAC1B,OAAO,EAAE,MAAM,CAAA;IACf,KAAK,EAAE,MAAM,CAAA;IACb,SAAS,EAAE,cAAc,EAAE,CAAA;CAC5B,CAAA"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=violation-rule.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"violation-rule.js","sourceRoot":"","sources":["../../src/rules/violation-rule.ts"],"names":[],"mappings":""}
@@ -0,0 +1,12 @@
1
+ export interface ViolationReport {
2
+ policyName: string;
3
+ detectorName: string;
4
+ message: string;
5
+ cause: {
6
+ culprit: string;
7
+ snippet: string;
8
+ };
9
+ file: string;
10
+ line?: number;
11
+ }
12
+ //# sourceMappingURL=violation.d.ts.map