@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,110 +1,110 @@
1
- import { OpenApi } from "@samchon/openapi";
2
- import { VariadicSingleton } from "tstl";
3
- import { Metadata } from "typia/lib/schemas/metadata/Metadata";
4
-
5
- import { ITypedHttpRoute } from "../../structures/ITypedHttpRoute";
6
- import { StringUtil } from "../../utils/StringUtil";
7
- import { SwaggerDescriptionComposer } from "./SwaggerDescriptionComposer";
8
-
9
- export namespace SwaggerOperationResponseComposer {
10
- export const compose = (props: {
11
- schema: (metadata: Metadata) => OpenApi.IJsonSchema | undefined;
12
- route: ITypedHttpRoute;
13
- }): Record<string, OpenApi.IOperation.IResponse> => {
14
- const output: Record<string, OpenApi.IOperation.IResponse> = {};
15
- // FROM DECORATOR
16
- for (const [status, error] of Object.entries(props.route.exceptions))
17
- output[status] = {
18
- description: error.description ?? undefined,
19
- content: {
20
- "application/json": {
21
- schema: props.schema(error.metadata),
22
- example: error.example,
23
- examples: error.examples,
24
- },
25
- },
26
- };
27
-
28
- // FROM COMMENTS
29
- for (const tag of props.route.jsDocTags) {
30
- if (tag.name !== "throw" && tag.name !== "throws") continue;
31
- const text: string | undefined = tag.text?.find(
32
- (elem) => elem.kind === "text",
33
- )?.text;
34
- if (text === undefined) continue;
35
-
36
- const elements: string[] = text.split(" ").map((str) => str.trim());
37
- const status: string = elements[0];
38
- if (
39
- isNaN(Number(status)) &&
40
- status !== "2XX" &&
41
- status !== "3XX" &&
42
- status !== "4XX" &&
43
- status !== "5XX"
44
- )
45
- continue;
46
-
47
- const description: string | undefined =
48
- elements.length === 1 ? undefined : elements.slice(1).join(" ");
49
- const oldbie = output[status];
50
- if (description && oldbie !== undefined)
51
- oldbie.description ??= description;
52
- else if (oldbie === undefined)
53
- output[status] = {
54
- description: description,
55
- content: {
56
- "application/json": {
57
- schema: {},
58
- },
59
- },
60
- };
61
- }
62
-
63
- // SUCCESS
64
- const description: string | undefined =
65
- SwaggerDescriptionComposer.descriptionFromJsDocTag({
66
- jsDocTags: props.route.jsDocTags,
67
- tag: "returns",
68
- }) ??
69
- SwaggerDescriptionComposer.descriptionFromJsDocTag({
70
- jsDocTags: props.route.jsDocTags,
71
- tag: "return",
72
- });
73
- output[
74
- props.route.success.status ??
75
- (props.route.method.toLowerCase() === "post" ? 201 : 200)
76
- ] = {
77
- description: props.route.success.encrypted
78
- ? `${warning.get(!!description, props.route.method)}${description ?? ""}`
79
- : (description ?? ""),
80
- content: props.route.success.contentType
81
- ? {
82
- [props.route.success.contentType]: {
83
- schema: props.schema(props.route.success.metadata),
84
- example: props.route.success.example,
85
- examples: props.route.success.examples,
86
- },
87
- }
88
- : undefined,
89
- ...(props.route.success.encrypted ? { "x-nestia-encrypted": true } : {}),
90
- };
91
- return output;
92
- };
93
- }
94
-
95
- const warning = new VariadicSingleton((described: boolean, method: string) => {
96
- const summary: string = "Response data have been encrypted.";
97
- const component: string = `[EncryptedRoute.${StringUtil.capitalize(method)}](https://github.com/samchon/@nestia/core#encryptedroute)`;
98
-
99
- const content: string[] = [
100
- "## Warning",
101
- "",
102
- summary,
103
- "",
104
- `The response body data would be encrypted as "AES-128(256) / CBC mode / PKCS#5 Padding / Base64 Encoding", through the ${component} component.`,
105
- "",
106
- `Therefore, just utilize this swagger editor only for referencing. If you need to call the real API, using [SDK](https://github.com/samchon/nestia#software-development-kit) would be much better.`,
107
- ];
108
- if (described === true) content.push("", "----------------", "", "");
109
- return content.join("\n");
110
- });
1
+ import { MetadataSchema } from "@typia/core";
2
+ import { OpenApi } from "@typia/interface";
3
+ import { VariadicSingleton } from "tstl";
4
+
5
+ import { ITypedHttpRoute } from "../../structures/ITypedHttpRoute";
6
+ import { StringUtil } from "../../utils/StringUtil";
7
+ import { SwaggerDescriptionComposer } from "./SwaggerDescriptionComposer";
8
+
9
+ export namespace SwaggerOperationResponseComposer {
10
+ export const compose = (props: {
11
+ schema: (metadata: MetadataSchema) => OpenApi.IJsonSchema | undefined;
12
+ route: ITypedHttpRoute;
13
+ }): Record<string, OpenApi.IOperation.IResponse> => {
14
+ const output: Record<string, OpenApi.IOperation.IResponse> = {};
15
+ // FROM DECORATOR
16
+ for (const [status, error] of Object.entries(props.route.exceptions))
17
+ output[status] = {
18
+ description: error.description ?? undefined,
19
+ content: {
20
+ "application/json": {
21
+ schema: props.schema(error.metadata),
22
+ example: error.example,
23
+ examples: error.examples,
24
+ },
25
+ },
26
+ };
27
+
28
+ // FROM COMMENTS
29
+ for (const tag of props.route.jsDocTags) {
30
+ if (tag.name !== "throw" && tag.name !== "throws") continue;
31
+ const text: string | undefined = tag.text?.find(
32
+ (elem) => elem.kind === "text",
33
+ )?.text;
34
+ if (text === undefined) continue;
35
+
36
+ const elements: string[] = text.split(" ").map((str) => str.trim());
37
+ const status: string = elements[0]!;
38
+ if (
39
+ isNaN(Number(status)) &&
40
+ status !== "2XX" &&
41
+ status !== "3XX" &&
42
+ status !== "4XX" &&
43
+ status !== "5XX"
44
+ )
45
+ continue;
46
+
47
+ const description: string | undefined =
48
+ elements.length === 1 ? undefined : elements.slice(1).join(" ");
49
+ const oldbie = output[status];
50
+ if (description && oldbie !== undefined)
51
+ oldbie.description ??= description;
52
+ else if (oldbie === undefined)
53
+ output[status] = {
54
+ description: description,
55
+ content: {
56
+ "application/json": {
57
+ schema: {},
58
+ },
59
+ },
60
+ };
61
+ }
62
+
63
+ // SUCCESS
64
+ const description: string | undefined =
65
+ SwaggerDescriptionComposer.descriptionFromJsDocTag({
66
+ jsDocTags: props.route.jsDocTags,
67
+ tag: "returns",
68
+ }) ??
69
+ SwaggerDescriptionComposer.descriptionFromJsDocTag({
70
+ jsDocTags: props.route.jsDocTags,
71
+ tag: "return",
72
+ });
73
+ output[
74
+ props.route.success.status ??
75
+ (props.route.method.toLowerCase() === "post" ? 201 : 200)
76
+ ] = {
77
+ description: props.route.success.encrypted
78
+ ? `${warning.get(!!description, props.route.method)}${description ?? ""}`
79
+ : (description ?? ""),
80
+ content: props.route.success.contentType
81
+ ? {
82
+ [props.route.success.contentType]: {
83
+ schema: props.schema(props.route.success.metadata),
84
+ example: props.route.success.example,
85
+ examples: props.route.success.examples,
86
+ },
87
+ }
88
+ : undefined,
89
+ ...(props.route.success.encrypted ? { "x-nestia-encrypted": true } : {}),
90
+ };
91
+ return output;
92
+ };
93
+ }
94
+
95
+ const warning = new VariadicSingleton((described: boolean, method: string) => {
96
+ const summary: string = "Response data have been encrypted.";
97
+ const component: string = `[EncryptedRoute.${StringUtil.capitalize(method)}](https://github.com/samchon/@nestia/core#encryptedroute)`;
98
+
99
+ const content: string[] = [
100
+ "## Warning",
101
+ "",
102
+ summary,
103
+ "",
104
+ `The response body data would be encrypted as "AES-128(256) / CBC mode / PKCS#5 Padding / Base64 Encoding", through the ${component} component.`,
105
+ "",
106
+ `Therefore, just utilize this swagger editor only for referencing. If you need to call the real API, using [SDK](https://github.com/samchon/nestia#software-development-kit) would be much better.`,
107
+ ];
108
+ if (described === true) content.push("", "----------------", "", "");
109
+ return content.join("\n");
110
+ });
package/src/module.ts CHANGED
@@ -1,3 +1,4 @@
1
- export * from "./INestiaConfig";
2
- export * from "./NestiaSdkApplication";
3
- export * from "./NestiaSwaggerComposer";
1
+ export * from "./INestiaConfig";
2
+ export * from "./NestiaSdkApplication";
3
+ export * from "./NestiaSwaggerComposer";
4
+ export * from "./decorators/OperationMetadata";
@@ -1,19 +1,18 @@
1
- import { MetadataFactory } from "typia/lib/factories/MetadataFactory";
2
- import { IMetadata } from "typia/lib/schemas/metadata/IMetadata";
3
- import { IMetadataComponents } from "typia/lib/schemas/metadata/IMetadataComponents";
4
-
5
- import { IReflectType } from "./IReflectType";
6
-
7
- export interface IReflectHttpOperationException {
8
- // BASIC PROPERTIES
9
- status: number | "2XX" | "3XX" | "4XX" | "5XX";
10
- description: string | null;
11
- example?: any;
12
- examples?: Record<string, any>;
13
-
14
- // REFLECTED PROPERTIES
15
- type: IReflectType;
16
- metadata: IMetadata;
17
- components: IMetadataComponents;
18
- validate: MetadataFactory.Validator;
19
- }
1
+ import { MetadataFactory } from "@typia/core";
2
+ import { IMetadataComponents, IMetadataSchema } from "@typia/interface";
3
+
4
+ import { IReflectType } from "./IReflectType";
5
+
6
+ export interface IReflectHttpOperationException {
7
+ // BASIC PROPERTIES
8
+ status: number | "2XX" | "3XX" | "4XX" | "5XX";
9
+ description: string | null;
10
+ example?: any;
11
+ examples?: Record<string, any>;
12
+
13
+ // REFLECTED PROPERTIES
14
+ type: IReflectType;
15
+ metadata: IMetadataSchema;
16
+ components: IMetadataComponents;
17
+ validate: MetadataFactory.Validator;
18
+ }
@@ -1,77 +1,79 @@
1
- import { IJsDocTagInfo } from "typia";
2
- import { MetadataFactory } from "typia/lib/factories/MetadataFactory";
3
- import { IMetadata } from "typia/lib/schemas/metadata/IMetadata";
4
- import { IMetadataComponents } from "typia/lib/schemas/metadata/IMetadataComponents";
5
-
6
- import { IReflectType } from "./IReflectType";
7
-
8
- export type IReflectHttpOperationParameter =
9
- | IReflectHttpOperationParameter.IBody
10
- | IReflectHttpOperationParameter.IHeaders
11
- | IReflectHttpOperationParameter.IParam
12
- | IReflectHttpOperationParameter.IQuery;
13
- export namespace IReflectHttpOperationParameter {
14
- export interface IBody extends IBase<"body"> {
15
- contentType:
16
- | "application/json"
17
- | "application/x-www-form-urlencoded"
18
- | "multipart/form-data"
19
- | "text/plain";
20
- encrypted: boolean;
21
- }
22
- export interface IHeaders extends IBase<"headers"> {
23
- field: string | null;
24
- }
25
- export interface IParam extends IBase<"param"> {
26
- field: string;
27
- }
28
- export interface IQuery extends IBase<"query"> {
29
- field: string | null;
30
- }
31
- interface IBase<Category extends string> {
32
- category: Category;
33
- name: string;
34
- index: number;
35
- type: IReflectType;
36
- metadata: IMetadata;
37
- components: IMetadataComponents;
38
- validate: MetadataFactory.Validator;
39
- example?: any;
40
- examples?: Record<string, any>;
41
- description: string | null;
42
- jsDocTags: IJsDocTagInfo[];
43
- }
44
-
45
- /** @internal */
46
- export type IPreconfigured =
47
- | IPreconfigured.IBody
48
- | IPreconfigured.IHeaders
49
- | IPreconfigured.IParam
50
- | IPreconfigured.IQuery;
51
-
52
- /** @internal */
53
- export namespace IPreconfigured {
54
- export interface IBody extends IBase<"body"> {
55
- field?: string;
56
- encrypted?: boolean;
57
- contentType:
58
- | "application/json"
59
- | "application/x-www-form-urlencoded"
60
- | "multipart/form-data"
61
- | "text/plain";
62
- }
63
- export interface IHeaders extends IBase<"headers"> {
64
- field?: string;
65
- }
66
- export interface IParam extends IBase<"param"> {
67
- field?: string;
68
- }
69
- export interface IQuery extends IBase<"query"> {
70
- field?: string;
71
- }
72
- interface IBase<Category extends string> {
73
- category: Category;
74
- index: number;
75
- }
76
- }
77
- }
1
+ import { MetadataFactory } from "@typia/core";
2
+ import {
3
+ IJsDocTagInfo,
4
+ IMetadataComponents,
5
+ IMetadataSchema,
6
+ } from "@typia/interface";
7
+
8
+ import { IReflectType } from "./IReflectType";
9
+
10
+ export type IReflectHttpOperationParameter =
11
+ | IReflectHttpOperationParameter.IBody
12
+ | IReflectHttpOperationParameter.IHeaders
13
+ | IReflectHttpOperationParameter.IParam
14
+ | IReflectHttpOperationParameter.IQuery;
15
+ export namespace IReflectHttpOperationParameter {
16
+ export interface IBody extends IBase<"body"> {
17
+ contentType:
18
+ | "application/json"
19
+ | "application/x-www-form-urlencoded"
20
+ | "multipart/form-data"
21
+ | "text/plain";
22
+ encrypted: boolean;
23
+ }
24
+ export interface IHeaders extends IBase<"headers"> {
25
+ field: string | null;
26
+ }
27
+ export interface IParam extends IBase<"param"> {
28
+ field: string;
29
+ }
30
+ export interface IQuery extends IBase<"query"> {
31
+ field: string | null;
32
+ }
33
+ interface IBase<Category extends string> {
34
+ category: Category;
35
+ name: string;
36
+ index: number;
37
+ type: IReflectType;
38
+ metadata: IMetadataSchema;
39
+ components: IMetadataComponents;
40
+ validate: MetadataFactory.Validator;
41
+ example?: any;
42
+ examples?: Record<string, any>;
43
+ description: string | null;
44
+ jsDocTags: IJsDocTagInfo[];
45
+ }
46
+
47
+ /** @internal */
48
+ export type IPreconfigured =
49
+ | IPreconfigured.IBody
50
+ | IPreconfigured.IHeaders
51
+ | IPreconfigured.IParam
52
+ | IPreconfigured.IQuery;
53
+
54
+ /** @internal */
55
+ export namespace IPreconfigured {
56
+ export interface IBody extends IBase<"body"> {
57
+ field?: string;
58
+ encrypted?: boolean;
59
+ contentType:
60
+ | "application/json"
61
+ | "application/x-www-form-urlencoded"
62
+ | "multipart/form-data"
63
+ | "text/plain";
64
+ }
65
+ export interface IHeaders extends IBase<"headers"> {
66
+ field?: string;
67
+ }
68
+ export interface IParam extends IBase<"param"> {
69
+ field?: string;
70
+ }
71
+ export interface IQuery extends IBase<"query"> {
72
+ field?: string;
73
+ }
74
+ interface IBase<Category extends string> {
75
+ category: Category;
76
+ index: number;
77
+ }
78
+ }
79
+ }
@@ -1,22 +1,21 @@
1
- import { MetadataFactory } from "typia/lib/factories/MetadataFactory";
2
- import { IMetadata } from "typia/lib/schemas/metadata/IMetadata";
3
- import { IMetadataComponents } from "typia/lib/schemas/metadata/IMetadataComponents";
4
-
5
- import { IReflectType } from "./IReflectType";
6
-
7
- export interface IReflectHttpOperationSuccess {
8
- type: IReflectType;
9
- status: number;
10
- contentType:
11
- | "application/json"
12
- | "text/plain"
13
- | "application/x-www-form-urlencoded"
14
- | "application/json"
15
- | null;
16
- encrypted: boolean;
17
- components: IMetadataComponents;
18
- metadata: IMetadata;
19
- validate: MetadataFactory.Validator;
20
- example?: any;
21
- examples?: Record<string, any>;
22
- }
1
+ import { MetadataFactory } from "@typia/core";
2
+ import { IMetadataComponents, IMetadataSchema } from "@typia/interface";
3
+
4
+ import { IReflectType } from "./IReflectType";
5
+
6
+ export interface IReflectHttpOperationSuccess {
7
+ type: IReflectType;
8
+ status: number;
9
+ contentType:
10
+ | "application/json"
11
+ | "text/plain"
12
+ | "application/x-www-form-urlencoded"
13
+ | "application/json"
14
+ | null;
15
+ encrypted: boolean;
16
+ components: IMetadataComponents;
17
+ metadata: IMetadataSchema;
18
+ validate: MetadataFactory.Validator;
19
+ example?: any;
20
+ examples?: Record<string, any>;
21
+ }
@@ -1,11 +1,11 @@
1
- import { IMetadataDictionary } from "typia/lib/schemas/metadata/IMetadataDictionary";
2
-
3
- import { INestiaProject } from "./INestiaProject";
4
- import { ITypedHttpRoute } from "./ITypedHttpRoute";
5
- import { ITypedWebSocketRoute } from "./ITypedWebSocketRoute";
6
-
7
- export interface ITypedApplication {
8
- project: INestiaProject;
9
- collection: IMetadataDictionary;
10
- routes: Array<ITypedHttpRoute | ITypedWebSocketRoute>;
11
- }
1
+ import { IMetadataDictionary } from "@typia/core";
2
+
3
+ import { INestiaProject } from "./INestiaProject";
4
+ import { ITypedHttpRoute } from "./ITypedHttpRoute";
5
+ import { ITypedWebSocketRoute } from "./ITypedWebSocketRoute";
6
+
7
+ export interface ITypedApplication {
8
+ project: INestiaProject;
9
+ collection: IMetadataDictionary;
10
+ routes: Array<ITypedHttpRoute | ITypedWebSocketRoute>;
11
+ }
@@ -1,15 +1,15 @@
1
- import { Metadata } from "typia/lib/schemas/metadata/Metadata";
2
-
3
- import { IReflectType } from "./IReflectType";
4
-
5
- export interface ITypedHttpRouteException {
6
- // BASIC PROPERTIES
7
- status: number | "2XX" | "3XX" | "4XX" | "5XX";
8
- description: string | null;
9
- example: any;
10
- examples: Record<string, any>;
11
-
12
- // REFLECTED PROPERTIES
13
- type: IReflectType;
14
- metadata: Metadata;
15
- }
1
+ import { MetadataSchema } from "@typia/core";
2
+
3
+ import { IReflectType } from "./IReflectType";
4
+
5
+ export interface ITypedHttpRouteException {
6
+ // BASIC PROPERTIES
7
+ status: number | "2XX" | "3XX" | "4XX" | "5XX";
8
+ description: string | null;
9
+ example: any;
10
+ examples: Record<string, any>;
11
+
12
+ // REFLECTED PROPERTIES
13
+ type: IReflectType;
14
+ metadata: MetadataSchema;
15
+ }
@@ -1,41 +1,41 @@
1
- import { IJsDocTagInfo } from "typia";
2
- import { Metadata } from "typia/lib/schemas/metadata/Metadata";
3
-
4
- import { IReflectType } from "./IReflectType";
5
-
6
- export type ITypedHttpRouteParameter =
7
- | ITypedHttpRouteParameter.IBody
8
- | ITypedHttpRouteParameter.IHeaders
9
- | ITypedHttpRouteParameter.IPath
10
- | ITypedHttpRouteParameter.IQuery;
11
- export namespace ITypedHttpRouteParameter {
12
- export interface IBody extends IBase<"body"> {
13
- contentType:
14
- | "application/json"
15
- | "application/x-www-form-urlencoded"
16
- | "multipart/form-data"
17
- | "text/plain";
18
- encrypted: boolean;
19
- }
20
- export interface IHeaders extends IBase<"headers"> {
21
- field: string | null;
22
- }
23
- export interface IPath extends IBase<"param"> {
24
- field: string;
25
- }
26
- export interface IQuery extends IBase<"query"> {
27
- field: string | null;
28
- }
29
-
30
- interface IBase<Category extends string> {
31
- category: Category;
32
- name: string;
33
- index: number;
34
- type: IReflectType;
35
- metadata: Metadata;
36
- example?: any;
37
- examples?: Record<string, any>;
38
- description: string | null;
39
- jsDocTags: IJsDocTagInfo[];
40
- }
41
- }
1
+ import { MetadataSchema } from "@typia/core";
2
+ import { IJsDocTagInfo } from "typia";
3
+
4
+ import { IReflectType } from "./IReflectType";
5
+
6
+ export type ITypedHttpRouteParameter =
7
+ | ITypedHttpRouteParameter.IBody
8
+ | ITypedHttpRouteParameter.IHeaders
9
+ | ITypedHttpRouteParameter.IPath
10
+ | ITypedHttpRouteParameter.IQuery;
11
+ export namespace ITypedHttpRouteParameter {
12
+ export interface IBody extends IBase<"body"> {
13
+ contentType:
14
+ | "application/json"
15
+ | "application/x-www-form-urlencoded"
16
+ | "multipart/form-data"
17
+ | "text/plain";
18
+ encrypted: boolean;
19
+ }
20
+ export interface IHeaders extends IBase<"headers"> {
21
+ field: string | null;
22
+ }
23
+ export interface IPath extends IBase<"param"> {
24
+ field: string;
25
+ }
26
+ export interface IQuery extends IBase<"query"> {
27
+ field: string | null;
28
+ }
29
+
30
+ interface IBase<Category extends string> {
31
+ category: Category;
32
+ name: string;
33
+ index: number;
34
+ type: IReflectType;
35
+ metadata: MetadataSchema;
36
+ example?: any;
37
+ examples?: Record<string, any>;
38
+ description: string | null;
39
+ jsDocTags: IJsDocTagInfo[];
40
+ }
41
+ }
@@ -1,22 +1,22 @@
1
- import { Metadata } from "typia/lib/schemas/metadata/Metadata";
2
-
3
- import { IReflectType } from "./IReflectType";
4
-
5
- export interface ITypedHttpRouteSuccess {
6
- type: IReflectType;
7
- status: number | null;
8
- contentType:
9
- | "application/json"
10
- | "text/plain"
11
- | "application/x-www-form-urlencoded"
12
- | "application/json"
13
- | null;
14
- encrypted: boolean;
15
- metadata: Metadata;
16
- example?: any;
17
- examples?: Record<string, any>;
18
- setHeaders: Array<
19
- | { type: "setter"; source: string; target?: string }
20
- | { type: "assigner"; source: string }
21
- >;
22
- }
1
+ import { MetadataSchema } from "@typia/core";
2
+
3
+ import { IReflectType } from "./IReflectType";
4
+
5
+ export interface ITypedHttpRouteSuccess {
6
+ type: IReflectType;
7
+ status: number | null;
8
+ contentType:
9
+ | "application/json"
10
+ | "text/plain"
11
+ | "application/x-www-form-urlencoded"
12
+ | "application/json"
13
+ | null;
14
+ encrypted: boolean;
15
+ metadata: MetadataSchema;
16
+ example?: any;
17
+ examples?: Record<string, any>;
18
+ setHeaders: Array<
19
+ | { type: "setter"; source: string; target?: string }
20
+ | { type: "assigner"; source: string }
21
+ >;
22
+ }