@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,205 +1,205 @@
1
- import ts from "typescript";
2
- import { IdentifierFactory } from "typia/lib/factories/IdentifierFactory";
3
- import { LiteralFactory } from "typia/lib/factories/LiteralFactory";
4
-
5
- import { INestiaProject } from "../../structures/INestiaProject";
6
- import { ITypedHttpRoute } from "../../structures/ITypedHttpRoute";
7
- import { FilePrinter } from "./FilePrinter";
8
- import { ImportDictionary } from "./ImportDictionary";
9
- import { SdkAliasCollection } from "./SdkAliasCollection";
10
- import { SdkHttpParameterProgrammer } from "./SdkHttpParameterProgrammer";
11
- import { SdkImportWizard } from "./SdkImportWizard";
12
-
13
- export namespace E2eFileProgrammer {
14
- export const generate =
15
- (project: INestiaProject) =>
16
- (props: { api: string; current: string }) =>
17
- async (route: ITypedHttpRoute): Promise<void> => {
18
- const importer: ImportDictionary = new ImportDictionary(
19
- `${props.current}/${getFunctionName(route)}.ts`,
20
- );
21
- if (project.config.clone !== true)
22
- for (const tuple of route.imports)
23
- for (const instance of tuple.instances)
24
- importer.internal({
25
- file: tuple.file,
26
- type: true,
27
- instance,
28
- });
29
- importer.internal({
30
- type: false,
31
- file: props.api,
32
- instance: null,
33
- name: "api",
34
- });
35
-
36
- const functor: ts.Statement = generateFunctor(project)(importer)(route);
37
- await FilePrinter.write({
38
- location: importer.file,
39
- statements: [
40
- ...importer.toStatements(props.current),
41
- FilePrinter.enter(),
42
- functor,
43
- ],
44
- });
45
- };
46
-
47
- const generateFunctor =
48
- (project: INestiaProject) =>
49
- (importer: ImportDictionary) =>
50
- (route: ITypedHttpRoute): ts.Statement =>
51
- ts.factory.createVariableStatement(
52
- [ts.factory.createModifier(ts.SyntaxKind.ExportKeyword)],
53
- ts.factory.createVariableDeclarationList(
54
- [
55
- ts.factory.createVariableDeclaration(
56
- ts.factory.createIdentifier(getFunctionName(route)),
57
- undefined,
58
- undefined,
59
- generateArrow(project)(importer)(route),
60
- ),
61
- ],
62
- ts.NodeFlags.Const,
63
- ),
64
- );
65
-
66
- const generateArrow =
67
- (project: INestiaProject) =>
68
- (importer: ImportDictionary) =>
69
- (route: ITypedHttpRoute) => {
70
- const random = IdentifierFactory.access(
71
- ts.factory.createIdentifier(SdkImportWizard.typia(importer)),
72
- "random",
73
- );
74
- const connection = route.headerObject
75
- ? ts.factory.createObjectLiteralExpression(
76
- [
77
- ts.factory.createSpreadAssignment(
78
- ts.factory.createIdentifier("connection"),
79
- ),
80
- ts.factory.createPropertyAssignment(
81
- "headers",
82
- ts.factory.createObjectLiteralExpression(
83
- [
84
- ts.factory.createSpreadAssignment(
85
- IdentifierFactory.access(
86
- ts.factory.createIdentifier("connection"),
87
- "headers",
88
- ),
89
- ),
90
- ts.factory.createSpreadAssignment(
91
- ts.factory.createCallExpression(
92
- random,
93
- [
94
- project.config.clone === true
95
- ? SdkAliasCollection.from(project)(importer)(
96
- route.headerObject.metadata,
97
- )
98
- : SdkAliasCollection.name(route.headerObject),
99
- ],
100
- undefined,
101
- ),
102
- ),
103
- ],
104
- true,
105
- ),
106
- ),
107
- ],
108
- true,
109
- )
110
- : ts.factory.createIdentifier("connection");
111
- const entries = SdkHttpParameterProgrammer.getEntries({
112
- project,
113
- importer,
114
- route,
115
- body: true,
116
- e2e: true,
117
- prefix: ["api", "functional", ...route.accessor].join(".") + ".",
118
- });
119
- const fetch = ts.factory.createCallExpression(
120
- ts.factory.createIdentifier(
121
- ["api", "functional", ...route.accessor].join("."),
122
- ),
123
- undefined,
124
- [
125
- connection,
126
- ...(project.config.keyword === true && entries.length !== 0
127
- ? [
128
- LiteralFactory.write(
129
- Object.fromEntries(
130
- entries.map((e) => [
131
- e.key,
132
- ts.factory.createCallExpression(
133
- IdentifierFactory.access(
134
- ts.factory.createIdentifier(
135
- SdkImportWizard.typia(importer),
136
- ),
137
- "random",
138
- ),
139
- [e.type],
140
- undefined,
141
- ),
142
- ]),
143
- ),
144
- ),
145
- ]
146
- : entries.map((e) =>
147
- ts.factory.createCallExpression(
148
- IdentifierFactory.access(
149
- ts.factory.createIdentifier(
150
- SdkImportWizard.typia(importer),
151
- ),
152
- "random",
153
- ),
154
- [e.type],
155
- undefined,
156
- ),
157
- )),
158
- ],
159
- );
160
- const assert = ts.factory.createCallExpression(
161
- IdentifierFactory.access(
162
- ts.factory.createIdentifier(SdkImportWizard.typia(importer)),
163
- "assert",
164
- ),
165
- undefined,
166
- [ts.factory.createIdentifier("output")],
167
- );
168
-
169
- return ts.factory.createArrowFunction(
170
- [ts.factory.createModifier(ts.SyntaxKind.AsyncKeyword)],
171
- undefined,
172
- [
173
- IdentifierFactory.parameter(
174
- "connection",
175
- ts.factory.createTypeReferenceNode("api.IConnection"),
176
- ),
177
- ],
178
- undefined,
179
- undefined,
180
- ts.factory.createBlock([
181
- ts.factory.createVariableStatement(
182
- [],
183
- ts.factory.createVariableDeclarationList(
184
- [
185
- ts.factory.createVariableDeclaration(
186
- "output",
187
- undefined,
188
- project.config.propagate !== true &&
189
- route.success.type.name === "void"
190
- ? undefined
191
- : SdkAliasCollection.response(project)(importer)(route),
192
- ts.factory.createAwaitExpression(fetch),
193
- ),
194
- ],
195
- ts.NodeFlags.Const,
196
- ),
197
- ),
198
- ts.factory.createExpressionStatement(assert),
199
- ]),
200
- );
201
- };
202
- }
203
-
204
- const getFunctionName = (route: ITypedHttpRoute): string =>
205
- ["test", "api", ...route.accessor].join("_");
1
+ import ts from "typescript";
2
+ import { IdentifierFactory } from "typia/lib/factories/IdentifierFactory";
3
+ import { LiteralFactory } from "typia/lib/factories/LiteralFactory";
4
+
5
+ import { INestiaProject } from "../../structures/INestiaProject";
6
+ import { ITypedHttpRoute } from "../../structures/ITypedHttpRoute";
7
+ import { FilePrinter } from "./FilePrinter";
8
+ import { ImportDictionary } from "./ImportDictionary";
9
+ import { SdkAliasCollection } from "./SdkAliasCollection";
10
+ import { SdkHttpParameterProgrammer } from "./SdkHttpParameterProgrammer";
11
+ import { SdkImportWizard } from "./SdkImportWizard";
12
+
13
+ export namespace E2eFileProgrammer {
14
+ export const generate =
15
+ (project: INestiaProject) =>
16
+ (props: { api: string; current: string }) =>
17
+ async (route: ITypedHttpRoute): Promise<void> => {
18
+ const importer: ImportDictionary = new ImportDictionary(
19
+ `${props.current}/${getFunctionName(route)}.ts`,
20
+ );
21
+ if (project.config.clone !== true)
22
+ for (const tuple of route.imports)
23
+ for (const instance of tuple.instances)
24
+ importer.internal({
25
+ file: tuple.file,
26
+ type: true,
27
+ instance,
28
+ });
29
+ importer.internal({
30
+ type: false,
31
+ file: props.api,
32
+ instance: null,
33
+ name: "api",
34
+ });
35
+
36
+ const functor: ts.Statement = generateFunctor(project)(importer)(route);
37
+ await FilePrinter.write({
38
+ location: importer.file,
39
+ statements: [
40
+ ...importer.toStatements(props.current),
41
+ FilePrinter.enter(),
42
+ functor,
43
+ ],
44
+ });
45
+ };
46
+
47
+ const generateFunctor =
48
+ (project: INestiaProject) =>
49
+ (importer: ImportDictionary) =>
50
+ (route: ITypedHttpRoute): ts.Statement =>
51
+ ts.factory.createVariableStatement(
52
+ [ts.factory.createModifier(ts.SyntaxKind.ExportKeyword)],
53
+ ts.factory.createVariableDeclarationList(
54
+ [
55
+ ts.factory.createVariableDeclaration(
56
+ ts.factory.createIdentifier(getFunctionName(route)),
57
+ undefined,
58
+ undefined,
59
+ generateArrow(project)(importer)(route),
60
+ ),
61
+ ],
62
+ ts.NodeFlags.Const,
63
+ ),
64
+ );
65
+
66
+ const generateArrow =
67
+ (project: INestiaProject) =>
68
+ (importer: ImportDictionary) =>
69
+ (route: ITypedHttpRoute) => {
70
+ const random = IdentifierFactory.access(
71
+ ts.factory.createIdentifier(SdkImportWizard.typia(importer)),
72
+ "random",
73
+ );
74
+ const connection = route.headerObject
75
+ ? ts.factory.createObjectLiteralExpression(
76
+ [
77
+ ts.factory.createSpreadAssignment(
78
+ ts.factory.createIdentifier("connection"),
79
+ ),
80
+ ts.factory.createPropertyAssignment(
81
+ "headers",
82
+ ts.factory.createObjectLiteralExpression(
83
+ [
84
+ ts.factory.createSpreadAssignment(
85
+ IdentifierFactory.access(
86
+ ts.factory.createIdentifier("connection"),
87
+ "headers",
88
+ ),
89
+ ),
90
+ ts.factory.createSpreadAssignment(
91
+ ts.factory.createCallExpression(
92
+ random,
93
+ [
94
+ project.config.clone === true
95
+ ? SdkAliasCollection.from(project)(importer)(
96
+ route.headerObject.metadata,
97
+ )
98
+ : SdkAliasCollection.name(route.headerObject),
99
+ ],
100
+ undefined,
101
+ ),
102
+ ),
103
+ ],
104
+ true,
105
+ ),
106
+ ),
107
+ ],
108
+ true,
109
+ )
110
+ : ts.factory.createIdentifier("connection");
111
+ const entries = SdkHttpParameterProgrammer.getEntries({
112
+ project,
113
+ importer,
114
+ route,
115
+ body: true,
116
+ e2e: true,
117
+ prefix: ["api", "functional", ...route.accessor].join(".") + ".",
118
+ });
119
+ const fetch = ts.factory.createCallExpression(
120
+ ts.factory.createIdentifier(
121
+ ["api", "functional", ...route.accessor].join("."),
122
+ ),
123
+ undefined,
124
+ [
125
+ connection,
126
+ ...(project.config.keyword === true && entries.length !== 0
127
+ ? [
128
+ LiteralFactory.write(
129
+ Object.fromEntries(
130
+ entries.map((e) => [
131
+ e.key,
132
+ ts.factory.createCallExpression(
133
+ IdentifierFactory.access(
134
+ ts.factory.createIdentifier(
135
+ SdkImportWizard.typia(importer),
136
+ ),
137
+ "random",
138
+ ),
139
+ [e.type],
140
+ undefined,
141
+ ),
142
+ ]),
143
+ ),
144
+ ),
145
+ ]
146
+ : entries.map((e) =>
147
+ ts.factory.createCallExpression(
148
+ IdentifierFactory.access(
149
+ ts.factory.createIdentifier(
150
+ SdkImportWizard.typia(importer),
151
+ ),
152
+ "random",
153
+ ),
154
+ [e.type],
155
+ undefined,
156
+ ),
157
+ )),
158
+ ],
159
+ );
160
+ const assert = ts.factory.createCallExpression(
161
+ IdentifierFactory.access(
162
+ ts.factory.createIdentifier(SdkImportWizard.typia(importer)),
163
+ "assert",
164
+ ),
165
+ undefined,
166
+ [ts.factory.createIdentifier("output")],
167
+ );
168
+
169
+ return ts.factory.createArrowFunction(
170
+ [ts.factory.createModifier(ts.SyntaxKind.AsyncKeyword)],
171
+ undefined,
172
+ [
173
+ IdentifierFactory.parameter(
174
+ "connection",
175
+ ts.factory.createTypeReferenceNode("api.IConnection"),
176
+ ),
177
+ ],
178
+ undefined,
179
+ undefined,
180
+ ts.factory.createBlock([
181
+ ts.factory.createVariableStatement(
182
+ [],
183
+ ts.factory.createVariableDeclarationList(
184
+ [
185
+ ts.factory.createVariableDeclaration(
186
+ "output",
187
+ undefined,
188
+ project.config.propagate !== true &&
189
+ route.success.type.name === "void"
190
+ ? undefined
191
+ : SdkAliasCollection.response(project)(importer)(route),
192
+ ts.factory.createAwaitExpression(fetch),
193
+ ),
194
+ ],
195
+ ts.NodeFlags.Const,
196
+ ),
197
+ ),
198
+ ts.factory.createExpressionStatement(assert),
199
+ ]),
200
+ );
201
+ };
202
+ }
203
+
204
+ const getFunctionName = (route: ITypedHttpRoute): string =>
205
+ ["test", "api", ...route.accessor].join("_");
@@ -1,53 +1,53 @@
1
- import fs from "fs";
2
- import { format } from "prettier";
3
- import ts from "typescript";
4
-
5
- export namespace FilePrinter {
6
- export const description = <Node extends ts.Node>(
7
- node: Node,
8
- comment: string,
9
- ): Node => {
10
- if (comment.length === 0) return node;
11
- ts.addSyntheticLeadingComment(
12
- node,
13
- ts.SyntaxKind.MultiLineCommentTrivia,
14
- ["*", ...comment.split("\n").map((str) => ` * ${str}`), ""].join("\n"),
15
- true,
16
- );
17
- return node;
18
- };
19
-
20
- export const enter = () =>
21
- ts.factory.createExpressionStatement(ts.factory.createIdentifier("\n"));
22
-
23
- export const write = async (props: {
24
- location: string;
25
- statements: ts.Statement[];
26
- top?: string;
27
- }): Promise<void> => {
28
- const script: string = ts
29
- .createPrinter()
30
- .printFile(
31
- ts.factory.createSourceFile(
32
- props.statements,
33
- ts.factory.createToken(ts.SyntaxKind.EndOfFileToken),
34
- ts.NodeFlags.None,
35
- ),
36
- );
37
- await fs.promises.writeFile(
38
- props.location,
39
- await beautify((props.top ?? "") + script),
40
- "utf8",
41
- );
42
- };
43
-
44
- const beautify = async (script: string): Promise<string> => {
45
- try {
46
- return await format(script, {
47
- parser: "typescript",
48
- });
49
- } catch {
50
- return script;
51
- }
52
- };
53
- }
1
+ import fs from "fs";
2
+ import { format } from "prettier";
3
+ import ts from "typescript";
4
+
5
+ export namespace FilePrinter {
6
+ export const description = <Node extends ts.Node>(
7
+ node: Node,
8
+ comment: string,
9
+ ): Node => {
10
+ if (comment.length === 0) return node;
11
+ ts.addSyntheticLeadingComment(
12
+ node,
13
+ ts.SyntaxKind.MultiLineCommentTrivia,
14
+ ["*", ...comment.split("\n").map((str) => ` * ${str}`), ""].join("\n"),
15
+ true,
16
+ );
17
+ return node;
18
+ };
19
+
20
+ export const enter = () =>
21
+ ts.factory.createExpressionStatement(ts.factory.createIdentifier("\n"));
22
+
23
+ export const write = async (props: {
24
+ location: string;
25
+ statements: ts.Statement[];
26
+ top?: string;
27
+ }): Promise<void> => {
28
+ const script: string = ts
29
+ .createPrinter()
30
+ .printFile(
31
+ ts.factory.createSourceFile(
32
+ props.statements,
33
+ ts.factory.createToken(ts.SyntaxKind.EndOfFileToken),
34
+ ts.NodeFlags.None,
35
+ ),
36
+ );
37
+ await fs.promises.writeFile(
38
+ props.location,
39
+ await beautify((props.top ?? "") + script),
40
+ "utf8",
41
+ );
42
+ };
43
+
44
+ const beautify = async (script: string): Promise<string> => {
45
+ try {
46
+ return await format(script, {
47
+ parser: "typescript",
48
+ });
49
+ } catch {
50
+ return script;
51
+ }
52
+ };
53
+ }