-
-
Notifications
You must be signed in to change notification settings - Fork 2.7k
/
no-unsafe-call.ts
51 lines (47 loc) · 1.38 KB
/
no-unsafe-call.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
import { TSESTree } from '@typescript-eslint/experimental-utils';
import * as util from '../util';
type MessageIds = 'unsafeCall' | 'unsafeNew';
export default util.createRule<[], MessageIds>({
name: 'no-unsafe-call',
meta: {
type: 'problem',
docs: {
description: 'Disallows calling an any type value',
category: 'Possible Errors',
recommended: false,
requiresTypeChecking: true,
},
messages: {
unsafeCall: 'Unsafe call of an any typed value',
unsafeNew: 'Unsafe construction of an any type value',
},
schema: [],
},
defaultOptions: [],
create(context) {
const { program, esTreeNodeToTSNodeMap } = util.getParserServices(context);
const checker = program.getTypeChecker();
function checkCall(
node:
| TSESTree.CallExpression
| TSESTree.OptionalCallExpression
| TSESTree.NewExpression,
reportingNode: TSESTree.Expression = node.callee,
messageId: MessageIds = 'unsafeCall',
): void {
const tsNode = esTreeNodeToTSNodeMap.get(node.callee);
if (util.isAnyType(tsNode, checker)) {
context.report({
node: reportingNode,
messageId: messageId,
});
}
}
return {
'CallExpression, OptionalCallExpression': checkCall,
NewExpression(node): void {
checkCall(node, node, 'unsafeNew');
},
};
},
});