@nestia/sdk 8.1.0 → 9.0.0-dev.20251107

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 (112) 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/executable/internal/NestiaConfigLoader.js +4 -4
  15. package/lib/executable/sdk.js +12 -12
  16. package/package.json +7 -7
  17. package/src/INestiaConfig.ts +267 -267
  18. package/src/NestiaSdkApplication.ts +307 -307
  19. package/src/NestiaSwaggerComposer.ts +138 -138
  20. package/src/analyses/AccessorAnalyzer.ts +67 -67
  21. package/src/analyses/ConfigAnalyzer.ts +155 -155
  22. package/src/analyses/DtoAnalyzer.ts +246 -246
  23. package/src/analyses/ExceptionAnalyzer.ts +154 -154
  24. package/src/analyses/GenericAnalyzer.ts +49 -49
  25. package/src/analyses/ImportAnalyzer.ts +126 -126
  26. package/src/analyses/PathAnalyzer.ts +69 -69
  27. package/src/analyses/ReflectControllerAnalyzer.ts +105 -105
  28. package/src/analyses/ReflectHttpOperationAnalyzer.ts +183 -183
  29. package/src/analyses/ReflectHttpOperationExceptionAnalyzer.ts +71 -71
  30. package/src/analyses/ReflectHttpOperationParameterAnalyzer.ts +348 -348
  31. package/src/analyses/ReflectHttpOperationResponseAnalyzer.ts +127 -127
  32. package/src/analyses/ReflectMetadataAnalyzer.ts +44 -44
  33. package/src/analyses/ReflectWebSocketOperationAnalyzer.ts +172 -172
  34. package/src/analyses/SecurityAnalyzer.ts +25 -25
  35. package/src/analyses/TypedHttpRouteAnalyzer.ts +204 -204
  36. package/src/analyses/TypedWebSocketRouteAnalyzer.ts +33 -33
  37. package/src/decorators/OperationMetadata.ts +15 -15
  38. package/src/executable/internal/CommandParser.ts +15 -15
  39. package/src/executable/internal/NestiaConfigLoader.ts +78 -78
  40. package/src/executable/internal/NestiaSdkCommand.ts +103 -103
  41. package/src/executable/sdk.ts +75 -75
  42. package/src/generates/CloneGenerator.ts +66 -66
  43. package/src/generates/E2eGenerator.ts +32 -32
  44. package/src/generates/SdkGenerator.ts +160 -160
  45. package/src/generates/SwaggerGenerator.ts +284 -284
  46. package/src/generates/internal/E2eFileProgrammer.ts +197 -197
  47. package/src/generates/internal/FilePrinter.ts +53 -53
  48. package/src/generates/internal/ImportDictionary.ts +192 -192
  49. package/src/generates/internal/SdkAliasCollection.ts +261 -261
  50. package/src/generates/internal/SdkDistributionComposer.ts +103 -103
  51. package/src/generates/internal/SdkFileProgrammer.ts +110 -110
  52. package/src/generates/internal/SdkHttpCloneProgrammer.ts +124 -124
  53. package/src/generates/internal/SdkHttpCloneReferencer.ts +77 -77
  54. package/src/generates/internal/SdkHttpFunctionProgrammer.ts +279 -279
  55. package/src/generates/internal/SdkHttpNamespaceProgrammer.ts +500 -500
  56. package/src/generates/internal/SdkHttpParameterProgrammer.ts +178 -178
  57. package/src/generates/internal/SdkHttpRouteProgrammer.ts +108 -108
  58. package/src/generates/internal/SdkHttpSimulationProgrammer.ts +310 -310
  59. package/src/generates/internal/SdkImportWizard.ts +62 -62
  60. package/src/generates/internal/SdkRouteDirectory.ts +18 -18
  61. package/src/generates/internal/SdkTypeProgrammer.ts +385 -385
  62. package/src/generates/internal/SdkTypeTagProgrammer.ts +104 -104
  63. package/src/generates/internal/SdkWebSocketNamespaceProgrammer.ts +381 -381
  64. package/src/generates/internal/SdkWebSocketParameterProgrammer.ts +87 -87
  65. package/src/generates/internal/SdkWebSocketRouteProgrammer.ts +302 -302
  66. package/src/generates/internal/SwaggerDescriptionComposer.ts +64 -64
  67. package/src/generates/internal/SwaggerOperationComposer.ts +119 -119
  68. package/src/generates/internal/SwaggerOperationParameterComposer.ts +177 -177
  69. package/src/generates/internal/SwaggerOperationResponseComposer.ts +110 -110
  70. package/src/index.ts +4 -4
  71. package/src/module.ts +3 -3
  72. package/src/structures/INestiaProject.ts +13 -13
  73. package/src/structures/INestiaSdkInput.ts +20 -20
  74. package/src/structures/IReflectApplication.ts +8 -8
  75. package/src/structures/IReflectController.ts +15 -15
  76. package/src/structures/IReflectHttpOperation.ts +26 -26
  77. package/src/structures/IReflectHttpOperationException.ts +19 -19
  78. package/src/structures/IReflectHttpOperationParameter.ts +77 -77
  79. package/src/structures/IReflectHttpOperationSuccess.ts +22 -22
  80. package/src/structures/IReflectImport.ts +6 -6
  81. package/src/structures/IReflectOperationError.ts +26 -26
  82. package/src/structures/IReflectType.ts +4 -4
  83. package/src/structures/IReflectWebSocketOperation.ts +17 -17
  84. package/src/structures/IReflectWebSocketOperationParameter.ts +36 -36
  85. package/src/structures/ITypedApplication.ts +11 -11
  86. package/src/structures/ITypedHttpRoute.ts +41 -41
  87. package/src/structures/ITypedHttpRouteException.ts +15 -15
  88. package/src/structures/ITypedHttpRouteParameter.ts +41 -41
  89. package/src/structures/ITypedHttpRouteSuccess.ts +22 -22
  90. package/src/structures/ITypedWebSocketRoute.ts +24 -24
  91. package/src/structures/ITypedWebSocketRouteParameter.ts +3 -3
  92. package/src/structures/MethodType.ts +5 -5
  93. package/src/structures/ParamCategory.ts +1 -1
  94. package/src/structures/TypeEntry.ts +22 -22
  95. package/src/transform.ts +9 -9
  96. package/src/transformers/IOperationMetadata.ts +44 -44
  97. package/src/transformers/ISdkOperationTransformerContext.ts +8 -8
  98. package/src/transformers/SdkOperationProgrammer.ts +238 -238
  99. package/src/transformers/SdkOperationTransformer.ts +252 -252
  100. package/src/transformers/TextPlainValidator.ts +17 -17
  101. package/src/typings/get-function-location.d.ts +7 -7
  102. package/src/utils/ArrayUtil.ts +26 -26
  103. package/src/utils/FileRetriever.ts +22 -22
  104. package/src/utils/MapUtil.ts +14 -14
  105. package/src/utils/MetadataUtil.ts +26 -26
  106. package/src/utils/PathUtil.ts +10 -10
  107. package/src/utils/SourceFinder.ts +63 -63
  108. package/src/utils/StringUtil.ts +17 -17
  109. package/src/utils/StripEnums.ts +5 -5
  110. package/src/utils/VersioningStrategy.ts +28 -28
  111. package/src/validators/HttpHeadersValidator.ts +34 -34
  112. package/src/validators/HttpQueryValidator.ts +34 -34
@@ -1,261 +1,261 @@
1
- import ts from "typescript";
2
- import { TypeFactory } from "typia/lib/factories/TypeFactory";
3
- import { Metadata } from "typia/lib/schemas/metadata/Metadata";
4
-
5
- import { INestiaProject } from "../../structures/INestiaProject";
6
- import { IReflectType } from "../../structures/IReflectType";
7
- import { ITypedHttpRoute } from "../../structures/ITypedHttpRoute";
8
- import { ITypedHttpRouteParameter } from "../../structures/ITypedHttpRouteParameter";
9
- import { ITypedWebSocketRoute } from "../../structures/ITypedWebSocketRoute";
10
- import { FilePrinter } from "./FilePrinter";
11
- import { ImportDictionary } from "./ImportDictionary";
12
- import { SdkHttpParameterProgrammer } from "./SdkHttpParameterProgrammer";
13
- import { SdkTypeProgrammer } from "./SdkTypeProgrammer";
14
-
15
- export namespace SdkAliasCollection {
16
- export const name = ({ type }: { type: IReflectType }): ts.TypeNode =>
17
- ts.factory.createTypeReferenceNode(
18
- type.name,
19
- type.typeArguments
20
- ? type.typeArguments.map((a) => name({ type: a }))
21
- : undefined,
22
- );
23
-
24
- export const from =
25
- (project: INestiaProject) =>
26
- (importer: ImportDictionary) =>
27
- (metadata: Metadata) =>
28
- SdkTypeProgrammer.write(project)(importer)(metadata);
29
-
30
- export const httpProps =
31
- (project: INestiaProject) =>
32
- (importer: ImportDictionary) =>
33
- (route: ITypedHttpRoute): ts.TypeNode =>
34
- ts.factory.createTypeLiteralNode(
35
- SdkHttpParameterProgrammer.getEntries({
36
- project,
37
- importer,
38
- route,
39
- body: true,
40
- prefix: false,
41
- })
42
- .map((e) => {
43
- const signature: ts.PropertySignature =
44
- ts.factory.createPropertySignature(
45
- undefined,
46
- e.key,
47
- e.required
48
- ? undefined
49
- : ts.factory.createToken(ts.SyntaxKind.QuestionToken),
50
- e.type,
51
- );
52
- const description: string | null =
53
- e.parameter.description ??
54
- route.jsDocTags
55
- ?.find(
56
- (tag) =>
57
- tag.name === "param" &&
58
- tag.text?.[0]?.kind === "parameterName" &&
59
- tag.text?.[0]?.text === e.key,
60
- )
61
- ?.text?.find((t) => t.kind === "text")?.text ??
62
- null;
63
- return description?.length
64
- ? [
65
- ts.factory.createIdentifier("\n") as any,
66
- FilePrinter.description(signature, description),
67
- ]
68
- : [signature];
69
- })
70
- .flat(),
71
- );
72
-
73
- export const websocketProps = (route: ITypedWebSocketRoute): ts.TypeNode =>
74
- ts.factory.createTypeLiteralNode([
75
- ...route.pathParameters.map((p) =>
76
- ts.factory.createPropertySignature(
77
- undefined,
78
- p.name,
79
- undefined,
80
- SdkAliasCollection.name(p),
81
- ),
82
- ),
83
- ...(route.query
84
- ? [
85
- ts.factory.createPropertySignature(
86
- undefined,
87
- "query",
88
- undefined,
89
- ts.factory.createTypeReferenceNode("Query"),
90
- ),
91
- ]
92
- : []),
93
- ts.factory.createPropertySignature(
94
- undefined,
95
- "provider",
96
- undefined,
97
- ts.factory.createTypeReferenceNode("Provider"),
98
- ),
99
- ]);
100
-
101
- export const headers =
102
- (project: INestiaProject) =>
103
- (importer: ImportDictionary) =>
104
- (param: ITypedHttpRouteParameter.IHeaders): ts.TypeNode => {
105
- if (project.config.clone === true)
106
- return from(project)(importer)(param.metadata);
107
- const type: ts.TypeNode = name(param);
108
- if (project.config.primitive === false) return type;
109
- return ts.factory.createTypeReferenceNode(
110
- importer.external({
111
- file: "typia",
112
- declaration: true,
113
- type: "element",
114
- name: "Resolved",
115
- }),
116
- [type],
117
- );
118
- };
119
-
120
- export const query =
121
- (project: INestiaProject) =>
122
- (importer: ImportDictionary) =>
123
- (param: ITypedHttpRouteParameter.IQuery): ts.TypeNode => {
124
- if (project.config.clone === true)
125
- return from(project)(importer)(param.metadata);
126
- const type: ts.TypeNode = name(param);
127
- if (project.config.primitive === false) return type;
128
- return ts.factory.createTypeReferenceNode(
129
- importer.external({
130
- file: "typia",
131
- declaration: true,
132
- type: "element",
133
- name: "Resolved",
134
- }),
135
- [type],
136
- );
137
- };
138
-
139
- export const body =
140
- (project: INestiaProject) =>
141
- (importer: ImportDictionary) =>
142
- (param: ITypedHttpRouteParameter.IBody): ts.TypeNode => {
143
- if (project.config.clone === true) {
144
- const type: ts.TypeNode = from(project)(importer)(param.metadata);
145
- return param.contentType === "multipart/form-data"
146
- ? formDataInput(importer)(type)
147
- : type;
148
- }
149
- const type: ts.TypeNode = name(param);
150
- if (param.contentType === "multipart/form-data")
151
- return formDataInput(importer)(type);
152
- else if (project.config.primitive === false) return type;
153
- return ts.factory.createTypeReferenceNode(
154
- importer.external({
155
- file: "typia",
156
- declaration: true,
157
- type: "element",
158
- name:
159
- param.contentType === "application/json" || param.encrypted === true
160
- ? "Primitive"
161
- : "Resolved",
162
- }),
163
- [type],
164
- );
165
- };
166
-
167
- export const response =
168
- (project: INestiaProject) =>
169
- (importer: ImportDictionary) =>
170
- (route: ITypedHttpRoute): ts.TypeNode => {
171
- const schema = (p: { metadata: Metadata; type: IReflectType }) =>
172
- p.metadata.size() === 0
173
- ? TypeFactory.keyword("void")
174
- : project.config.clone === true
175
- ? from(project)(importer)(p.metadata)
176
- : project.config.primitive !== false
177
- ? ts.factory.createTypeReferenceNode(
178
- importer.external({
179
- file: "typia",
180
- declaration: true,
181
- type: "element",
182
- name:
183
- route.success.contentType === "application/json" ||
184
- route.success.encrypted === true
185
- ? "Primitive"
186
- : "Resolved",
187
- }),
188
- [name(p)],
189
- )
190
- : name(p);
191
- if (project.config.propagate !== true) return schema(route.success);
192
-
193
- const branches: IBranch[] = [
194
- {
195
- status: String(
196
- route.success.status ?? (route.method === "POST" ? 201 : 200),
197
- ),
198
- type: schema(route.success),
199
- },
200
- ...Object.entries(route.exceptions).map(([status, value]) => ({
201
- status,
202
- type: schema(value),
203
- })),
204
- ];
205
- return ts.factory.createTypeReferenceNode(
206
- importer.external({
207
- file: "@nestia/fetcher",
208
- declaration: true,
209
- type: "element",
210
- name: "IPropagation",
211
- }),
212
- [
213
- ts.factory.createTypeLiteralNode(
214
- branches.map((b) =>
215
- ts.factory.createPropertySignature(
216
- undefined,
217
- ts.factory.createNumericLiteral(b.status),
218
- undefined,
219
- b.type,
220
- ),
221
- ),
222
- ),
223
- ...(route.success.status
224
- ? [
225
- ts.factory.createLiteralTypeNode(
226
- ts.factory.createNumericLiteral(route.success.status),
227
- ),
228
- ]
229
- : []),
230
- ],
231
- );
232
- };
233
-
234
- export const responseBody =
235
- (project: INestiaProject) =>
236
- (importer: ImportDictionary) =>
237
- (route: ITypedHttpRoute): ts.TypeNode =>
238
- response({
239
- ...project,
240
- config: {
241
- ...project.config,
242
- propagate: false,
243
- },
244
- })(importer)(route);
245
-
246
- const formDataInput = (importer: ImportDictionary) => (type: ts.TypeNode) =>
247
- ts.factory.createTypeReferenceNode(
248
- importer.external({
249
- file: "@nestia/fetcher",
250
- declaration: true,
251
- type: "element",
252
- name: "FormDataInput",
253
- }),
254
- [type],
255
- );
256
- }
257
-
258
- interface IBranch {
259
- status: string;
260
- type: ts.TypeNode;
261
- }
1
+ import ts from "typescript";
2
+ import { TypeFactory } from "typia/lib/factories/TypeFactory";
3
+ import { Metadata } from "typia/lib/schemas/metadata/Metadata";
4
+
5
+ import { INestiaProject } from "../../structures/INestiaProject";
6
+ import { IReflectType } from "../../structures/IReflectType";
7
+ import { ITypedHttpRoute } from "../../structures/ITypedHttpRoute";
8
+ import { ITypedHttpRouteParameter } from "../../structures/ITypedHttpRouteParameter";
9
+ import { ITypedWebSocketRoute } from "../../structures/ITypedWebSocketRoute";
10
+ import { FilePrinter } from "./FilePrinter";
11
+ import { ImportDictionary } from "./ImportDictionary";
12
+ import { SdkHttpParameterProgrammer } from "./SdkHttpParameterProgrammer";
13
+ import { SdkTypeProgrammer } from "./SdkTypeProgrammer";
14
+
15
+ export namespace SdkAliasCollection {
16
+ export const name = ({ type }: { type: IReflectType }): ts.TypeNode =>
17
+ ts.factory.createTypeReferenceNode(
18
+ type.name,
19
+ type.typeArguments
20
+ ? type.typeArguments.map((a) => name({ type: a }))
21
+ : undefined,
22
+ );
23
+
24
+ export const from =
25
+ (project: INestiaProject) =>
26
+ (importer: ImportDictionary) =>
27
+ (metadata: Metadata) =>
28
+ SdkTypeProgrammer.write(project)(importer)(metadata);
29
+
30
+ export const httpProps =
31
+ (project: INestiaProject) =>
32
+ (importer: ImportDictionary) =>
33
+ (route: ITypedHttpRoute): ts.TypeNode =>
34
+ ts.factory.createTypeLiteralNode(
35
+ SdkHttpParameterProgrammer.getEntries({
36
+ project,
37
+ importer,
38
+ route,
39
+ body: true,
40
+ prefix: false,
41
+ })
42
+ .map((e) => {
43
+ const signature: ts.PropertySignature =
44
+ ts.factory.createPropertySignature(
45
+ undefined,
46
+ e.key,
47
+ e.required
48
+ ? undefined
49
+ : ts.factory.createToken(ts.SyntaxKind.QuestionToken),
50
+ e.type,
51
+ );
52
+ const description: string | null =
53
+ e.parameter.description ??
54
+ route.jsDocTags
55
+ ?.find(
56
+ (tag) =>
57
+ tag.name === "param" &&
58
+ tag.text?.[0]?.kind === "parameterName" &&
59
+ tag.text?.[0]?.text === e.key,
60
+ )
61
+ ?.text?.find((t) => t.kind === "text")?.text ??
62
+ null;
63
+ return description?.length
64
+ ? [
65
+ ts.factory.createIdentifier("\n") as any,
66
+ FilePrinter.description(signature, description),
67
+ ]
68
+ : [signature];
69
+ })
70
+ .flat(),
71
+ );
72
+
73
+ export const websocketProps = (route: ITypedWebSocketRoute): ts.TypeNode =>
74
+ ts.factory.createTypeLiteralNode([
75
+ ...route.pathParameters.map((p) =>
76
+ ts.factory.createPropertySignature(
77
+ undefined,
78
+ p.name,
79
+ undefined,
80
+ SdkAliasCollection.name(p),
81
+ ),
82
+ ),
83
+ ...(route.query
84
+ ? [
85
+ ts.factory.createPropertySignature(
86
+ undefined,
87
+ "query",
88
+ undefined,
89
+ ts.factory.createTypeReferenceNode("Query"),
90
+ ),
91
+ ]
92
+ : []),
93
+ ts.factory.createPropertySignature(
94
+ undefined,
95
+ "provider",
96
+ undefined,
97
+ ts.factory.createTypeReferenceNode("Provider"),
98
+ ),
99
+ ]);
100
+
101
+ export const headers =
102
+ (project: INestiaProject) =>
103
+ (importer: ImportDictionary) =>
104
+ (param: ITypedHttpRouteParameter.IHeaders): ts.TypeNode => {
105
+ if (project.config.clone === true)
106
+ return from(project)(importer)(param.metadata);
107
+ const type: ts.TypeNode = name(param);
108
+ if (project.config.primitive === false) return type;
109
+ return ts.factory.createTypeReferenceNode(
110
+ importer.external({
111
+ file: "typia",
112
+ declaration: true,
113
+ type: "element",
114
+ name: "Resolved",
115
+ }),
116
+ [type],
117
+ );
118
+ };
119
+
120
+ export const query =
121
+ (project: INestiaProject) =>
122
+ (importer: ImportDictionary) =>
123
+ (param: ITypedHttpRouteParameter.IQuery): ts.TypeNode => {
124
+ if (project.config.clone === true)
125
+ return from(project)(importer)(param.metadata);
126
+ const type: ts.TypeNode = name(param);
127
+ if (project.config.primitive === false) return type;
128
+ return ts.factory.createTypeReferenceNode(
129
+ importer.external({
130
+ file: "typia",
131
+ declaration: true,
132
+ type: "element",
133
+ name: "Resolved",
134
+ }),
135
+ [type],
136
+ );
137
+ };
138
+
139
+ export const body =
140
+ (project: INestiaProject) =>
141
+ (importer: ImportDictionary) =>
142
+ (param: ITypedHttpRouteParameter.IBody): ts.TypeNode => {
143
+ if (project.config.clone === true) {
144
+ const type: ts.TypeNode = from(project)(importer)(param.metadata);
145
+ return param.contentType === "multipart/form-data"
146
+ ? formDataInput(importer)(type)
147
+ : type;
148
+ }
149
+ const type: ts.TypeNode = name(param);
150
+ if (param.contentType === "multipart/form-data")
151
+ return formDataInput(importer)(type);
152
+ else if (project.config.primitive === false) return type;
153
+ return ts.factory.createTypeReferenceNode(
154
+ importer.external({
155
+ file: "typia",
156
+ declaration: true,
157
+ type: "element",
158
+ name:
159
+ param.contentType === "application/json" || param.encrypted === true
160
+ ? "Primitive"
161
+ : "Resolved",
162
+ }),
163
+ [type],
164
+ );
165
+ };
166
+
167
+ export const response =
168
+ (project: INestiaProject) =>
169
+ (importer: ImportDictionary) =>
170
+ (route: ITypedHttpRoute): ts.TypeNode => {
171
+ const schema = (p: { metadata: Metadata; type: IReflectType }) =>
172
+ p.metadata.size() === 0
173
+ ? TypeFactory.keyword("void")
174
+ : project.config.clone === true
175
+ ? from(project)(importer)(p.metadata)
176
+ : project.config.primitive !== false
177
+ ? ts.factory.createTypeReferenceNode(
178
+ importer.external({
179
+ file: "typia",
180
+ declaration: true,
181
+ type: "element",
182
+ name:
183
+ route.success.contentType === "application/json" ||
184
+ route.success.encrypted === true
185
+ ? "Primitive"
186
+ : "Resolved",
187
+ }),
188
+ [name(p)],
189
+ )
190
+ : name(p);
191
+ if (project.config.propagate !== true) return schema(route.success);
192
+
193
+ const branches: IBranch[] = [
194
+ {
195
+ status: String(
196
+ route.success.status ?? (route.method === "POST" ? 201 : 200),
197
+ ),
198
+ type: schema(route.success),
199
+ },
200
+ ...Object.entries(route.exceptions).map(([status, value]) => ({
201
+ status,
202
+ type: schema(value),
203
+ })),
204
+ ];
205
+ return ts.factory.createTypeReferenceNode(
206
+ importer.external({
207
+ file: "@nestia/fetcher",
208
+ declaration: true,
209
+ type: "element",
210
+ name: "IPropagation",
211
+ }),
212
+ [
213
+ ts.factory.createTypeLiteralNode(
214
+ branches.map((b) =>
215
+ ts.factory.createPropertySignature(
216
+ undefined,
217
+ ts.factory.createNumericLiteral(b.status),
218
+ undefined,
219
+ b.type,
220
+ ),
221
+ ),
222
+ ),
223
+ ...(route.success.status
224
+ ? [
225
+ ts.factory.createLiteralTypeNode(
226
+ ts.factory.createNumericLiteral(route.success.status),
227
+ ),
228
+ ]
229
+ : []),
230
+ ],
231
+ );
232
+ };
233
+
234
+ export const responseBody =
235
+ (project: INestiaProject) =>
236
+ (importer: ImportDictionary) =>
237
+ (route: ITypedHttpRoute): ts.TypeNode =>
238
+ response({
239
+ ...project,
240
+ config: {
241
+ ...project.config,
242
+ propagate: false,
243
+ },
244
+ })(importer)(route);
245
+
246
+ const formDataInput = (importer: ImportDictionary) => (type: ts.TypeNode) =>
247
+ ts.factory.createTypeReferenceNode(
248
+ importer.external({
249
+ file: "@nestia/fetcher",
250
+ declaration: true,
251
+ type: "element",
252
+ name: "FormDataInput",
253
+ }),
254
+ [type],
255
+ );
256
+ }
257
+
258
+ interface IBranch {
259
+ status: string;
260
+ type: ts.TypeNode;
261
+ }