@nestia/sdk 7.0.0-dev.20250607 → 7.0.0

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