@nestia/sdk 10.0.2 → 11.0.0-dev.20260312

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 (151) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +93 -93
  3. package/assets/bundle/api/HttpError.ts +1 -1
  4. package/assets/bundle/api/IConnection.ts +1 -1
  5. package/assets/bundle/api/Primitive.ts +1 -1
  6. package/assets/bundle/api/Resolved.ts +1 -1
  7. package/assets/bundle/api/index.ts +4 -4
  8. package/assets/bundle/api/module.ts +6 -6
  9. package/assets/bundle/distribute/README.md +37 -37
  10. package/assets/bundle/distribute/package.json +28 -28
  11. package/assets/bundle/distribute/tsconfig.json +109 -109
  12. package/assets/bundle/e2e/index.ts +42 -42
  13. package/assets/config/nestia.config.ts +97 -97
  14. package/lib/INestiaConfig.d.ts +3 -3
  15. package/lib/NestiaSdkApplication.js.map +1 -1
  16. package/lib/NestiaSwaggerComposer.d.ts +3 -2
  17. package/lib/NestiaSwaggerComposer.js +5 -6
  18. package/lib/NestiaSwaggerComposer.js.map +1 -1
  19. package/lib/analyses/AccessorAnalyzer.js +2 -2
  20. package/lib/analyses/AccessorAnalyzer.js.map +1 -1
  21. package/lib/analyses/DtoAnalyzer.js.map +1 -1
  22. package/lib/analyses/ImportAnalyzer.js.map +1 -1
  23. package/lib/analyses/ReflectHttpOperationAnalyzer.js +3 -3
  24. package/lib/analyses/ReflectHttpOperationAnalyzer.js.map +1 -1
  25. package/lib/analyses/ReflectHttpOperationExceptionAnalyzer.js +4 -2
  26. package/lib/analyses/ReflectHttpOperationExceptionAnalyzer.js.map +1 -1
  27. package/lib/analyses/ReflectHttpOperationParameterAnalyzer.js +7 -11
  28. package/lib/analyses/ReflectHttpOperationParameterAnalyzer.js.map +1 -1
  29. package/lib/analyses/ReflectHttpOperationResponseAnalyzer.js +6 -6
  30. package/lib/analyses/ReflectHttpOperationResponseAnalyzer.js.map +1 -1
  31. package/lib/analyses/TypedHttpRouteAnalyzer.d.ts +1 -1
  32. package/lib/analyses/TypedHttpRouteAnalyzer.js +6 -8
  33. package/lib/analyses/TypedHttpRouteAnalyzer.js.map +1 -1
  34. package/lib/executable/internal/NestiaConfigLoader.js +111 -52
  35. package/lib/executable/internal/NestiaConfigLoader.js.map +1 -1
  36. package/lib/executable/internal/NestiaSdkCommand.js.map +1 -1
  37. package/lib/executable/sdk.js +0 -0
  38. package/lib/generates/SwaggerGenerator.d.ts +1 -1
  39. package/lib/generates/SwaggerGenerator.js +11 -12
  40. package/lib/generates/SwaggerGenerator.js.map +1 -1
  41. package/lib/generates/internal/E2eFileProgrammer.js +8 -9
  42. package/lib/generates/internal/E2eFileProgrammer.js.map +1 -1
  43. package/lib/generates/internal/SdkAliasCollection.d.ts +2 -2
  44. package/lib/generates/internal/SdkAliasCollection.js +2 -2
  45. package/lib/generates/internal/SdkAliasCollection.js.map +1 -1
  46. package/lib/generates/internal/SdkDistributionComposer.js +1 -1
  47. package/lib/generates/internal/SdkHttpCloneProgrammer.js.map +1 -1
  48. package/lib/generates/internal/SdkHttpCloneReferencer.js.map +1 -1
  49. package/lib/generates/internal/SdkHttpFunctionProgrammer.js +11 -12
  50. package/lib/generates/internal/SdkHttpFunctionProgrammer.js.map +1 -1
  51. package/lib/generates/internal/SdkHttpNamespaceProgrammer.js +13 -16
  52. package/lib/generates/internal/SdkHttpNamespaceProgrammer.js.map +1 -1
  53. package/lib/generates/internal/SdkHttpRouteProgrammer.js +4 -4
  54. package/lib/generates/internal/SdkHttpRouteProgrammer.js.map +1 -1
  55. package/lib/generates/internal/SdkHttpSimulationProgrammer.js +12 -16
  56. package/lib/generates/internal/SdkHttpSimulationProgrammer.js.map +1 -1
  57. package/lib/generates/internal/SdkImportWizard.js +2 -2
  58. package/lib/generates/internal/SdkImportWizard.js.map +1 -1
  59. package/lib/generates/internal/SdkTypeProgrammer.d.ts +2 -3
  60. package/lib/generates/internal/SdkTypeProgrammer.js +6 -7
  61. package/lib/generates/internal/SdkTypeProgrammer.js.map +1 -1
  62. package/lib/generates/internal/SdkTypeTagProgrammer.d.ts +1 -1
  63. package/lib/generates/internal/SdkTypeTagProgrammer.js +11 -11
  64. package/lib/generates/internal/SdkTypeTagProgrammer.js.map +1 -1
  65. package/lib/generates/internal/SdkWebSocketNamespaceProgrammer.js +6 -8
  66. package/lib/generates/internal/SdkWebSocketNamespaceProgrammer.js.map +1 -1
  67. package/lib/generates/internal/SdkWebSocketRouteProgrammer.js +2 -2
  68. package/lib/generates/internal/SdkWebSocketRouteProgrammer.js.map +1 -1
  69. package/lib/generates/internal/SwaggerOperationComposer.d.ts +3 -3
  70. package/lib/generates/internal/SwaggerOperationComposer.js.map +1 -1
  71. package/lib/generates/internal/SwaggerOperationParameterComposer.d.ts +1 -1
  72. package/lib/generates/internal/SwaggerOperationParameterComposer.js +10 -8
  73. package/lib/generates/internal/SwaggerOperationParameterComposer.js.map +1 -1
  74. package/lib/generates/internal/SwaggerOperationResponseComposer.d.ts +3 -3
  75. package/lib/generates/internal/SwaggerOperationResponseComposer.js.map +1 -1
  76. package/lib/module.d.ts +1 -0
  77. package/lib/module.js +1 -0
  78. package/lib/module.js.map +1 -1
  79. package/lib/structures/IReflectHttpOperationException.d.ts +3 -4
  80. package/lib/structures/IReflectHttpOperationParameter.d.ts +3 -5
  81. package/lib/structures/IReflectHttpOperationSuccess.d.ts +3 -4
  82. package/lib/structures/ITypedApplication.d.ts +1 -1
  83. package/lib/structures/ITypedHttpRouteException.d.ts +2 -2
  84. package/lib/structures/ITypedHttpRouteParameter.d.ts +2 -2
  85. package/lib/structures/ITypedHttpRouteSuccess.d.ts +2 -2
  86. package/lib/transformers/IOperationMetadata.d.ts +2 -4
  87. package/lib/transformers/ISdkOperationTransformerContext.d.ts +1 -1
  88. package/lib/transformers/SdkOperationProgrammer.js +8 -10
  89. package/lib/transformers/SdkOperationProgrammer.js.map +1 -1
  90. package/lib/transformers/SdkOperationTransformer.js +6 -8
  91. package/lib/transformers/SdkOperationTransformer.js.map +1 -1
  92. package/lib/transformers/TextPlainValidator.d.ts +2 -2
  93. package/lib/transformers/TextPlainValidator.js.map +1 -1
  94. package/lib/utils/MetadataUtil.d.ts +2 -2
  95. package/lib/utils/MetadataUtil.js.map +1 -1
  96. package/lib/validators/HttpHeadersValidator.d.ts +2 -3
  97. package/lib/validators/HttpHeadersValidator.js +2 -2
  98. package/lib/validators/HttpHeadersValidator.js.map +1 -1
  99. package/lib/validators/HttpQueryValidator.d.ts +2 -3
  100. package/lib/validators/HttpQueryValidator.js +2 -2
  101. package/lib/validators/HttpQueryValidator.js.map +1 -1
  102. package/package.json +44 -30
  103. package/src/INestiaConfig.ts +267 -267
  104. package/src/NestiaSdkApplication.ts +307 -307
  105. package/src/NestiaSwaggerComposer.ts +143 -138
  106. package/src/analyses/AccessorAnalyzer.ts +67 -67
  107. package/src/analyses/DtoAnalyzer.ts +260 -260
  108. package/src/analyses/ImportAnalyzer.ts +126 -126
  109. package/src/analyses/ReflectHttpOperationAnalyzer.ts +183 -183
  110. package/src/analyses/ReflectHttpOperationExceptionAnalyzer.ts +72 -71
  111. package/src/analyses/ReflectHttpOperationParameterAnalyzer.ts +350 -348
  112. package/src/analyses/ReflectHttpOperationResponseAnalyzer.ts +126 -127
  113. package/src/analyses/TypedHttpRouteAnalyzer.ts +208 -204
  114. package/src/executable/internal/NestiaConfigLoader.ts +85 -78
  115. package/src/executable/internal/NestiaSdkCommand.ts +107 -103
  116. package/src/generates/SwaggerGenerator.ts +291 -284
  117. package/src/generates/internal/E2eFileProgrammer.ts +196 -197
  118. package/src/generates/internal/FilePrinter.ts +64 -64
  119. package/src/generates/internal/ImportDictionary.ts +192 -192
  120. package/src/generates/internal/SdkAliasCollection.ts +260 -261
  121. package/src/generates/internal/SdkFileProgrammer.ts +110 -110
  122. package/src/generates/internal/SdkHttpCloneProgrammer.ts +126 -124
  123. package/src/generates/internal/SdkHttpCloneReferencer.ts +77 -77
  124. package/src/generates/internal/SdkHttpFunctionProgrammer.ts +278 -279
  125. package/src/generates/internal/SdkHttpNamespaceProgrammer.ts +502 -500
  126. package/src/generates/internal/SdkHttpRouteProgrammer.ts +109 -108
  127. package/src/generates/internal/SdkHttpSimulationProgrammer.ts +312 -310
  128. package/src/generates/internal/SdkImportWizard.ts +62 -62
  129. package/src/generates/internal/SdkTypeProgrammer.ts +388 -385
  130. package/src/generates/internal/SdkTypeTagProgrammer.ts +114 -104
  131. package/src/generates/internal/SdkWebSocketNamespaceProgrammer.ts +379 -381
  132. package/src/generates/internal/SdkWebSocketRouteProgrammer.ts +302 -302
  133. package/src/generates/internal/SwaggerOperationComposer.ts +119 -119
  134. package/src/generates/internal/SwaggerOperationParameterComposer.ts +161 -162
  135. package/src/generates/internal/SwaggerOperationResponseComposer.ts +110 -110
  136. package/src/module.ts +4 -3
  137. package/src/structures/IReflectHttpOperationException.ts +18 -19
  138. package/src/structures/IReflectHttpOperationParameter.ts +79 -77
  139. package/src/structures/IReflectHttpOperationSuccess.ts +21 -22
  140. package/src/structures/ITypedApplication.ts +11 -11
  141. package/src/structures/ITypedHttpRouteException.ts +15 -15
  142. package/src/structures/ITypedHttpRouteParameter.ts +41 -41
  143. package/src/structures/ITypedHttpRouteSuccess.ts +22 -22
  144. package/src/transformers/IOperationMetadata.ts +46 -44
  145. package/src/transformers/ISdkOperationTransformerContext.ts +8 -8
  146. package/src/transformers/SdkOperationProgrammer.ts +240 -238
  147. package/src/transformers/SdkOperationTransformer.ts +248 -252
  148. package/src/transformers/TextPlainValidator.ts +17 -17
  149. package/src/utils/MetadataUtil.ts +26 -26
  150. package/src/validators/HttpHeadersValidator.ts +36 -34
  151. package/src/validators/HttpQueryValidator.ts +36 -34
@@ -1,252 +1,248 @@
1
- import path from "path";
2
- import { HashSet, Singleton, hash } from "tstl";
3
- import ts from "typescript";
4
- import { LiteralFactory } from "typia/lib/factories/LiteralFactory";
5
- import { MetadataCollection } from "typia/lib/factories/MetadataCollection";
6
- import { TypeFactory } from "typia/lib/factories/TypeFactory";
7
-
8
- import { ImportAnalyzer } from "../analyses/ImportAnalyzer";
9
- import { IReflectImport } from "../structures/IReflectImport";
10
- import { IOperationMetadata } from "./IOperationMetadata";
11
- import { ISdkOperationTransformerContext } from "./ISdkOperationTransformerContext";
12
- import { SdkOperationProgrammer } from "./SdkOperationProgrammer";
13
-
14
- export namespace SdkOperationTransformer {
15
- export const iterateFile =
16
- (checker: ts.TypeChecker) => (api: ts.TransformationContext) => {
17
- const context: ISdkOperationTransformerContext = {
18
- checker,
19
- transformer: api,
20
- collection: collection.get(),
21
- };
22
- return (file: ts.SourceFile): ts.SourceFile => {
23
- if (file.isDeclarationFile === true) return file;
24
- const visitor: IVisitor = {
25
- done: false,
26
- visited: new HashSet(),
27
- };
28
- file = ts.visitEachChild(
29
- file,
30
- (node) =>
31
- iterateNode({
32
- context,
33
- imports: new Singleton(() => ImportAnalyzer.analyze(file)),
34
- visitor,
35
- node,
36
- }),
37
- api,
38
- );
39
- if (visitor.done === false) return file;
40
- return ts.factory.updateSourceFile(file, [
41
- ts.factory.createImportDeclaration(
42
- undefined,
43
- ts.factory.createImportClause(
44
- false,
45
- undefined,
46
- ts.factory.createNamespaceImport(
47
- ts.factory.createIdentifier("__OperationMetadata"),
48
- ),
49
- ),
50
- ts.factory.createStringLiteral(
51
- "@nestia/sdk/lib/decorators/OperationMetadata",
52
- ),
53
- undefined,
54
- ),
55
- ...file.statements,
56
- ]);
57
- };
58
- };
59
-
60
- interface IVisitor {
61
- done: boolean;
62
- visited: HashSet<MethodKey>;
63
- }
64
-
65
- const iterateNode = (props: {
66
- context: ISdkOperationTransformerContext;
67
- imports: Singleton<IReflectImport[]>;
68
- visitor: IVisitor;
69
- node: ts.Node;
70
- }): ts.Node =>
71
- ts.visitEachChild(
72
- transformNode(props),
73
- (child) =>
74
- iterateNode({
75
- ...props,
76
- node: child,
77
- }),
78
- props.context.transformer,
79
- );
80
-
81
- const transformNode = (props: {
82
- context: ISdkOperationTransformerContext;
83
- imports: Singleton<IReflectImport[]>;
84
- visitor: IVisitor;
85
- node: ts.Node;
86
- }): ts.Node => {
87
- return ts.isClassDeclaration(props.node)
88
- ? transformClass({
89
- ...props,
90
- node: props.node,
91
- })
92
- : props.node;
93
- };
94
-
95
- const transformClass = (props: {
96
- context: ISdkOperationTransformerContext;
97
- visitor: IVisitor;
98
- imports: Singleton<IReflectImport[]>;
99
- node: ts.ClassDeclaration;
100
- }): ts.ClassDeclaration => {
101
- // TO AVOID COMMENT COMPILATION BUG
102
- const symbolDict: Map<string, ts.Symbol> = new Map();
103
- const classType: ts.InterfaceType = props.context.checker.getTypeAtLocation(
104
- props.node,
105
- ) as ts.InterfaceType;
106
- for (const symbol of classType.getProperties()) {
107
- const declaration: ts.Declaration | undefined = (symbol.declarations ||
108
- [])[0];
109
- if (!declaration || !ts.isMethodDeclaration(declaration)) continue;
110
- const identifier = declaration.name;
111
- if (!ts.isIdentifier(identifier)) continue;
112
- symbolDict.set(identifier.escapedText.toString(), symbol);
113
- }
114
- return ts.factory.updateClassDeclaration(
115
- props.node,
116
- props.node.modifiers,
117
- props.node.name,
118
- props.node.typeParameters,
119
- props.node.heritageClauses,
120
- props.node.members.map((m) =>
121
- ts.isMethodDeclaration(m)
122
- ? transformMethod({
123
- ...props,
124
- class: props.node,
125
- node: m,
126
- symbol: symbolDict.get(m.name.getText()),
127
- })
128
- : m,
129
- ),
130
- );
131
- };
132
-
133
- const transformMethod = (props: {
134
- context: ISdkOperationTransformerContext;
135
- visitor: IVisitor;
136
- imports: Singleton<IReflectImport[]>;
137
- class: ts.ClassDeclaration;
138
- node: ts.MethodDeclaration;
139
- symbol: ts.Symbol | undefined;
140
- }): ts.MethodDeclaration => {
141
- const decorators: readonly ts.Decorator[] | undefined = ts.getDecorators
142
- ? ts.getDecorators(props.node)
143
- : (props.node as any).decorators;
144
- if (!decorators?.length) return props.node;
145
-
146
- const key: MethodKey = new MethodKey(
147
- props.class.name?.getText() ?? "",
148
- props.node.name.getText(),
149
- );
150
- props.visitor.done ||= true;
151
- if (props.visitor.visited.has(key)) return props.node;
152
- else props.visitor.visited.insert(key);
153
-
154
- const metadata: IOperationMetadata = SdkOperationProgrammer.write({
155
- ...props,
156
- exceptions: getExceptionTypes({
157
- checker: props.context.checker,
158
- decorators,
159
- }),
160
- });
161
- return ts.factory.updateMethodDeclaration(
162
- props.node,
163
- [
164
- ...(props.node.modifiers ?? []),
165
- ts.factory.createDecorator(
166
- ts.factory.createCallExpression(
167
- ts.factory.createIdentifier(
168
- "__OperationMetadata.OperationMetadata",
169
- ),
170
- undefined,
171
- [
172
- ts.factory.createAsExpression(
173
- LiteralFactory.write(metadata),
174
- TypeFactory.keyword("any"),
175
- ),
176
- ],
177
- ),
178
- ),
179
- ],
180
- props.node.asteriskToken,
181
- props.node.name,
182
- props.node.questionToken,
183
- props.node.typeParameters,
184
- props.node.parameters,
185
- props.node.type,
186
- props.node.body,
187
- );
188
- };
189
-
190
- const getExceptionTypes = (props: {
191
- checker: ts.TypeChecker;
192
- decorators: readonly ts.Decorator[];
193
- }) =>
194
- props.decorators
195
- .map((deco) => {
196
- if (false === ts.isCallExpression(deco.expression)) return null;
197
-
198
- const signature: ts.Signature | undefined =
199
- props.checker.getResolvedSignature(deco.expression);
200
- if (signature === undefined) return null;
201
- else if (!signature.declaration) return null;
202
-
203
- const location: string = path.resolve(
204
- signature.declaration.getSourceFile()?.fileName ?? "",
205
- );
206
- if (
207
- location.includes(TYPED_EXCEPTION_LIB_PATH) === false &&
208
- location.includes(TYPED_EXCEPTION_MONO_PATH) === false
209
- )
210
- return null;
211
- else if (deco.expression.typeArguments?.length !== 1) return null;
212
- return deco.expression.typeArguments[0];
213
- })
214
- .filter((t) => t !== null);
215
- }
216
-
217
- class MethodKey {
218
- public constructor(
219
- public readonly className: string,
220
- public readonly methodName: string,
221
- ) {}
222
-
223
- public equals(o: MethodKey): boolean {
224
- return this.className === o.className && this.methodName === o.methodName;
225
- }
226
-
227
- public hashCode(): number {
228
- return hash(this.className, this.methodName);
229
- }
230
- }
231
-
232
- const TYPED_EXCEPTION_LIB_PATH = path.join(
233
- "@nestia",
234
- "core",
235
- "lib",
236
- "decorators",
237
- `TypedException.d.ts`,
238
- );
239
- const TYPED_EXCEPTION_MONO_PATH = path.join(
240
- "packages",
241
- "core",
242
- "lib",
243
- "decorators",
244
- `TypedException.d.ts`,
245
- );
246
-
247
- const collection = new Singleton(
248
- () =>
249
- new MetadataCollection({
250
- replace: MetadataCollection.replace,
251
- }),
252
- );
1
+ import { LiteralFactory, MetadataCollection, TypeFactory } from "@typia/core";
2
+ import path from "path";
3
+ import { HashSet, Singleton, hash } from "tstl";
4
+ import ts from "typescript";
5
+
6
+ import { ImportAnalyzer } from "../analyses/ImportAnalyzer";
7
+ import { IReflectImport } from "../structures/IReflectImport";
8
+ import { IOperationMetadata } from "./IOperationMetadata";
9
+ import { ISdkOperationTransformerContext } from "./ISdkOperationTransformerContext";
10
+ import { SdkOperationProgrammer } from "./SdkOperationProgrammer";
11
+
12
+ export namespace SdkOperationTransformer {
13
+ export const iterateFile =
14
+ (checker: ts.TypeChecker) => (api: ts.TransformationContext) => {
15
+ const context: ISdkOperationTransformerContext = {
16
+ checker,
17
+ transformer: api,
18
+ collection: collection.get(),
19
+ };
20
+ return (file: ts.SourceFile): ts.SourceFile => {
21
+ if (file.isDeclarationFile === true) return file;
22
+ const visitor: IVisitor = {
23
+ done: false,
24
+ visited: new HashSet(),
25
+ };
26
+ file = ts.visitEachChild(
27
+ file,
28
+ (node) =>
29
+ iterateNode({
30
+ context,
31
+ imports: new Singleton(() => ImportAnalyzer.analyze(file)),
32
+ visitor,
33
+ node,
34
+ }),
35
+ api,
36
+ );
37
+ if (visitor.done === false) return file;
38
+ return ts.factory.updateSourceFile(file, [
39
+ ts.factory.createImportDeclaration(
40
+ undefined,
41
+ ts.factory.createImportClause(
42
+ false,
43
+ undefined,
44
+ ts.factory.createNamespaceImport(
45
+ ts.factory.createIdentifier("__OperationMetadata"),
46
+ ),
47
+ ),
48
+ ts.factory.createStringLiteral("@nestia/sdk"),
49
+ undefined,
50
+ ),
51
+ ...file.statements,
52
+ ]);
53
+ };
54
+ };
55
+
56
+ interface IVisitor {
57
+ done: boolean;
58
+ visited: HashSet<MethodKey>;
59
+ }
60
+
61
+ const iterateNode = (props: {
62
+ context: ISdkOperationTransformerContext;
63
+ imports: Singleton<IReflectImport[]>;
64
+ visitor: IVisitor;
65
+ node: ts.Node;
66
+ }): ts.Node =>
67
+ ts.visitEachChild(
68
+ transformNode(props),
69
+ (child) =>
70
+ iterateNode({
71
+ ...props,
72
+ node: child,
73
+ }),
74
+ props.context.transformer,
75
+ );
76
+
77
+ const transformNode = (props: {
78
+ context: ISdkOperationTransformerContext;
79
+ imports: Singleton<IReflectImport[]>;
80
+ visitor: IVisitor;
81
+ node: ts.Node;
82
+ }): ts.Node => {
83
+ return ts.isClassDeclaration(props.node)
84
+ ? transformClass({
85
+ ...props,
86
+ node: props.node,
87
+ })
88
+ : props.node;
89
+ };
90
+
91
+ const transformClass = (props: {
92
+ context: ISdkOperationTransformerContext;
93
+ visitor: IVisitor;
94
+ imports: Singleton<IReflectImport[]>;
95
+ node: ts.ClassDeclaration;
96
+ }): ts.ClassDeclaration => {
97
+ // TO AVOID COMMENT COMPILATION BUG
98
+ const symbolDict: Map<string, ts.Symbol> = new Map();
99
+ const classType: ts.InterfaceType = props.context.checker.getTypeAtLocation(
100
+ props.node,
101
+ ) as ts.InterfaceType;
102
+ for (const symbol of classType.getProperties()) {
103
+ const declaration: ts.Declaration | undefined = (symbol.declarations ||
104
+ [])[0];
105
+ if (!declaration || !ts.isMethodDeclaration(declaration)) continue;
106
+ const identifier = declaration.name;
107
+ if (!ts.isIdentifier(identifier)) continue;
108
+ symbolDict.set(identifier.escapedText.toString(), symbol);
109
+ }
110
+ return ts.factory.updateClassDeclaration(
111
+ props.node,
112
+ props.node.modifiers,
113
+ props.node.name,
114
+ props.node.typeParameters,
115
+ props.node.heritageClauses,
116
+ props.node.members.map((m) =>
117
+ ts.isMethodDeclaration(m)
118
+ ? transformMethod({
119
+ ...props,
120
+ class: props.node,
121
+ node: m,
122
+ symbol: symbolDict.get(m.name.getText()),
123
+ })
124
+ : m,
125
+ ),
126
+ );
127
+ };
128
+
129
+ const transformMethod = (props: {
130
+ context: ISdkOperationTransformerContext;
131
+ visitor: IVisitor;
132
+ imports: Singleton<IReflectImport[]>;
133
+ class: ts.ClassDeclaration;
134
+ node: ts.MethodDeclaration;
135
+ symbol: ts.Symbol | undefined;
136
+ }): ts.MethodDeclaration => {
137
+ const decorators: readonly ts.Decorator[] | undefined = ts.getDecorators
138
+ ? ts.getDecorators(props.node)
139
+ : (props.node as any).decorators;
140
+ if (!decorators?.length) return props.node;
141
+
142
+ const key: MethodKey = new MethodKey(
143
+ props.class.name?.getText() ?? "",
144
+ props.node.name.getText(),
145
+ );
146
+ props.visitor.done ||= true;
147
+ if (props.visitor.visited.has(key)) return props.node;
148
+ else props.visitor.visited.insert(key);
149
+
150
+ const metadata: IOperationMetadata = SdkOperationProgrammer.write({
151
+ ...props,
152
+ exceptions: getExceptionTypes({
153
+ checker: props.context.checker,
154
+ decorators,
155
+ }),
156
+ });
157
+ return ts.factory.updateMethodDeclaration(
158
+ props.node,
159
+ [
160
+ ...(props.node.modifiers ?? []),
161
+ ts.factory.createDecorator(
162
+ ts.factory.createCallExpression(
163
+ ts.factory.createIdentifier(
164
+ "__OperationMetadata.OperationMetadata",
165
+ ),
166
+ undefined,
167
+ [
168
+ ts.factory.createAsExpression(
169
+ LiteralFactory.write(metadata),
170
+ TypeFactory.keyword("any"),
171
+ ),
172
+ ],
173
+ ),
174
+ ),
175
+ ],
176
+ props.node.asteriskToken,
177
+ props.node.name,
178
+ props.node.questionToken,
179
+ props.node.typeParameters,
180
+ props.node.parameters,
181
+ props.node.type,
182
+ props.node.body,
183
+ );
184
+ };
185
+
186
+ const getExceptionTypes = (props: {
187
+ checker: ts.TypeChecker;
188
+ decorators: readonly ts.Decorator[];
189
+ }) =>
190
+ props.decorators
191
+ .map((deco) => {
192
+ if (false === ts.isCallExpression(deco.expression)) return null;
193
+
194
+ const signature: ts.Signature | undefined =
195
+ props.checker.getResolvedSignature(deco.expression);
196
+ if (signature === undefined) return null;
197
+ else if (!signature.declaration) return null;
198
+
199
+ const location: string = path.resolve(
200
+ signature.declaration.getSourceFile()?.fileName ?? "",
201
+ );
202
+ if (
203
+ location.includes(TYPED_EXCEPTION_LIB_PATH) === false &&
204
+ location.includes(TYPED_EXCEPTION_MONO_PATH) === false
205
+ )
206
+ return null;
207
+ else if (deco.expression.typeArguments?.length !== 1) return null;
208
+ return deco.expression.typeArguments[0]!;
209
+ })
210
+ .filter((t) => t !== null);
211
+ }
212
+
213
+ class MethodKey {
214
+ public constructor(
215
+ public readonly className: string,
216
+ public readonly methodName: string,
217
+ ) {}
218
+
219
+ public equals(o: MethodKey): boolean {
220
+ return this.className === o.className && this.methodName === o.methodName;
221
+ }
222
+
223
+ public hashCode(): number {
224
+ return hash(this.className, this.methodName);
225
+ }
226
+ }
227
+
228
+ const TYPED_EXCEPTION_LIB_PATH = path.join(
229
+ "@nestia",
230
+ "core",
231
+ "lib",
232
+ "decorators",
233
+ `TypedException.d.ts`,
234
+ );
235
+ const TYPED_EXCEPTION_MONO_PATH = path.join(
236
+ "packages",
237
+ "core",
238
+ "src",
239
+ "decorators",
240
+ `TypedException.ts`,
241
+ );
242
+
243
+ const collection = new Singleton(
244
+ () =>
245
+ new MetadataCollection({
246
+ replace: MetadataCollection.replace,
247
+ }),
248
+ );
@@ -1,17 +1,17 @@
1
- import { Metadata } from "typia/lib/schemas/metadata/Metadata";
2
-
3
- export namespace TextPlainValidator {
4
- export const validate = (metadata: Metadata): string[] => {
5
- const expected: number =
6
- metadata.atomics.filter((a) => a.type === "string").length +
7
- metadata.constants
8
- .filter((c) => c.type === "string")
9
- .map((c) => c.values.length)
10
- .reduce((a, b) => a + b, 0) +
11
- metadata.templates.length +
12
- metadata.natives.filter((n) => n.name === "String").length;
13
- if (metadata.size() === 0 || metadata.size() !== expected)
14
- return [`Only string type is allowed in the "text/plain" content type.`];
15
- return [];
16
- };
17
- }
1
+ import { MetadataSchema } from "@typia/core";
2
+
3
+ export namespace TextPlainValidator {
4
+ export const validate = (metadata: MetadataSchema): string[] => {
5
+ const expected: number =
6
+ metadata.atomics.filter((a) => a.type === "string").length +
7
+ metadata.constants
8
+ .filter((c) => c.type === "string")
9
+ .map((c) => c.values.length)
10
+ .reduce((a, b) => a + b, 0) +
11
+ metadata.templates.length +
12
+ metadata.natives.filter((n) => n.name === "String").length;
13
+ if (metadata.size() === 0 || metadata.size() !== expected)
14
+ return [`Only string type is allowed in the "text/plain" content type.`];
15
+ return [];
16
+ };
17
+ }
@@ -1,26 +1,26 @@
1
- import { Metadata } from "typia/lib/schemas/metadata/Metadata";
2
-
3
- export namespace MetadataUtil {
4
- export const visit = (closure: (m: Metadata) => unknown) => {
5
- const visited: WeakSet<Metadata> = new WeakSet();
6
- const iterate = (metadata: Metadata): void => {
7
- if (visited.has(metadata)) return;
8
- visited.add(metadata);
9
- closure(metadata);
10
- for (const alias of metadata.aliases) iterate(alias.type.value);
11
- for (const array of metadata.arrays) iterate(array.type.value);
12
- for (const tuple of metadata.tuples) tuple.type.elements.map(iterate);
13
- for (const object of metadata.objects)
14
- object.type.properties.forEach((p) => {
15
- iterate(p.key);
16
- iterate(p.value);
17
- });
18
- if (metadata.escaped) {
19
- iterate(metadata.escaped.original);
20
- iterate(metadata.escaped.returns);
21
- }
22
- if (metadata.rest) iterate(metadata.rest);
23
- };
24
- return iterate;
25
- };
26
- }
1
+ import { MetadataSchema } from "@typia/core";
2
+
3
+ export namespace MetadataUtil {
4
+ export const visit = (closure: (m: MetadataSchema) => unknown) => {
5
+ const visited: WeakSet<MetadataSchema> = new WeakSet();
6
+ const iterate = (metadata: MetadataSchema): void => {
7
+ if (visited.has(metadata)) return;
8
+ visited.add(metadata);
9
+ closure(metadata);
10
+ for (const alias of metadata.aliases) iterate(alias.type.value);
11
+ for (const array of metadata.arrays) iterate(array.type.value);
12
+ for (const tuple of metadata.tuples) tuple.type.elements.map(iterate);
13
+ for (const object of metadata.objects)
14
+ object.type.properties.forEach((p) => {
15
+ iterate(p.key);
16
+ iterate(p.value);
17
+ });
18
+ if (metadata.escaped) {
19
+ iterate(metadata.escaped.original);
20
+ iterate(metadata.escaped.returns);
21
+ }
22
+ if (metadata.rest) iterate(metadata.rest);
23
+ };
24
+ return iterate;
25
+ };
26
+ }