@checkdigit/eslint-plugin 7.5.0-PR.93-b62d → 7.6.0-PR.75-5da1

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 (66) hide show
  1. package/dist-mjs/agent/add-assert-import.mjs +58 -0
  2. package/dist-mjs/agent/add-base-path-const.mjs +65 -0
  3. package/dist-mjs/agent/add-base-path-import.mjs +60 -0
  4. package/dist-mjs/agent/add-url-domain.mjs +61 -0
  5. package/dist-mjs/agent/agent-test-wiring.mjs +221 -0
  6. package/dist-mjs/agent/fetch-response-body-json.mjs +146 -0
  7. package/dist-mjs/agent/fetch-response-header-getter.mjs +117 -0
  8. package/dist-mjs/agent/fetch-response-status.mjs +66 -0
  9. package/dist-mjs/agent/fetch-then.mjs +269 -0
  10. package/dist-mjs/agent/fetch.mjs +38 -0
  11. package/dist-mjs/agent/file.mjs +43 -0
  12. package/dist-mjs/agent/fix-function-call-arguments.mjs +153 -0
  13. package/dist-mjs/agent/no-fixture.mjs +361 -0
  14. package/dist-mjs/agent/no-mapped-response.mjs +75 -0
  15. package/dist-mjs/agent/no-service-wrapper.mjs +185 -0
  16. package/dist-mjs/agent/no-status-code.mjs +59 -0
  17. package/dist-mjs/agent/no-unused-function-argument.mjs +79 -0
  18. package/dist-mjs/agent/no-unused-imports.mjs +81 -0
  19. package/dist-mjs/agent/no-unused-service-variable.mjs +74 -0
  20. package/dist-mjs/agent/response-reference.mjs +70 -0
  21. package/dist-mjs/agent/url.mjs +32 -0
  22. package/dist-mjs/index.mjs +146 -4
  23. package/dist-types/agent/add-assert-import.d.ts +4 -0
  24. package/dist-types/agent/add-base-path-const.d.ts +4 -0
  25. package/dist-types/agent/add-base-path-import.d.ts +4 -0
  26. package/dist-types/agent/add-url-domain.d.ts +4 -0
  27. package/dist-types/agent/agent-test-wiring.d.ts +4 -0
  28. package/dist-types/agent/fetch-response-body-json.d.ts +4 -0
  29. package/dist-types/agent/fetch-response-header-getter.d.ts +4 -0
  30. package/dist-types/agent/fetch-response-status.d.ts +4 -0
  31. package/dist-types/agent/fetch-then.d.ts +4 -0
  32. package/dist-types/agent/fetch.d.ts +5 -0
  33. package/dist-types/agent/file.d.ts +7 -0
  34. package/dist-types/agent/fix-function-call-arguments.d.ts +9 -0
  35. package/dist-types/agent/no-fixture.d.ts +4 -0
  36. package/dist-types/agent/no-mapped-response.d.ts +4 -0
  37. package/dist-types/agent/no-service-wrapper.d.ts +4 -0
  38. package/dist-types/agent/no-status-code.d.ts +4 -0
  39. package/dist-types/agent/no-unused-function-argument.d.ts +4 -0
  40. package/dist-types/agent/no-unused-imports.d.ts +4 -0
  41. package/dist-types/agent/no-unused-service-variable.d.ts +4 -0
  42. package/dist-types/agent/response-reference.d.ts +16 -0
  43. package/dist-types/agent/url.d.ts +4 -0
  44. package/package.json +1 -1
  45. package/src/agent/add-assert-import.ts +74 -0
  46. package/src/agent/add-base-path-const.ts +81 -0
  47. package/src/agent/add-base-path-import.ts +69 -0
  48. package/src/agent/add-url-domain.ts +76 -0
  49. package/src/agent/agent-test-wiring.ts +273 -0
  50. package/src/agent/fetch-response-body-json.ts +197 -0
  51. package/src/agent/fetch-response-header-getter.ts +148 -0
  52. package/src/agent/fetch-response-status.ts +87 -0
  53. package/src/agent/fetch-then.ts +357 -0
  54. package/src/agent/fetch.ts +57 -0
  55. package/src/agent/file.ts +42 -0
  56. package/src/agent/fix-function-call-arguments.ts +200 -0
  57. package/src/agent/no-fixture.ts +521 -0
  58. package/src/agent/no-mapped-response.ts +84 -0
  59. package/src/agent/no-service-wrapper.ts +241 -0
  60. package/src/agent/no-status-code.ts +72 -0
  61. package/src/agent/no-unused-function-argument.ts +98 -0
  62. package/src/agent/no-unused-imports.ts +103 -0
  63. package/src/agent/no-unused-service-variable.ts +93 -0
  64. package/src/agent/response-reference.ts +129 -0
  65. package/src/agent/url.ts +32 -0
  66. package/src/index.ts +142 -0
@@ -1,8 +1,28 @@
1
1
  // src/index.ts
2
+ import addUrlDomain, { ruleId as addUrlDomainRuleId } from "./agent/add-url-domain.mjs";
3
+ import agentTestWiring, { ruleId as agentTestWiringRuleId } from "./agent/agent-test-wiring.mjs";
4
+ import fetchResponseBodyJson, { ruleId as fetchResponseBodyJsonRuleId } from "./agent/fetch-response-body-json.mjs";
5
+ import fetchResponseHeaderGetter, {
6
+ ruleId as fetchResponseHeaderGetterRuleId
7
+ } from "./agent/fetch-response-header-getter.mjs";
8
+ import fetchResponseStatus, { ruleId as fetchResponseStatusRuleId } from "./agent/fetch-response-status.mjs";
9
+ import fetchThen, { ruleId as fetchThenRuleId } from "./agent/fetch-then.mjs";
10
+ import fixFunctionCallArguments, {
11
+ ruleId as fixFunctionCallArgumentsRuleId
12
+ } from "./agent/fix-function-call-arguments.mjs";
2
13
  import invalidJsonStringify, { ruleId as invalidJsonStringifyRuleId } from "./invalid-json-stringify.mjs";
3
14
  import noDuplicatedImports, { ruleId as noDuplicatedImportsRuleId } from "./no-duplicated-imports.mjs";
15
+ import noFixture, { ruleId as noFixtureRuleId } from "./agent/no-fixture.mjs";
4
16
  import noLegacyServiceTyping, { ruleId as noLegacyServiceTypingRuleId } from "./no-legacy-service-typing.mjs";
17
+ import noMappedResponse, { ruleId as noMappedResponseRuleId } from "./agent/no-mapped-response.mjs";
5
18
  import noPromiseInstanceMethod, { ruleId as noPromiseInstanceMethodRuleId } from "./no-promise-instance-method.mjs";
19
+ import noServiceWrapper, { ruleId as noServiceWrapperRuleId } from "./agent/no-service-wrapper.mjs";
20
+ import noStatusCode, { ruleId as noStatusCodeRuleId } from "./agent/no-status-code.mjs";
21
+ import noUnusedFunctionArguments, {
22
+ ruleId as noUnusedFunctionArgumentsRuleId
23
+ } from "./agent/no-unused-function-argument.mjs";
24
+ import noUnusedImports, { ruleId as noUnusedImportsRuleId } from "./agent/no-unused-imports.mjs";
25
+ import noUnusedServiceVariables, { ruleId as noUnusedServiceVariablesRuleId } from "./agent/no-unused-service-variable.mjs";
6
26
  import requireFixedServicesImport, {
7
27
  ruleId as requireFixedServicesImportRuleId
8
28
  } from "./require-fixed-services-import.mjs";
@@ -13,6 +33,9 @@ import requireTypeOutOfTypeOnlyImports, {
13
33
  ruleId as requireTypeOutOfTypeOnlyImportsRuleId
14
34
  } from "./require-type-out-of-type-only-imports.mjs";
15
35
  import noServeRuntime, { ruleId as noServeRuntimeRuleId } from "./no-serve-runtime.mjs";
36
+ import addBasePathConst, { ruleId as addBasePathConstRuleId } from "./agent/add-base-path-const.mjs";
37
+ import addBasePathImport, { ruleId as addBasePathImportRuleId } from "./agent/add-base-path-import.mjs";
38
+ import addAssertImport, { ruleId as addAssertImportRuleId } from "./agent/add-assert-import.mjs";
16
39
  import filePathComment from "./file-path-comment.mjs";
17
40
  import noCardNumbers from "./no-card-numbers.mjs";
18
41
  import noSideEffects from "./no-side-effects.mjs";
@@ -38,12 +61,29 @@ var rules = {
38
61
  "object-literal-response": objectLiteralResponse,
39
62
  [invalidJsonStringifyRuleId]: invalidJsonStringify,
40
63
  [noPromiseInstanceMethodRuleId]: noPromiseInstanceMethod,
64
+ [noFixtureRuleId]: noFixture,
65
+ [fetchThenRuleId]: fetchThen,
66
+ [noServiceWrapperRuleId]: noServiceWrapper,
67
+ [noStatusCodeRuleId]: noStatusCode,
68
+ [fetchResponseBodyJsonRuleId]: fetchResponseBodyJson,
69
+ [fetchResponseHeaderGetterRuleId]: fetchResponseHeaderGetter,
70
+ [fetchResponseStatusRuleId]: fetchResponseStatus,
71
+ [addUrlDomainRuleId]: addUrlDomain,
41
72
  [noLegacyServiceTypingRuleId]: noLegacyServiceTyping,
73
+ [noMappedResponseRuleId]: noMappedResponse,
42
74
  [requireResolveFullResponseRuleId]: requireResolveFullResponse,
43
75
  [noDuplicatedImportsRuleId]: noDuplicatedImports,
44
76
  [noServeRuntimeRuleId]: noServeRuntime,
77
+ [addBasePathConstRuleId]: addBasePathConst,
78
+ [addBasePathImportRuleId]: addBasePathImport,
79
+ [addAssertImportRuleId]: addAssertImport,
45
80
  [requireFixedServicesImportRuleId]: requireFixedServicesImport,
46
- [requireTypeOutOfTypeOnlyImportsRuleId]: requireTypeOutOfTypeOnlyImports
81
+ [requireTypeOutOfTypeOnlyImportsRuleId]: requireTypeOutOfTypeOnlyImports,
82
+ [noUnusedFunctionArgumentsRuleId]: noUnusedFunctionArguments,
83
+ [noUnusedServiceVariablesRuleId]: noUnusedServiceVariables,
84
+ [noUnusedImportsRuleId]: noUnusedImports,
85
+ [fixFunctionCallArgumentsRuleId]: fixFunctionCallArguments,
86
+ [agentTestWiringRuleId]: agentTestWiring
47
87
  };
48
88
  var plugin = {
49
89
  rules
@@ -74,7 +114,26 @@ var configs = {
74
114
  [`@checkdigit/${noDuplicatedImportsRuleId}`]: "error",
75
115
  [`@checkdigit/${requireFixedServicesImportRuleId}`]: "error",
76
116
  [`@checkdigit/${requireTypeOutOfTypeOnlyImportsRuleId}`]: "error",
77
- [`@checkdigit/${noServeRuntimeRuleId}`]: "error"
117
+ [`@checkdigit/${noServeRuntimeRuleId}`]: "error",
118
+ // --- agent rules BEGIN ---
119
+ [`@checkdigit/${noMappedResponseRuleId}`]: "off",
120
+ [`@checkdigit/${addUrlDomainRuleId}`]: "off",
121
+ [`@checkdigit/${noFixtureRuleId}`]: "off",
122
+ [`@checkdigit/${noServiceWrapperRuleId}`]: "off",
123
+ [`@checkdigit/${noStatusCodeRuleId}`]: "off",
124
+ [`@checkdigit/${fetchResponseBodyJsonRuleId}`]: "off",
125
+ [`@checkdigit/${fetchResponseHeaderGetterRuleId}`]: "off",
126
+ [`@checkdigit/${fetchResponseStatusRuleId}`]: "off",
127
+ [`@checkdigit/${fetchThenRuleId}`]: "off",
128
+ [`@checkdigit/${noUnusedFunctionArgumentsRuleId}`]: "off",
129
+ [`@checkdigit/${noUnusedServiceVariablesRuleId}`]: "off",
130
+ [`@checkdigit/${noUnusedImportsRuleId}`]: "off",
131
+ [`@checkdigit/${fixFunctionCallArgumentsRuleId}`]: "off",
132
+ [`@checkdigit/${agentTestWiringRuleId}`]: "off",
133
+ [`@checkdigit/${addBasePathConstRuleId}`]: "off",
134
+ [`@checkdigit/${addBasePathImportRuleId}`]: "off",
135
+ [`@checkdigit/${addAssertImportRuleId}`]: "off"
136
+ // --- agent rules END ---
78
137
  }
79
138
  }
80
139
  ],
@@ -103,7 +162,90 @@ var configs = {
103
162
  [`@checkdigit/${noDuplicatedImportsRuleId}`]: "error",
104
163
  [`@checkdigit/${requireFixedServicesImportRuleId}`]: "off",
105
164
  [`@checkdigit/${requireTypeOutOfTypeOnlyImportsRuleId}`]: "error",
106
- [`@checkdigit/${noServeRuntimeRuleId}`]: "off"
165
+ [`@checkdigit/${noServeRuntimeRuleId}`]: "off",
166
+ // --- agent rules BEGIN ---
167
+ [`@checkdigit/${noMappedResponseRuleId}`]: "off",
168
+ [`@checkdigit/${addUrlDomainRuleId}`]: "off",
169
+ [`@checkdigit/${noFixtureRuleId}`]: "off",
170
+ [`@checkdigit/${noServiceWrapperRuleId}`]: "off",
171
+ [`@checkdigit/${noStatusCodeRuleId}`]: "off",
172
+ [`@checkdigit/${fetchResponseBodyJsonRuleId}`]: "off",
173
+ [`@checkdigit/${fetchResponseHeaderGetterRuleId}`]: "off",
174
+ [`@checkdigit/${fetchResponseStatusRuleId}`]: "off",
175
+ [`@checkdigit/${fetchThenRuleId}`]: "off",
176
+ [`@checkdigit/${noUnusedFunctionArgumentsRuleId}`]: "off",
177
+ [`@checkdigit/${noUnusedServiceVariablesRuleId}`]: "off",
178
+ [`@checkdigit/${noUnusedImportsRuleId}`]: "off",
179
+ [`@checkdigit/${fixFunctionCallArgumentsRuleId}`]: "off",
180
+ [`@checkdigit/${agentTestWiringRuleId}`]: "off",
181
+ [`@checkdigit/${addBasePathConstRuleId}`]: "off",
182
+ [`@checkdigit/${addBasePathImportRuleId}`]: "off",
183
+ [`@checkdigit/${addAssertImportRuleId}`]: "off"
184
+ // --- agent rules END ---
185
+ }
186
+ }
187
+ ],
188
+ "agent-phase-1-test": [
189
+ {
190
+ files: ["**/*.spec.ts", "**/*.test.ts", "src/api/v*/index.ts"],
191
+ // eslint-disable-next-line sonarjs/no-duplicate-string
192
+ ignores: ["src/plugin/**"],
193
+ plugins: {
194
+ "@checkdigit": plugin
195
+ },
196
+ rules: {
197
+ [`@checkdigit/${noMappedResponseRuleId}`]: "error",
198
+ [`@checkdigit/${addUrlDomainRuleId}`]: "error",
199
+ [`@checkdigit/${noServiceWrapperRuleId}`]: "error",
200
+ [`@checkdigit/${noStatusCodeRuleId}`]: "error",
201
+ [`@checkdigit/${fetchResponseBodyJsonRuleId}`]: "error",
202
+ [`@checkdigit/${fetchResponseHeaderGetterRuleId}`]: "error",
203
+ [`@checkdigit/${fetchResponseStatusRuleId}`]: "error",
204
+ [`@checkdigit/${fetchThenRuleId}`]: "error",
205
+ [`@checkdigit/${noUnusedFunctionArgumentsRuleId}`]: "error",
206
+ [`@checkdigit/${noUnusedServiceVariablesRuleId}`]: "error",
207
+ [`@checkdigit/${noUnusedImportsRuleId}`]: "error",
208
+ [`@checkdigit/${fixFunctionCallArgumentsRuleId}`]: "error",
209
+ [`@checkdigit/${addBasePathConstRuleId}`]: "error",
210
+ [`@checkdigit/${addBasePathImportRuleId}`]: "error",
211
+ [`@checkdigit/${addAssertImportRuleId}`]: "error",
212
+ [`@checkdigit/${noFixtureRuleId}`]: "error"
213
+ }
214
+ },
215
+ {
216
+ files: ["**/*.spec.ts"],
217
+ ignores: ["src/plugin/**"],
218
+ plugins: {
219
+ "@checkdigit": plugin
220
+ },
221
+ rules: {
222
+ [`@checkdigit/${agentTestWiringRuleId}`]: "error"
223
+ }
224
+ }
225
+ ],
226
+ "agent-phase-2-production": [
227
+ {
228
+ files: ["**/*.ts"],
229
+ ignores: ["src/plugin/**"],
230
+ plugins: {
231
+ "@checkdigit": plugin
232
+ },
233
+ rules: {
234
+ [`@checkdigit/${noMappedResponseRuleId}`]: "error",
235
+ [`@checkdigit/${addUrlDomainRuleId}`]: "error",
236
+ [`@checkdigit/${noServiceWrapperRuleId}`]: "error",
237
+ [`@checkdigit/${noStatusCodeRuleId}`]: "error",
238
+ [`@checkdigit/${fetchResponseBodyJsonRuleId}`]: "error",
239
+ [`@checkdigit/${fetchResponseHeaderGetterRuleId}`]: "error",
240
+ [`@checkdigit/${fetchResponseStatusRuleId}`]: "error",
241
+ [`@checkdigit/${fetchThenRuleId}`]: "error",
242
+ [`@checkdigit/${noUnusedFunctionArgumentsRuleId}`]: "error",
243
+ [`@checkdigit/${noUnusedServiceVariablesRuleId}`]: "error",
244
+ [`@checkdigit/${noUnusedImportsRuleId}`]: "error",
245
+ [`@checkdigit/${fixFunctionCallArgumentsRuleId}`]: "error",
246
+ [`@checkdigit/${addBasePathConstRuleId}`]: "error",
247
+ [`@checkdigit/${addBasePathImportRuleId}`]: "error",
248
+ [`@checkdigit/${addAssertImportRuleId}`]: "error"
107
249
  }
108
250
  }
109
251
  ]
@@ -116,4 +258,4 @@ var src_default = defaultToExport;
116
258
  export {
117
259
  src_default as default
118
260
  };
119
- //# sourceMappingURL=data:application/json;base64,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
261
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2luZGV4LnRzIl0sCiAgIm1hcHBpbmdzIjogIjtBQVVBLE9BQU8sZ0JBQWdCLFVBQVUsMEJBQTBCO0FBQzNELE9BQU8sbUJBQW1CLFVBQVUsNkJBQTZCO0FBQ2pFLE9BQU8seUJBQXlCLFVBQVUsbUNBQW1DO0FBQzdFLE9BQU87QUFBQSxFQUNMLFVBQVU7QUFBQSxPQUNMO0FBQ1AsT0FBTyx1QkFBdUIsVUFBVSxpQ0FBaUM7QUFDekUsT0FBTyxhQUFhLFVBQVUsdUJBQXVCO0FBQ3JELE9BQU87QUFBQSxFQUNMLFVBQVU7QUFBQSxPQUNMO0FBQ1AsT0FBTyx3QkFBd0IsVUFBVSxrQ0FBa0M7QUFDM0UsT0FBTyx1QkFBdUIsVUFBVSxpQ0FBaUM7QUFDekUsT0FBTyxhQUFhLFVBQVUsdUJBQXVCO0FBQ3JELE9BQU8seUJBQXlCLFVBQVUsbUNBQW1DO0FBQzdFLE9BQU8sb0JBQW9CLFVBQVUsOEJBQThCO0FBQ25FLE9BQU8sMkJBQTJCLFVBQVUscUNBQXFDO0FBQ2pGLE9BQU8sb0JBQW9CLFVBQVUsOEJBQThCO0FBQ25FLE9BQU8sZ0JBQWdCLFVBQVUsMEJBQTBCO0FBQzNELE9BQU87QUFBQSxFQUNMLFVBQVU7QUFBQSxPQUNMO0FBQ1AsT0FBTyxtQkFBbUIsVUFBVSw2QkFBNkI7QUFDakUsT0FBTyw0QkFBNEIsVUFBVSxzQ0FBc0M7QUFDbkYsT0FBTztBQUFBLEVBQ0wsVUFBVTtBQUFBLE9BQ0w7QUFDUCxPQUFPO0FBQUEsRUFDTCxVQUFVO0FBQUEsT0FDTDtBQUNQLE9BQU87QUFBQSxFQUNMLFVBQVU7QUFBQSxPQUNMO0FBQ1AsT0FBTyxrQkFBa0IsVUFBVSw0QkFBNEI7QUFDL0QsT0FBTyxvQkFBb0IsVUFBVSw4QkFBOEI7QUFDbkUsT0FBTyxxQkFBcUIsVUFBVSwrQkFBK0I7QUFDckUsT0FBTyxtQkFBbUIsVUFBVSw2QkFBNkI7QUFDakUsT0FBTyxxQkFBcUI7QUFDNUIsT0FBTyxtQkFBbUI7QUFDMUIsT0FBTyxtQkFBbUI7QUFDMUIsT0FBTyxvQkFBb0I7QUFDM0IsT0FBTyxrQkFBa0I7QUFDekIsT0FBTyxZQUFZO0FBQ25CLE9BQU8sc0JBQXNCO0FBQzdCLE9BQU8sMkJBQTJCO0FBQ2xDLE9BQU8sa0JBQWtCO0FBQ3pCLE9BQU8seUNBQXlDO0FBQ2hELE9BQU8seUJBQXlCO0FBRWhDLElBQU0sUUFBc0Q7QUFBQSxFQUMxRCxxQkFBcUI7QUFBQSxFQUNyQixtQkFBbUI7QUFBQSxFQUNuQixxQkFBcUI7QUFBQSxFQUNyQixXQUFXO0FBQUEsRUFDWCx5QkFBeUI7QUFBQSxFQUN6QixrQkFBa0I7QUFBQSxFQUNsQixzQkFBc0I7QUFBQSxFQUN0QixtQkFBbUI7QUFBQSxFQUNuQiw4QkFBOEI7QUFBQSxFQUM5QiwyQ0FBMkM7QUFBQSxFQUMzQywyQkFBMkI7QUFBQSxFQUMzQixDQUFDLDBCQUEwQixHQUFHO0FBQUEsRUFDOUIsQ0FBQyw2QkFBNkIsR0FBRztBQUFBLEVBQ2pDLENBQUMsZUFBZSxHQUFHO0FBQUEsRUFDbkIsQ0FBQyxlQUFlLEdBQUc7QUFBQSxFQUNuQixDQUFDLHNCQUFzQixHQUFHO0FBQUEsRUFDMUIsQ0FBQyxrQkFBa0IsR0FBRztBQUFBLEVBQ3RCLENBQUMsMkJBQTJCLEdBQUc7QUFBQSxFQUMvQixDQUFDLCtCQUErQixHQUFHO0FBQUEsRUFDbkMsQ0FBQyx5QkFBeUIsR0FBRztBQUFBLEVBQzdCLENBQUMsa0JBQWtCLEdBQUc7QUFBQSxFQUN0QixDQUFDLDJCQUEyQixHQUFHO0FBQUEsRUFDL0IsQ0FBQyxzQkFBc0IsR0FBRztBQUFBLEVBQzFCLENBQUMsZ0NBQWdDLEdBQUc7QUFBQSxFQUNwQyxDQUFDLHlCQUF5QixHQUFHO0FBQUEsRUFDN0IsQ0FBQyxvQkFBb0IsR0FBRztBQUFBLEVBQ3hCLENBQUMsc0JBQXNCLEdBQUc7QUFBQSxFQUMxQixDQUFDLHVCQUF1QixHQUFHO0FBQUEsRUFDM0IsQ0FBQyxxQkFBcUIsR0FBRztBQUFBLEVBQ3pCLENBQUMsZ0NBQWdDLEdBQUc7QUFBQSxFQUNwQyxDQUFDLHFDQUFxQyxHQUFHO0FBQUEsRUFDekMsQ0FBQywrQkFBK0IsR0FBRztBQUFBLEVBQ25DLENBQUMsOEJBQThCLEdBQUc7QUFBQSxFQUNsQyxDQUFDLHFCQUFxQixHQUFHO0FBQUEsRUFDekIsQ0FBQyw4QkFBOEIsR0FBRztBQUFBLEVBQ2xDLENBQUMscUJBQXFCLEdBQUc7QUFDM0I7QUFFQSxJQUFNLFNBQXFDO0FBQUEsRUFDekM7QUFDRjtBQUVBLElBQU0sVUFBd0Q7QUFBQSxFQUM1RCxLQUFLO0FBQUEsSUFDSDtBQUFBLE1BQ0UsT0FBTyxDQUFDLFNBQVM7QUFBQSxNQUNqQixTQUFTO0FBQUEsUUFDUCxlQUFlO0FBQUEsTUFDakI7QUFBQSxNQUNBLE9BQU87QUFBQSxRQUNMLCtCQUErQjtBQUFBLFFBQy9CLGlDQUFpQztBQUFBLFFBQ2pDLGlDQUFpQztBQUFBLFFBQ2pDLHVCQUF1QjtBQUFBLFFBQ3ZCLHFDQUFxQztBQUFBLFFBQ3JDLGtDQUFrQztBQUFBLFFBQ2xDLCtCQUErQixDQUFDLFNBQVMsRUFBRSxxQkFBcUIsQ0FBQyxVQUFVLFNBQVMsT0FBTyxXQUFXLEVBQUUsQ0FBQztBQUFBLFFBQ3pHLDBDQUEwQztBQUFBLFFBQzFDLHVEQUF1RDtBQUFBLFFBQ3ZELHVDQUF1QztBQUFBLFFBQ3ZDLDhCQUE4QjtBQUFBLFFBQzlCLENBQUMsZUFBZSwwQkFBMEIsRUFBRSxHQUFHO0FBQUEsUUFDL0MsQ0FBQyxlQUFlLDZCQUE2QixFQUFFLEdBQUc7QUFBQSxRQUNsRCxDQUFDLGVBQWUsMkJBQTJCLEVBQUUsR0FBRztBQUFBLFFBQ2hELENBQUMsZUFBZSxnQ0FBZ0MsRUFBRSxHQUFHO0FBQUEsUUFDckQsQ0FBQyxlQUFlLHlCQUF5QixFQUFFLEdBQUc7QUFBQSxRQUM5QyxDQUFDLGVBQWUsZ0NBQWdDLEVBQUUsR0FBRztBQUFBLFFBQ3JELENBQUMsZUFBZSxxQ0FBcUMsRUFBRSxHQUFHO0FBQUEsUUFDMUQsQ0FBQyxlQUFlLG9CQUFvQixFQUFFLEdBQUc7QUFBQTtBQUFBLFFBRXpDLENBQUMsZUFBZSxzQkFBc0IsRUFBRSxHQUFHO0FBQUEsUUFDM0MsQ0FBQyxlQUFlLGtCQUFrQixFQUFFLEdBQUc7QUFBQSxRQUN2QyxDQUFDLGVBQWUsZUFBZSxFQUFFLEdBQUc7QUFBQSxRQUNwQyxDQUFDLGVBQWUsc0JBQXNCLEVBQUUsR0FBRztBQUFBLFFBQzNDLENBQUMsZUFBZSxrQkFBa0IsRUFBRSxHQUFHO0FBQUEsUUFDdkMsQ0FBQyxlQUFlLDJCQUEyQixFQUFFLEdBQUc7QUFBQSxRQUNoRCxDQUFDLGVBQWUsK0JBQStCLEVBQUUsR0FBRztBQUFBLFFBQ3BELENBQUMsZUFBZSx5QkFBeUIsRUFBRSxHQUFHO0FBQUEsUUFDOUMsQ0FBQyxlQUFlLGVBQWUsRUFBRSxHQUFHO0FBQUEsUUFDcEMsQ0FBQyxlQUFlLCtCQUErQixFQUFFLEdBQUc7QUFBQSxRQUNwRCxDQUFDLGVBQWUsOEJBQThCLEVBQUUsR0FBRztBQUFBLFFBQ25ELENBQUMsZUFBZSxxQkFBcUIsRUFBRSxHQUFHO0FBQUEsUUFDMUMsQ0FBQyxlQUFlLDhCQUE4QixFQUFFLEdBQUc7QUFBQSxRQUNuRCxDQUFDLGVBQWUscUJBQXFCLEVBQUUsR0FBRztBQUFBLFFBQzFDLENBQUMsZUFBZSxzQkFBc0IsRUFBRSxHQUFHO0FBQUEsUUFDM0MsQ0FBQyxlQUFlLHVCQUF1QixFQUFFLEdBQUc7QUFBQSxRQUM1QyxDQUFDLGVBQWUscUJBQXFCLEVBQUUsR0FBRztBQUFBO0FBQUEsTUFFNUM7QUFBQSxJQUNGO0FBQUEsRUFDRjtBQUFBLEVBQ0EsYUFBYTtBQUFBLElBQ1g7QUFBQSxNQUNFLE9BQU8sQ0FBQyxTQUFTO0FBQUEsTUFDakIsU0FBUztBQUFBLFFBQ1AsZUFBZTtBQUFBLE1BQ2pCO0FBQUEsTUFDQSxPQUFPO0FBQUEsUUFDTCwrQkFBK0I7QUFBQSxRQUMvQixpQ0FBaUM7QUFBQSxRQUNqQyxpQ0FBaUM7QUFBQSxRQUNqQyx1QkFBdUI7QUFBQSxRQUN2QixxQ0FBcUM7QUFBQSxRQUNyQyxrQ0FBa0M7QUFBQSxRQUNsQywrQkFBK0I7QUFBQSxRQUMvQiwwQ0FBMEM7QUFBQSxRQUMxQyx1REFBdUQ7QUFBQSxRQUN2RCx1Q0FBdUM7QUFBQSxRQUN2Qyw4QkFBOEI7QUFBQSxRQUM5QixDQUFDLGVBQWUsMEJBQTBCLEVBQUUsR0FBRztBQUFBLFFBQy9DLENBQUMsZUFBZSw2QkFBNkIsRUFBRSxHQUFHO0FBQUEsUUFDbEQsQ0FBQyxlQUFlLDJCQUEyQixFQUFFLEdBQUc7QUFBQSxRQUNoRCxDQUFDLGVBQWUsZ0NBQWdDLEVBQUUsR0FBRztBQUFBLFFBQ3JELENBQUMsZUFBZSx5QkFBeUIsRUFBRSxHQUFHO0FBQUEsUUFDOUMsQ0FBQyxlQUFlLGdDQUFnQyxFQUFFLEdBQUc7QUFBQSxRQUNyRCxDQUFDLGVBQWUscUNBQXFDLEVBQUUsR0FBRztBQUFBLFFBQzFELENBQUMsZUFBZSxvQkFBb0IsRUFBRSxHQUFHO0FBQUE7QUFBQSxRQUV6QyxDQUFDLGVBQWUsc0JBQXNCLEVBQUUsR0FBRztBQUFBLFFBQzNDLENBQUMsZUFBZSxrQkFBa0IsRUFBRSxHQUFHO0FBQUEsUUFDdkMsQ0FBQyxlQUFlLGVBQWUsRUFBRSxHQUFHO0FBQUEsUUFDcEMsQ0FBQyxlQUFlLHNCQUFzQixFQUFFLEdBQUc7QUFBQSxRQUMzQyxDQUFDLGVBQWUsa0JBQWtCLEVBQUUsR0FBRztBQUFBLFFBQ3ZDLENBQUMsZUFBZSwyQkFBMkIsRUFBRSxHQUFHO0FBQUEsUUFDaEQsQ0FBQyxlQUFlLCtCQUErQixFQUFFLEdBQUc7QUFBQSxRQUNwRCxDQUFDLGVBQWUseUJBQXlCLEVBQUUsR0FBRztBQUFBLFFBQzlDLENBQUMsZUFBZSxlQUFlLEVBQUUsR0FBRztBQUFBLFFBQ3BDLENBQUMsZUFBZSwrQkFBK0IsRUFBRSxHQUFHO0FBQUEsUUFDcEQsQ0FBQyxlQUFlLDhCQUE4QixFQUFFLEdBQUc7QUFBQSxRQUNuRCxDQUFDLGVBQWUscUJBQXFCLEVBQUUsR0FBRztBQUFBLFFBQzFDLENBQUMsZUFBZSw4QkFBOEIsRUFBRSxHQUFHO0FBQUEsUUFDbkQsQ0FBQyxlQUFlLHFCQUFxQixFQUFFLEdBQUc7QUFBQSxRQUMxQyxDQUFDLGVBQWUsc0JBQXNCLEVBQUUsR0FBRztBQUFBLFFBQzNDLENBQUMsZUFBZSx1QkFBdUIsRUFBRSxHQUFHO0FBQUEsUUFDNUMsQ0FBQyxlQUFlLHFCQUFxQixFQUFFLEdBQUc7QUFBQTtBQUFBLE1BRTVDO0FBQUEsSUFDRjtBQUFBLEVBQ0Y7QUFBQSxFQUNBLHNCQUFzQjtBQUFBLElBQ3BCO0FBQUEsTUFDRSxPQUFPLENBQUMsZ0JBQWdCLGdCQUFnQixxQkFBcUI7QUFBQTtBQUFBLE1BRTdELFNBQVMsQ0FBQyxlQUFlO0FBQUEsTUFDekIsU0FBUztBQUFBLFFBQ1AsZUFBZTtBQUFBLE1BQ2pCO0FBQUEsTUFDQSxPQUFPO0FBQUEsUUFDTCxDQUFDLGVBQWUsc0JBQXNCLEVBQUUsR0FBRztBQUFBLFFBQzNDLENBQUMsZUFBZSxrQkFBa0IsRUFBRSxHQUFHO0FBQUEsUUFDdkMsQ0FBQyxlQUFlLHNCQUFzQixFQUFFLEdBQUc7QUFBQSxRQUMzQyxDQUFDLGVBQWUsa0JBQWtCLEVBQUUsR0FBRztBQUFBLFFBQ3ZDLENBQUMsZUFBZSwyQkFBMkIsRUFBRSxHQUFHO0FBQUEsUUFDaEQsQ0FBQyxlQUFlLCtCQUErQixFQUFFLEdBQUc7QUFBQSxRQUNwRCxDQUFDLGVBQWUseUJBQXlCLEVBQUUsR0FBRztBQUFBLFFBQzlDLENBQUMsZUFBZSxlQUFlLEVBQUUsR0FBRztBQUFBLFFBQ3BDLENBQUMsZUFBZSwrQkFBK0IsRUFBRSxHQUFHO0FBQUEsUUFDcEQsQ0FBQyxlQUFlLDhCQUE4QixFQUFFLEdBQUc7QUFBQSxRQUNuRCxDQUFDLGVBQWUscUJBQXFCLEVBQUUsR0FBRztBQUFBLFFBQzFDLENBQUMsZUFBZSw4QkFBOEIsRUFBRSxHQUFHO0FBQUEsUUFDbkQsQ0FBQyxlQUFlLHNCQUFzQixFQUFFLEdBQUc7QUFBQSxRQUMzQyxDQUFDLGVBQWUsdUJBQXVCLEVBQUUsR0FBRztBQUFBLFFBQzVDLENBQUMsZUFBZSxxQkFBcUIsRUFBRSxHQUFHO0FBQUEsUUFDMUMsQ0FBQyxlQUFlLGVBQWUsRUFBRSxHQUFHO0FBQUEsTUFDdEM7QUFBQSxJQUNGO0FBQUEsSUFDQTtBQUFBLE1BQ0UsT0FBTyxDQUFDLGNBQWM7QUFBQSxNQUN0QixTQUFTLENBQUMsZUFBZTtBQUFBLE1BQ3pCLFNBQVM7QUFBQSxRQUNQLGVBQWU7QUFBQSxNQUNqQjtBQUFBLE1BQ0EsT0FBTztBQUFBLFFBQ0wsQ0FBQyxlQUFlLHFCQUFxQixFQUFFLEdBQUc7QUFBQSxNQUM1QztBQUFBLElBQ0Y7QUFBQSxFQUNGO0FBQUEsRUFDQSw0QkFBNEI7QUFBQSxJQUMxQjtBQUFBLE1BQ0UsT0FBTyxDQUFDLFNBQVM7QUFBQSxNQUNqQixTQUFTLENBQUMsZUFBZTtBQUFBLE1BQ3pCLFNBQVM7QUFBQSxRQUNQLGVBQWU7QUFBQSxNQUNqQjtBQUFBLE1BQ0EsT0FBTztBQUFBLFFBQ0wsQ0FBQyxlQUFlLHNCQUFzQixFQUFFLEdBQUc7QUFBQSxRQUMzQyxDQUFDLGVBQWUsa0JBQWtCLEVBQUUsR0FBRztBQUFBLFFBQ3ZDLENBQUMsZUFBZSxzQkFBc0IsRUFBRSxHQUFHO0FBQUEsUUFDM0MsQ0FBQyxlQUFlLGtCQUFrQixFQUFFLEdBQUc7QUFBQSxRQUN2QyxDQUFDLGVBQWUsMkJBQTJCLEVBQUUsR0FBRztBQUFBLFFBQ2hELENBQUMsZUFBZSwrQkFBK0IsRUFBRSxHQUFHO0FBQUEsUUFDcEQsQ0FBQyxlQUFlLHlCQUF5QixFQUFFLEdBQUc7QUFBQSxRQUM5QyxDQUFDLGVBQWUsZUFBZSxFQUFFLEdBQUc7QUFBQSxRQUNwQyxDQUFDLGVBQWUsK0JBQStCLEVBQUUsR0FBRztBQUFBLFFBQ3BELENBQUMsZUFBZSw4QkFBOEIsRUFBRSxHQUFHO0FBQUEsUUFDbkQsQ0FBQyxlQUFlLHFCQUFxQixFQUFFLEdBQUc7QUFBQSxRQUMxQyxDQUFDLGVBQWUsOEJBQThCLEVBQUUsR0FBRztBQUFBLFFBQ25ELENBQUMsZUFBZSxzQkFBc0IsRUFBRSxHQUFHO0FBQUEsUUFDM0MsQ0FBQyxlQUFlLHVCQUF1QixFQUFFLEdBQUc7QUFBQSxRQUM1QyxDQUFDLGVBQWUscUJBQXFCLEVBQUUsR0FBRztBQUFBLE1BQzVDO0FBQUEsSUFDRjtBQUFBLEVBQ0Y7QUFDRjtBQUVBLElBQU0sa0JBRUY7QUFBQSxFQUNGLEdBQUc7QUFBQSxFQUNIO0FBQ0Y7QUFDQSxJQUFPLGNBQVE7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -0,0 +1,4 @@
1
+ import { ESLintUtils } from '@typescript-eslint/utils';
2
+ export declare const ruleId = "add-assert-import";
3
+ declare const rule: ESLintUtils.RuleModule<'addAssertImport'>;
4
+ export default rule;
@@ -0,0 +1,4 @@
1
+ import { ESLintUtils } from '@typescript-eslint/utils';
2
+ export declare const ruleId = "add-base-path-const";
3
+ declare const rule: ESLintUtils.RuleModule<'addBasePathConst'>;
4
+ export default rule;
@@ -0,0 +1,4 @@
1
+ import { ESLintUtils } from '@typescript-eslint/utils';
2
+ export declare const ruleId = "add-base-path-import";
3
+ declare const rule: ESLintUtils.RuleModule<'addBasePathImport'>;
4
+ export default rule;
@@ -0,0 +1,4 @@
1
+ import { ESLintUtils } from '@typescript-eslint/utils';
2
+ export declare const ruleId = "add-url-domain";
3
+ declare const rule: ESLintUtils.RuleModule<'addDomain' | 'unknownError'>;
4
+ export default rule;
@@ -0,0 +1,4 @@
1
+ import { ESLintUtils } from '@typescript-eslint/utils';
2
+ export declare const ruleId = "agent-test-wiring";
3
+ declare const rule: ESLintUtils.RuleModule<'updateTestWiring' | 'unknownError'>;
4
+ export default rule;
@@ -0,0 +1,4 @@
1
+ import { ESLintUtils } from '@typescript-eslint/utils';
2
+ export declare const ruleId = "fetch-response-body-json";
3
+ declare const rule: ESLintUtils.RuleModule<'unknownError' | 'replaceBodyWithJson' | 'refactorNeeded'>;
4
+ export default rule;
@@ -0,0 +1,4 @@
1
+ import { ESLintUtils } from '@typescript-eslint/utils';
2
+ export declare const ruleId = "fetch-response-header-getter-ts";
3
+ declare const rule: ESLintUtils.RuleModule<'unknownError' | 'useGetter'>;
4
+ export default rule;
@@ -0,0 +1,4 @@
1
+ import { ESLintUtils } from '@typescript-eslint/utils';
2
+ export declare const ruleId = "fetch-response-status";
3
+ declare const rule: ESLintUtils.RuleModule<'unknownError' | 'renameStatusCodeProperty'>;
4
+ export default rule;
@@ -0,0 +1,4 @@
1
+ import { type Rule } from 'eslint';
2
+ export declare const ruleId = "fetch-then";
3
+ declare const rule: Rule.RuleModule;
4
+ export default rule;
@@ -0,0 +1,5 @@
1
+ import type { Node } from 'estree';
2
+ export declare function getResponseBodyRetrievalText(responseVariableName: string): string;
3
+ export declare function getResponseHeadersRetrievalText(responseVariableName: string): string;
4
+ export declare function isInvalidResponseHeadersAccess(responseHeadersAccess: Node): boolean;
5
+ export declare function hasAssertions(fixtureCall: Node): boolean;
@@ -0,0 +1,7 @@
1
+ export declare function isApiIndexFile(filename: string): boolean;
2
+ export declare function getProjectRootFolder(indexFilename: string): string;
3
+ export declare function getSwaggerPathByIndexFile(indexFilename: string): string;
4
+ export declare function loadSwagger(filename: string): string;
5
+ export declare function loadPackageJson(projectRoot: string): string;
6
+ export declare function getApiFolder(folder: string): string | undefined;
7
+ export declare function getApiIndexPathByFilename(filename: string): string | undefined;
@@ -0,0 +1,9 @@
1
+ import { ESLintUtils } from '@typescript-eslint/utils';
2
+ export declare const ruleId = "fix-function-call-arguments";
3
+ export interface FixFunctionCallArgumentsRuleOptions {
4
+ typesToCheck: string[];
5
+ }
6
+ declare const rule: ESLintUtils.RuleModule<'removeIncompatibleFunctionArguments' | 'unknownError', [
7
+ FixFunctionCallArgumentsRuleOptions
8
+ ]>;
9
+ export default rule;
@@ -0,0 +1,4 @@
1
+ import { type Rule } from 'eslint';
2
+ export declare const ruleId = "no-fixture";
3
+ declare const rule: Rule.RuleModule;
4
+ export default rule;
@@ -0,0 +1,4 @@
1
+ import { ESLintUtils } from '@typescript-eslint/utils';
2
+ export declare const ruleId = "no-mapped-response";
3
+ declare const rule: ESLintUtils.RuleModule<'unknownError' | 'replaceFullResponseWithFetchResponse'>;
4
+ export default rule;
@@ -0,0 +1,4 @@
1
+ import { ESLintUtils } from '@typescript-eslint/utils';
2
+ export declare const ruleId = "no-service-wrapper";
3
+ declare const rule: ESLintUtils.RuleModule<'unknownError' | 'preferNativeFetch' | 'invalidOptions'>;
4
+ export default rule;
@@ -0,0 +1,4 @@
1
+ import { ESLintUtils } from '@typescript-eslint/utils';
2
+ export declare const ruleId = "no-status-code";
3
+ declare const rule: ESLintUtils.RuleModule<'unknownError' | 'replaceStatusCode'>;
4
+ export default rule;
@@ -0,0 +1,4 @@
1
+ import { ESLintUtils } from '@typescript-eslint/utils';
2
+ export declare const ruleId = "no-unused-function-argument";
3
+ declare const rule: ESLintUtils.RuleModule<'unknownError' | 'removeUnusedFunctionArguments'>;
4
+ export default rule;
@@ -0,0 +1,4 @@
1
+ import { ESLintUtils } from '@typescript-eslint/utils';
2
+ export declare const ruleId = "no-unused-imports";
3
+ declare const rule: ESLintUtils.RuleModule<'unknownError' | 'removeUnusedImports'>;
4
+ export default rule;
@@ -0,0 +1,4 @@
1
+ import { ESLintUtils } from '@typescript-eslint/utils';
2
+ export declare const ruleId = "no-unused-service-variable";
3
+ declare const rule: ESLintUtils.RuleModule<'unknownError' | 'removeUnusedServiceVariables'>;
4
+ export default rule;
@@ -0,0 +1,16 @@
1
+ import type { MemberExpression, ObjectPattern, VariableDeclaration } from 'estree';
2
+ import { type Scope } from 'eslint';
3
+ /**
4
+ * analyze response related variables and their references
5
+ * the implementation is for fixture API, but it can be used for fetch API as well since the tree structure is similar
6
+ * @param variableDeclaration - variable declaration node
7
+ */
8
+ export declare function analyzeResponseReferences(variableDeclaration: VariableDeclaration | undefined, scopeManager: Scope.ScopeManager): {
9
+ variable?: Scope.Variable;
10
+ bodyReferences: MemberExpression[];
11
+ headersReferences: MemberExpression[];
12
+ statusReferences: MemberExpression[];
13
+ destructuringBodyVariable?: Scope.Variable | ObjectPattern;
14
+ destructuringHeadersVariable?: Scope.Variable | ObjectPattern;
15
+ destructuringHeadersReferences?: MemberExpression[] | undefined;
16
+ };
@@ -0,0 +1,4 @@
1
+ export declare function isServiceApiCallUrl(url: string): boolean;
2
+ export declare function replaceEndpointUrlPrefixWithBasePath(url: string): string;
3
+ export declare function replaceEndpointUrlPrefixWithDomain(url: string): string;
4
+ export declare function addBasePathUrlDomain(url: string): string;
package/package.json CHANGED
@@ -1 +1 @@
1
- {"name":"@checkdigit/eslint-plugin","version":"7.5.0-PR.93-b62d","description":"Check Digit eslint plugins","keywords":["eslint","eslintplugin"],"homepage":"https://github.com/checkdigit/eslint-plugin#readme","bugs":{"url":"https://github.com/checkdigit/eslint-plugin/issues"},"repository":{"type":"git","url":"https://github.com/checkdigit/eslint-plugin"},"license":"MIT","author":"Check Digit, LLC","sideEffects":false,"type":"module","exports":{".":{"types":"./dist-types/index.d.ts","import":"./dist-mjs/index.mjs","default":"./dist-mjs/index.mjs"}},"files":["src","dist-types","dist-mjs","!src/**/test/**","!src/**/*.test.ts","!src/**/*.spec.ts","!dist-types/**/test/**","!dist-types/**/*.test.d.ts","!dist-types/**/*.spec.d.ts","!dist-mjs/**/test/**","!dist-mjs/**/*.test.mjs","!dist-mjs/**/*.spec.mjs","SECURITY.md"],"scripts":{"build:dist-mjs":"rimraf dist-mjs && npx builder --type=module --sourceMap --outDir=dist-mjs && node dist-mjs/index.mjs","build:dist-types":"rimraf dist-types && npx builder --type=types --outDir=dist-types","ci:compile":"tsc --noEmit","ci:coverage":"NODE_OPTIONS=\"--disable-warning ExperimentalWarning --experimental-vm-modules\" jest --coverage=true","ci:lint":"npm run lint","ci:style":"npm run prettier","ci:test":"NODE_OPTIONS=\"--disable-warning ExperimentalWarning --experimental-vm-modules\" jest --coverage=false","lint":"eslint --max-warnings 0 .","lint:fix":"eslint --max-warnings 0 --fix .","prepare":"","prepublishOnly":"npm run build:dist-types && npm run build:dist-mjs","prettier":"prettier --ignore-path .gitignore --list-different .","prettier:fix":"prettier --ignore-path .gitignore --write .","test":"npm run ci:compile && npm run ci:test && npm run ci:lint && npm run ci:style"},"prettier":"@checkdigit/prettier-config","jest":{"preset":"@checkdigit/jest-config"},"dependencies":{"@typescript-eslint/type-utils":"^8.15.0","@typescript-eslint/utils":"^8.15.0","ts-api-utils":"^1.4.0"},"devDependencies":{"@checkdigit/jest-config":"^6.0.2","@checkdigit/prettier-config":"^5.5.1","@checkdigit/typescript-config":"^8.0.0","@eslint/js":"^9.15.0","@types/eslint":"^9.6.1","@types/eslint-config-prettier":"^6.11.3","@typescript-eslint/parser":"^8.15.0","@typescript-eslint/rule-tester":"^8.15.0","eslint":"^9.15.0","eslint-config-prettier":"^9.1.0","eslint-import-resolver-typescript":"^3.6.3","eslint-plugin-eslint-plugin":"^6.3.2","eslint-plugin-import":"^2.31.0","eslint-plugin-no-only-tests":"^3.3.0","eslint-plugin-no-secrets":"^1.1.2","eslint-plugin-node":"^11.1.0","eslint-plugin-sonarjs":"1.0.4","http-status-codes":"^2.3.0","rimraf":"^6.0.1","typescript-eslint":"^8.15.0"},"peerDependencies":{"eslint":">=9 <10"},"engines":{"node":">=20.17"}}
1
+ {"name":"@checkdigit/eslint-plugin","version":"7.6.0-PR.75-5da1","description":"Check Digit eslint plugins","keywords":["eslint","eslintplugin"],"homepage":"https://github.com/checkdigit/eslint-plugin#readme","bugs":{"url":"https://github.com/checkdigit/eslint-plugin/issues"},"repository":{"type":"git","url":"https://github.com/checkdigit/eslint-plugin"},"license":"MIT","author":"Check Digit, LLC","sideEffects":false,"type":"module","exports":{".":{"types":"./dist-types/index.d.ts","import":"./dist-mjs/index.mjs","default":"./dist-mjs/index.mjs"}},"files":["src","dist-types","dist-mjs","!src/**/test/**","!src/**/*.test.ts","!src/**/*.spec.ts","!dist-types/**/test/**","!dist-types/**/*.test.d.ts","!dist-types/**/*.spec.d.ts","!dist-mjs/**/test/**","!dist-mjs/**/*.test.mjs","!dist-mjs/**/*.spec.mjs","SECURITY.md"],"scripts":{"build:dist-mjs":"rimraf dist-mjs && npx builder --type=module --sourceMap --outDir=dist-mjs && node dist-mjs/index.mjs","build:dist-types":"rimraf dist-types && npx builder --type=types --outDir=dist-types","ci:compile":"tsc --noEmit","ci:coverage":"NODE_OPTIONS=\"--disable-warning ExperimentalWarning --experimental-vm-modules\" jest --coverage=true","ci:lint":"npm run lint","ci:style":"npm run prettier","ci:test":"NODE_OPTIONS=\"--disable-warning ExperimentalWarning --experimental-vm-modules\" jest --coverage=false","lint":"eslint --max-warnings 0 .","lint:fix":"eslint --max-warnings 0 --fix .","prepare":"","prepublishOnly":"npm run build:dist-types && npm run build:dist-mjs","prettier":"prettier --ignore-path .gitignore --list-different .","prettier:fix":"prettier --ignore-path .gitignore --write .","test":"npm run ci:compile && npm run ci:test && npm run ci:lint && npm run ci:style"},"prettier":"@checkdigit/prettier-config","jest":{"preset":"@checkdigit/jest-config"},"dependencies":{"@typescript-eslint/type-utils":"^8.15.0","@typescript-eslint/utils":"^8.15.0","debug":"^4.3.7","ts-api-utils":"^1.4.0"},"devDependencies":{"@checkdigit/jest-config":"^6.0.2","@checkdigit/prettier-config":"^5.5.1","@checkdigit/typescript-config":"^8.0.0","@eslint/js":"^9.15.0","@types/debug":"^4.1.12","@types/eslint":"^9.6.1","@types/eslint-config-prettier":"^6.11.3","@typescript-eslint/parser":"^8.15.0","@typescript-eslint/rule-tester":"^8.15.0","eslint":"^9.15.0","eslint-config-prettier":"^9.1.0","eslint-import-resolver-typescript":"^3.6.3","eslint-plugin-eslint-plugin":"^6.3.2","eslint-plugin-import":"^2.31.0","eslint-plugin-no-only-tests":"^3.3.0","eslint-plugin-no-secrets":"^1.1.2","eslint-plugin-node":"^11.1.0","eslint-plugin-sonarjs":"1.0.4","http-status-codes":"^2.3.0","rimraf":"^6.0.1","typescript-eslint":"^8.15.0"},"peerDependencies":{"eslint":">=9 <10"},"engines":{"node":">=20.17"}}
@@ -0,0 +1,74 @@
1
+ // agent/add-url-domain.ts
2
+
3
+ /*
4
+ * Copyright (c) 2021-2024 Check Digit, LLC
5
+ *
6
+ * This code is licensed under the MIT license (see LICENSE.txt for details).
7
+ */
8
+
9
+ import { strict as assert } from 'node:assert';
10
+
11
+ import { AST_NODE_TYPES, ESLintUtils } from '@typescript-eslint/utils';
12
+
13
+ import getDocumentationUrl from '../get-documentation-url';
14
+
15
+ export const ruleId = 'add-assert-import';
16
+
17
+ const ASSERT_IMPORT_STATEMENT = "import { strict as assert } from 'node:assert';";
18
+
19
+ const createRule = ESLintUtils.RuleCreator((name) => getDocumentationUrl(name));
20
+
21
+ const rule: ESLintUtils.RuleModule<'addAssertImport'> = createRule({
22
+ name: ruleId,
23
+ meta: {
24
+ type: 'suggestion',
25
+ docs: {
26
+ description: 'Add import of assert module of node.',
27
+ },
28
+ messages: {
29
+ addAssertImport: 'Add import of assert module of node.',
30
+ },
31
+ fixable: 'code',
32
+ schema: [],
33
+ },
34
+ defaultOptions: [],
35
+ create(context) {
36
+ let isAssertImported = false;
37
+ let isAssertUsed = false;
38
+
39
+ return {
40
+ ImportDeclaration: (node) => {
41
+ if (node.source.value === 'assert' || node.source.value === 'node:assert') {
42
+ isAssertImported = true;
43
+ }
44
+ },
45
+ CallExpression: (callExpression) => {
46
+ // detect if assert is used
47
+ if (
48
+ (callExpression.callee.type === AST_NODE_TYPES.Identifier && callExpression.callee.name === 'assert') ||
49
+ (callExpression.callee.type === AST_NODE_TYPES.MemberExpression &&
50
+ callExpression.callee.object.type === AST_NODE_TYPES.Identifier &&
51
+ callExpression.callee.object.name === 'assert')
52
+ ) {
53
+ isAssertUsed = true;
54
+ }
55
+ },
56
+ 'Program:exit': (program) => {
57
+ // add assert import if necessary
58
+ if (isAssertUsed && !isAssertImported) {
59
+ const firstStatement = program.body[0];
60
+ assert(firstStatement);
61
+ context.report({
62
+ node: program,
63
+ messageId: 'addAssertImport',
64
+ fix(fixer) {
65
+ return fixer.insertTextBefore(firstStatement, `${ASSERT_IMPORT_STATEMENT}\n`);
66
+ },
67
+ });
68
+ }
69
+ },
70
+ };
71
+ },
72
+ });
73
+
74
+ export default rule;
@@ -0,0 +1,81 @@
1
+ // agent/add-url-domain.ts
2
+
3
+ /*
4
+ * Copyright (c) 2021-2024 Check Digit, LLC
5
+ *
6
+ * This code is licensed under the MIT license (see LICENSE.txt for details).
7
+ */
8
+
9
+ import { strict as assert } from 'node:assert';
10
+
11
+ import { AST_NODE_TYPES, ESLintUtils, TSESTree } from '@typescript-eslint/utils';
12
+
13
+ import getDocumentationUrl from '../get-documentation-url';
14
+ import { getProjectRootFolder, getSwaggerPathByIndexFile, isApiIndexFile, loadPackageJson, loadSwagger } from './file';
15
+
16
+ export const ruleId = 'add-base-path-const';
17
+
18
+ const createRule = ESLintUtils.RuleCreator((name) => getDocumentationUrl(name));
19
+
20
+ const rule: ESLintUtils.RuleModule<'addBasePathConst'> = createRule({
21
+ name: ruleId,
22
+ meta: {
23
+ type: 'suggestion',
24
+ docs: {
25
+ description: 'Add BASE_PATH const variable.',
26
+ },
27
+ messages: {
28
+ addBasePathConst: 'Add BASE_PATH const variable.',
29
+ },
30
+ fixable: 'code',
31
+ schema: [],
32
+ },
33
+ defaultOptions: [],
34
+ create(context) {
35
+ const sourceCode = context.sourceCode;
36
+
37
+ return {
38
+ Program: (program: TSESTree.Program) => {
39
+ if (!isApiIndexFile(context.filename)) {
40
+ return;
41
+ }
42
+
43
+ const scope = sourceCode.getScope(program).childScopes[0];
44
+ assert(scope);
45
+
46
+ const foundBasePathConst = scope.variables.find((variable) => variable.name === 'BASE_PATH');
47
+ if (foundBasePathConst) {
48
+ return;
49
+ }
50
+
51
+ const swaggerPath = getSwaggerPathByIndexFile(context.filename);
52
+ const swaggerFileContents = loadSwagger(swaggerPath);
53
+ const baseUrlLine = swaggerFileContents
54
+ .split('\n')
55
+ .find((line) => /^\s*-\s*url:\s*\/.*$/u.test(line) || /^basePath:.*/u.test(line));
56
+ const baseUrl = baseUrlLine?.split(':')[1]?.trim();
57
+ assert(baseUrl !== undefined);
58
+
59
+ const packageRoot = getProjectRootFolder(context.filename);
60
+ const packageJson = JSON.parse(loadPackageJson(packageRoot)) as { name: string };
61
+ const serviceName = packageJson.name.split('/')[1];
62
+ assert(serviceName !== undefined);
63
+
64
+ const domain = `https://${serviceName}.checkdigit${baseUrl}`;
65
+
66
+ const lastImportStatement = program.body.findLast((node) => node.type === AST_NODE_TYPES.ImportDeclaration);
67
+ assert(lastImportStatement);
68
+
69
+ context.report({
70
+ messageId: 'addBasePathConst',
71
+ node: program,
72
+ fix(fixer) {
73
+ return fixer.insertTextAfter(lastImportStatement, `\nexport const BASE_PATH = '${domain}';\n`);
74
+ },
75
+ });
76
+ },
77
+ };
78
+ },
79
+ });
80
+
81
+ export default rule;
@@ -0,0 +1,69 @@
1
+ // agent/add-url-domain.ts
2
+
3
+ /*
4
+ * Copyright (c) 2021-2024 Check Digit, LLC
5
+ *
6
+ * This code is licensed under the MIT license (see LICENSE.txt for details).
7
+ */
8
+
9
+ import { strict as assert } from 'node:assert';
10
+
11
+ import { AST_NODE_TYPES, ESLintUtils } from '@typescript-eslint/utils';
12
+
13
+ import getDocumentationUrl from '../get-documentation-url';
14
+ import { getApiIndexPathByFilename } from './file';
15
+
16
+ export const ruleId = 'add-base-path-import';
17
+
18
+ const createRule = ESLintUtils.RuleCreator((name) => getDocumentationUrl(name));
19
+
20
+ const rule: ESLintUtils.RuleModule<'addBasePathImport'> = createRule({
21
+ name: ruleId,
22
+ meta: {
23
+ type: 'suggestion',
24
+ docs: {
25
+ description: 'Add import of BASE_PATH if it is used but not imported.',
26
+ },
27
+ messages: {
28
+ addBasePathImport: 'Add import of BASE_PATH.',
29
+ },
30
+ fixable: 'code',
31
+ schema: [],
32
+ },
33
+ defaultOptions: [],
34
+ create(context) {
35
+ const sourceCode = context.sourceCode;
36
+
37
+ return {
38
+ Program: (program) => {
39
+ const isBasePathUsed = sourceCode.text.includes(`$\{BASE_PATH}`);
40
+ if (isBasePathUsed) {
41
+ const topScope = sourceCode.getScope(program).childScopes[0];
42
+ assert(topScope);
43
+ if (topScope.variables.some((variable) => variable.name === 'BASE_PATH')) {
44
+ return;
45
+ }
46
+
47
+ const apiIndexPath = getApiIndexPathByFilename(context.filename);
48
+ if (apiIndexPath !== undefined) {
49
+ const lastImportStatement = program.body.findLast(
50
+ (statement) => statement.type === AST_NODE_TYPES.ImportDeclaration,
51
+ );
52
+ assert(lastImportStatement);
53
+
54
+ const basePathImportStatement = `\nimport { BASE_PATH } from '${apiIndexPath}';\n`;
55
+ context.report({
56
+ node: program,
57
+ messageId: 'addBasePathImport',
58
+ fix(fixer) {
59
+ return fixer.insertTextAfter(lastImportStatement, basePathImportStatement);
60
+ },
61
+ });
62
+ }
63
+ }
64
+ },
65
+ };
66
+ },
67
+ });
68
+
69
+ export default rule;