@checkdigit/eslint-plugin 6.6.0-PR.75-edd9 → 6.6.0-PR.77-5328
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/dist-cjs/index.cjs +755 -2130
- package/dist-cjs/metafile.json +82 -519
- package/dist-mjs/index.mjs +2 -64
- package/dist-mjs/require-resolve-full-response.mjs +5 -2
- package/dist-types/index.d.ts +1 -50
- package/dist-types/require-resolve-full-response.d.ts +3 -1
- package/package.json +1 -1
- package/src/index.ts +0 -62
- package/src/require-resolve-full-response.ts +2 -1
- package/dist-mjs/agent/add-url-domain.mjs +0 -61
- package/dist-mjs/agent/fetch-response-body-json.mjs +0 -63
- package/dist-mjs/agent/fetch-response-header-getter.mjs +0 -117
- package/dist-mjs/agent/fetch-then.mjs +0 -269
- package/dist-mjs/agent/fetch.mjs +0 -34
- package/dist-mjs/agent/no-fixture.mjs +0 -328
- package/dist-mjs/agent/no-full-response.mjs +0 -67
- package/dist-mjs/agent/no-mapped-response.mjs +0 -75
- package/dist-mjs/agent/no-service-wrapper.mjs +0 -184
- package/dist-mjs/agent/no-status-code.mjs +0 -59
- package/dist-mjs/agent/response-reference.mjs +0 -56
- package/dist-mjs/agent/url.mjs +0 -26
- package/dist-types/agent/add-url-domain.d.ts +0 -4
- package/dist-types/agent/fetch-response-body-json.d.ts +0 -4
- package/dist-types/agent/fetch-response-header-getter.d.ts +0 -4
- package/dist-types/agent/fetch-then.d.ts +0 -4
- package/dist-types/agent/fetch.d.ts +0 -4
- package/dist-types/agent/no-fixture.d.ts +0 -4
- package/dist-types/agent/no-full-response.d.ts +0 -4
- package/dist-types/agent/no-mapped-response.d.ts +0 -4
- package/dist-types/agent/no-service-wrapper.d.ts +0 -4
- package/dist-types/agent/no-status-code.d.ts +0 -4
- package/dist-types/agent/response-reference.d.ts +0 -16
- package/dist-types/agent/url.d.ts +0 -5
- package/src/agent/add-url-domain.ts +0 -75
- package/src/agent/fetch-response-body-json.ts +0 -76
- package/src/agent/fetch-response-header-getter.ts +0 -148
- package/src/agent/fetch-then.ts +0 -354
- package/src/agent/fetch.ts +0 -52
- package/src/agent/no-fixture.ts +0 -453
- package/src/agent/no-full-response.ts +0 -75
- package/src/agent/no-mapped-response.ts +0 -84
- package/src/agent/no-service-wrapper.ts +0 -238
- package/src/agent/no-status-code.ts +0 -71
- package/src/agent/response-reference.ts +0 -100
- package/src/agent/url.ts +0 -23
package/dist-mjs/index.mjs
CHANGED
|
@@ -1,17 +1,6 @@
|
|
|
1
1
|
// src/index.ts
|
|
2
|
-
import addUrlDomain, { ruleId as addUrlDomainRuleId } from "./agent/add-url-domain.mjs";
|
|
3
|
-
import fetchResponseBodyJson, { ruleId as fetchResponseBodyJsonRuleId } from "./agent/fetch-response-body-json.mjs";
|
|
4
|
-
import fetchResponseHeaderGetter, {
|
|
5
|
-
ruleId as fetchResponseHeaderGetterRuleId
|
|
6
|
-
} from "./agent/fetch-response-header-getter.mjs";
|
|
7
|
-
import fetchThen, { ruleId as fetchThenRuleId } from "./agent/fetch-then.mjs";
|
|
8
2
|
import invalidJsonStringify, { ruleId as invalidJsonStringifyRuleId } from "./invalid-json-stringify.mjs";
|
|
9
|
-
import noFixture, { ruleId as noFixtureRuleId } from "./agent/no-fixture.mjs";
|
|
10
|
-
import noFullResponse, { ruleId as noFullResponseRuleId } from "./agent/no-full-response.mjs";
|
|
11
|
-
import noMappedResponse, { ruleId as noMappedResponseRuleId } from "./agent/no-mapped-response.mjs";
|
|
12
3
|
import noPromiseInstanceMethod, { ruleId as noPromiseInstanceMethodRuleId } from "./no-promise-instance-method.mjs";
|
|
13
|
-
import noServiceWrapper, { ruleId as noServiceWrapperRuleId } from "./agent/no-service-wrapper.mjs";
|
|
14
|
-
import noStatusCode, { ruleId as noStatusCodeRuleId } from "./agent/no-status-code.mjs";
|
|
15
4
|
import requireResolveFullResponse, {
|
|
16
5
|
ruleId as requireResolveFullResponseRuleId
|
|
17
6
|
} from "./require-resolve-full-response.mjs";
|
|
@@ -37,15 +26,6 @@ var src_default = {
|
|
|
37
26
|
"object-literal-response": objectLiteralResponse,
|
|
38
27
|
[invalidJsonStringifyRuleId]: invalidJsonStringify,
|
|
39
28
|
[noPromiseInstanceMethodRuleId]: noPromiseInstanceMethod,
|
|
40
|
-
[noFixtureRuleId]: noFixture,
|
|
41
|
-
[fetchThenRuleId]: fetchThen,
|
|
42
|
-
[noServiceWrapperRuleId]: noServiceWrapper,
|
|
43
|
-
[noStatusCodeRuleId]: noStatusCode,
|
|
44
|
-
[fetchResponseBodyJsonRuleId]: fetchResponseBodyJson,
|
|
45
|
-
[fetchResponseHeaderGetterRuleId]: fetchResponseHeaderGetter,
|
|
46
|
-
[addUrlDomainRuleId]: addUrlDomain,
|
|
47
|
-
[noFullResponseRuleId]: noFullResponse,
|
|
48
|
-
[noMappedResponseRuleId]: noMappedResponse,
|
|
49
29
|
[requireResolveFullResponseRuleId]: requireResolveFullResponse
|
|
50
30
|
},
|
|
51
31
|
configs: {
|
|
@@ -62,15 +42,7 @@ var src_default = {
|
|
|
62
42
|
"@checkdigit/no-test-import": "error",
|
|
63
43
|
[`@checkdigit/${invalidJsonStringifyRuleId}`]: "error",
|
|
64
44
|
[`@checkdigit/${noPromiseInstanceMethodRuleId}`]: "error",
|
|
65
|
-
[`@checkdigit/${
|
|
66
|
-
[`@checkdigit/${requireResolveFullResponseRuleId}`]: "error",
|
|
67
|
-
[`@checkdigit/${addUrlDomainRuleId}`]: "off",
|
|
68
|
-
[`@checkdigit/${noFixtureRuleId}`]: "off",
|
|
69
|
-
[`@checkdigit/${noServiceWrapperRuleId}`]: "off",
|
|
70
|
-
[`@checkdigit/${noStatusCodeRuleId}`]: "off",
|
|
71
|
-
[`@checkdigit/${fetchResponseBodyJsonRuleId}`]: "off",
|
|
72
|
-
[`@checkdigit/${fetchResponseHeaderGetterRuleId}`]: "off",
|
|
73
|
-
[`@checkdigit/${fetchThenRuleId}`]: "off"
|
|
45
|
+
[`@checkdigit/${requireResolveFullResponseRuleId}`]: "error"
|
|
74
46
|
}
|
|
75
47
|
},
|
|
76
48
|
recommended: {
|
|
@@ -87,44 +59,10 @@ var src_default = {
|
|
|
87
59
|
[`@checkdigit/${invalidJsonStringifyRuleId}`]: "error",
|
|
88
60
|
[`@checkdigit/${noPromiseInstanceMethodRuleId}`]: "error"
|
|
89
61
|
}
|
|
90
|
-
},
|
|
91
|
-
"agent-phase-1-test": {
|
|
92
|
-
overrides: [
|
|
93
|
-
{
|
|
94
|
-
files: ["*.spec.ts", "*.test.ts", "src/api/v*/index.ts"]
|
|
95
|
-
}
|
|
96
|
-
],
|
|
97
|
-
rules: {
|
|
98
|
-
[`@checkdigit/${noFullResponseRuleId}`]: "error",
|
|
99
|
-
[`@checkdigit/${requireResolveFullResponseRuleId}`]: "error",
|
|
100
|
-
[`@checkdigit/${noMappedResponseRuleId}`]: "error",
|
|
101
|
-
[`@checkdigit/${addUrlDomainRuleId}`]: "error",
|
|
102
|
-
[`@checkdigit/${noFixtureRuleId}`]: "error",
|
|
103
|
-
[`@checkdigit/${noServiceWrapperRuleId}`]: "error",
|
|
104
|
-
[`@checkdigit/${noStatusCodeRuleId}`]: "error",
|
|
105
|
-
[`@checkdigit/${fetchResponseBodyJsonRuleId}`]: "error",
|
|
106
|
-
[`@checkdigit/${fetchResponseHeaderGetterRuleId}`]: "error",
|
|
107
|
-
[`@checkdigit/${fetchThenRuleId}`]: "error"
|
|
108
|
-
}
|
|
109
|
-
},
|
|
110
|
-
"agent-phase-2-production": {
|
|
111
|
-
ignorePatterns: ["*.spec.ts", "*.test.ts"],
|
|
112
|
-
rules: {
|
|
113
|
-
[`@checkdigit/${noFullResponseRuleId}`]: "error",
|
|
114
|
-
[`@checkdigit/${requireResolveFullResponseRuleId}`]: "error",
|
|
115
|
-
[`@checkdigit/${noMappedResponseRuleId}`]: "error",
|
|
116
|
-
[`@checkdigit/${addUrlDomainRuleId}`]: "error",
|
|
117
|
-
[`@checkdigit/${noFixtureRuleId}`]: "off",
|
|
118
|
-
[`@checkdigit/${noServiceWrapperRuleId}`]: "error",
|
|
119
|
-
[`@checkdigit/${noStatusCodeRuleId}`]: "error",
|
|
120
|
-
[`@checkdigit/${fetchResponseBodyJsonRuleId}`]: "error",
|
|
121
|
-
[`@checkdigit/${fetchResponseHeaderGetterRuleId}`]: "error",
|
|
122
|
-
[`@checkdigit/${fetchThenRuleId}`]: "error"
|
|
123
|
-
}
|
|
124
62
|
}
|
|
125
63
|
}
|
|
126
64
|
};
|
|
127
65
|
export {
|
|
128
66
|
src_default as default
|
|
129
67
|
};
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2luZGV4LnRzIl0sCiAgIm1hcHBpbmdzIjogIjtBQVFBLE9BQU8sd0JBQXdCLFVBQVUsa0NBQWtDO0FBQzNFLE9BQU8sMkJBQTJCLFVBQVUscUNBQXFDO0FBQ2pGLE9BQU87QUFBQSxFQUNMLFVBQVU7QUFBQSxPQUNMO0FBQ1AsT0FBTyxxQkFBcUI7QUFDNUIsT0FBTyxtQkFBbUI7QUFDMUIsT0FBTyxrQkFBa0I7QUFDekIsT0FBTyxZQUFZO0FBQ25CLE9BQU8sc0JBQXNCO0FBQzdCLE9BQU8sMkJBQTJCO0FBQ2xDLE9BQU8sa0JBQWtCO0FBQ3pCLE9BQU8seUNBQXlDO0FBQ2hELE9BQU8seUJBQXlCO0FBRWhDLElBQU8sY0FBUTtBQUFBLEVBQ2IsT0FBTztBQUFBLElBQ0wscUJBQXFCO0FBQUEsSUFDckIsbUJBQW1CO0FBQUEsSUFDbkIsV0FBVztBQUFBLElBQ1gseUJBQXlCO0FBQUEsSUFDekIsa0JBQWtCO0FBQUEsSUFDbEIsc0JBQXNCO0FBQUEsSUFDdEIsOEJBQThCO0FBQUEsSUFDOUIsMkNBQTJDO0FBQUEsSUFDM0MsMkJBQTJCO0FBQUEsSUFDM0IsQ0FBQywwQkFBMEIsR0FBRztBQUFBLElBQzlCLENBQUMsNkJBQTZCLEdBQUc7QUFBQSxJQUNqQyxDQUFDLGdDQUFnQyxHQUFHO0FBQUEsRUFDdEM7QUFBQSxFQUNBLFNBQVM7QUFBQSxJQUNQLEtBQUs7QUFBQSxNQUNILE9BQU87QUFBQSxRQUNMLCtCQUErQjtBQUFBLFFBQy9CLGlDQUFpQztBQUFBLFFBQ2pDLHVCQUF1QjtBQUFBLFFBQ3ZCLHFDQUFxQztBQUFBLFFBQ3JDLGtDQUFrQztBQUFBLFFBQ2xDLDBDQUEwQztBQUFBLFFBQzFDLHVEQUF1RDtBQUFBLFFBQ3ZELHVDQUF1QztBQUFBLFFBQ3ZDLDhCQUE4QjtBQUFBLFFBQzlCLENBQUMsZUFBZSwwQkFBMEIsRUFBRSxHQUFHO0FBQUEsUUFDL0MsQ0FBQyxlQUFlLDZCQUE2QixFQUFFLEdBQUc7QUFBQSxRQUNsRCxDQUFDLGVBQWUsZ0NBQWdDLEVBQUUsR0FBRztBQUFBLE1BQ3ZEO0FBQUEsSUFDRjtBQUFBLElBQ0EsYUFBYTtBQUFBLE1BQ1gsT0FBTztBQUFBLFFBQ0wsK0JBQStCO0FBQUEsUUFDL0IsaUNBQWlDO0FBQUEsUUFDakMsdUJBQXVCO0FBQUEsUUFDdkIscUNBQXFDO0FBQUEsUUFDckMsa0NBQWtDO0FBQUEsUUFDbEMsMENBQTBDO0FBQUEsUUFDMUMsdURBQXVEO0FBQUEsUUFDdkQsdUNBQXVDO0FBQUEsUUFDdkMsOEJBQThCO0FBQUEsUUFDOUIsQ0FBQyxlQUFlLDBCQUEwQixFQUFFLEdBQUc7QUFBQSxRQUMvQyxDQUFDLGVBQWUsNkJBQTZCLEVBQUUsR0FBRztBQUFBLE1BQ3BEO0FBQUEsSUFDRjtBQUFBLEVBQ0Y7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
|
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
// src/require-resolve-full-response.ts
|
|
2
2
|
import { AST_NODE_TYPES, ESLintUtils } from "@typescript-eslint/utils";
|
|
3
3
|
import { DefinitionType } from "@typescript-eslint/scope-manager";
|
|
4
|
-
import { PLAIN_URL_REGEXP, TOKENIZED_URL_REGEXP } from "./agent/url.mjs";
|
|
5
4
|
import { strict as assert } from "node:assert";
|
|
6
5
|
import getDocumentationUrl from "./get-documentation-url.mjs";
|
|
7
6
|
import { getEnclosingScopeNode } from "./library/ts-tree.mjs";
|
|
8
7
|
var ruleId = "require-resolve-full-response";
|
|
8
|
+
var PLAIN_URL_REGEXP = /^[`']\/\w+(?<serviceNamePart>-\w+)*\/v\d+\/(?<any>.|\r|\n)+[`']$/u;
|
|
9
|
+
var TOKENIZED_URL_REGEXP = /^`\$\{(?<serviceNamePart>[A-Z]+_)*BASE_PATH\}\/(?<any>.|\r|\n)+`$/u;
|
|
9
10
|
var createRule = ESLintUtils.RuleCreator((name) => getDocumentationUrl(name));
|
|
10
11
|
var rule = createRule({
|
|
11
12
|
name: ruleId,
|
|
@@ -150,7 +151,9 @@ var rule = createRule({
|
|
|
150
151
|
});
|
|
151
152
|
var require_resolve_full_response_default = rule;
|
|
152
153
|
export {
|
|
154
|
+
PLAIN_URL_REGEXP,
|
|
155
|
+
TOKENIZED_URL_REGEXP,
|
|
153
156
|
require_resolve_full_response_default as default,
|
|
154
157
|
ruleId
|
|
155
158
|
};
|
|
156
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
159
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL3JlcXVpcmUtcmVzb2x2ZS1mdWxsLXJlc3BvbnNlLnRzIl0sCiAgIm1hcHBpbmdzIjogIjtBQVFBLFNBQVMsZ0JBQWdCLG1CQUE2QjtBQUN0RCxTQUFTLHNCQUFrQztBQUMzQyxTQUFTLFVBQVUsY0FBYztBQUNqQyxPQUFPLHlCQUF5QjtBQUNoQyxTQUFTLDZCQUE2QjtBQUUvQixJQUFNLFNBQVM7QUFDZixJQUFNLG1CQUFtQjtBQUN6QixJQUFNLHVCQUF1QjtBQUVwQyxJQUFNLGFBQWEsWUFBWSxZQUFZLENBQUMsU0FBUyxvQkFBb0IsSUFBSSxDQUFDO0FBRTlFLElBQU0sT0FBTyxXQUFXO0FBQUEsRUFDdEIsTUFBTTtBQUFBLEVBQ04sTUFBTTtBQUFBLElBQ0osTUFBTTtBQUFBLElBQ04sTUFBTTtBQUFBLE1BQ0osYUFBYTtBQUFBLElBQ2Y7QUFBQSxJQUNBLFVBQVU7QUFBQSxNQUNSLGdCQUNFO0FBQUEsTUFDRixjQUFjO0FBQUEsSUFDaEI7QUFBQSxJQUNBLFFBQVEsQ0FBQztBQUFBLEVBQ1g7QUFBQSxFQUNBLGdCQUFnQixDQUFDO0FBQUEsRUFDakIsT0FBTyxTQUFTO0FBQ2QsVUFBTSxhQUFhLFFBQVE7QUFDM0IsVUFBTSxlQUFlLFdBQVc7QUFDaEMsVUFBTSxnQkFBZ0IsWUFBWSxrQkFBa0IsT0FBTztBQUMzRCxVQUFNLGNBQWMsY0FBYyxRQUFRLGVBQWU7QUFFekQsYUFBUyxtQkFBbUIsYUFBd0MsT0FBYztBQUNoRixVQUNHLGFBQWEsU0FBUyxlQUFlLFdBQVcsT0FBTyxZQUFZLFVBQVUsWUFDOUUsYUFBYSxTQUFTLGVBQWUsaUJBQ3JDO0FBQ0EsY0FBTSxVQUFVLFdBQVcsUUFBUSxXQUFXO0FBQzlDLGVBQU8saUJBQWlCLEtBQUssT0FBTyxLQUFLLHFCQUFxQixLQUFLLE9BQU87QUFBQSxNQUM1RTtBQUVBLFVBQUksYUFBYSxTQUFTLGVBQWUsWUFBWTtBQUNuRCxjQUFNLGdCQUFnQixNQUFNLFVBQVUsS0FBSyxDQUFD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
|
package/dist-types/index.d.ts
CHANGED
|
@@ -11,16 +11,7 @@ declare const _default: {
|
|
|
11
11
|
'object-literal-response': import("eslint").Rule.RuleModule;
|
|
12
12
|
"invalid-json-stringify": import("eslint").Rule.RuleModule;
|
|
13
13
|
"no-promise-instance-method": import("eslint").Rule.RuleModule;
|
|
14
|
-
"
|
|
15
|
-
"fetch-then": import("eslint").Rule.RuleModule;
|
|
16
|
-
"no-service-wrapper": import("@typescript-eslint/utils/ts-eslint").RuleModule<"unknownError" | "preferNativeFetch" | "invalidOptions", never[], import("@typescript-eslint/utils/ts-eslint").RuleListener>;
|
|
17
|
-
"no-status-code": import("@typescript-eslint/utils/ts-eslint").RuleModule<"unknownError" | "replaceStatusCode", never[], import("@typescript-eslint/utils/ts-eslint").RuleListener>;
|
|
18
|
-
"fetch-response-body-json": import("@typescript-eslint/utils/ts-eslint").RuleModule<"unknownError" | "replaceBodyWithJson", never[], import("@typescript-eslint/utils/ts-eslint").RuleListener>;
|
|
19
|
-
"fetch-response-header-getter-ts": import("@typescript-eslint/utils/ts-eslint").RuleModule<"unknownError" | "useGetter", never[], import("@typescript-eslint/utils/ts-eslint").RuleListener>;
|
|
20
|
-
"add-url-domain": import("@typescript-eslint/utils/ts-eslint").RuleModule<"addDomain" | "unknownError", never[], import("@typescript-eslint/utils/ts-eslint").RuleListener>;
|
|
21
|
-
"no-full-response": import("@typescript-eslint/utils/ts-eslint").RuleModule<"unknownError" | "removeFullResponse", never[], import("@typescript-eslint/utils/ts-eslint").RuleListener>;
|
|
22
|
-
"no-mapped-response": import("@typescript-eslint/utils/ts-eslint").RuleModule<"unknownError" | "replaceFullResponseWithFetchResponse", never[], import("@typescript-eslint/utils/ts-eslint").RuleListener>;
|
|
23
|
-
"require-resolve-full-response": import("@typescript-eslint/utils/ts-eslint").RuleModule<"unknownError" | "invalidOptions", never[], import("@typescript-eslint/utils/ts-eslint").RuleListener>;
|
|
14
|
+
"require-resolve-full-response": import("@typescript-eslint/utils/ts-eslint").RuleModule<"invalidOptions" | "unknownError", never[], import("@typescript-eslint/utils/ts-eslint").RuleListener>;
|
|
24
15
|
};
|
|
25
16
|
configs: {
|
|
26
17
|
all: {
|
|
@@ -36,15 +27,7 @@ declare const _default: {
|
|
|
36
27
|
'@checkdigit/no-test-import': string;
|
|
37
28
|
"@checkdigit/invalid-json-stringify": string;
|
|
38
29
|
"@checkdigit/no-promise-instance-method": string;
|
|
39
|
-
"@checkdigit/no-full-response": string;
|
|
40
30
|
"@checkdigit/require-resolve-full-response": string;
|
|
41
|
-
"@checkdigit/add-url-domain": string;
|
|
42
|
-
"@checkdigit/no-fixture": string;
|
|
43
|
-
"@checkdigit/no-service-wrapper": string;
|
|
44
|
-
"@checkdigit/no-status-code": string;
|
|
45
|
-
"@checkdigit/fetch-response-body-json": string;
|
|
46
|
-
"@checkdigit/fetch-response-header-getter-ts": string;
|
|
47
|
-
"@checkdigit/fetch-then": string;
|
|
48
31
|
};
|
|
49
32
|
};
|
|
50
33
|
recommended: {
|
|
@@ -62,38 +45,6 @@ declare const _default: {
|
|
|
62
45
|
"@checkdigit/no-promise-instance-method": string;
|
|
63
46
|
};
|
|
64
47
|
};
|
|
65
|
-
'agent-phase-1-test': {
|
|
66
|
-
overrides: {
|
|
67
|
-
files: string[];
|
|
68
|
-
}[];
|
|
69
|
-
rules: {
|
|
70
|
-
"@checkdigit/no-full-response": string;
|
|
71
|
-
"@checkdigit/require-resolve-full-response": string;
|
|
72
|
-
"@checkdigit/no-mapped-response": string;
|
|
73
|
-
"@checkdigit/add-url-domain": string;
|
|
74
|
-
"@checkdigit/no-fixture": string;
|
|
75
|
-
"@checkdigit/no-service-wrapper": string;
|
|
76
|
-
"@checkdigit/no-status-code": string;
|
|
77
|
-
"@checkdigit/fetch-response-body-json": string;
|
|
78
|
-
"@checkdigit/fetch-response-header-getter-ts": string;
|
|
79
|
-
"@checkdigit/fetch-then": string;
|
|
80
|
-
};
|
|
81
|
-
};
|
|
82
|
-
'agent-phase-2-production': {
|
|
83
|
-
ignorePatterns: string[];
|
|
84
|
-
rules: {
|
|
85
|
-
"@checkdigit/no-full-response": string;
|
|
86
|
-
"@checkdigit/require-resolve-full-response": string;
|
|
87
|
-
"@checkdigit/no-mapped-response": string;
|
|
88
|
-
"@checkdigit/add-url-domain": string;
|
|
89
|
-
"@checkdigit/no-fixture": string;
|
|
90
|
-
"@checkdigit/no-service-wrapper": string;
|
|
91
|
-
"@checkdigit/no-status-code": string;
|
|
92
|
-
"@checkdigit/fetch-response-body-json": string;
|
|
93
|
-
"@checkdigit/fetch-response-header-getter-ts": string;
|
|
94
|
-
"@checkdigit/fetch-then": string;
|
|
95
|
-
};
|
|
96
|
-
};
|
|
97
48
|
};
|
|
98
49
|
};
|
|
99
50
|
export default _default;
|
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
import { ESLintUtils } from '@typescript-eslint/utils';
|
|
2
2
|
export declare const ruleId = "require-resolve-full-response";
|
|
3
|
-
declare const
|
|
3
|
+
export declare const PLAIN_URL_REGEXP: RegExp;
|
|
4
|
+
export declare const TOKENIZED_URL_REGEXP: RegExp;
|
|
5
|
+
declare const rule: ESLintUtils.RuleModule<"invalidOptions" | "unknownError", never[], ESLintUtils.RuleListener>;
|
|
4
6
|
export default rule;
|
package/package.json
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"name":"@checkdigit/eslint-plugin","version":"6.6.0-PR.
|
|
1
|
+
{"name":"@checkdigit/eslint-plugin","version":"6.6.0-PR.77-5328","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","require":"./dist-cjs/index.cjs","import":"./dist-mjs/index.mjs","default":"./dist-mjs/index.mjs"}},"files":["src","dist-types","dist-cjs","dist-mjs","!src/**/*.test.ts","!src/**/*.spec.ts","!dist-types/**/*.test.d.ts","!dist-types/**/*.spec.d.ts","!dist-cjs/**/*.test.cjs","!dist-cjs/**/*.spec.cjs","!dist-mjs/**/*.test.mjs","!dist-mjs/**/*.spec.mjs","SECURITY.md"],"scripts":{"build:dist-cjs":"rimraf dist-cjs && npx builder --type=commonjs --sourceMap --entryPoint=index.ts --outDir=dist-cjs --outFile=index.cjs --external=espree && echo \"module.exports = module.exports.default;\" >> dist-cjs/index.cjs && node dist-cjs/index.cjs","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 --ignore-path .gitignore .","lint:fix":"eslint --ignore-path .gitignore . --fix","prepublishOnly":"npm run build:dist-types && npm run build:dist-cjs && 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":"7.18.0","@typescript-eslint/utils":"7.18.0","ts-api-utils":"^1.3.0"},"devDependencies":{"@checkdigit/jest-config":"^6.0.2","@checkdigit/prettier-config":"^5.5.0","@checkdigit/typescript-config":"6.0.0","@types/eslint":"8.56.10","@typescript-eslint/eslint-plugin":"7.18.0","@typescript-eslint/parser":"7.18.0","@typescript-eslint/rule-tester":"7.18.0","eslint-config-prettier":"^9.1.0","eslint-plugin-eslint-plugin":"^6.2.0","eslint-plugin-import":"^2.29.1","eslint-plugin-no-only-tests":"^3.1.0","eslint-plugin-no-secrets":"^1.0.2","eslint-plugin-node":"^11.1.0","eslint-plugin-sonarjs":"0.24.0","http-status-codes":"^2.3.0"},"peerDependencies":{"eslint":">=8 <9"},"engines":{"node":">=20.14"}}
|
package/src/index.ts
CHANGED
|
@@ -6,19 +6,8 @@
|
|
|
6
6
|
* This code is licensed under the MIT license (see LICENSE.txt for details).
|
|
7
7
|
*/
|
|
8
8
|
|
|
9
|
-
import addUrlDomain, { ruleId as addUrlDomainRuleId } from './agent/add-url-domain';
|
|
10
|
-
import fetchResponseBodyJson, { ruleId as fetchResponseBodyJsonRuleId } from './agent/fetch-response-body-json';
|
|
11
|
-
import fetchResponseHeaderGetter, {
|
|
12
|
-
ruleId as fetchResponseHeaderGetterRuleId,
|
|
13
|
-
} from './agent/fetch-response-header-getter';
|
|
14
|
-
import fetchThen, { ruleId as fetchThenRuleId } from './agent/fetch-then';
|
|
15
9
|
import invalidJsonStringify, { ruleId as invalidJsonStringifyRuleId } from './invalid-json-stringify';
|
|
16
|
-
import noFixture, { ruleId as noFixtureRuleId } from './agent/no-fixture';
|
|
17
|
-
import noFullResponse, { ruleId as noFullResponseRuleId } from './agent/no-full-response';
|
|
18
|
-
import noMappedResponse, { ruleId as noMappedResponseRuleId } from './agent/no-mapped-response';
|
|
19
10
|
import noPromiseInstanceMethod, { ruleId as noPromiseInstanceMethodRuleId } from './no-promise-instance-method';
|
|
20
|
-
import noServiceWrapper, { ruleId as noServiceWrapperRuleId } from './agent/no-service-wrapper';
|
|
21
|
-
import noStatusCode, { ruleId as noStatusCodeRuleId } from './agent/no-status-code';
|
|
22
11
|
import requireResolveFullResponse, {
|
|
23
12
|
ruleId as requireResolveFullResponseRuleId,
|
|
24
13
|
} from './require-resolve-full-response';
|
|
@@ -45,15 +34,6 @@ export default {
|
|
|
45
34
|
'object-literal-response': objectLiteralResponse,
|
|
46
35
|
[invalidJsonStringifyRuleId]: invalidJsonStringify,
|
|
47
36
|
[noPromiseInstanceMethodRuleId]: noPromiseInstanceMethod,
|
|
48
|
-
[noFixtureRuleId]: noFixture,
|
|
49
|
-
[fetchThenRuleId]: fetchThen,
|
|
50
|
-
[noServiceWrapperRuleId]: noServiceWrapper,
|
|
51
|
-
[noStatusCodeRuleId]: noStatusCode,
|
|
52
|
-
[fetchResponseBodyJsonRuleId]: fetchResponseBodyJson,
|
|
53
|
-
[fetchResponseHeaderGetterRuleId]: fetchResponseHeaderGetter,
|
|
54
|
-
[addUrlDomainRuleId]: addUrlDomain,
|
|
55
|
-
[noFullResponseRuleId]: noFullResponse,
|
|
56
|
-
[noMappedResponseRuleId]: noMappedResponse,
|
|
57
37
|
[requireResolveFullResponseRuleId]: requireResolveFullResponse,
|
|
58
38
|
},
|
|
59
39
|
configs: {
|
|
@@ -70,15 +50,7 @@ export default {
|
|
|
70
50
|
'@checkdigit/no-test-import': 'error',
|
|
71
51
|
[`@checkdigit/${invalidJsonStringifyRuleId}`]: 'error',
|
|
72
52
|
[`@checkdigit/${noPromiseInstanceMethodRuleId}`]: 'error',
|
|
73
|
-
[`@checkdigit/${noFullResponseRuleId}`]: 'error',
|
|
74
53
|
[`@checkdigit/${requireResolveFullResponseRuleId}`]: 'error',
|
|
75
|
-
[`@checkdigit/${addUrlDomainRuleId}`]: 'off',
|
|
76
|
-
[`@checkdigit/${noFixtureRuleId}`]: 'off',
|
|
77
|
-
[`@checkdigit/${noServiceWrapperRuleId}`]: 'off',
|
|
78
|
-
[`@checkdigit/${noStatusCodeRuleId}`]: 'off',
|
|
79
|
-
[`@checkdigit/${fetchResponseBodyJsonRuleId}`]: 'off',
|
|
80
|
-
[`@checkdigit/${fetchResponseHeaderGetterRuleId}`]: 'off',
|
|
81
|
-
[`@checkdigit/${fetchThenRuleId}`]: 'off',
|
|
82
54
|
},
|
|
83
55
|
},
|
|
84
56
|
recommended: {
|
|
@@ -96,39 +68,5 @@ export default {
|
|
|
96
68
|
[`@checkdigit/${noPromiseInstanceMethodRuleId}`]: 'error',
|
|
97
69
|
},
|
|
98
70
|
},
|
|
99
|
-
'agent-phase-1-test': {
|
|
100
|
-
overrides: [
|
|
101
|
-
{
|
|
102
|
-
files: ['*.spec.ts', '*.test.ts', 'src/api/v*/index.ts'],
|
|
103
|
-
},
|
|
104
|
-
],
|
|
105
|
-
rules: {
|
|
106
|
-
[`@checkdigit/${noFullResponseRuleId}`]: 'error',
|
|
107
|
-
[`@checkdigit/${requireResolveFullResponseRuleId}`]: 'error',
|
|
108
|
-
[`@checkdigit/${noMappedResponseRuleId}`]: 'error',
|
|
109
|
-
[`@checkdigit/${addUrlDomainRuleId}`]: 'error',
|
|
110
|
-
[`@checkdigit/${noFixtureRuleId}`]: 'error',
|
|
111
|
-
[`@checkdigit/${noServiceWrapperRuleId}`]: 'error',
|
|
112
|
-
[`@checkdigit/${noStatusCodeRuleId}`]: 'error',
|
|
113
|
-
[`@checkdigit/${fetchResponseBodyJsonRuleId}`]: 'error',
|
|
114
|
-
[`@checkdigit/${fetchResponseHeaderGetterRuleId}`]: 'error',
|
|
115
|
-
[`@checkdigit/${fetchThenRuleId}`]: 'error',
|
|
116
|
-
},
|
|
117
|
-
},
|
|
118
|
-
'agent-phase-2-production': {
|
|
119
|
-
ignorePatterns: ['*.spec.ts', '*.test.ts'],
|
|
120
|
-
rules: {
|
|
121
|
-
[`@checkdigit/${noFullResponseRuleId}`]: 'error',
|
|
122
|
-
[`@checkdigit/${requireResolveFullResponseRuleId}`]: 'error',
|
|
123
|
-
[`@checkdigit/${noMappedResponseRuleId}`]: 'error',
|
|
124
|
-
[`@checkdigit/${addUrlDomainRuleId}`]: 'error',
|
|
125
|
-
[`@checkdigit/${noFixtureRuleId}`]: 'off',
|
|
126
|
-
[`@checkdigit/${noServiceWrapperRuleId}`]: 'error',
|
|
127
|
-
[`@checkdigit/${noStatusCodeRuleId}`]: 'error',
|
|
128
|
-
[`@checkdigit/${fetchResponseBodyJsonRuleId}`]: 'error',
|
|
129
|
-
[`@checkdigit/${fetchResponseHeaderGetterRuleId}`]: 'error',
|
|
130
|
-
[`@checkdigit/${fetchThenRuleId}`]: 'error',
|
|
131
|
-
},
|
|
132
|
-
},
|
|
133
71
|
},
|
|
134
72
|
};
|
|
@@ -8,12 +8,13 @@
|
|
|
8
8
|
|
|
9
9
|
import { AST_NODE_TYPES, ESLintUtils, TSESTree } from '@typescript-eslint/utils';
|
|
10
10
|
import { DefinitionType, type Scope } from '@typescript-eslint/scope-manager';
|
|
11
|
-
import { PLAIN_URL_REGEXP, TOKENIZED_URL_REGEXP } from './agent/url';
|
|
12
11
|
import { strict as assert } from 'node:assert';
|
|
13
12
|
import getDocumentationUrl from './get-documentation-url';
|
|
14
13
|
import { getEnclosingScopeNode } from './library/ts-tree';
|
|
15
14
|
|
|
16
15
|
export const ruleId = 'require-resolve-full-response';
|
|
16
|
+
export const PLAIN_URL_REGEXP = /^[`']\/\w+(?<serviceNamePart>-\w+)*\/v\d+\/(?<any>.|\r|\n)+[`']$/u;
|
|
17
|
+
export const TOKENIZED_URL_REGEXP = /^`\$\{(?<serviceNamePart>[A-Z]+_)*BASE_PATH\}\/(?<any>.|\r|\n)+`$/u;
|
|
17
18
|
|
|
18
19
|
const createRule = ESLintUtils.RuleCreator((name) => getDocumentationUrl(name));
|
|
19
20
|
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
// src/agent/add-url-domain.ts
|
|
2
|
-
import { AST_NODE_TYPES, ESLintUtils } from "@typescript-eslint/utils";
|
|
3
|
-
import { addBasePathUrlDomain } from "./url.mjs";
|
|
4
|
-
import getDocumentationUrl from "../get-documentation-url.mjs";
|
|
5
|
-
var ruleId = "add-url-domain";
|
|
6
|
-
var createRule = ESLintUtils.RuleCreator((name) => getDocumentationUrl(name));
|
|
7
|
-
var rule = createRule({
|
|
8
|
-
name: ruleId,
|
|
9
|
-
meta: {
|
|
10
|
-
type: "suggestion",
|
|
11
|
-
docs: {
|
|
12
|
-
description: "Add HTTP domain to the BASE_PATH like url constant variable."
|
|
13
|
-
},
|
|
14
|
-
messages: {
|
|
15
|
-
addDomain: "Add HTTP domain to the BASE_PATH like url constant variable.",
|
|
16
|
-
unknownError: 'Unknown error occurred in file "{{fileName}}": {{ error }}.'
|
|
17
|
-
},
|
|
18
|
-
fixable: "code",
|
|
19
|
-
schema: []
|
|
20
|
-
},
|
|
21
|
-
defaultOptions: [],
|
|
22
|
-
create(context) {
|
|
23
|
-
const sourceCode = context.sourceCode;
|
|
24
|
-
return {
|
|
25
|
-
"VariableDeclarator[id.name=/^([A-Z]+_)*BASE_PATH$/]": (basePathDeclarator) => {
|
|
26
|
-
try {
|
|
27
|
-
if (basePathDeclarator.init === null || basePathDeclarator.init.type !== AST_NODE_TYPES.Literal && basePathDeclarator.init.type !== AST_NODE_TYPES.TemplateLiteral) {
|
|
28
|
-
return;
|
|
29
|
-
}
|
|
30
|
-
const urlText = sourceCode.getText(basePathDeclarator.init);
|
|
31
|
-
const replacement = addBasePathUrlDomain(urlText);
|
|
32
|
-
if (replacement !== urlText) {
|
|
33
|
-
context.report({
|
|
34
|
-
messageId: "addDomain",
|
|
35
|
-
node: basePathDeclarator.init,
|
|
36
|
-
fix(fixer) {
|
|
37
|
-
return fixer.replaceText(basePathDeclarator.init, replacement);
|
|
38
|
-
}
|
|
39
|
-
});
|
|
40
|
-
}
|
|
41
|
-
} catch (error) {
|
|
42
|
-
console.error(`Failed to apply ${ruleId} rule for file "${context.filename}":`, error);
|
|
43
|
-
context.report({
|
|
44
|
-
node: basePathDeclarator,
|
|
45
|
-
messageId: "unknownError",
|
|
46
|
-
data: {
|
|
47
|
-
fileName: context.filename,
|
|
48
|
-
error: error instanceof Error ? error.toString() : JSON.stringify(error)
|
|
49
|
-
}
|
|
50
|
-
});
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
};
|
|
54
|
-
}
|
|
55
|
-
});
|
|
56
|
-
var add_url_domain_default = rule;
|
|
57
|
-
export {
|
|
58
|
-
add_url_domain_default as default,
|
|
59
|
-
ruleId
|
|
60
|
-
};
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FnZW50L2FkZC11cmwtZG9tYWluLnRzIl0sCiAgIm1hcHBpbmdzIjogIjtBQVFBLFNBQVMsZ0JBQWdCLG1CQUE2QjtBQUN0RCxTQUFTLDRCQUE0QjtBQUNyQyxPQUFPLHlCQUF5QjtBQUV6QixJQUFNLFNBQVM7QUFFdEIsSUFBTSxhQUFhLFlBQVksWUFBWSxDQUFDLFNBQVMsb0JBQW9CLElBQUksQ0FBQztBQUU5RSxJQUFNLE9BQU8sV0FBVztBQUFBLEVBQ3RCLE1BQU07QUFBQSxFQUNOLE1BQU07QUFBQSxJQUNKLE1BQU07QUFBQSxJQUNOLE1BQU07QUFBQSxNQUNKLGFBQWE7QUFBQSxJQUNmO0FBQUEsSUFDQSxVQUFVO0FBQUEsTUFDUixXQUFXO0FBQUEsTUFDWCxjQUFjO0FBQUEsSUFDaEI7QUFBQSxJQUNBLFNBQVM7QUFBQSxJQUNULFFBQVEsQ0FBQztBQUFBLEVBQ1g7QUFBQSxFQUNBLGdCQUFnQixDQUFDO0FBQUEsRUFDakIsT0FBTyxTQUFTO0FBQ2QsVUFBTSxhQUFhLFFBQVE7QUFFM0IsV0FBTztBQUFBLE1BQ0wsdURBQXVELENBQUMsdUJBQW9EO0FBQzFHLFlBQUk7QUFDRixjQUNFLG1CQUFtQixTQUFTLFFBQzNCLG1CQUFtQixLQUFLLFNBQVMsZUFBZSxXQUMvQyxtQkFBbUIsS0FBSyxTQUFTLGVBQWUsaUJBQ2xEO0FBQ0E7QUFBQSxVQUNGO0FBRUEsZ0JBQU0sVUFBVSxXQUFXLFFBQVEsbUJBQW1CLElBQUk7QUFDMUQsZ0JBQU0sY0FBYyxxQkFBcUIsT0FBTztBQUVoRCxjQUFJLGdCQUFnQixTQUFTO0FBQzNCLG9CQUFRLE9BQU87QUFBQSxjQUNiLFdBQVc7QUFBQSxjQUNYLE1BQU0sbUJBQW1CO0FBQUEsY0FDekIsSUFBSSxPQUFPO0FBQ1QsdUJBQU8sTUFBTSxZQUFZLG1CQUFtQixNQUF1QixXQUFXO0FBQUEsY0FDaEY7QUFBQSxZQUNGLENBQUM7QUFBQSxVQUNIO0FBQUEsUUFDRixTQUFTLE9BQU87QUFFZCxrQkFBUSxNQUFNLG1CQUFtQixNQUFNLG1CQUFtQixRQUFRLFFBQVEsTUFBTSxLQUFLO0FBQ3JGLGtCQUFRLE9BQU87QUFBQSxZQUNiLE1BQU07QUFBQSxZQUNOLFdBQVc7QUFBQSxZQUNYLE1BQU07QUFBQSxjQUNKLFVBQVUsUUFBUTtBQUFBLGNBQ2xCLE9BQU8saUJBQWlCLFFBQVEsTUFBTSxTQUFTLElBQUksS0FBSyxVQUFVLEtBQUs7QUFBQSxZQUN6RTtBQUFBLFVBQ0YsQ0FBQztBQUFBLFFBQ0g7QUFBQSxNQUNGO0FBQUEsSUFDRjtBQUFBLEVBQ0Y7QUFDRixDQUFDO0FBRUQsSUFBTyx5QkFBUTsiLAogICJuYW1lcyI6IFtdCn0K
|
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
// src/agent/fetch-response-body-json.ts
|
|
2
|
-
import { AST_NODE_TYPES, ESLintUtils } from "@typescript-eslint/utils";
|
|
3
|
-
import getDocumentationUrl from "../get-documentation-url.mjs";
|
|
4
|
-
var ruleId = "fetch-response-body-json";
|
|
5
|
-
var createRule = ESLintUtils.RuleCreator((name) => getDocumentationUrl(name));
|
|
6
|
-
var rule = createRule({
|
|
7
|
-
name: ruleId,
|
|
8
|
-
meta: {
|
|
9
|
-
type: "suggestion",
|
|
10
|
-
docs: {
|
|
11
|
-
description: 'Replace "response.body" with "await response.json()".'
|
|
12
|
-
},
|
|
13
|
-
messages: {
|
|
14
|
-
replaceBodyWithJson: 'Replace "response.body" with "await response.json()".',
|
|
15
|
-
unknownError: 'Unknown error occurred in file "{{fileName}}": {{ error }}.'
|
|
16
|
-
},
|
|
17
|
-
fixable: "code",
|
|
18
|
-
schema: []
|
|
19
|
-
},
|
|
20
|
-
defaultOptions: [],
|
|
21
|
-
create(context) {
|
|
22
|
-
const parserServices = ESLintUtils.getParserServices(context);
|
|
23
|
-
const typeChecker = parserServices.program.getTypeChecker();
|
|
24
|
-
const sourceCode = context.sourceCode;
|
|
25
|
-
return {
|
|
26
|
-
'MemberExpression[property.name="body"]': (responseBody) => {
|
|
27
|
-
try {
|
|
28
|
-
const responseNode = parserServices.esTreeNodeToTSNodeMap.get(responseBody.object);
|
|
29
|
-
const responseType = typeChecker.getTypeAtLocation(responseNode);
|
|
30
|
-
const shouldReplace = responseType.getProperties().some((symbol) => symbol.name === "body") && responseType.getProperties().some((symbol) => symbol.name === "json");
|
|
31
|
-
if (shouldReplace) {
|
|
32
|
-
const responseText = sourceCode.getText(responseBody.object);
|
|
33
|
-
const needAwait = responseBody.parent.type !== AST_NODE_TYPES.ReturnStatement;
|
|
34
|
-
const replacementText = needAwait ? `(await ${responseText}.json())` : `${responseText}.json()`;
|
|
35
|
-
context.report({
|
|
36
|
-
messageId: "replaceBodyWithJson",
|
|
37
|
-
node: responseBody,
|
|
38
|
-
fix(fixer) {
|
|
39
|
-
return fixer.replaceText(responseBody, replacementText);
|
|
40
|
-
}
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
} catch (error) {
|
|
44
|
-
console.error(`Failed to apply ${ruleId} rule for file "${context.filename}":`, error);
|
|
45
|
-
context.report({
|
|
46
|
-
node: responseBody,
|
|
47
|
-
messageId: "unknownError",
|
|
48
|
-
data: {
|
|
49
|
-
fileName: context.filename,
|
|
50
|
-
error: error instanceof Error ? error.toString() : JSON.stringify(error)
|
|
51
|
-
}
|
|
52
|
-
});
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
};
|
|
56
|
-
}
|
|
57
|
-
});
|
|
58
|
-
var fetch_response_body_json_default = rule;
|
|
59
|
-
export {
|
|
60
|
-
fetch_response_body_json_default as default,
|
|
61
|
-
ruleId
|
|
62
|
-
};
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FnZW50L2ZldGNoLXJlc3BvbnNlLWJvZHktanNvbi50cyJdLAogICJtYXBwaW5ncyI6ICI7QUFRQSxTQUFTLGdCQUFnQixtQkFBNkI7QUFDdEQsT0FBTyx5QkFBeUI7QUFFekIsSUFBTSxTQUFTO0FBRXRCLElBQU0sYUFBYSxZQUFZLFlBQVksQ0FBQyxTQUFTLG9CQUFvQixJQUFJLENBQUM7QUFFOUUsSUFBTSxPQUFPLFdBQVc7QUFBQSxFQUN0QixNQUFNO0FBQUEsRUFDTixNQUFNO0FBQUEsSUFDSixNQUFNO0FBQUEsSUFDTixNQUFNO0FBQUEsTUFDSixhQUFhO0FBQUEsSUFDZjtBQUFBLElBQ0EsVUFBVTtBQUFBLE1BQ1IscUJBQXFCO0FBQUEsTUFDckIsY0FBYztBQUFBLElBQ2hCO0FBQUEsSUFDQSxTQUFTO0FBQUEsSUFDVCxRQUFRLENBQUM7QUFBQSxFQUNYO0FBQUEsRUFDQSxnQkFBZ0IsQ0FBQztBQUFBLEVBQ2pCLE9BQU8sU0FBUztBQUNkLFVBQU0saUJBQWlCLFlBQVksa0JBQWtCLE9BQU87QUFDNUQsVUFBTSxjQUFjLGVBQWUsUUFBUSxlQUFlO0FBQzFELFVBQU0sYUFBYSxRQUFRO0FBRTNCLFdBQU87QUFBQSxNQUNMLDBDQUEwQyxDQUFDLGlCQUE0QztBQUNyRixZQUFJO0FBQ0YsZ0JBQU0sZUFBZSxlQUFlLHNCQUFzQixJQUFJLGFBQWEsTUFBTTtBQUNqRixnQkFBTSxlQUFlLFlBQVksa0JBQWtCLFlBQVk7QUFFL0QsZ0JBQU0sZ0JBQ0osYUFBYSxjQUFjLEVBQUUsS0FBSyxDQUFDLFdBQVcsT0FBTyxTQUFTLE1BQU0sS0FDcEUsYUFBYSxjQUFjLEVBQUUsS0FBSyxDQUFDLFdBQVcsT0FBTyxTQUFTLE1BQU07QUFFdEUsY0FBSSxlQUFlO0FBQ2pCLGtCQUFNLGVBQWUsV0FBVyxRQUFRLGFBQWEsTUFBTTtBQUMzRCxrQkFBTSxZQUFZLGFBQWEsT0FBTyxTQUFTLGVBQWU7QUFDOUQsa0JBQU0sa0JBQWtCLFlBQVksVUFBVSxZQUFZLGFBQWEsR0FBRyxZQUFZO0FBRXRGLG9CQUFRLE9BQU87QUFBQSxjQUNiLFdBQVc7QUFBQSxjQUNYLE1BQU07QUFBQSxjQUNOLElBQUksT0FBTztBQUNULHVCQUFPLE1BQU0sWUFBWSxjQUFjLGVBQWU7QUFBQSxjQUN4RDtBQUFBLFlBQ0YsQ0FBQztBQUFBLFVBQ0g7QUFBQSxRQUNGLFNBQVMsT0FBTztBQUVkLGtCQUFRLE1BQU0sbUJBQW1CLE1BQU0sbUJBQW1CLFFBQVEsUUFBUSxNQUFNLEtBQUs7QUFDckYsa0JBQVEsT0FBTztBQUFBLFlBQ2IsTUFBTTtBQUFBLFlBQ04sV0FBVztBQUFBLFlBQ1gsTUFBTTtBQUFBLGNBQ0osVUFBVSxRQUFRO0FBQUEsY0FDbEIsT0FBTyxpQkFBaUIsUUFBUSxNQUFNLFNBQVMsSUFBSSxLQUFLLFVBQVUsS0FBSztBQUFBLFlBQ3pFO0FBQUEsVUFDRixDQUFDO0FBQUEsUUFDSDtBQUFBLE1BQ0Y7QUFBQSxJQUNGO0FBQUEsRUFDRjtBQUNGLENBQUM7QUFFRCxJQUFPLG1DQUFROyIsCiAgIm5hbWVzIjogW10KfQo=
|
|
@@ -1,117 +0,0 @@
|
|
|
1
|
-
// src/agent/fetch-response-header-getter.ts
|
|
2
|
-
import { AST_NODE_TYPES, ESLintUtils } from "@typescript-eslint/utils";
|
|
3
|
-
import getDocumentationUrl from "../get-documentation-url.mjs";
|
|
4
|
-
var ruleId = "fetch-response-header-getter-ts";
|
|
5
|
-
var HEADER_BUILTIN_FUNCTIONS = Object.keys(Headers.prototype);
|
|
6
|
-
var createRule = ESLintUtils.RuleCreator((name) => getDocumentationUrl(name));
|
|
7
|
-
var rule = createRule({
|
|
8
|
-
name: ruleId,
|
|
9
|
-
meta: {
|
|
10
|
-
type: "suggestion",
|
|
11
|
-
docs: {
|
|
12
|
-
description: 'Use "get()" method to get header value from the headers object of the fetch response.'
|
|
13
|
-
},
|
|
14
|
-
messages: {
|
|
15
|
-
useGetter: 'Use "get()" method to get header value from the headers object of the fetch response.',
|
|
16
|
-
unknownError: 'Unknown error occurred in file "{{fileName}}": {{ error }}.'
|
|
17
|
-
},
|
|
18
|
-
fixable: "code",
|
|
19
|
-
schema: []
|
|
20
|
-
},
|
|
21
|
-
defaultOptions: [],
|
|
22
|
-
create(context) {
|
|
23
|
-
const parserServices = ESLintUtils.getParserServices(context);
|
|
24
|
-
const typeChecker = parserServices.program.getTypeChecker();
|
|
25
|
-
const sourceCode = context.sourceCode;
|
|
26
|
-
return {
|
|
27
|
-
MemberExpression: (responseHeadersAccess) => {
|
|
28
|
-
try {
|
|
29
|
-
if (responseHeadersAccess.property.type === AST_NODE_TYPES.Identifier && HEADER_BUILTIN_FUNCTIONS.includes(responseHeadersAccess.property.name)) {
|
|
30
|
-
return;
|
|
31
|
-
}
|
|
32
|
-
const responseHeadersTsNode = parserServices.esTreeNodeToTSNodeMap.get(responseHeadersAccess.object);
|
|
33
|
-
let responseHeadersType = typeChecker.getTypeAtLocation(responseHeadersTsNode);
|
|
34
|
-
responseHeadersType = responseHeadersType.isUnion() ? responseHeadersType.types[0] : responseHeadersType;
|
|
35
|
-
const responseHeadersTypeName = (
|
|
36
|
-
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
|
|
37
|
-
(responseHeadersType.symbol ?? responseHeadersType.aliasSymbol)?.escapedName
|
|
38
|
-
);
|
|
39
|
-
if (responseHeadersTypeName !== "Headers" && responseHeadersTypeName !== "HeaderGetter") {
|
|
40
|
-
return;
|
|
41
|
-
}
|
|
42
|
-
let replacementText;
|
|
43
|
-
if (!responseHeadersAccess.computed) {
|
|
44
|
-
replacementText = `${sourceCode.getText(responseHeadersAccess.object)}.get('${sourceCode.getText(responseHeadersAccess.property)}')`;
|
|
45
|
-
} else if (responseHeadersAccess.property.type === AST_NODE_TYPES.Identifier || responseHeadersAccess.property.type === AST_NODE_TYPES.Literal || responseHeadersAccess.property.type === AST_NODE_TYPES.TemplateLiteral) {
|
|
46
|
-
replacementText = `${sourceCode.getText(responseHeadersAccess.object)}.get(${sourceCode.getText(responseHeadersAccess.property)})`;
|
|
47
|
-
} else {
|
|
48
|
-
throw new Error(`Unexpected property type: ${responseHeadersAccess.property.type}`);
|
|
49
|
-
}
|
|
50
|
-
context.report({
|
|
51
|
-
messageId: "useGetter",
|
|
52
|
-
node: responseHeadersAccess.property,
|
|
53
|
-
fix(fixer) {
|
|
54
|
-
return fixer.replaceText(responseHeadersAccess, replacementText);
|
|
55
|
-
}
|
|
56
|
-
});
|
|
57
|
-
} catch (error) {
|
|
58
|
-
console.error(`Failed to apply ${ruleId} rule for file "${context.filename}":`, error);
|
|
59
|
-
context.report({
|
|
60
|
-
node: responseHeadersAccess,
|
|
61
|
-
messageId: "unknownError",
|
|
62
|
-
data: {
|
|
63
|
-
fileName: context.filename,
|
|
64
|
-
error: error instanceof Error ? error.toString() : JSON.stringify(error)
|
|
65
|
-
}
|
|
66
|
-
});
|
|
67
|
-
}
|
|
68
|
-
},
|
|
69
|
-
// convert response.get() to response.headers.get()
|
|
70
|
-
'CallExpression[callee.property.name="get"]': (responseHeadersAccess) => {
|
|
71
|
-
try {
|
|
72
|
-
if (responseHeadersAccess.callee.type !== AST_NODE_TYPES.MemberExpression) {
|
|
73
|
-
return;
|
|
74
|
-
}
|
|
75
|
-
if (responseHeadersAccess.callee.object.type !== AST_NODE_TYPES.Identifier || responseHeadersAccess.callee.object.name === "request") {
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
const responseNode = responseHeadersAccess.callee.object;
|
|
79
|
-
const responseHeadersTsNode = parserServices.esTreeNodeToTSNodeMap.get(responseNode);
|
|
80
|
-
const responseType = typeChecker.getTypeAtLocation(responseHeadersTsNode);
|
|
81
|
-
const typeName = typeChecker.typeToString(responseType);
|
|
82
|
-
if (typeName === "InboundContext" || typeName.endsWith("RequestType")) {
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
const hasHeadersProperty = responseType.getProperties().some((symbol) => symbol.name === "headers");
|
|
86
|
-
if (!hasHeadersProperty) {
|
|
87
|
-
return;
|
|
88
|
-
}
|
|
89
|
-
const replacementText = `${sourceCode.getText(responseNode)}.headers`;
|
|
90
|
-
context.report({
|
|
91
|
-
messageId: "useGetter",
|
|
92
|
-
node: responseHeadersAccess,
|
|
93
|
-
fix(fixer) {
|
|
94
|
-
return fixer.replaceText(responseNode, replacementText);
|
|
95
|
-
}
|
|
96
|
-
});
|
|
97
|
-
} catch (error) {
|
|
98
|
-
console.error(`Failed to apply ${ruleId} rule for file "${context.filename}":`, error);
|
|
99
|
-
context.report({
|
|
100
|
-
node: responseHeadersAccess,
|
|
101
|
-
messageId: "unknownError",
|
|
102
|
-
data: {
|
|
103
|
-
fileName: context.filename,
|
|
104
|
-
error: error instanceof Error ? error.toString() : JSON.stringify(error)
|
|
105
|
-
}
|
|
106
|
-
});
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
};
|
|
110
|
-
}
|
|
111
|
-
});
|
|
112
|
-
var fetch_response_header_getter_default = rule;
|
|
113
|
-
export {
|
|
114
|
-
fetch_response_header_getter_default as default,
|
|
115
|
-
ruleId
|
|
116
|
-
};
|
|
117
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FnZW50L2ZldGNoLXJlc3BvbnNlLWhlYWRlci1nZXR0ZXIudHMiXSwKICAibWFwcGluZ3MiOiAiO0FBUUEsU0FBUyxnQkFBZ0IsbUJBQTZCO0FBQ3RELE9BQU8seUJBQXlCO0FBRXpCLElBQU0sU0FBUztBQUN0QixJQUFNLDJCQUEyQixPQUFPLEtBQUssUUFBUSxTQUFTO0FBRTlELElBQU0sYUFBYSxZQUFZLFlBQVksQ0FBQyxTQUFTLG9CQUFvQixJQUFJLENBQUM7QUFFOUUsSUFBTSxPQUFPLFdBQVc7QUFBQSxFQUN0QixNQUFNO0FBQUEsRUFDTixNQUFNO0FBQUEsSUFDSixNQUFNO0FBQUEsSUFDTixNQUFNO0FBQUEsTUFDSixhQUFhO0FBQUEsSUFDZjtBQUFBLElBQ0EsVUFBVTtBQUFBLE1BQ1IsV0FBVztBQUFBLE1BQ1gsY0FBYztBQUFBLElBQ2hCO0FBQUEsSUFDQSxTQUFTO0FBQUEsSUFDVCxRQUFRLENBQUM7QUFBQSxFQUNYO0FBQUEsRUFDQSxnQkFBZ0IsQ0FBQztBQUFBLEVBQ2pCLE9BQU8sU0FBUztBQUNkLFVBQU0saUJBQWlCLFlBQVksa0JBQWtCLE9BQU87QUFDNUQsVUFBTSxjQUFjLGVBQWUsUUFBUSxlQUFlO0FBQzFELFVBQU0sYUFBYSxRQUFRO0FBRTNCLFdBQU87QUFBQSxNQUNMLGtCQUFrQixDQUFDLDBCQUFxRDtBQUN0RSxZQUFJO0FBQ0YsY0FDRSxzQkFBc0IsU0FBUyxTQUFTLGVBQWUsY0FDdkQseUJBQXlCLFNBQVMsc0JBQXNCLFNBQVMsSUFBSSxHQUNyRTtBQUVBO0FBQUEsVUFDRjtBQUVBLGdCQUFNLHdCQUF3QixlQUFlLHNCQUFzQixJQUFJLHNCQUFzQixNQUFNO0FBQ25HLGNBQUksc0JBQXNCLFlBQVksa0JBQWtCLHFCQUFxQjtBQUU3RSxnQ0FBc0Isb0JBQW9CLFFBQVEsSUFBSSxvQkFBb0IsTUFBTSxDQUFDLElBQUs7QUFFdEYsZ0JBQU07QUFBQTtBQUFBLGFBQ0gsb0JBQW9CLFVBQVUs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
|