@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,64 +1,64 @@
1
- import { IJsDocTagInfo } from "typia";
2
-
3
- export namespace SwaggerDescriptionComposer {
4
- export const compose = <Kind extends "summary" | "title">(props: {
5
- description: string | null;
6
- jsDocTags: IJsDocTagInfo[];
7
- kind: Kind;
8
- }): Kind extends "summary"
9
- ? { summary?: string; description?: string }
10
- : { title?: string; description?: string } => {
11
- const title: string | undefined = (() => {
12
- const [explicit] = getJsDocTexts({
13
- jsDocTags: props.jsDocTags,
14
- name: props.kind,
15
- });
16
- if (explicit?.length) return explicit;
17
- else if (!props.description?.length) return undefined;
18
-
19
- const index: number = props.description.indexOf("\n");
20
- const top: string = (
21
- index === -1 ? props.description : props.description.substring(0, index)
22
- ).trim();
23
- return top.endsWith(".") ? top.substring(0, top.length - 1) : undefined;
24
- })();
25
- return {
26
- [props.kind]: title,
27
- description: props.description?.length ? props.description : undefined,
28
- } as any;
29
- };
30
-
31
- export const descriptionFromJsDocTag = (props: {
32
- jsDocTags: IJsDocTagInfo[];
33
- tag: string;
34
- parameter?: string;
35
- }): string | undefined => {
36
- const parametric: (elem: IJsDocTagInfo) => boolean = props.parameter
37
- ? (tag) =>
38
- tag.text!.find(
39
- (elem) =>
40
- elem.kind === "parameterName" && elem.text === props.parameter,
41
- ) !== undefined
42
- : () => true;
43
- const tag: IJsDocTagInfo | undefined = props.jsDocTags.find(
44
- (tag) => tag.name === props.tag && tag.text && parametric(tag),
45
- );
46
- return tag && tag.text
47
- ? tag.text.find((elem) => elem.kind === "text")?.text
48
- : undefined;
49
- };
50
-
51
- export const getJsDocTexts = (props: {
52
- jsDocTags: IJsDocTagInfo[];
53
- name: string;
54
- }): string[] =>
55
- props.jsDocTags
56
- .filter(
57
- (tag) =>
58
- tag.name === props.name &&
59
- tag.text &&
60
- tag.text.find((elem) => elem.kind === "text" && elem.text.length) !==
61
- undefined,
62
- )
63
- .map((tag) => tag.text!.find((elem) => elem.kind === "text")!.text);
64
- }
1
+ import { IJsDocTagInfo } from "typia";
2
+
3
+ export namespace SwaggerDescriptionComposer {
4
+ export const compose = <Kind extends "summary" | "title">(props: {
5
+ description: string | null;
6
+ jsDocTags: IJsDocTagInfo[];
7
+ kind: Kind;
8
+ }): Kind extends "summary"
9
+ ? { summary?: string; description?: string }
10
+ : { title?: string; description?: string } => {
11
+ const title: string | undefined = (() => {
12
+ const [explicit] = getJsDocTexts({
13
+ jsDocTags: props.jsDocTags,
14
+ name: props.kind,
15
+ });
16
+ if (explicit?.length) return explicit;
17
+ else if (!props.description?.length) return undefined;
18
+
19
+ const index: number = props.description.indexOf("\n");
20
+ const top: string = (
21
+ index === -1 ? props.description : props.description.substring(0, index)
22
+ ).trim();
23
+ return top.endsWith(".") ? top.substring(0, top.length - 1) : undefined;
24
+ })();
25
+ return {
26
+ [props.kind]: title,
27
+ description: props.description?.length ? props.description : undefined,
28
+ } as any;
29
+ };
30
+
31
+ export const descriptionFromJsDocTag = (props: {
32
+ jsDocTags: IJsDocTagInfo[];
33
+ tag: string;
34
+ parameter?: string;
35
+ }): string | undefined => {
36
+ const parametric: (elem: IJsDocTagInfo) => boolean = props.parameter
37
+ ? (tag) =>
38
+ tag.text!.find(
39
+ (elem) =>
40
+ elem.kind === "parameterName" && elem.text === props.parameter,
41
+ ) !== undefined
42
+ : () => true;
43
+ const tag: IJsDocTagInfo | undefined = props.jsDocTags.find(
44
+ (tag) => tag.name === props.tag && tag.text && parametric(tag),
45
+ );
46
+ return tag && tag.text
47
+ ? tag.text.find((elem) => elem.kind === "text")?.text
48
+ : undefined;
49
+ };
50
+
51
+ export const getJsDocTexts = (props: {
52
+ jsDocTags: IJsDocTagInfo[];
53
+ name: string;
54
+ }): string[] =>
55
+ props.jsDocTags
56
+ .filter(
57
+ (tag) =>
58
+ tag.name === props.name &&
59
+ tag.text &&
60
+ tag.text.find((elem) => elem.kind === "text" && elem.text.length) !==
61
+ undefined,
62
+ )
63
+ .map((tag) => tag.text!.find((elem) => elem.kind === "text")!.text);
64
+ }
@@ -1,119 +1,119 @@
1
- import { OpenApi } from "@samchon/openapi";
2
- import { Metadata } from "typia/lib/schemas/metadata/Metadata";
3
-
4
- import { INestiaConfig } from "../../INestiaConfig";
5
- import { SecurityAnalyzer } from "../../analyses/SecurityAnalyzer";
6
- import { ITypedHttpRoute } from "../../structures/ITypedHttpRoute";
7
- import { SwaggerDescriptionComposer } from "./SwaggerDescriptionComposer";
8
- import { SwaggerOperationParameterComposer } from "./SwaggerOperationParameterComposer";
9
- import { SwaggerOperationResponseComposer } from "./SwaggerOperationResponseComposer";
10
-
11
- export namespace SwaggerOperationComposer {
12
- export const compose = (props: {
13
- config: Omit<INestiaConfig.ISwaggerConfig, "output">;
14
- document: OpenApi.IDocument;
15
- schema: (metadata: Metadata) => OpenApi.IJsonSchema | undefined;
16
- route: ITypedHttpRoute;
17
- }): OpenApi.IOperation => {
18
- // COMPOSE TAGS
19
- const tags: Set<string> = new Set([
20
- ...props.route.controller.tags,
21
- ...props.route.tags,
22
- ...SwaggerDescriptionComposer.getJsDocTexts({
23
- jsDocTags: props.route.jsDocTags,
24
- name: "tag",
25
- }).map((t) => t.split(" ")[0]),
26
- ]);
27
- if (tags.size) {
28
- props.document.tags ??= [];
29
- for (const t of tags)
30
- if (props.document.tags.find((elem) => elem.name === t) === undefined)
31
- props.document.tags.push({ name: t });
32
- for (const texts of SwaggerDescriptionComposer.getJsDocTexts({
33
- jsDocTags: props.route.jsDocTags,
34
- name: "tag",
35
- })) {
36
- const [name, ...description] = texts.split(" ");
37
- if (description.length)
38
- props.document.tags.find(
39
- (elem) => elem.name === name,
40
- )!.description ??= description.join(" ");
41
- }
42
- }
43
-
44
- // SECURITY
45
- const security: Record<string, string[]>[] = SecurityAnalyzer.merge(
46
- ...props.route.controller.security,
47
- ...props.route.security,
48
- ...props.route.jsDocTags
49
- .filter((tag) => tag.name === "security")
50
- .map((tag) =>
51
- tag.text === undefined
52
- ? [{}]
53
- : tag.text.map((text) => {
54
- const line: string[] = text.text
55
- .split(" ")
56
- .filter((s) => s.trim())
57
- .filter((s) => !!s.length);
58
- if (line.length === 0) return {};
59
- return {
60
- [line[0]]: line.slice(1),
61
- };
62
- }),
63
- )
64
- .flat(),
65
- );
66
-
67
- // FINALIZE
68
- return {
69
- ...SwaggerDescriptionComposer.compose({
70
- description: props.route.description,
71
- jsDocTags: props.route.jsDocTags,
72
- kind: "summary",
73
- }),
74
- deprecated: props.route.jsDocTags.some((tag) => tag.name === "deprecated")
75
- ? true
76
- : undefined,
77
- tags: Array.from(tags),
78
- operationId:
79
- props.route.operationId ??
80
- props.config.operationId?.({
81
- class: props.route.controller.class.name,
82
- function: props.route.name,
83
- method: props.route.method as "GET",
84
- path: props.route.path,
85
- }),
86
- parameters: [
87
- ...props.route.pathParameters,
88
- ...props.route.queryParameters,
89
- ...(props.route.queryObject ? [props.route.queryObject] : []),
90
- ...(props.route.headerObject ? [props.route.headerObject] : []),
91
- ]
92
- .map((p) =>
93
- SwaggerOperationParameterComposer.compose({
94
- config: props.config,
95
- document: props.document,
96
- schema: props.schema(p.metadata)!,
97
- parameter: p,
98
- jsDocTags: props.route.jsDocTags,
99
- }),
100
- )
101
- .flat(),
102
- requestBody: props.route.body
103
- ? SwaggerOperationParameterComposer.body({
104
- schema: props.schema(props.route.body.metadata)!,
105
- jsDocTags: props.route.jsDocTags,
106
- parameter: props.route.body,
107
- })
108
- : undefined,
109
- responses: SwaggerOperationResponseComposer.compose({
110
- schema: props.schema,
111
- route: props.route,
112
- }),
113
- security: security.length ? security : undefined,
114
- ...(props.route.extensions ?? {}),
115
- "x-samchon-accessor": props.route.accessor,
116
- "x-samchon-controller": props.route.controller.class.name,
117
- };
118
- };
119
- }
1
+ import { OpenApi } from "@samchon/openapi";
2
+ import { Metadata } from "typia/lib/schemas/metadata/Metadata";
3
+
4
+ import { INestiaConfig } from "../../INestiaConfig";
5
+ import { SecurityAnalyzer } from "../../analyses/SecurityAnalyzer";
6
+ import { ITypedHttpRoute } from "../../structures/ITypedHttpRoute";
7
+ import { SwaggerDescriptionComposer } from "./SwaggerDescriptionComposer";
8
+ import { SwaggerOperationParameterComposer } from "./SwaggerOperationParameterComposer";
9
+ import { SwaggerOperationResponseComposer } from "./SwaggerOperationResponseComposer";
10
+
11
+ export namespace SwaggerOperationComposer {
12
+ export const compose = (props: {
13
+ config: Omit<INestiaConfig.ISwaggerConfig, "output">;
14
+ document: OpenApi.IDocument;
15
+ schema: (metadata: Metadata) => OpenApi.IJsonSchema | undefined;
16
+ route: ITypedHttpRoute;
17
+ }): OpenApi.IOperation => {
18
+ // COMPOSE TAGS
19
+ const tags: Set<string> = new Set([
20
+ ...props.route.controller.tags,
21
+ ...props.route.tags,
22
+ ...SwaggerDescriptionComposer.getJsDocTexts({
23
+ jsDocTags: props.route.jsDocTags,
24
+ name: "tag",
25
+ }).map((t) => t.split(" ")[0]),
26
+ ]);
27
+ if (tags.size) {
28
+ props.document.tags ??= [];
29
+ for (const t of tags)
30
+ if (props.document.tags.find((elem) => elem.name === t) === undefined)
31
+ props.document.tags.push({ name: t });
32
+ for (const texts of SwaggerDescriptionComposer.getJsDocTexts({
33
+ jsDocTags: props.route.jsDocTags,
34
+ name: "tag",
35
+ })) {
36
+ const [name, ...description] = texts.split(" ");
37
+ if (description.length)
38
+ props.document.tags.find(
39
+ (elem) => elem.name === name,
40
+ )!.description ??= description.join(" ");
41
+ }
42
+ }
43
+
44
+ // SECURITY
45
+ const security: Record<string, string[]>[] = SecurityAnalyzer.merge(
46
+ ...props.route.controller.security,
47
+ ...props.route.security,
48
+ ...props.route.jsDocTags
49
+ .filter((tag) => tag.name === "security")
50
+ .map((tag) =>
51
+ tag.text === undefined
52
+ ? [{}]
53
+ : tag.text.map((text) => {
54
+ const line: string[] = text.text
55
+ .split(" ")
56
+ .filter((s) => s.trim())
57
+ .filter((s) => !!s.length);
58
+ if (line.length === 0) return {};
59
+ return {
60
+ [line[0]]: line.slice(1),
61
+ };
62
+ }),
63
+ )
64
+ .flat(),
65
+ );
66
+
67
+ // FINALIZE
68
+ return {
69
+ ...SwaggerDescriptionComposer.compose({
70
+ description: props.route.description,
71
+ jsDocTags: props.route.jsDocTags,
72
+ kind: "summary",
73
+ }),
74
+ deprecated: props.route.jsDocTags.some((tag) => tag.name === "deprecated")
75
+ ? true
76
+ : undefined,
77
+ tags: Array.from(tags),
78
+ operationId:
79
+ props.route.operationId ??
80
+ props.config.operationId?.({
81
+ class: props.route.controller.class.name,
82
+ function: props.route.name,
83
+ method: props.route.method as "GET",
84
+ path: props.route.path,
85
+ }),
86
+ parameters: [
87
+ ...props.route.pathParameters,
88
+ ...props.route.queryParameters,
89
+ ...(props.route.queryObject ? [props.route.queryObject] : []),
90
+ ...(props.route.headerObject ? [props.route.headerObject] : []),
91
+ ]
92
+ .map((p) =>
93
+ SwaggerOperationParameterComposer.compose({
94
+ config: props.config,
95
+ document: props.document,
96
+ schema: props.schema(p.metadata)!,
97
+ parameter: p,
98
+ jsDocTags: props.route.jsDocTags,
99
+ }),
100
+ )
101
+ .flat(),
102
+ requestBody: props.route.body
103
+ ? SwaggerOperationParameterComposer.body({
104
+ schema: props.schema(props.route.body.metadata)!,
105
+ jsDocTags: props.route.jsDocTags,
106
+ parameter: props.route.body,
107
+ })
108
+ : undefined,
109
+ responses: SwaggerOperationResponseComposer.compose({
110
+ schema: props.schema,
111
+ route: props.route,
112
+ }),
113
+ security: security.length ? security : undefined,
114
+ ...(props.route.extensions ?? {}),
115
+ "x-samchon-accessor": props.route.accessor,
116
+ "x-samchon-controller": props.route.controller.class.name,
117
+ };
118
+ };
119
+ }