@nestia/sdk 4.2.0-dev.20241211 → 4.2.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.
- package/LICENSE +21 -21
- package/README.md +87 -87
- package/assets/bundle/api/HttpError.ts +1 -1
- package/assets/bundle/api/IConnection.ts +1 -1
- package/assets/bundle/api/Primitive.ts +1 -1
- package/assets/bundle/api/Resolved.ts +1 -1
- package/assets/bundle/api/index.ts +4 -4
- package/assets/bundle/api/module.ts +6 -6
- package/assets/bundle/distribute/README.md +37 -37
- package/assets/bundle/distribute/package.json +28 -28
- package/assets/bundle/distribute/tsconfig.json +109 -109
- package/assets/bundle/e2e/index.ts +42 -42
- package/assets/config/nestia.config.ts +97 -97
- package/lib/executable/internal/NestiaConfigLoader.js +4 -4
- package/lib/executable/sdk.js +12 -12
- package/package.json +5 -5
- package/src/INestiaConfig.ts +271 -271
- package/src/NestiaSdkApplication.ts +307 -307
- package/src/NestiaSwaggerComposer.ts +138 -138
- package/src/analyses/AccessorAnalyzer.ts +67 -67
- package/src/analyses/ConfigAnalyzer.ts +155 -155
- package/src/analyses/ExceptionAnalyzer.ts +154 -154
- package/src/analyses/GenericAnalyzer.ts +49 -49
- package/src/analyses/ImportAnalyzer.ts +171 -171
- package/src/analyses/PathAnalyzer.ts +69 -69
- package/src/analyses/ReflectControllerAnalyzer.ts +105 -105
- package/src/analyses/ReflectHttpOperationAnalyzer.ts +183 -183
- package/src/analyses/ReflectHttpOperationExceptionAnalyzer.ts +71 -71
- package/src/analyses/ReflectHttpOperationParameterAnalyzer.ts +348 -348
- package/src/analyses/ReflectHttpOperationResponseAnalyzer.ts +127 -127
- package/src/analyses/ReflectMetadataAnalyzer.ts +44 -44
- package/src/analyses/ReflectWebSocketOperationAnalyzer.ts +172 -172
- package/src/analyses/SecurityAnalyzer.ts +25 -25
- package/src/analyses/TypedHttpRouteAnalyzer.ts +186 -186
- package/src/analyses/TypedWebSocketRouteAnalyzer.ts +18 -18
- package/src/decorators/OperationMetadata.ts +15 -15
- package/src/executable/internal/CommandParser.ts +15 -15
- package/src/executable/internal/NestiaConfigLoader.ts +78 -78
- package/src/executable/internal/NestiaSdkCommand.ts +103 -103
- package/src/executable/sdk.ts +75 -75
- package/src/generates/CloneGenerator.ts +66 -66
- package/src/generates/E2eGenerator.ts +32 -32
- package/src/generates/SdkGenerator.ts +159 -159
- package/src/generates/SwaggerGenerator.ts +292 -292
- package/src/generates/internal/E2eFileProgrammer.ts +183 -183
- package/src/generates/internal/FilePrinter.ts +53 -53
- package/src/generates/internal/ImportDictionary.ts +147 -147
- package/src/generates/internal/SdkAliasCollection.ts +185 -185
- package/src/generates/internal/SdkDistributionComposer.ts +103 -103
- package/src/generates/internal/SdkFileProgrammer.ts +116 -116
- package/src/generates/internal/SdkHttpCloneProgrammer.ts +124 -124
- package/src/generates/internal/SdkHttpCloneReferencer.ts +71 -71
- package/src/generates/internal/SdkHttpFunctionProgrammer.ts +301 -301
- package/src/generates/internal/SdkHttpNamespaceProgrammer.ts +529 -529
- package/src/generates/internal/SdkHttpRouteProgrammer.ts +117 -117
- package/src/generates/internal/SdkHttpSimulationProgrammer.ts +362 -362
- package/src/generates/internal/SdkImportWizard.ts +55 -55
- package/src/generates/internal/SdkRouteDirectory.ts +18 -18
- package/src/generates/internal/SdkTypeProgrammer.ts +394 -394
- package/src/generates/internal/SdkWebSocketNamespaceProgrammer.ts +363 -363
- package/src/generates/internal/SdkWebSocketRouteProgrammer.ts +265 -265
- package/src/generates/internal/SwaggerDescriptionComposer.ts +64 -64
- package/src/generates/internal/SwaggerOperationComposer.ts +117 -117
- package/src/generates/internal/SwaggerOperationParameterComposer.ts +177 -177
- package/src/generates/internal/SwaggerOperationResponseComposer.ts +110 -110
- package/src/index.ts +4 -4
- package/src/module.ts +3 -3
- package/src/structures/INestiaProject.ts +13 -13
- package/src/structures/INestiaSdkInput.ts +20 -20
- package/src/structures/IReflectApplication.ts +8 -8
- package/src/structures/IReflectController.ts +15 -15
- package/src/structures/IReflectHttpOperation.ts +26 -26
- package/src/structures/IReflectHttpOperationException.ts +19 -19
- package/src/structures/IReflectHttpOperationParameter.ts +81 -81
- package/src/structures/IReflectHttpOperationSuccess.ts +22 -22
- package/src/structures/IReflectOperationError.ts +26 -26
- package/src/structures/IReflectType.ts +4 -4
- package/src/structures/IReflectTypeImport.ts +4 -4
- package/src/structures/IReflectWebSocketOperation.ts +17 -17
- package/src/structures/IReflectWebSocketOperationParameter.ts +38 -38
- package/src/structures/ITypedApplication.ts +11 -11
- package/src/structures/ITypedHttpRoute.ts +30 -30
- package/src/structures/ITypedHttpRouteException.ts +15 -15
- package/src/structures/ITypedHttpRouteParameter.ts +41 -41
- package/src/structures/ITypedHttpRouteSuccess.ts +22 -22
- package/src/structures/ITypedWebSocketRoute.ts +20 -20
- package/src/structures/ITypedWebSocketRouteParameter.ts +3 -3
- package/src/structures/MethodType.ts +5 -5
- package/src/structures/ParamCategory.ts +1 -1
- package/src/structures/TypeEntry.ts +22 -22
- package/src/transform.ts +9 -9
- package/src/transformers/IOperationMetadata.ts +44 -44
- package/src/transformers/ISdkOperationTransformerContext.ts +8 -8
- package/src/transformers/SdkOperationProgrammer.ts +209 -209
- package/src/transformers/SdkOperationTransformer.ts +253 -253
- package/src/transformers/TextPlainValidator.ts +17 -17
- package/src/typings/get-function-location.d.ts +7 -7
- package/src/utils/ArrayUtil.ts +26 -26
- package/src/utils/FileRetriever.ts +22 -22
- package/src/utils/MapUtil.ts +14 -14
- package/src/utils/MetadataUtil.ts +26 -26
- package/src/utils/PathUtil.ts +10 -10
- package/src/utils/SourceFinder.ts +66 -66
- package/src/utils/StringUtil.ts +17 -17
- package/src/utils/StripEnums.ts +5 -5
- package/src/utils/VersioningStrategy.ts +28 -28
- package/src/validators/HttpHeadersValidator.ts +34 -34
- package/src/validators/HttpQueryValidator.ts +34 -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
|
-
// SUCESS
|
|
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 { 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
|
+
// SUCESS
|
|
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/index.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import * as nestia from "./module";
|
|
2
|
-
|
|
3
|
-
export * from "./module";
|
|
4
|
-
export default nestia;
|
|
1
|
+
import * as nestia from "./module";
|
|
2
|
+
|
|
3
|
+
export * from "./module";
|
|
4
|
+
export default nestia;
|
package/src/module.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from "./INestiaConfig";
|
|
2
|
-
export * from "./NestiaSdkApplication";
|
|
3
|
-
export * from "./NestiaSwaggerComposer";
|
|
1
|
+
export * from "./INestiaConfig";
|
|
2
|
+
export * from "./NestiaSdkApplication";
|
|
3
|
+
export * from "./NestiaSwaggerComposer";
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import ts from "typescript";
|
|
2
|
-
|
|
3
|
-
import { INestiaConfig } from "../INestiaConfig";
|
|
4
|
-
import { INestiaSdkInput } from "./INestiaSdkInput";
|
|
5
|
-
import { IReflectOperationError } from "./IReflectOperationError";
|
|
6
|
-
|
|
7
|
-
export interface INestiaProject {
|
|
8
|
-
config: INestiaConfig;
|
|
9
|
-
input: INestiaSdkInput;
|
|
10
|
-
checker: ts.TypeChecker;
|
|
11
|
-
errors: IReflectOperationError[];
|
|
12
|
-
warnings: IReflectOperationError[];
|
|
13
|
-
}
|
|
1
|
+
import ts from "typescript";
|
|
2
|
+
|
|
3
|
+
import { INestiaConfig } from "../INestiaConfig";
|
|
4
|
+
import { INestiaSdkInput } from "./INestiaSdkInput";
|
|
5
|
+
import { IReflectOperationError } from "./IReflectOperationError";
|
|
6
|
+
|
|
7
|
+
export interface INestiaProject {
|
|
8
|
+
config: INestiaConfig;
|
|
9
|
+
input: INestiaSdkInput;
|
|
10
|
+
checker: ts.TypeChecker;
|
|
11
|
+
errors: IReflectOperationError[];
|
|
12
|
+
warnings: IReflectOperationError[];
|
|
13
|
+
}
|
|
@@ -1,20 +1,20 @@
|
|
|
1
|
-
import { RouteInfo, VersionValue } from "@nestjs/common/interfaces";
|
|
2
|
-
|
|
3
|
-
export interface INestiaSdkInput {
|
|
4
|
-
controllers: INestiaSdkInput.IController[];
|
|
5
|
-
globalPrefix?: {
|
|
6
|
-
prefix: string;
|
|
7
|
-
exclude?: Array<string | RouteInfo>;
|
|
8
|
-
};
|
|
9
|
-
versioning?: {
|
|
10
|
-
prefix: string;
|
|
11
|
-
defaultVersion?: VersionValue;
|
|
12
|
-
};
|
|
13
|
-
}
|
|
14
|
-
export namespace INestiaSdkInput {
|
|
15
|
-
export interface IController {
|
|
16
|
-
class: Function;
|
|
17
|
-
location: string;
|
|
18
|
-
prefixes: string[];
|
|
19
|
-
}
|
|
20
|
-
}
|
|
1
|
+
import { RouteInfo, VersionValue } from "@nestjs/common/interfaces";
|
|
2
|
+
|
|
3
|
+
export interface INestiaSdkInput {
|
|
4
|
+
controllers: INestiaSdkInput.IController[];
|
|
5
|
+
globalPrefix?: {
|
|
6
|
+
prefix: string;
|
|
7
|
+
exclude?: Array<string | RouteInfo>;
|
|
8
|
+
};
|
|
9
|
+
versioning?: {
|
|
10
|
+
prefix: string;
|
|
11
|
+
defaultVersion?: VersionValue;
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
export namespace INestiaSdkInput {
|
|
15
|
+
export interface IController {
|
|
16
|
+
class: Function;
|
|
17
|
+
location: string;
|
|
18
|
+
prefixes: string[];
|
|
19
|
+
}
|
|
20
|
+
}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { INestApplication } from "@nestjs/common";
|
|
2
|
-
|
|
3
|
-
import { IReflectController } from "./IReflectController";
|
|
4
|
-
|
|
5
|
-
export interface IReflectApplication {
|
|
6
|
-
application: INestApplication;
|
|
7
|
-
controllers: IReflectController[];
|
|
8
|
-
}
|
|
1
|
+
import { INestApplication } from "@nestjs/common";
|
|
2
|
+
|
|
3
|
+
import { IReflectController } from "./IReflectController";
|
|
4
|
+
|
|
5
|
+
export interface IReflectApplication {
|
|
6
|
+
application: INestApplication;
|
|
7
|
+
controllers: IReflectController[];
|
|
8
|
+
}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import type { VERSION_NEUTRAL } from "@nestjs/common/interfaces";
|
|
2
|
-
|
|
3
|
-
import { IReflectHttpOperation } from "./IReflectHttpOperation";
|
|
4
|
-
import { IReflectWebSocketOperation } from "./IReflectWebSocketOperation";
|
|
5
|
-
|
|
6
|
-
export interface IReflectController {
|
|
7
|
-
class: Function;
|
|
8
|
-
prefixes: string[];
|
|
9
|
-
paths: string[];
|
|
10
|
-
file: string;
|
|
11
|
-
versions: Array<string | typeof VERSION_NEUTRAL> | undefined;
|
|
12
|
-
operations: Array<IReflectHttpOperation | IReflectWebSocketOperation>;
|
|
13
|
-
security: Record<string, string[]>[];
|
|
14
|
-
tags: string[];
|
|
15
|
-
}
|
|
1
|
+
import type { VERSION_NEUTRAL } from "@nestjs/common/interfaces";
|
|
2
|
+
|
|
3
|
+
import { IReflectHttpOperation } from "./IReflectHttpOperation";
|
|
4
|
+
import { IReflectWebSocketOperation } from "./IReflectWebSocketOperation";
|
|
5
|
+
|
|
6
|
+
export interface IReflectController {
|
|
7
|
+
class: Function;
|
|
8
|
+
prefixes: string[];
|
|
9
|
+
paths: string[];
|
|
10
|
+
file: string;
|
|
11
|
+
versions: Array<string | typeof VERSION_NEUTRAL> | undefined;
|
|
12
|
+
operations: Array<IReflectHttpOperation | IReflectWebSocketOperation>;
|
|
13
|
+
security: Record<string, string[]>[];
|
|
14
|
+
tags: string[];
|
|
15
|
+
}
|
|
@@ -1,26 +1,26 @@
|
|
|
1
|
-
import { VERSION_NEUTRAL } from "@nestjs/common/interfaces";
|
|
2
|
-
import { IJsDocTagInfo } from "typia";
|
|
3
|
-
|
|
4
|
-
import { IReflectHttpOperationException } from "./IReflectHttpOperationException";
|
|
5
|
-
import { IReflectHttpOperationParameter } from "./IReflectHttpOperationParameter";
|
|
6
|
-
import { IReflectHttpOperationSuccess } from "./IReflectHttpOperationSuccess";
|
|
7
|
-
import { IReflectTypeImport } from "./IReflectTypeImport";
|
|
8
|
-
|
|
9
|
-
export interface IReflectHttpOperation {
|
|
10
|
-
protocol: "http";
|
|
11
|
-
function: Function;
|
|
12
|
-
name: string;
|
|
13
|
-
method: string;
|
|
14
|
-
paths: string[];
|
|
15
|
-
versions: Array<string | typeof VERSION_NEUTRAL> | undefined;
|
|
16
|
-
parameters: IReflectHttpOperationParameter[];
|
|
17
|
-
success: IReflectHttpOperationSuccess;
|
|
18
|
-
exceptions: Record<string, IReflectHttpOperationException>;
|
|
19
|
-
security: Record<string, string[]>[];
|
|
20
|
-
tags: string[];
|
|
21
|
-
imports: IReflectTypeImport[];
|
|
22
|
-
operationId: string | undefined;
|
|
23
|
-
description: string | null;
|
|
24
|
-
jsDocTags: IJsDocTagInfo[];
|
|
25
|
-
extensions?: Record<string, any>;
|
|
26
|
-
}
|
|
1
|
+
import { VERSION_NEUTRAL } from "@nestjs/common/interfaces";
|
|
2
|
+
import { IJsDocTagInfo } from "typia";
|
|
3
|
+
|
|
4
|
+
import { IReflectHttpOperationException } from "./IReflectHttpOperationException";
|
|
5
|
+
import { IReflectHttpOperationParameter } from "./IReflectHttpOperationParameter";
|
|
6
|
+
import { IReflectHttpOperationSuccess } from "./IReflectHttpOperationSuccess";
|
|
7
|
+
import { IReflectTypeImport } from "./IReflectTypeImport";
|
|
8
|
+
|
|
9
|
+
export interface IReflectHttpOperation {
|
|
10
|
+
protocol: "http";
|
|
11
|
+
function: Function;
|
|
12
|
+
name: string;
|
|
13
|
+
method: string;
|
|
14
|
+
paths: string[];
|
|
15
|
+
versions: Array<string | typeof VERSION_NEUTRAL> | undefined;
|
|
16
|
+
parameters: IReflectHttpOperationParameter[];
|
|
17
|
+
success: IReflectHttpOperationSuccess;
|
|
18
|
+
exceptions: Record<string, IReflectHttpOperationException>;
|
|
19
|
+
security: Record<string, string[]>[];
|
|
20
|
+
tags: string[];
|
|
21
|
+
imports: IReflectTypeImport[];
|
|
22
|
+
operationId: string | undefined;
|
|
23
|
+
description: string | null;
|
|
24
|
+
jsDocTags: IJsDocTagInfo[];
|
|
25
|
+
extensions?: Record<string, any>;
|
|
26
|
+
}
|
|
@@ -1,19 +1,19 @@
|
|
|
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/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,81 +1,81 @@
|
|
|
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
|
-
/**
|
|
46
|
-
* @internal
|
|
47
|
-
*/
|
|
48
|
-
export type IPreconfigured =
|
|
49
|
-
| IPreconfigured.IBody
|
|
50
|
-
| IPreconfigured.IHeaders
|
|
51
|
-
| IPreconfigured.IParam
|
|
52
|
-
| IPreconfigured.IQuery;
|
|
53
|
-
|
|
54
|
-
/**
|
|
55
|
-
* @internal
|
|
56
|
-
*/
|
|
57
|
-
export namespace IPreconfigured {
|
|
58
|
-
export interface IBody extends IBase<"body"> {
|
|
59
|
-
field?: string;
|
|
60
|
-
encrypted?: boolean;
|
|
61
|
-
contentType:
|
|
62
|
-
| "application/json"
|
|
63
|
-
| "application/x-www-form-urlencoded"
|
|
64
|
-
| "multipart/form-data"
|
|
65
|
-
| "text/plain";
|
|
66
|
-
}
|
|
67
|
-
export interface IHeaders extends IBase<"headers"> {
|
|
68
|
-
field?: string;
|
|
69
|
-
}
|
|
70
|
-
export interface IParam extends IBase<"param"> {
|
|
71
|
-
field?: string;
|
|
72
|
-
}
|
|
73
|
-
export interface IQuery extends IBase<"query"> {
|
|
74
|
-
field?: string;
|
|
75
|
-
}
|
|
76
|
-
interface IBase<Category extends string> {
|
|
77
|
-
category: Category;
|
|
78
|
-
index: number;
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
}
|
|
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
|
+
/**
|
|
46
|
+
* @internal
|
|
47
|
+
*/
|
|
48
|
+
export type IPreconfigured =
|
|
49
|
+
| IPreconfigured.IBody
|
|
50
|
+
| IPreconfigured.IHeaders
|
|
51
|
+
| IPreconfigured.IParam
|
|
52
|
+
| IPreconfigured.IQuery;
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* @internal
|
|
56
|
+
*/
|
|
57
|
+
export namespace IPreconfigured {
|
|
58
|
+
export interface IBody extends IBase<"body"> {
|
|
59
|
+
field?: string;
|
|
60
|
+
encrypted?: boolean;
|
|
61
|
+
contentType:
|
|
62
|
+
| "application/json"
|
|
63
|
+
| "application/x-www-form-urlencoded"
|
|
64
|
+
| "multipart/form-data"
|
|
65
|
+
| "text/plain";
|
|
66
|
+
}
|
|
67
|
+
export interface IHeaders extends IBase<"headers"> {
|
|
68
|
+
field?: string;
|
|
69
|
+
}
|
|
70
|
+
export interface IParam extends IBase<"param"> {
|
|
71
|
+
field?: string;
|
|
72
|
+
}
|
|
73
|
+
export interface IQuery extends IBase<"query"> {
|
|
74
|
+
field?: string;
|
|
75
|
+
}
|
|
76
|
+
interface IBase<Category extends string> {
|
|
77
|
+
category: Category;
|
|
78
|
+
index: number;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
@@ -1,22 +1,22 @@
|
|
|
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/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
|
+
}
|