@fyuld/snitch 2.3.2 → 2.3.4
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/assets/json-schemas/policy.schema.json +125 -0
- package/assets/json-schemas/snitchconfig.schema.json +36 -0
- package/assets/json-schemas/third-party-tool.schema.json +77 -0
- package/dist/commands/firstRun.js +1 -1
- package/dist/commands/firstRun.js.map +1 -1
- package/dist/commands/init.js +2 -2
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/prepare.d.ts.map +1 -1
- package/dist/commands/prepare.js +20 -3
- package/dist/commands/prepare.js.map +1 -1
- package/dist/config/policy-loader.js +1 -1
- package/dist/config/policy-loader.js.map +1 -1
- package/dist/datamodel/snitch-configuration.d.ts +1 -0
- package/dist/datamodel/snitch-configuration.d.ts.map +1 -1
- package/dist/datamodel/snitch-configuration.js.map +1 -1
- package/dist/reporting/violation-reporter.js +1 -1
- package/dist/reporting/violation-reporter.js.map +1 -1
- package/dist/utils/enforcement-software.d.ts.map +1 -1
- package/dist/utils/enforcement-software.js +12 -25
- package/dist/utils/enforcement-software.js.map +1 -1
- package/package.json +2 -3
- package/.snitchconfig.json +0 -34
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"title": "Policy Configuration",
|
|
5
|
+
"description": "Policy definition with violation rules and provider pipelines",
|
|
6
|
+
"properties": {
|
|
7
|
+
"title": {
|
|
8
|
+
"type": "string",
|
|
9
|
+
"description": "Human-readable policy title"
|
|
10
|
+
},
|
|
11
|
+
"violations": {
|
|
12
|
+
"type": "array",
|
|
13
|
+
"description": "Violation rules for this policy",
|
|
14
|
+
"items": {
|
|
15
|
+
"$ref": "#/definitions/ViolationRule"
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
"required": ["title", "violations"],
|
|
20
|
+
"additionalProperties": false,
|
|
21
|
+
"definitions": {
|
|
22
|
+
"ViolationRule": {
|
|
23
|
+
"type": "object",
|
|
24
|
+
"properties": {
|
|
25
|
+
"message": {
|
|
26
|
+
"type": "string",
|
|
27
|
+
"description": "Violation message template with placeholders"
|
|
28
|
+
},
|
|
29
|
+
"cause": {
|
|
30
|
+
"type": "string",
|
|
31
|
+
"description": "Cause description template with placeholders"
|
|
32
|
+
},
|
|
33
|
+
"providers": {
|
|
34
|
+
"type": "array",
|
|
35
|
+
"description": "Provider pipeline for detecting violations",
|
|
36
|
+
"items": {
|
|
37
|
+
"$ref": "#/definitions/ProviderConfig"
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
},
|
|
41
|
+
"required": ["message", "cause", "providers"],
|
|
42
|
+
"additionalProperties": false
|
|
43
|
+
},
|
|
44
|
+
"ProviderConfig": {
|
|
45
|
+
"oneOf": [
|
|
46
|
+
{ "$ref": "#/definitions/IdentityProvider" },
|
|
47
|
+
{ "$ref": "#/definitions/FilterByFileProvider" },
|
|
48
|
+
{ "$ref": "#/definitions/FilterExcludeFunctionNamesProvider" },
|
|
49
|
+
{ "$ref": "#/definitions/FilterHasLiteralArgumentsProvider" },
|
|
50
|
+
{ "$ref": "#/definitions/FilterByDeclarationTypeProvider" }
|
|
51
|
+
]
|
|
52
|
+
},
|
|
53
|
+
"IdentityProvider": {
|
|
54
|
+
"type": "object",
|
|
55
|
+
"properties": {
|
|
56
|
+
"type": { "const": "identity" },
|
|
57
|
+
"source": {
|
|
58
|
+
"enum": [
|
|
59
|
+
"functionInvocations",
|
|
60
|
+
"literals",
|
|
61
|
+
"declarations",
|
|
62
|
+
"typeDeclarations",
|
|
63
|
+
"topLevelFunctions",
|
|
64
|
+
"exports",
|
|
65
|
+
"sequentialGroups"
|
|
66
|
+
]
|
|
67
|
+
}
|
|
68
|
+
},
|
|
69
|
+
"required": ["type", "source"],
|
|
70
|
+
"additionalProperties": false
|
|
71
|
+
},
|
|
72
|
+
"FilterByFileProvider": {
|
|
73
|
+
"type": "object",
|
|
74
|
+
"properties": {
|
|
75
|
+
"type": { "const": "filter-by-file" },
|
|
76
|
+
"patterns": {
|
|
77
|
+
"type": "array",
|
|
78
|
+
"items": { "type": "string" }
|
|
79
|
+
}
|
|
80
|
+
},
|
|
81
|
+
"required": ["type", "patterns"],
|
|
82
|
+
"additionalProperties": false
|
|
83
|
+
},
|
|
84
|
+
"FilterExcludeFunctionNamesProvider": {
|
|
85
|
+
"type": "object",
|
|
86
|
+
"properties": {
|
|
87
|
+
"type": { "const": "filter-exclude-function-names" },
|
|
88
|
+
"names": {
|
|
89
|
+
"type": "array",
|
|
90
|
+
"items": { "type": "string" }
|
|
91
|
+
}
|
|
92
|
+
},
|
|
93
|
+
"required": ["type", "names"],
|
|
94
|
+
"additionalProperties": false
|
|
95
|
+
},
|
|
96
|
+
"FilterHasLiteralArgumentsProvider": {
|
|
97
|
+
"type": "object",
|
|
98
|
+
"properties": {
|
|
99
|
+
"type": { "const": "filter-has-literal-arguments" },
|
|
100
|
+
"literalKinds": {
|
|
101
|
+
"type": "array",
|
|
102
|
+
"items": {
|
|
103
|
+
"enum": ["string", "number", "boolean", "null", "object", "array"]
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
},
|
|
107
|
+
"required": ["type", "literalKinds"],
|
|
108
|
+
"additionalProperties": false
|
|
109
|
+
},
|
|
110
|
+
"FilterByDeclarationTypeProvider": {
|
|
111
|
+
"type": "object",
|
|
112
|
+
"properties": {
|
|
113
|
+
"type": { "const": "filter-by-declaration-type" },
|
|
114
|
+
"declarationTypes": {
|
|
115
|
+
"type": "array",
|
|
116
|
+
"items": {
|
|
117
|
+
"enum": ["interface", "type", "enum", "class", "function", "const", "let", "var"]
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
},
|
|
121
|
+
"required": ["type", "declarationTypes"],
|
|
122
|
+
"additionalProperties": false
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"title": "Snitch Configuration",
|
|
4
|
+
"description": "Configuration file for Snitch code quality policies",
|
|
5
|
+
"type": "object",
|
|
6
|
+
"properties": {
|
|
7
|
+
"extends": {
|
|
8
|
+
"type": "string",
|
|
9
|
+
"description": "Base configuration to extend from"
|
|
10
|
+
},
|
|
11
|
+
"sourceDirectory": {
|
|
12
|
+
"type": "string",
|
|
13
|
+
"description": "Directory containing source code to analyze"
|
|
14
|
+
},
|
|
15
|
+
"testsDirectory": {
|
|
16
|
+
"type": "string",
|
|
17
|
+
"description": "Directory containing test files"
|
|
18
|
+
},
|
|
19
|
+
"policies": {
|
|
20
|
+
"type": "object",
|
|
21
|
+
"description": "Policy definitions with provider pipelines",
|
|
22
|
+
"additionalProperties": {
|
|
23
|
+
"$ref": "./policy.schema.json"
|
|
24
|
+
}
|
|
25
|
+
},
|
|
26
|
+
"thirdPartyTools": {
|
|
27
|
+
"type": "array",
|
|
28
|
+
"description": "Third party tools (formatters, test runners, etc.) to install and configure",
|
|
29
|
+
"items": {
|
|
30
|
+
"$ref": "./third-party-tool.schema.json"
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
},
|
|
34
|
+
"required": ["sourceDirectory", "testsDirectory", "policies"],
|
|
35
|
+
"additionalProperties": false
|
|
36
|
+
}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"title": "Third Party Tool Configuration",
|
|
5
|
+
"description": "Configuration for third party tools (formatters, test runners, build tools, etc.)",
|
|
6
|
+
"properties": {
|
|
7
|
+
"title": {
|
|
8
|
+
"type": "string",
|
|
9
|
+
"description": "Human-readable tool name"
|
|
10
|
+
},
|
|
11
|
+
"description": {
|
|
12
|
+
"type": "string",
|
|
13
|
+
"description": "Description of what the tool does"
|
|
14
|
+
},
|
|
15
|
+
"id": {
|
|
16
|
+
"type": "string",
|
|
17
|
+
"description": "Unique identifier for the tool"
|
|
18
|
+
},
|
|
19
|
+
"purpose": {
|
|
20
|
+
"type": "array",
|
|
21
|
+
"description": "List of purposes this tool serves",
|
|
22
|
+
"items": {
|
|
23
|
+
"type": "string"
|
|
24
|
+
}
|
|
25
|
+
},
|
|
26
|
+
"configFilename": {
|
|
27
|
+
"type": "string",
|
|
28
|
+
"description": "The filename to create for this tool's configuration"
|
|
29
|
+
},
|
|
30
|
+
"software": {
|
|
31
|
+
"type": "object",
|
|
32
|
+
"description": "Software package information",
|
|
33
|
+
"properties": {
|
|
34
|
+
"pm": {
|
|
35
|
+
"type": "string",
|
|
36
|
+
"enum": ["npm"],
|
|
37
|
+
"description": "Package manager to use"
|
|
38
|
+
},
|
|
39
|
+
"name": {
|
|
40
|
+
"type": "string",
|
|
41
|
+
"description": "Package name"
|
|
42
|
+
},
|
|
43
|
+
"version": {
|
|
44
|
+
"type": "string",
|
|
45
|
+
"description": "Package version (optional)"
|
|
46
|
+
}
|
|
47
|
+
},
|
|
48
|
+
"required": ["pm", "name"],
|
|
49
|
+
"additionalProperties": false
|
|
50
|
+
},
|
|
51
|
+
"configuration": {
|
|
52
|
+
"oneOf": [
|
|
53
|
+
{
|
|
54
|
+
"type": "string",
|
|
55
|
+
"description": "URI to configuration file (URL or file path)"
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
"type": "object",
|
|
59
|
+
"description": "Inline configuration object"
|
|
60
|
+
}
|
|
61
|
+
]
|
|
62
|
+
},
|
|
63
|
+
"sideEffects": {
|
|
64
|
+
"type": "object",
|
|
65
|
+
"description": "Side effects to apply to project files",
|
|
66
|
+
"properties": {
|
|
67
|
+
"package.json": {
|
|
68
|
+
"type": "object",
|
|
69
|
+
"description": "Modifications to merge into package.json"
|
|
70
|
+
}
|
|
71
|
+
},
|
|
72
|
+
"additionalProperties": false
|
|
73
|
+
}
|
|
74
|
+
},
|
|
75
|
+
"required": ["title", "description", "id", "purpose", "configFilename", "software", "configuration"],
|
|
76
|
+
"additionalProperties": false
|
|
77
|
+
}
|
|
@@ -54,7 +54,7 @@ async function firstRunCommand(projectName, maybeUrl) {
|
|
|
54
54
|
license: 'UNLICENSED',
|
|
55
55
|
};
|
|
56
56
|
fs.writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2), 'utf-8');
|
|
57
|
-
console.log('
|
|
57
|
+
console.log('Created package.json');
|
|
58
58
|
}
|
|
59
59
|
await (0, init_1.initCommand)(maybeUrl);
|
|
60
60
|
await (0, prepare_1.prepareCommand)();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"firstRun.js","sourceRoot":"","sources":["../../src/commands/firstRun.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAMA,0CAqBC;AA3BD,uCAAwB;AACxB,2CAA4B;AAE5B,iCAAoC;AACpC,uCAA0C;AAEnC,KAAK,UAAU,eAAe,CAAC,WAAwB,EAAE,QAAc;IAC5E,MAAM,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,CAAA;IACpD,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,eAAe,CAAC,EAAE,CAAC;QACpC,MAAM,WAAW,GAAG;YAClB,IAAI,EAAE,WAAW;YACjB,OAAO,EAAE,OAAO;YAChB,WAAW,EAAE,EAAE;YACf,IAAI,EAAE,UAAU;YAChB,OAAO,EAAE;gBACP,IAAI,EAAE,2CAA2C;aAClD;YACD,QAAQ,EAAE,EAAE;YACZ,MAAM,EAAE,EAAE;YACV,OAAO,EAAE,YAAY;SACtB,CAAA;QACD,EAAE,CAAC,aAAa,CAAC,eAAe,EAAE,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAA;QAChF,OAAO,CAAC,GAAG,CAAC,
|
|
1
|
+
{"version":3,"file":"firstRun.js","sourceRoot":"","sources":["../../src/commands/firstRun.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAMA,0CAqBC;AA3BD,uCAAwB;AACxB,2CAA4B;AAE5B,iCAAoC;AACpC,uCAA0C;AAEnC,KAAK,UAAU,eAAe,CAAC,WAAwB,EAAE,QAAc;IAC5E,MAAM,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,CAAA;IACpD,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,eAAe,CAAC,EAAE,CAAC;QACpC,MAAM,WAAW,GAAG;YAClB,IAAI,EAAE,WAAW;YACjB,OAAO,EAAE,OAAO;YAChB,WAAW,EAAE,EAAE;YACf,IAAI,EAAE,UAAU;YAChB,OAAO,EAAE;gBACP,IAAI,EAAE,2CAA2C;aAClD;YACD,QAAQ,EAAE,EAAE;YACZ,MAAM,EAAE,EAAE;YACV,OAAO,EAAE,YAAY;SACtB,CAAA;QACD,EAAE,CAAC,aAAa,CAAC,eAAe,EAAE,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAA;QAChF,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAA;IACrC,CAAC;IAED,MAAM,IAAA,kBAAW,EAAC,QAAQ,CAAC,CAAA;IAC3B,MAAM,IAAA,wBAAc,GAAE,CAAA;AACxB,CAAC"}
|
package/dist/commands/init.js
CHANGED
|
@@ -41,7 +41,7 @@ const downloadedConfigInit_1 = require("./init/downloadedConfigInit");
|
|
|
41
41
|
async function initCommand(uri) {
|
|
42
42
|
const targetPath = path.resolve('.snitchconfig.json');
|
|
43
43
|
if (fs.existsSync(targetPath)) {
|
|
44
|
-
console.log('
|
|
44
|
+
console.log('.snitchconfig.json already exists in current directory');
|
|
45
45
|
console.log(` Location: ${targetPath}`);
|
|
46
46
|
console.log('\nNo changes made.');
|
|
47
47
|
return;
|
|
@@ -56,7 +56,7 @@ async function initCommand(uri) {
|
|
|
56
56
|
configContent = (0, defaultConfigInit_1.getBundledConfig)();
|
|
57
57
|
}
|
|
58
58
|
fs.writeFileSync(targetPath, configContent, 'utf-8');
|
|
59
|
-
console.log('
|
|
59
|
+
console.log('Created .snitchconfig.json in current directory');
|
|
60
60
|
console.log(` Location: ${targetPath}`);
|
|
61
61
|
console.log('\nYou can now customize the configuration for your project.');
|
|
62
62
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/commands/init.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAMA,kCAyBC;AA/BD,2CAA4B;AAC5B,uCAAwB;AAExB,gEAA2D;AAC3D,sEAA4E;AAErE,KAAK,UAAU,WAAW,CAAC,GAAS;IACzC,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAA;IAErD,IAAI,EAAE,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;QAC9B,OAAO,CAAC,GAAG,CAAC,
|
|
1
|
+
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/commands/init.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAMA,kCAyBC;AA/BD,2CAA4B;AAC5B,uCAAwB;AAExB,gEAA2D;AAC3D,sEAA4E;AAErE,KAAK,UAAU,WAAW,CAAC,GAAS;IACzC,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAA;IAErD,IAAI,EAAE,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;QAC9B,OAAO,CAAC,GAAG,CAAC,wDAAwD,CAAC,CAAA;QACrE,OAAO,CAAC,GAAG,CAAC,gBAAgB,UAAU,EAAE,CAAC,CAAA;QACzC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAA;QACjC,OAAM;IACR,CAAC;IAED,IAAI,aAAqB,CAAA;IAEzB,IAAI,GAAG,EAAE,CAAC;QACR,OAAO,CAAC,GAAG,CAAC,4BAA4B,GAAG,EAAE,CAAC,CAAA;QAC9C,aAAa,GAAG,MAAM,IAAA,qCAAc,EAAC,GAAG,CAAC,CAAA;QACzC,IAAA,qCAAc,EAAC,aAAa,EAAE,GAAG,CAAC,CAAA;IACpC,CAAC;SAAM,CAAC;QACN,aAAa,GAAG,IAAA,oCAAgB,GAAE,CAAA;IACpC,CAAC;IAED,EAAE,CAAC,aAAa,CAAC,UAAU,EAAE,aAAa,EAAE,OAAO,CAAC,CAAA;IAEpD,OAAO,CAAC,GAAG,CAAC,iDAAiD,CAAC,CAAA;IAC9D,OAAO,CAAC,GAAG,CAAC,eAAe,UAAU,EAAE,CAAC,CAAA;IACxC,OAAO,CAAC,GAAG,CAAC,6DAA6D,CAAC,CAAA;AAC5E,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prepare.d.ts","sourceRoot":"","sources":["../../src/commands/prepare.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"prepare.d.ts","sourceRoot":"","sources":["../../src/commands/prepare.ts"],"names":[],"mappings":"AAQA,wBAAsB,cAAc,IAAI,OAAO,CAAC,IAAI,CAAC,CAqCpD"}
|
package/dist/commands/prepare.js
CHANGED
|
@@ -32,18 +32,22 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
32
32
|
return result;
|
|
33
33
|
};
|
|
34
34
|
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
35
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
39
|
exports.prepareCommand = prepareCommand;
|
|
37
40
|
const fs = __importStar(require("fs"));
|
|
38
41
|
const path = __importStar(require("path"));
|
|
39
42
|
const https = __importStar(require("https"));
|
|
43
|
+
const ajv_1 = __importDefault(require("ajv"));
|
|
40
44
|
const SnitchConfigManager_1 = require("../SnitchConfigManager");
|
|
41
45
|
const enforcement_software_1 = require("../utils/enforcement-software");
|
|
42
46
|
async function prepareCommand() {
|
|
43
47
|
const config = SnitchConfigManager_1.SnitchConfigManager.loadConfig();
|
|
44
48
|
const packageJsonPath = path.resolve('package.json');
|
|
45
49
|
if (!fs.existsSync(packageJsonPath)) {
|
|
46
|
-
console.log('
|
|
50
|
+
console.log('No package.json found. Please run "npm init" first.');
|
|
47
51
|
return;
|
|
48
52
|
}
|
|
49
53
|
const sourceDir = path.resolve(config.sourceDirectory);
|
|
@@ -58,7 +62,7 @@ async function prepareCommand() {
|
|
|
58
62
|
createdDirs.push(config.testsDirectory);
|
|
59
63
|
}
|
|
60
64
|
if (createdDirs.length > 0) {
|
|
61
|
-
console.log('
|
|
65
|
+
console.log('Created directories:');
|
|
62
66
|
createdDirs.forEach((dir) => console.log(` - ${dir}`));
|
|
63
67
|
}
|
|
64
68
|
if (config.thirdPartyTools && config.thirdPartyTools.length > 0) {
|
|
@@ -73,9 +77,11 @@ async function prepareCommand() {
|
|
|
73
77
|
async function resolveThirdPartyTool(entry) {
|
|
74
78
|
if ('$ref' in entry) {
|
|
75
79
|
const url = entry.$ref;
|
|
76
|
-
|
|
80
|
+
const filename = url.substring(url.lastIndexOf('/') + 1);
|
|
81
|
+
console.log(`Fetching configuration: ${filename} from ${url}`);
|
|
77
82
|
const content = await fetchUrl(url);
|
|
78
83
|
const parsed = JSON.parse(content);
|
|
84
|
+
validateThirdPartyTool(parsed, filename);
|
|
79
85
|
return parsed;
|
|
80
86
|
}
|
|
81
87
|
if ('_extends' in entry) {
|
|
@@ -83,6 +89,17 @@ async function resolveThirdPartyTool(entry) {
|
|
|
83
89
|
}
|
|
84
90
|
return entry;
|
|
85
91
|
}
|
|
92
|
+
function validateThirdPartyTool(tool, source) {
|
|
93
|
+
const schemaPath = path.resolve(__dirname, '../../assets/json-schemas/third-party-tool.schema.json');
|
|
94
|
+
const schema = JSON.parse(fs.readFileSync(schemaPath, 'utf-8'));
|
|
95
|
+
const ajv = new ajv_1.default({ allErrors: true, strict: false });
|
|
96
|
+
const validate = ajv.compile(schema);
|
|
97
|
+
if (!validate(tool)) {
|
|
98
|
+
const errors = validate.errors?.map((err) => ` ${err.instancePath || '(root)'}: ${err.message}`).join('\n') ||
|
|
99
|
+
'Unknown validation error';
|
|
100
|
+
throw new Error(`Invalid third party tool configuration in ${source}:\n${errors}`);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
86
103
|
async function fetchUrl(url) {
|
|
87
104
|
return new Promise((resolve, reject) => {
|
|
88
105
|
https
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prepare.js","sourceRoot":"","sources":["../../src/commands/prepare.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"prepare.js","sourceRoot":"","sources":["../../src/commands/prepare.ts"],"names":[],"mappings":"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"}
|
|
@@ -8,7 +8,7 @@ function loadPoliciesFromConfig(config) {
|
|
|
8
8
|
const policies = [];
|
|
9
9
|
for (const [id, policyEntry] of Object.entries(config.policies)) {
|
|
10
10
|
if ('$ref' in policyEntry || '_extends' in policyEntry) {
|
|
11
|
-
console.warn(
|
|
11
|
+
console.warn(`Policy '${id}' uses $ref or _extends which are not yet supported. Skipping.`);
|
|
12
12
|
continue;
|
|
13
13
|
}
|
|
14
14
|
policies.push(convertToPolicyObject(id, policyEntry));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"policy-loader.js","sourceRoot":"","sources":["../../src/config/policy-loader.ts"],"names":[],"mappings":";;AAGA,wDAgBC;AAhBD,SAAgB,sBAAsB,CAAC,MAA2B;IAChE,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QACrB,OAAO,EAAE,CAAA;IACX,CAAC;IAED,MAAM,QAAQ,GAAa,EAAE,CAAA;IAE7B,KAAK,MAAM,CAAC,EAAE,EAAE,WAAW,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC;QAChE,IAAI,MAAM,IAAI,WAAW,IAAI,UAAU,IAAI,WAAW,EAAE,CAAC;YACvD,OAAO,CAAC,IAAI,CAAC,
|
|
1
|
+
{"version":3,"file":"policy-loader.js","sourceRoot":"","sources":["../../src/config/policy-loader.ts"],"names":[],"mappings":";;AAGA,wDAgBC;AAhBD,SAAgB,sBAAsB,CAAC,MAA2B;IAChE,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QACrB,OAAO,EAAE,CAAA;IACX,CAAC;IAED,MAAM,QAAQ,GAAa,EAAE,CAAA;IAE7B,KAAK,MAAM,CAAC,EAAE,EAAE,WAAW,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC;QAChE,IAAI,MAAM,IAAI,WAAW,IAAI,UAAU,IAAI,WAAW,EAAE,CAAC;YACvD,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE,gEAAgE,CAAC,CAAA;YAC3F,SAAQ;QACV,CAAC;QACD,QAAQ,CAAC,IAAI,CAAC,qBAAqB,CAAC,EAAE,EAAE,WAAW,CAAC,CAAC,CAAA;IACvD,CAAC;IAED,OAAO,QAAQ,CAAA;AACjB,CAAC;AAED,SAAS,qBAAqB,CAAC,EAAU,EAAE,MAAoB;IAC7D,OAAO;QACL,EAAE;QACF,KAAK,EAAE,MAAM,CAAC,KAAK;QACnB,UAAU,EAAE,MAAM,CAAC,UAAU;KAC9B,CAAA;AACH,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"snitch-configuration.d.ts","sourceRoot":"","sources":["../../src/datamodel/snitch-configuration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AAC3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAA;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAA;AACvD,OAAO,EAAE,GAAG,EAAE,MAAM,OAAO,CAAA;AAE3B,MAAM,MAAM,YAAY,GAAG;IACzB,KAAK,EAAE,MAAM,CAAA;IACb,UAAU,EAAE,aAAa,EAAE,CAAA;CAC5B,CAAA;AAED,MAAM,MAAM,sBAAsB,CAAC,IAAI,IAAI,IAAI,GAAG;IAAE,IAAI,EAAE,MAAM,CAAA;CAAE,GAAG,CAAC;IAAE,QAAQ,EAAE,MAAM,CAAA;CAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAA;AAE3G,MAAM,MAAM,cAAc,GAAG;IAC3B,KAAK,EAAE,MAAM,CAAA;IACb,WAAW,EAAE,MAAM,CAAA;IACnB,EAAE,EAAE,MAAM,CAAA;IACV,OAAO,EAAE,MAAM,EAAE,CAAA;IACjB,QAAQ,EAAE;QACR,EAAE,EAAE,KAAK,CAAA;QACT,IAAI,EAAE,MAAM,CAAA;QACZ,OAAO,CAAC,EAAE,MAAM,CAAA;KACjB,CAAA;IACD,aAAa,EAAE,GAAG,GAAG,MAAM,CAAA;IAC3B,WAAW,CAAC,EAAE;QACZ,cAAc,CAAC,EAAE,MAAM,CAAA;KACxB,CAAA;CACF,CAAA;AAED,MAAM,MAAM,mBAAmB,GAAG;IAChC,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,eAAe,EAAE,MAAM,CAAA;IACvB,cAAc,EAAE,MAAM,CAAA;IACtB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAA;IAC9C,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,sBAAsB,CAAC,YAAY,CAAC,CAAC,CAAA;IAC9D,eAAe,CAAC,EAAE,sBAAsB,CAAC,cAAc,CAAC,EAAE,CAAA;CAC3D,CAAA;AAED,eAAO,MAAM,yBAAyB,EAAE,UAAU,CAAC,mBAAmB,CAgCrE,CAAA"}
|
|
1
|
+
{"version":3,"file":"snitch-configuration.d.ts","sourceRoot":"","sources":["../../src/datamodel/snitch-configuration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AAC3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAA;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAA;AACvD,OAAO,EAAE,GAAG,EAAE,MAAM,OAAO,CAAA;AAE3B,MAAM,MAAM,YAAY,GAAG;IACzB,KAAK,EAAE,MAAM,CAAA;IACb,UAAU,EAAE,aAAa,EAAE,CAAA;CAC5B,CAAA;AAED,MAAM,MAAM,sBAAsB,CAAC,IAAI,IAAI,IAAI,GAAG;IAAE,IAAI,EAAE,MAAM,CAAA;CAAE,GAAG,CAAC;IAAE,QAAQ,EAAE,MAAM,CAAA;CAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAA;AAE3G,MAAM,MAAM,cAAc,GAAG;IAC3B,KAAK,EAAE,MAAM,CAAA;IACb,WAAW,EAAE,MAAM,CAAA;IACnB,EAAE,EAAE,MAAM,CAAA;IACV,OAAO,EAAE,MAAM,EAAE,CAAA;IACjB,cAAc,EAAE,MAAM,CAAA;IACtB,QAAQ,EAAE;QACR,EAAE,EAAE,KAAK,CAAA;QACT,IAAI,EAAE,MAAM,CAAA;QACZ,OAAO,CAAC,EAAE,MAAM,CAAA;KACjB,CAAA;IACD,aAAa,EAAE,GAAG,GAAG,MAAM,CAAA;IAC3B,WAAW,CAAC,EAAE;QACZ,cAAc,CAAC,EAAE,MAAM,CAAA;KACxB,CAAA;CACF,CAAA;AAED,MAAM,MAAM,mBAAmB,GAAG;IAChC,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,eAAe,EAAE,MAAM,CAAA;IACvB,cAAc,EAAE,MAAM,CAAA;IACtB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAA;IAC9C,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,sBAAsB,CAAC,YAAY,CAAC,CAAC,CAAA;IAC9D,eAAe,CAAC,EAAE,sBAAsB,CAAC,cAAc,CAAC,EAAE,CAAA;CAC3D,CAAA;AAED,eAAO,MAAM,yBAAyB,EAAE,UAAU,CAAC,mBAAmB,CAgCrE,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"snitch-configuration.js","sourceRoot":"","sources":["../../src/datamodel/snitch-configuration.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"snitch-configuration.js","sourceRoot":"","sources":["../../src/datamodel/snitch-configuration.ts"],"names":[],"mappings":";;;AAsCa,QAAA,yBAAyB,GAAoC;IACxE,IAAI,EAAE,QAAQ;IACd,UAAU,EAAE;QACV,OAAO,EAAE;YACP,IAAI,EAAE,QAAQ;YACd,QAAQ,EAAE,IAAI;SACf;QACD,eAAe,EAAE;YACf,IAAI,EAAE,QAAQ;SACf;QACD,cAAc,EAAE;YACd,IAAI,EAAE,QAAQ;SACf;QACD,QAAQ,EAAE;YACR,IAAI,EAAE,QAAQ;YACd,QAAQ,EAAE,EAAE;YACZ,oBAAoB,EAAE,IAAI;YAC1B,QAAQ,EAAE,IAAI;SACf;QACD,QAAQ,EAAE;YACR,IAAI,EAAE,QAAQ;YACd,QAAQ,EAAE,EAAE;YACZ,oBAAoB,EAAE,IAAI;SAC3B;QACD,eAAe,EAAE;YACf,IAAI,EAAE,OAAO;YACb,KAAK,EAAE,EAAS;YAChB,QAAQ,EAAE,IAAI;SACf;KACF;IACD,QAAQ,EAAE,CAAC,iBAAiB,EAAE,gBAAgB,EAAE,UAAU,CAAC;IAC3D,oBAAoB,EAAE,KAAK;CAC5B,CAAA"}
|
|
@@ -4,7 +4,7 @@ exports.reportViolations = reportViolations;
|
|
|
4
4
|
exports.getViolationSummary = getViolationSummary;
|
|
5
5
|
function reportViolations(violations) {
|
|
6
6
|
if (violations.length === 0) {
|
|
7
|
-
console.log('\
|
|
7
|
+
console.log('\nNo violations found\n');
|
|
8
8
|
return;
|
|
9
9
|
}
|
|
10
10
|
// Group violations by file
|
|
@@ -1 +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,
|
|
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,yBAAyB,CAAC,CAAA;QACtC,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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"enforcement-software.d.ts","sourceRoot":"","sources":["../../src/utils/enforcement-software.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAA;
|
|
1
|
+
{"version":3,"file":"enforcement-software.d.ts","sourceRoot":"","sources":["../../src/utils/enforcement-software.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAA;AAQlE,wBAAsB,oBAAoB,CAAC,KAAK,EAAE,cAAc,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CA+BjF"}
|
|
@@ -39,34 +39,28 @@ const path = __importStar(require("path"));
|
|
|
39
39
|
const child_process_1 = require("child_process");
|
|
40
40
|
const https = __importStar(require("https"));
|
|
41
41
|
const json_merge_1 = require("./json-merge");
|
|
42
|
-
const CONFIG_FILENAMES = {
|
|
43
|
-
prettier: '.prettierrc.json',
|
|
44
|
-
jest: 'jest.config.json',
|
|
45
|
-
typescript: 'tsconfig.json',
|
|
46
|
-
};
|
|
47
42
|
async function setupThirdPartyTools(tools) {
|
|
48
|
-
const
|
|
43
|
+
const createdFiles = new Set();
|
|
49
44
|
const allSideEffects = [];
|
|
50
45
|
for (const tool of tools) {
|
|
51
|
-
const {
|
|
46
|
+
const { configFilename, configuration, sideEffects } = tool;
|
|
52
47
|
const configContent = await resolveConfiguration(configuration);
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
48
|
+
if (createdFiles.has(configFilename)) {
|
|
49
|
+
throw new Error(`Duplicate config filename detected: ${configFilename}. Multiple tools are trying to create the same file.`);
|
|
50
|
+
}
|
|
51
|
+
fs.writeFileSync(path.resolve(configFilename), configContent, 'utf-8');
|
|
52
|
+
createdFiles.add(configFilename);
|
|
53
|
+
console.log(`Created ${configFilename}`);
|
|
58
54
|
if (sideEffects) {
|
|
59
55
|
allSideEffects.push(sideEffects);
|
|
60
56
|
}
|
|
61
57
|
}
|
|
62
|
-
if (packages.length > 0) {
|
|
63
|
-
console.log(`📦 Installing ${packages.length} packages: ${packages.join(', ')}`);
|
|
64
|
-
(0, child_process_1.execSync)(`npm install --save-dev ${packages.join(' ')}`, { stdio: 'inherit' });
|
|
65
|
-
console.log(`✓ Installed all packages`);
|
|
66
|
-
}
|
|
67
58
|
for (const sideEffects of allSideEffects) {
|
|
68
59
|
applySideEffects(sideEffects);
|
|
69
60
|
}
|
|
61
|
+
console.log('Running npm install to install packages from package.json...');
|
|
62
|
+
(0, child_process_1.execSync)('npm install', { stdio: 'inherit' });
|
|
63
|
+
console.log('Installed all packages');
|
|
70
64
|
}
|
|
71
65
|
async function resolveConfiguration(source) {
|
|
72
66
|
if (typeof source === 'object') {
|
|
@@ -92,20 +86,13 @@ async function resolveConfiguration(source) {
|
|
|
92
86
|
});
|
|
93
87
|
});
|
|
94
88
|
}
|
|
95
|
-
function getConfigFilename(softwareName) {
|
|
96
|
-
const filename = CONFIG_FILENAMES[softwareName];
|
|
97
|
-
if (!filename) {
|
|
98
|
-
throw new Error(`Unknown third party tool: ${softwareName}. Supported: ${Object.keys(CONFIG_FILENAMES).join(', ')}`);
|
|
99
|
-
}
|
|
100
|
-
return filename;
|
|
101
|
-
}
|
|
102
89
|
function applySideEffects(sideEffects) {
|
|
103
90
|
if (sideEffects['package.json']) {
|
|
104
91
|
const packageJsonPath = path.resolve('package.json');
|
|
105
92
|
const currentPackageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf-8'));
|
|
106
93
|
const mergedPackageJson = (0, json_merge_1.mergeJson)(currentPackageJson, sideEffects['package.json']);
|
|
107
94
|
fs.writeFileSync(packageJsonPath, JSON.stringify(mergedPackageJson, null, 2), 'utf-8');
|
|
108
|
-
console.log('
|
|
95
|
+
console.log('Updated package.json with side effects');
|
|
109
96
|
}
|
|
110
97
|
}
|
|
111
98
|
//# sourceMappingURL=enforcement-software.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"enforcement-software.js","sourceRoot":"","sources":["../../src/utils/enforcement-software.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"enforcement-software.js","sourceRoot":"","sources":["../../src/utils/enforcement-software.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@fyuld/snitch",
|
|
3
|
-
"version": "2.3.
|
|
3
|
+
"version": "2.3.4",
|
|
4
4
|
"description": "Snitch",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -40,8 +40,7 @@
|
|
|
40
40
|
},
|
|
41
41
|
"files": [
|
|
42
42
|
"dist",
|
|
43
|
-
"
|
|
44
|
-
"snitchconfig.schema.json"
|
|
43
|
+
"assets"
|
|
45
44
|
],
|
|
46
45
|
"dependencies": {
|
|
47
46
|
"@fyuld/errors": "^1.1.0",
|
package/.snitchconfig.json
DELETED
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"sourceDirectory": "src",
|
|
3
|
-
"testsDirectory": "test",
|
|
4
|
-
"policies": {
|
|
5
|
-
"keep-tests-clean": {
|
|
6
|
-
"title": "Keep Tests Clean",
|
|
7
|
-
"violations": [
|
|
8
|
-
{
|
|
9
|
-
"message": "Found literal in function call: {functionName}",
|
|
10
|
-
"cause": "{literalValue}",
|
|
11
|
-
"providers": [
|
|
12
|
-
{ "type": "identity", "source": "functionInvocations" },
|
|
13
|
-
{ "type": "filter-by-file", "patterns": ["test/**/*.ts", "**/*.test.ts", "**/*.spec.ts"] },
|
|
14
|
-
{ "type": "filter-exclude-function-names", "names": ["test", "given", "when", "then", "describe", "it"] },
|
|
15
|
-
{ "type": "filter-has-literal-arguments", "literalKinds": ["string", "number"] }
|
|
16
|
-
]
|
|
17
|
-
}
|
|
18
|
-
]
|
|
19
|
-
},
|
|
20
|
-
"no-vars": {
|
|
21
|
-
"title": "No Var Declarations",
|
|
22
|
-
"violations": [
|
|
23
|
-
{
|
|
24
|
-
"message": "Found var declaration: {declarationName}",
|
|
25
|
-
"cause": "{definition}",
|
|
26
|
-
"providers": [
|
|
27
|
-
{ "type": "identity", "source": "declarations" },
|
|
28
|
-
{ "type": "filter-by-declaration-type", "declarationTypes": ["var"] }
|
|
29
|
-
]
|
|
30
|
-
}
|
|
31
|
-
]
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
}
|