@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.
- package/.snitchconfig.json +25 -135
- package/dist/SnitchConfigManager.d.ts +9 -0
- package/dist/SnitchConfigManager.d.ts.map +1 -0
- package/dist/SnitchConfigManager.js +112 -0
- package/dist/SnitchConfigManager.js.map +1 -0
- package/dist/commands/firstRun.d.ts +2 -0
- package/dist/commands/firstRun.d.ts.map +1 -0
- package/dist/commands/firstRun.js +10 -0
- package/dist/commands/firstRun.js.map +1 -0
- package/dist/commands/init/defaultConfigInit.d.ts +2 -0
- package/dist/commands/init/defaultConfigInit.d.ts.map +1 -0
- package/dist/commands/init/defaultConfigInit.js +53 -0
- package/dist/commands/init/defaultConfigInit.js.map +1 -0
- package/dist/commands/init/downloadedConfigInit.d.ts +3 -0
- package/dist/commands/init/downloadedConfigInit.d.ts.map +1 -0
- package/dist/commands/init/downloadedConfigInit.js +80 -0
- package/dist/commands/init/downloadedConfigInit.js.map +1 -0
- package/dist/commands/init.d.ts +1 -1
- package/dist/commands/init.d.ts.map +1 -1
- package/dist/commands/init.js +11 -12
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/prepare.d.ts +2 -0
- package/dist/commands/prepare.d.ts.map +1 -0
- package/dist/commands/prepare.js +61 -0
- package/dist/commands/prepare.js.map +1 -0
- package/dist/common/fs.d.ts +1 -0
- package/dist/common/fs.d.ts.map +1 -0
- package/dist/common/fs.js +2 -0
- package/dist/common/fs.js.map +1 -0
- package/dist/common/index.d.ts +2 -0
- package/dist/common/index.d.ts.map +1 -0
- package/dist/common/index.js +18 -0
- package/dist/common/index.js.map +1 -0
- package/dist/common/json.d.ts +21 -0
- package/dist/common/json.d.ts.map +1 -0
- package/dist/common/json.js +41 -0
- package/dist/common/json.js.map +1 -0
- package/dist/common/strings.d.ts +8 -0
- package/dist/common/strings.d.ts.map +1 -0
- package/dist/common/strings.js +15 -0
- package/dist/common/strings.js.map +1 -0
- package/dist/config/policy-loader.d.ts +4 -0
- package/dist/config/policy-loader.d.ts.map +1 -0
- package/dist/config/policy-loader.js +21 -0
- package/dist/config/policy-loader.js.map +1 -0
- package/dist/datamodel/commands.d.ts +25 -0
- package/dist/datamodel/commands.d.ts.map +1 -0
- package/dist/datamodel/commands.js +31 -0
- package/dist/datamodel/commands.js.map +1 -0
- package/dist/datamodel/common.d.ts +11 -0
- package/dist/datamodel/common.d.ts.map +1 -0
- package/dist/datamodel/common.js +3 -0
- package/dist/datamodel/common.js.map +1 -0
- package/dist/datamodel/errors.d.ts +16 -0
- package/dist/datamodel/errors.d.ts.map +1 -0
- package/dist/datamodel/errors.js +51 -0
- package/dist/datamodel/errors.js.map +1 -0
- package/dist/datamodel/index.d.ts +9 -0
- package/dist/datamodel/index.d.ts.map +1 -0
- package/dist/datamodel/index.js +25 -0
- package/dist/datamodel/index.js.map +1 -0
- package/dist/datamodel/internal-configs.d.ts +14 -0
- package/dist/datamodel/internal-configs.d.ts.map +1 -0
- package/dist/datamodel/internal-configs.js +3 -0
- package/dist/datamodel/internal-configs.js.map +1 -0
- package/dist/datamodel/public-configs.d.ts +27 -0
- package/dist/datamodel/public-configs.d.ts.map +1 -0
- package/dist/datamodel/public-configs.js +3 -0
- package/dist/datamodel/public-configs.js.map +1 -0
- package/dist/datamodel/snitch-configuration.d.ts +16 -0
- package/dist/datamodel/snitch-configuration.d.ts.map +1 -0
- package/dist/datamodel/snitch-configuration.js +32 -0
- package/dist/datamodel/snitch-configuration.js.map +1 -0
- package/dist/datamodel/typeguards.d.ts +3 -0
- package/dist/datamodel/typeguards.d.ts.map +1 -0
- package/dist/datamodel/typeguards.js +7 -0
- package/dist/datamodel/typeguards.js.map +1 -0
- package/dist/datamodel/typescript-specific.d.ts +7 -0
- package/dist/datamodel/typescript-specific.d.ts.map +1 -0
- package/dist/datamodel/typescript-specific.js +11 -0
- package/dist/datamodel/typescript-specific.js.map +1 -0
- package/dist/index.d.ts +2 -8
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -17
- package/dist/index.js.map +1 -1
- package/dist/reporting/violation-reporter.d.ts +4 -0
- package/dist/reporting/violation-reporter.d.ts.map +1 -0
- package/dist/reporting/violation-reporter.js +45 -0
- package/dist/reporting/violation-reporter.js.map +1 -0
- package/dist/rules/policies/code-should-have-declarations.d.ts +3 -0
- package/dist/rules/policies/code-should-have-declarations.d.ts.map +1 -0
- package/dist/rules/policies/code-should-have-declarations.js +15 -0
- package/dist/rules/policies/code-should-have-declarations.js.map +1 -0
- package/dist/rules/policies/keep-tests-clean.d.ts +3 -0
- package/dist/rules/policies/keep-tests-clean.d.ts.map +1 -0
- package/dist/rules/policies/keep-tests-clean.js +21 -0
- package/dist/rules/policies/keep-tests-clean.js.map +1 -0
- package/dist/rules/policies/no-vars.d.ts +3 -0
- package/dist/rules/policies/no-vars.d.ts.map +1 -0
- package/dist/rules/policies/no-vars.js +19 -0
- package/dist/rules/policies/no-vars.js.map +1 -0
- package/dist/rules/policy-executor.d.ts +5 -0
- package/dist/rules/policy-executor.d.ts.map +1 -0
- package/dist/rules/policy-executor.js +10 -0
- package/dist/rules/policy-executor.js.map +1 -0
- package/dist/rules/policy.d.ts +7 -0
- package/dist/rules/policy.d.ts.map +1 -0
- package/dist/rules/policy.js +3 -0
- package/dist/rules/policy.js.map +1 -0
- package/dist/rules/provider-executor.d.ts +5 -0
- package/dist/rules/provider-executor.d.ts.map +1 -0
- package/dist/rules/provider-executor.js +105 -0
- package/dist/rules/provider-executor.js.map +1 -0
- package/dist/rules/provider.d.ts +26 -0
- package/dist/rules/provider.d.ts.map +1 -0
- package/dist/rules/provider.js +3 -0
- package/dist/rules/provider.js.map +1 -0
- package/dist/rules/providers/filter-by-declaration-type-provider.d.ts +8 -0
- package/dist/rules/providers/filter-by-declaration-type-provider.d.ts.map +1 -0
- package/dist/rules/providers/filter-by-declaration-type-provider.js +15 -0
- package/dist/rules/providers/filter-by-declaration-type-provider.js.map +1 -0
- package/dist/rules/providers/filter-by-file-provider.d.ts +8 -0
- package/dist/rules/providers/filter-by-file-provider.d.ts.map +1 -0
- package/dist/rules/providers/filter-by-file-provider.js +16 -0
- package/dist/rules/providers/filter-by-file-provider.js.map +1 -0
- package/dist/rules/providers/filter-exclude-function-names-provider.d.ts +8 -0
- package/dist/rules/providers/filter-exclude-function-names-provider.d.ts.map +1 -0
- package/dist/rules/providers/filter-exclude-function-names-provider.js +15 -0
- package/dist/rules/providers/filter-exclude-function-names-provider.js.map +1 -0
- package/dist/rules/providers/filter-has-literal-arguments-provider.d.ts +8 -0
- package/dist/rules/providers/filter-has-literal-arguments-provider.d.ts.map +1 -0
- package/dist/rules/providers/filter-has-literal-arguments-provider.js +26 -0
- package/dist/rules/providers/filter-has-literal-arguments-provider.js.map +1 -0
- package/dist/rules/providers/identity-provider.d.ts +8 -0
- package/dist/rules/providers/identity-provider.d.ts.map +1 -0
- package/dist/rules/providers/identity-provider.js +30 -0
- package/dist/rules/providers/identity-provider.js.map +1 -0
- package/dist/rules/violation-rule.d.ts +7 -0
- package/dist/rules/violation-rule.d.ts.map +1 -0
- package/dist/rules/violation-rule.js +3 -0
- package/dist/rules/violation-rule.js.map +1 -0
- package/dist/rules/violation.d.ts +12 -0
- package/dist/rules/violation.d.ts.map +1 -0
- package/dist/rules/violation.js +3 -0
- package/dist/rules/violation.js.map +1 -0
- package/dist/snitch.js +114 -44
- package/dist/snitch.js.map +1 -1
- package/dist/utils/AstAnalysis.d.ts +28 -0
- package/dist/utils/AstAnalysis.d.ts.map +1 -0
- package/dist/utils/AstAnalysis.js +117 -0
- package/dist/utils/AstAnalysis.js.map +1 -0
- package/dist/utils/args.d.ts +6 -0
- package/dist/utils/args.d.ts.map +1 -0
- package/dist/utils/args.js +23 -0
- package/dist/utils/args.js.map +1 -0
- package/dist/utils/ast-parser.d.ts +68 -0
- package/dist/utils/ast-parser.d.ts.map +1 -0
- package/dist/utils/ast-parser.js +364 -0
- package/dist/utils/ast-parser.js.map +1 -0
- package/dist/utils/fs.d.ts +8 -0
- package/dist/utils/fs.d.ts.map +1 -0
- package/dist/utils/fs.js +93 -0
- package/dist/utils/fs.js.map +1 -0
- package/dist/utils/pattern-scanner.d.ts +5 -21
- package/dist/utils/pattern-scanner.d.ts.map +1 -1
- package/dist/utils/pattern-scanner.js +13 -17
- package/dist/utils/pattern-scanner.js.map +1 -1
- package/dist/utils/ts-parser.d.ts.map +1 -1
- package/dist/utils/ts-parser.js +5 -12
- package/dist/utils/ts-parser.js.map +1 -1
- package/package.json +15 -6
- package/snitchconfig.schema.json +107 -51
- package/dist/commands/badimports.d.ts +0 -2
- package/dist/commands/badimports.d.ts.map +0 -1
- package/dist/commands/badimports.js +0 -8
- package/dist/commands/badimports.js.map +0 -1
- package/dist/commands/dirtydefaults.d.ts +0 -2
- package/dist/commands/dirtydefaults.d.ts.map +0 -1
- package/dist/commands/dirtydefaults.js +0 -8
- package/dist/commands/dirtydefaults.js.map +0 -1
- package/dist/commands/dm.d.ts +0 -2
- package/dist/commands/dm.d.ts.map +0 -1
- package/dist/commands/dm.js +0 -100
- package/dist/commands/dm.js.map +0 -1
- package/dist/commands/enumerate.d.ts +0 -2
- package/dist/commands/enumerate.d.ts.map +0 -1
- package/dist/commands/enumerate.js +0 -8
- package/dist/commands/enumerate.js.map +0 -1
- package/dist/commands/expectmagic.d.ts +0 -2
- package/dist/commands/expectmagic.d.ts.map +0 -1
- package/dist/commands/expectmagic.js +0 -8
- package/dist/commands/expectmagic.js.map +0 -1
- package/dist/commands/fixtures.d.ts +0 -2
- package/dist/commands/fixtures.d.ts.map +0 -1
- package/dist/commands/fixtures.js +0 -8
- package/dist/commands/fixtures.js.map +0 -1
- package/dist/commands/scan.d.ts +0 -2
- package/dist/commands/scan.d.ts.map +0 -1
- package/dist/commands/scan.js +0 -108
- package/dist/commands/scan.js.map +0 -1
- package/dist/commands/vocab.d.ts +0 -2
- package/dist/commands/vocab.d.ts.map +0 -1
- package/dist/commands/vocab.js +0 -166
- package/dist/commands/vocab.js.map +0 -1
- package/dist/datamodel.d.ts +0 -18
- package/dist/datamodel.d.ts.map +0 -1
- package/dist/datamodel.js +0 -23
- package/dist/datamodel.js.map +0 -1
|
@@ -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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
1
|
+
{"version":3,"file":"violation-rule.js","sourceRoot":"","sources":["../../src/rules/violation-rule.ts"],"names":[],"mappings":""}
|