@nestia/core 10.0.2 → 11.0.0-dev.20260305
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/LICENSE +21 -21
- package/README.md +93 -93
- package/lib/adaptors/WebSocketAdaptor.js.map +1 -1
- package/lib/decorators/DynamicModule.js +54 -10
- package/lib/decorators/DynamicModule.js.map +1 -1
- package/lib/decorators/EncryptedBody.js +2 -2
- package/lib/decorators/EncryptedBody.js.map +1 -1
- package/lib/decorators/EncryptedController.d.ts +1 -1
- package/lib/decorators/EncryptedModule.d.ts +1 -1
- package/lib/decorators/EncryptedModule.js +54 -10
- package/lib/decorators/EncryptedModule.js.map +1 -1
- package/lib/decorators/EncryptedRoute.js +2 -2
- package/lib/decorators/EncryptedRoute.js.map +1 -1
- package/lib/decorators/HumanRoute.d.ts +1 -2
- package/lib/decorators/HumanRoute.js +1 -2
- package/lib/decorators/HumanRoute.js.map +1 -1
- package/lib/decorators/NoTransformConfigurationError.js +1 -1
- package/lib/decorators/NoTransformConfigurationError.js.map +1 -1
- package/lib/decorators/SwaggerCustomizer.d.ts +1 -1
- package/lib/decorators/TypedFormData.js.map +1 -1
- package/lib/decorators/TypedParam.js +1 -1
- package/lib/decorators/TypedParam.js.map +1 -1
- package/lib/decorators/internal/get_path_and_querify.js +1 -1
- package/lib/decorators/internal/get_path_and_querify.js.map +1 -1
- package/lib/decorators/internal/get_path_and_stringify.js +1 -1
- package/lib/decorators/internal/get_path_and_stringify.js.map +1 -1
- package/lib/decorators/internal/headers_to_object.js.map +1 -1
- package/lib/decorators/internal/validate_request_body.js +1 -1
- package/lib/decorators/internal/validate_request_body.js.map +1 -1
- package/lib/decorators/internal/validate_request_form_data.js +1 -1
- package/lib/decorators/internal/validate_request_form_data.js.map +1 -1
- package/lib/decorators/internal/validate_request_headers.js +1 -1
- package/lib/decorators/internal/validate_request_headers.js.map +1 -1
- package/lib/decorators/internal/validate_request_query.js +1 -1
- package/lib/decorators/internal/validate_request_query.js.map +1 -1
- package/lib/module.d.ts +1 -0
- package/lib/module.js +1 -0
- package/lib/module.js.map +1 -1
- package/lib/options/INestiaTransformProject.d.ts +1 -1
- package/lib/programmers/PlainBodyProgrammer.js +5 -8
- package/lib/programmers/PlainBodyProgrammer.js.map +1 -1
- package/lib/programmers/TypedBodyProgrammer.js +13 -21
- package/lib/programmers/TypedBodyProgrammer.js.map +1 -1
- package/lib/programmers/TypedFormDataBodyProgrammer.js +11 -20
- package/lib/programmers/TypedFormDataBodyProgrammer.js.map +1 -1
- package/lib/programmers/TypedHeadersProgrammer.js +4 -6
- package/lib/programmers/TypedHeadersProgrammer.js.map +1 -1
- package/lib/programmers/TypedParamProgrammer.js +2 -2
- package/lib/programmers/TypedParamProgrammer.js.map +1 -1
- package/lib/programmers/TypedQueryBodyProgrammer.js +9 -16
- package/lib/programmers/TypedQueryBodyProgrammer.js.map +1 -1
- package/lib/programmers/TypedQueryProgrammer.js +9 -16
- package/lib/programmers/TypedQueryProgrammer.js.map +1 -1
- package/lib/programmers/TypedQueryRouteProgrammer.js +6 -10
- package/lib/programmers/TypedQueryRouteProgrammer.js.map +1 -1
- package/lib/programmers/TypedRouteProgrammer.js +8 -13
- package/lib/programmers/TypedRouteProgrammer.js.map +1 -1
- package/lib/programmers/http/HttpAssertQuerifyProgrammer.d.ts +1 -1
- package/lib/programmers/http/HttpAssertQuerifyProgrammer.js +5 -7
- package/lib/programmers/http/HttpAssertQuerifyProgrammer.js.map +1 -1
- package/lib/programmers/http/HttpIsQuerifyProgrammer.d.ts +1 -1
- package/lib/programmers/http/HttpIsQuerifyProgrammer.js +5 -7
- package/lib/programmers/http/HttpIsQuerifyProgrammer.js.map +1 -1
- package/lib/programmers/http/HttpQuerifyProgrammer.d.ts +1 -1
- package/lib/programmers/http/HttpQuerifyProgrammer.js +13 -19
- package/lib/programmers/http/HttpQuerifyProgrammer.js.map +1 -1
- package/lib/programmers/http/HttpValidateQuerifyProgrammer.d.ts +1 -1
- package/lib/programmers/http/HttpValidateQuerifyProgrammer.js +6 -8
- package/lib/programmers/http/HttpValidateQuerifyProgrammer.js.map +1 -1
- package/lib/programmers/internal/CoreMetadataUtil.d.ts +3 -3
- package/lib/programmers/internal/CoreMetadataUtil.js.map +1 -1
- package/lib/transform.d.ts +1 -1
- package/lib/transform.js.map +1 -1
- package/lib/transformers/FileTransformer.js +2 -2
- package/lib/transformers/FileTransformer.js.map +1 -1
- package/lib/transformers/MethodTransformer.js.map +1 -1
- package/lib/transformers/ParameterDecoratorTransformer.js +1 -1
- package/lib/transformers/ParameterDecoratorTransformer.js.map +1 -1
- package/lib/transformers/TypedRouteTransformer.js +1 -1
- package/lib/transformers/TypedRouteTransformer.js.map +1 -1
- package/lib/transformers/WebSocketRouteTransformer.js +1 -1
- package/lib/transformers/WebSocketRouteTransformer.js.map +1 -1
- package/package.json +34 -26
- package/src/adaptors/WebSocketAdaptor.ts +429 -429
- package/src/decorators/DynamicModule.ts +44 -44
- package/src/decorators/EncryptedBody.ts +96 -97
- package/src/decorators/EncryptedController.ts +40 -40
- package/src/decorators/EncryptedModule.ts +98 -98
- package/src/decorators/EncryptedRoute.ts +212 -213
- package/src/decorators/HumanRoute.ts +21 -22
- package/src/decorators/NoTransformConfigurationError.ts +34 -34
- package/src/decorators/PlainBody.ts +76 -76
- package/src/decorators/SwaggerCustomizer.ts +97 -97
- package/src/decorators/SwaggerExample.ts +100 -100
- package/src/decorators/TypedBody.ts +57 -57
- package/src/decorators/TypedException.ts +147 -147
- package/src/decorators/TypedFormData.ts +187 -195
- package/src/decorators/TypedHeaders.ts +66 -66
- package/src/decorators/TypedParam.ts +77 -77
- package/src/decorators/TypedQuery.ts +234 -234
- package/src/decorators/TypedRoute.ts +196 -196
- package/src/decorators/WebSocketRoute.ts +242 -242
- package/src/decorators/internal/EncryptedConstant.ts +2 -2
- package/src/decorators/internal/IWebSocketRouteReflect.ts +23 -23
- package/src/decorators/internal/NoTransformConfigureError.ts +2 -2
- package/src/decorators/internal/get_path_and_querify.ts +94 -94
- package/src/decorators/internal/get_path_and_stringify.ts +110 -110
- package/src/decorators/internal/get_text_body.ts +16 -16
- package/src/decorators/internal/headers_to_object.ts +11 -11
- package/src/decorators/internal/is_request_body_undefined.ts +12 -12
- package/src/decorators/internal/load_controller.ts +45 -45
- package/src/decorators/internal/route_error.ts +43 -43
- package/src/decorators/internal/validate_request_body.ts +64 -64
- package/src/decorators/internal/validate_request_form_data.ts +67 -67
- package/src/decorators/internal/validate_request_headers.ts +76 -76
- package/src/decorators/internal/validate_request_query.ts +64 -64
- package/src/index.ts +5 -5
- package/src/module.ts +23 -22
- package/src/options/INestiaTransformOptions.ts +34 -34
- package/src/options/INestiaTransformProject.ts +10 -8
- package/src/options/IRequestBodyValidator.ts +20 -20
- package/src/options/IRequestFormDataProps.ts +27 -27
- package/src/options/IRequestHeadersValidator.ts +22 -22
- package/src/options/IRequestQueryValidator.ts +20 -20
- package/src/options/IResponseBodyQuerifier.ts +25 -25
- package/src/options/IResponseBodyStringifier.ts +30 -30
- package/src/programmers/PlainBodyProgrammer.ts +72 -70
- package/src/programmers/TypedBodyProgrammer.ts +144 -142
- package/src/programmers/TypedFormDataBodyProgrammer.ts +118 -118
- package/src/programmers/TypedHeadersProgrammer.ts +65 -63
- package/src/programmers/TypedParamProgrammer.ts +33 -33
- package/src/programmers/TypedQueryBodyProgrammer.ts +111 -109
- package/src/programmers/TypedQueryProgrammer.ts +113 -111
- package/src/programmers/TypedQueryRouteProgrammer.ts +104 -102
- package/src/programmers/TypedRouteProgrammer.ts +96 -94
- package/src/programmers/http/HttpAssertQuerifyProgrammer.ts +74 -72
- package/src/programmers/http/HttpIsQuerifyProgrammer.ts +77 -75
- package/src/programmers/http/HttpQuerifyProgrammer.ts +110 -108
- package/src/programmers/http/HttpValidateQuerifyProgrammer.ts +78 -76
- package/src/programmers/internal/CoreMetadataUtil.ts +21 -21
- package/src/transform.ts +35 -35
- package/src/transformers/FileTransformer.ts +109 -110
- package/src/transformers/MethodTransformer.ts +103 -103
- package/src/transformers/NodeTransformer.ts +23 -23
- package/src/transformers/ParameterDecoratorTransformer.ts +143 -143
- package/src/transformers/ParameterTransformer.ts +57 -57
- package/src/transformers/TypedRouteTransformer.ts +85 -85
- package/src/transformers/WebSocketRouteTransformer.ts +120 -120
- package/src/typings/Creator.ts +3 -3
- package/src/typings/get-function-location.d.ts +7 -7
- package/src/utils/ArrayUtil.ts +7 -7
- package/src/utils/ExceptionManager.ts +115 -115
- package/src/utils/Singleton.ts +16 -16
- package/src/utils/SourceFinder.ts +54 -54
- package/src/utils/VersioningStrategy.ts +27 -27
|
@@ -1,110 +1,109 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
import {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
export
|
|
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
|
-
file.
|
|
41
|
-
file.
|
|
42
|
-
file.
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
ts.
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
error
|
|
108
|
-
error.
|
|
109
|
-
typeof error.
|
|
110
|
-
typeof error.message === "string";
|
|
1
|
+
import { ImportProgrammer, TransformerError } from "@typia/core";
|
|
2
|
+
import ts from "typescript";
|
|
3
|
+
|
|
4
|
+
import { INestiaTransformContext } from "../options/INestiaTransformProject";
|
|
5
|
+
import { NodeTransformer } from "./NodeTransformer";
|
|
6
|
+
|
|
7
|
+
export namespace FileTransformer {
|
|
8
|
+
export const transform =
|
|
9
|
+
(context: Omit<INestiaTransformContext, "importer" | "transformer">) =>
|
|
10
|
+
(transformer: ts.TransformationContext) =>
|
|
11
|
+
(file: ts.SourceFile): ts.SourceFile => {
|
|
12
|
+
if (file.isDeclarationFile) return file;
|
|
13
|
+
const importer = new ImportProgrammer({
|
|
14
|
+
internalPrefix: "nestia_core_transform",
|
|
15
|
+
});
|
|
16
|
+
file = ts.visitEachChild(
|
|
17
|
+
file,
|
|
18
|
+
(node) =>
|
|
19
|
+
iterate_node({
|
|
20
|
+
context: {
|
|
21
|
+
...context,
|
|
22
|
+
transformer,
|
|
23
|
+
importer,
|
|
24
|
+
},
|
|
25
|
+
file,
|
|
26
|
+
node,
|
|
27
|
+
}),
|
|
28
|
+
transformer,
|
|
29
|
+
);
|
|
30
|
+
const index: number = find_import_injection_index(file);
|
|
31
|
+
return ts.factory.updateSourceFile(
|
|
32
|
+
file,
|
|
33
|
+
[
|
|
34
|
+
...file.statements.slice(0, index),
|
|
35
|
+
...importer.toStatements(),
|
|
36
|
+
...file.statements.slice(index),
|
|
37
|
+
],
|
|
38
|
+
false,
|
|
39
|
+
file.referencedFiles,
|
|
40
|
+
file.typeReferenceDirectives,
|
|
41
|
+
file.hasNoDefaultLib,
|
|
42
|
+
file.libReferenceDirectives,
|
|
43
|
+
);
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
const iterate_node = (props: {
|
|
47
|
+
context: INestiaTransformContext;
|
|
48
|
+
file: ts.SourceFile;
|
|
49
|
+
node: ts.Node;
|
|
50
|
+
}): ts.Node =>
|
|
51
|
+
ts.visitEachChild(
|
|
52
|
+
try_transform_node(props) ?? props.node,
|
|
53
|
+
(child) =>
|
|
54
|
+
iterate_node({
|
|
55
|
+
context: props.context,
|
|
56
|
+
file: props.file,
|
|
57
|
+
node: child,
|
|
58
|
+
}),
|
|
59
|
+
props.context.transformer,
|
|
60
|
+
);
|
|
61
|
+
|
|
62
|
+
const try_transform_node = (props: {
|
|
63
|
+
context: INestiaTransformContext;
|
|
64
|
+
file: ts.SourceFile;
|
|
65
|
+
node: ts.Node;
|
|
66
|
+
}): ts.Node | null => {
|
|
67
|
+
try {
|
|
68
|
+
return NodeTransformer.transform(props);
|
|
69
|
+
} catch (exp) {
|
|
70
|
+
// ONLY ACCEPT TRANSFORMER-ERROR
|
|
71
|
+
if (!isTransformerError(exp)) throw exp;
|
|
72
|
+
|
|
73
|
+
// AVOID SPECIAL BUG OF TYPESCRIPT COMPILER API
|
|
74
|
+
(props.node as any).parent ??= props.file;
|
|
75
|
+
|
|
76
|
+
// REPORT DIAGNOSTIC
|
|
77
|
+
const diagnostic = (ts as any).createDiagnosticForNode(props.node, {
|
|
78
|
+
key: exp.code,
|
|
79
|
+
category: ts.DiagnosticCategory.Error,
|
|
80
|
+
message: exp.message,
|
|
81
|
+
code: `(${exp.code})` as any,
|
|
82
|
+
});
|
|
83
|
+
props.context.extras.addDiagnostic(diagnostic);
|
|
84
|
+
return null;
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
|
|
88
|
+
const find_import_injection_index = (file: ts.SourceFile): number => {
|
|
89
|
+
let i: number = 0;
|
|
90
|
+
for (; i < file.statements.length; ++i) {
|
|
91
|
+
const stmt: ts.Statement = file.statements[i]!;
|
|
92
|
+
if (
|
|
93
|
+
ts.isExpressionStatement(stmt) &&
|
|
94
|
+
ts.isStringLiteralLike(stmt.expression) &&
|
|
95
|
+
stmt.expression.text.startsWith("use ")
|
|
96
|
+
)
|
|
97
|
+
continue;
|
|
98
|
+
break;
|
|
99
|
+
}
|
|
100
|
+
return i;
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
const isTransformerError = (error: any): error is TransformerError =>
|
|
105
|
+
typeof error === "object" &&
|
|
106
|
+
error !== null &&
|
|
107
|
+
error.constructor.name === "TransformerError" &&
|
|
108
|
+
typeof error.code === "string" &&
|
|
109
|
+
typeof error.message === "string";
|
|
@@ -1,103 +1,103 @@
|
|
|
1
|
-
import ts from "typescript";
|
|
2
|
-
|
|
3
|
-
import { INestiaTransformContext } from "../options/INestiaTransformProject";
|
|
4
|
-
import { TypedRouteTransformer } from "./TypedRouteTransformer";
|
|
5
|
-
import { WebSocketRouteTransformer } from "./WebSocketRouteTransformer";
|
|
6
|
-
|
|
7
|
-
export namespace MethodTransformer {
|
|
8
|
-
export const transform = (props: {
|
|
9
|
-
context: INestiaTransformContext;
|
|
10
|
-
method: ts.MethodDeclaration;
|
|
11
|
-
}): ts.MethodDeclaration => {
|
|
12
|
-
const decorators: readonly ts.Decorator[] | undefined = ts.getDecorators
|
|
13
|
-
? ts.getDecorators(props.method)
|
|
14
|
-
: (props.method as any).decorators;
|
|
15
|
-
if (!decorators?.length) return props.method;
|
|
16
|
-
|
|
17
|
-
const signature: ts.Signature | undefined =
|
|
18
|
-
props.context.checker.getSignatureFromDeclaration(props.method);
|
|
19
|
-
const original: ts.Type | undefined =
|
|
20
|
-
signature && props.context.checker.getReturnTypeOfSignature(signature);
|
|
21
|
-
const type: ts.Type | undefined =
|
|
22
|
-
original && get_escaped_type(props.context.checker)(original);
|
|
23
|
-
|
|
24
|
-
if (type === undefined) return props.method;
|
|
25
|
-
|
|
26
|
-
const operator = (decorator: ts.Decorator): ts.Decorator => {
|
|
27
|
-
decorator = TypedRouteTransformer.transform({
|
|
28
|
-
context: props.context,
|
|
29
|
-
decorator,
|
|
30
|
-
type,
|
|
31
|
-
});
|
|
32
|
-
decorator = WebSocketRouteTransformer.validate({
|
|
33
|
-
context: props.context,
|
|
34
|
-
method: props.method,
|
|
35
|
-
decorator,
|
|
36
|
-
});
|
|
37
|
-
return decorator;
|
|
38
|
-
};
|
|
39
|
-
if (ts.getDecorators !== undefined)
|
|
40
|
-
return ts.factory.updateMethodDeclaration(
|
|
41
|
-
props.method,
|
|
42
|
-
(props.method.modifiers || []).map((mod) =>
|
|
43
|
-
ts.isDecorator(mod) ? operator(mod) : mod,
|
|
44
|
-
),
|
|
45
|
-
props.method.asteriskToken,
|
|
46
|
-
props.method.name,
|
|
47
|
-
props.method.questionToken,
|
|
48
|
-
props.method.typeParameters,
|
|
49
|
-
props.method.parameters,
|
|
50
|
-
props.method.type,
|
|
51
|
-
props.method.body,
|
|
52
|
-
);
|
|
53
|
-
// eslint-disable-next-line
|
|
54
|
-
return (ts.factory.updateMethodDeclaration as any)(
|
|
55
|
-
props.method,
|
|
56
|
-
decorators.map(operator),
|
|
57
|
-
(props.method as any).modifiers,
|
|
58
|
-
props.method.asteriskToken,
|
|
59
|
-
props.method.name,
|
|
60
|
-
props.method.questionToken,
|
|
61
|
-
props.method.typeParameters,
|
|
62
|
-
props.method.parameters,
|
|
63
|
-
props.method.type,
|
|
64
|
-
props.method.body,
|
|
65
|
-
);
|
|
66
|
-
};
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
const get_escaped_type =
|
|
70
|
-
(checker: ts.TypeChecker) =>
|
|
71
|
-
(type: ts.Type): ts.Type => {
|
|
72
|
-
const symbol: ts.Symbol | undefined = type.getSymbol() || type.aliasSymbol;
|
|
73
|
-
return symbol && get_name(symbol) === "Promise"
|
|
74
|
-
? escape_promise(checker)(type)
|
|
75
|
-
: type;
|
|
76
|
-
};
|
|
77
|
-
|
|
78
|
-
const escape_promise =
|
|
79
|
-
(checker: ts.TypeChecker) =>
|
|
80
|
-
(type: ts.Type): ts.Type => {
|
|
81
|
-
const generic: readonly ts.Type[] = checker.getTypeArguments(
|
|
82
|
-
type as ts.TypeReference,
|
|
83
|
-
);
|
|
84
|
-
if (generic.length !== 1)
|
|
85
|
-
throw new Error(
|
|
86
|
-
"Error on ImportAnalyzer.analyze(): invalid promise type.",
|
|
87
|
-
);
|
|
88
|
-
return generic[0]
|
|
89
|
-
};
|
|
90
|
-
|
|
91
|
-
const get_name = (symbol: ts.Symbol): string =>
|
|
92
|
-
explore_name(symbol.getDeclarations()![0]
|
|
93
|
-
symbol.escapedName.toString(),
|
|
94
|
-
);
|
|
95
|
-
|
|
96
|
-
const explore_name =
|
|
97
|
-
(decl: ts.Node) =>
|
|
98
|
-
(name: string): string =>
|
|
99
|
-
ts.isModuleBlock(decl)
|
|
100
|
-
? explore_name(decl.parent.parent)(
|
|
101
|
-
`${decl.parent.name.getFullText().trim()}.${name}`,
|
|
102
|
-
)
|
|
103
|
-
: name;
|
|
1
|
+
import ts from "typescript";
|
|
2
|
+
|
|
3
|
+
import { INestiaTransformContext } from "../options/INestiaTransformProject";
|
|
4
|
+
import { TypedRouteTransformer } from "./TypedRouteTransformer";
|
|
5
|
+
import { WebSocketRouteTransformer } from "./WebSocketRouteTransformer";
|
|
6
|
+
|
|
7
|
+
export namespace MethodTransformer {
|
|
8
|
+
export const transform = (props: {
|
|
9
|
+
context: INestiaTransformContext;
|
|
10
|
+
method: ts.MethodDeclaration;
|
|
11
|
+
}): ts.MethodDeclaration => {
|
|
12
|
+
const decorators: readonly ts.Decorator[] | undefined = ts.getDecorators
|
|
13
|
+
? ts.getDecorators(props.method)
|
|
14
|
+
: (props.method as any).decorators;
|
|
15
|
+
if (!decorators?.length) return props.method;
|
|
16
|
+
|
|
17
|
+
const signature: ts.Signature | undefined =
|
|
18
|
+
props.context.checker.getSignatureFromDeclaration(props.method);
|
|
19
|
+
const original: ts.Type | undefined =
|
|
20
|
+
signature && props.context.checker.getReturnTypeOfSignature(signature);
|
|
21
|
+
const type: ts.Type | undefined =
|
|
22
|
+
original && get_escaped_type(props.context.checker)(original);
|
|
23
|
+
|
|
24
|
+
if (type === undefined) return props.method;
|
|
25
|
+
|
|
26
|
+
const operator = (decorator: ts.Decorator): ts.Decorator => {
|
|
27
|
+
decorator = TypedRouteTransformer.transform({
|
|
28
|
+
context: props.context,
|
|
29
|
+
decorator,
|
|
30
|
+
type,
|
|
31
|
+
});
|
|
32
|
+
decorator = WebSocketRouteTransformer.validate({
|
|
33
|
+
context: props.context,
|
|
34
|
+
method: props.method,
|
|
35
|
+
decorator,
|
|
36
|
+
});
|
|
37
|
+
return decorator;
|
|
38
|
+
};
|
|
39
|
+
if (ts.getDecorators !== undefined)
|
|
40
|
+
return ts.factory.updateMethodDeclaration(
|
|
41
|
+
props.method,
|
|
42
|
+
(props.method.modifiers || []).map((mod) =>
|
|
43
|
+
ts.isDecorator(mod) ? operator(mod) : mod,
|
|
44
|
+
),
|
|
45
|
+
props.method.asteriskToken,
|
|
46
|
+
props.method.name,
|
|
47
|
+
props.method.questionToken,
|
|
48
|
+
props.method.typeParameters,
|
|
49
|
+
props.method.parameters,
|
|
50
|
+
props.method.type,
|
|
51
|
+
props.method.body,
|
|
52
|
+
);
|
|
53
|
+
// eslint-disable-next-line
|
|
54
|
+
return (ts.factory.updateMethodDeclaration as any)(
|
|
55
|
+
props.method,
|
|
56
|
+
decorators.map(operator),
|
|
57
|
+
(props.method as any).modifiers,
|
|
58
|
+
props.method.asteriskToken,
|
|
59
|
+
props.method.name,
|
|
60
|
+
props.method.questionToken,
|
|
61
|
+
props.method.typeParameters,
|
|
62
|
+
props.method.parameters,
|
|
63
|
+
props.method.type,
|
|
64
|
+
props.method.body,
|
|
65
|
+
);
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
const get_escaped_type =
|
|
70
|
+
(checker: ts.TypeChecker) =>
|
|
71
|
+
(type: ts.Type): ts.Type => {
|
|
72
|
+
const symbol: ts.Symbol | undefined = type.getSymbol() || type.aliasSymbol;
|
|
73
|
+
return symbol && get_name(symbol) === "Promise"
|
|
74
|
+
? escape_promise(checker)(type)
|
|
75
|
+
: type;
|
|
76
|
+
};
|
|
77
|
+
|
|
78
|
+
const escape_promise =
|
|
79
|
+
(checker: ts.TypeChecker) =>
|
|
80
|
+
(type: ts.Type): ts.Type => {
|
|
81
|
+
const generic: readonly ts.Type[] = checker.getTypeArguments(
|
|
82
|
+
type as ts.TypeReference,
|
|
83
|
+
);
|
|
84
|
+
if (generic.length !== 1)
|
|
85
|
+
throw new Error(
|
|
86
|
+
"Error on ImportAnalyzer.analyze(): invalid promise type.",
|
|
87
|
+
);
|
|
88
|
+
return generic[0]!;
|
|
89
|
+
};
|
|
90
|
+
|
|
91
|
+
const get_name = (symbol: ts.Symbol): string =>
|
|
92
|
+
explore_name(symbol.getDeclarations()![0]!.parent)(
|
|
93
|
+
symbol.escapedName.toString(),
|
|
94
|
+
);
|
|
95
|
+
|
|
96
|
+
const explore_name =
|
|
97
|
+
(decl: ts.Node) =>
|
|
98
|
+
(name: string): string =>
|
|
99
|
+
ts.isModuleBlock(decl)
|
|
100
|
+
? explore_name(decl.parent.parent)(
|
|
101
|
+
`${decl.parent.name.getFullText().trim()}.${name}`,
|
|
102
|
+
)
|
|
103
|
+
: name;
|
|
@@ -1,23 +1,23 @@
|
|
|
1
|
-
import ts from "typescript";
|
|
2
|
-
|
|
3
|
-
import { INestiaTransformContext } from "../options/INestiaTransformProject";
|
|
4
|
-
import { MethodTransformer } from "./MethodTransformer";
|
|
5
|
-
import { ParameterTransformer } from "./ParameterTransformer";
|
|
6
|
-
|
|
7
|
-
export namespace NodeTransformer {
|
|
8
|
-
export const transform = (props: {
|
|
9
|
-
context: INestiaTransformContext;
|
|
10
|
-
node: ts.Node;
|
|
11
|
-
}): ts.Node =>
|
|
12
|
-
ts.isMethodDeclaration(props.node)
|
|
13
|
-
? MethodTransformer.transform({
|
|
14
|
-
context: props.context,
|
|
15
|
-
method: props.node,
|
|
16
|
-
})
|
|
17
|
-
: ts.isParameter(props.node)
|
|
18
|
-
? ParameterTransformer.transform({
|
|
19
|
-
context: props.context,
|
|
20
|
-
param: props.node,
|
|
21
|
-
})
|
|
22
|
-
: props.node;
|
|
23
|
-
}
|
|
1
|
+
import ts from "typescript";
|
|
2
|
+
|
|
3
|
+
import { INestiaTransformContext } from "../options/INestiaTransformProject";
|
|
4
|
+
import { MethodTransformer } from "./MethodTransformer";
|
|
5
|
+
import { ParameterTransformer } from "./ParameterTransformer";
|
|
6
|
+
|
|
7
|
+
export namespace NodeTransformer {
|
|
8
|
+
export const transform = (props: {
|
|
9
|
+
context: INestiaTransformContext;
|
|
10
|
+
node: ts.Node;
|
|
11
|
+
}): ts.Node =>
|
|
12
|
+
ts.isMethodDeclaration(props.node)
|
|
13
|
+
? MethodTransformer.transform({
|
|
14
|
+
context: props.context,
|
|
15
|
+
method: props.node,
|
|
16
|
+
})
|
|
17
|
+
: ts.isParameter(props.node)
|
|
18
|
+
? ParameterTransformer.transform({
|
|
19
|
+
context: props.context,
|
|
20
|
+
param: props.node,
|
|
21
|
+
})
|
|
22
|
+
: props.node;
|
|
23
|
+
}
|