@nestia/core 2.4.2 → 2.4.3

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 (112) hide show
  1. package/lib/decorators/DynamicModule.js.map +1 -1
  2. package/lib/decorators/EncryptedBody.js.map +1 -1
  3. package/lib/decorators/EncryptedController.js.map +1 -1
  4. package/lib/decorators/EncryptedModule.js.map +1 -1
  5. package/lib/decorators/EncryptedRoute.js +0 -2
  6. package/lib/decorators/EncryptedRoute.js.map +1 -1
  7. package/lib/decorators/PlainBody.js.map +1 -1
  8. package/lib/decorators/TypedBody.js.map +1 -1
  9. package/lib/decorators/TypedException.js.map +1 -1
  10. package/lib/decorators/TypedHeaders.js.map +1 -1
  11. package/lib/decorators/TypedParam.js.map +1 -1
  12. package/lib/decorators/TypedQuery.js +1 -5
  13. package/lib/decorators/TypedQuery.js.map +1 -1
  14. package/lib/decorators/TypedRoute.js.map +1 -1
  15. package/lib/decorators/internal/NoTransformConfigureError.js.map +1 -1
  16. package/lib/decorators/internal/get_path_and_querify.js.map +1 -1
  17. package/lib/decorators/internal/get_path_and_stringify.js.map +1 -1
  18. package/lib/decorators/internal/get_text_body.js.map +1 -1
  19. package/lib/decorators/internal/headers_to_object.js.map +1 -1
  20. package/lib/decorators/internal/load_controller.js.map +1 -1
  21. package/lib/decorators/internal/route_error.js.map +1 -1
  22. package/lib/decorators/internal/validate_request_body.js.map +1 -1
  23. package/lib/decorators/internal/validate_request_headers.js.map +1 -1
  24. package/lib/decorators/internal/validate_request_query.js.map +1 -1
  25. package/lib/programmers/PlainBodyProgrammer.js.map +1 -1
  26. package/lib/programmers/TypedBodyProgrammer.js.map +1 -1
  27. package/lib/programmers/TypedExceptionProgrammer.js.map +1 -1
  28. package/lib/programmers/TypedHeadersProgrammer.js.map +1 -1
  29. package/lib/programmers/TypedParamProgrammer.js.map +1 -1
  30. package/lib/programmers/TypedQueryBodyProgrammer.js.map +1 -1
  31. package/lib/programmers/TypedQueryProgrammer.js.map +1 -1
  32. package/lib/programmers/TypedQueryRouteProgrammer.js.map +1 -1
  33. package/lib/programmers/TypedRouteProgrammer.js.map +1 -1
  34. package/lib/programmers/http/HttpAssertQuerifyProgrammer.js.map +1 -1
  35. package/lib/programmers/http/HttpIsQuerifyProgrammer.js.map +1 -1
  36. package/lib/programmers/http/HttpQuerifyProgrammer.js.map +1 -1
  37. package/lib/programmers/http/HttpValidateQuerifyProgrammer.js.map +1 -1
  38. package/lib/programmers/internal/CoreMetadataUtil.js.map +1 -1
  39. package/lib/transform.js.map +1 -1
  40. package/lib/transformers/FileTransformer.js.map +1 -1
  41. package/lib/transformers/MethodTransformer.js +1 -2
  42. package/lib/transformers/MethodTransformer.js.map +1 -1
  43. package/lib/transformers/NodeTransformer.js.map +1 -1
  44. package/lib/transformers/ParameterDecoratorTransformer.js +1 -3
  45. package/lib/transformers/ParameterDecoratorTransformer.js.map +1 -1
  46. package/lib/transformers/ParameterTransformer.js.map +1 -1
  47. package/lib/transformers/TypedExceptionTransformer.js.map +1 -1
  48. package/lib/transformers/TypedRouteTransformer.js +1 -2
  49. package/lib/transformers/TypedRouteTransformer.js.map +1 -1
  50. package/lib/utils/ExceptionManager.js.map +1 -1
  51. package/lib/utils/Singleton.js.map +1 -1
  52. package/lib/utils/SourceFinder.js +1 -3
  53. package/lib/utils/SourceFinder.js.map +1 -1
  54. package/package.json +3 -6
  55. package/src/decorators/DynamicModule.ts +39 -39
  56. package/src/decorators/EncryptedBody.ts +49 -57
  57. package/src/decorators/EncryptedController.ts +38 -38
  58. package/src/decorators/EncryptedModule.ts +79 -79
  59. package/src/decorators/EncryptedRoute.ts +126 -135
  60. package/src/decorators/PlainBody.ts +72 -75
  61. package/src/decorators/TypedBody.ts +59 -60
  62. package/src/decorators/TypedException.ts +89 -89
  63. package/src/decorators/TypedHeaders.ts +69 -70
  64. package/src/decorators/TypedParam.ts +65 -66
  65. package/src/decorators/TypedQuery.ts +246 -253
  66. package/src/decorators/TypedRoute.ts +144 -147
  67. package/src/decorators/internal/EncryptedConstant.ts +4 -4
  68. package/src/decorators/internal/NoTransformConfigureError.ts +8 -8
  69. package/src/decorators/internal/get_path_and_querify.ts +103 -104
  70. package/src/decorators/internal/get_path_and_stringify.ts +91 -94
  71. package/src/decorators/internal/get_text_body.ts +20 -20
  72. package/src/decorators/internal/headers_to_object.ts +13 -13
  73. package/src/decorators/internal/load_controller.ts +51 -51
  74. package/src/decorators/internal/route_error.ts +45 -45
  75. package/src/decorators/internal/validate_request_body.ts +57 -61
  76. package/src/decorators/internal/validate_request_headers.ts +68 -73
  77. package/src/decorators/internal/validate_request_query.ts +56 -59
  78. package/src/index.ts +5 -5
  79. package/src/module.ts +14 -14
  80. package/src/options/INestiaTransformOptions.ts +17 -17
  81. package/src/options/INestiaTransformProject.ts +7 -7
  82. package/src/options/IRequestBodyValidator.ts +20 -20
  83. package/src/options/IRequestHeadersValidator.ts +22 -22
  84. package/src/options/IRequestQueryValidator.ts +20 -20
  85. package/src/options/IResponseBodyQuerifier.ts +25 -25
  86. package/src/options/IResponseBodyStringifier.ts +25 -25
  87. package/src/programmers/PlainBodyProgrammer.ts +52 -56
  88. package/src/programmers/TypedBodyProgrammer.ts +108 -112
  89. package/src/programmers/TypedExceptionProgrammer.ts +72 -76
  90. package/src/programmers/TypedHeadersProgrammer.ts +56 -59
  91. package/src/programmers/TypedParamProgrammer.ts +24 -25
  92. package/src/programmers/TypedQueryBodyProgrammer.ts +56 -57
  93. package/src/programmers/TypedQueryProgrammer.ts +56 -57
  94. package/src/programmers/TypedQueryRouteProgrammer.ts +51 -55
  95. package/src/programmers/TypedRouteProgrammer.ts +51 -55
  96. package/src/programmers/http/HttpAssertQuerifyProgrammer.ts +58 -59
  97. package/src/programmers/http/HttpIsQuerifyProgrammer.ts +62 -63
  98. package/src/programmers/http/HttpQuerifyProgrammer.ts +96 -105
  99. package/src/programmers/http/HttpValidateQuerifyProgrammer.ts +63 -64
  100. package/src/programmers/internal/CoreMetadataUtil.ts +21 -21
  101. package/src/transform.ts +35 -36
  102. package/src/transformers/FileTransformer.ts +66 -67
  103. package/src/transformers/MethodTransformer.ts +94 -97
  104. package/src/transformers/NodeTransformer.ts +16 -16
  105. package/src/transformers/ParameterDecoratorTransformer.ts +121 -126
  106. package/src/transformers/ParameterTransformer.ts +48 -53
  107. package/src/transformers/TypedExceptionTransformer.ts +49 -51
  108. package/src/transformers/TypedRouteTransformer.ts +95 -96
  109. package/src/typings/Creator.ts +3 -3
  110. package/src/utils/ExceptionManager.ts +112 -112
  111. package/src/utils/Singleton.ts +20 -20
  112. package/src/utils/SourceFinder.ts +57 -60
@@ -1,56 +1,52 @@
1
- import ts from "typescript";
2
-
3
- import { MetadataCollection } from "typia/lib/factories/MetadataCollection";
4
- import { MetadataFactory } from "typia/lib/factories/MetadataFactory";
5
- import { AssertProgrammer } from "typia/lib/programmers/AssertProgrammer";
6
- import { Metadata } from "typia/lib/schemas/metadata/Metadata";
7
- import { TransformerError } from "typia/lib/transformers/TransformerError";
8
-
9
- import { INestiaTransformProject } from "../options/INestiaTransformProject";
10
-
11
- export namespace PlainBodyProgrammer {
12
- export const generate =
13
- (project: INestiaTransformProject) =>
14
- (modulo: ts.LeftHandSideExpression) =>
15
- (type: ts.Type): ts.Expression => {
16
- const result = MetadataFactory.analyze(project.checker)({
17
- escape: false,
18
- constant: true,
19
- absorb: true,
20
- validate,
21
- })(new MetadataCollection())(type);
22
- if (result.success === false)
23
- throw TransformerError.from("@core.nestia.TypedParam")(
24
- result.errors,
25
- );
26
- return AssertProgrammer.write({
27
- ...project,
28
- options: {
29
- numeric: false,
30
- finite: false,
31
- functional: false,
32
- },
33
- })(modulo)(false)(type);
34
- };
35
- }
36
-
37
- const validate = (metadata: Metadata): string[] => {
38
- const errors: string[] = [];
39
- const insert = (msg: string) => errors.push(msg);
40
-
41
- const expected: number =
42
- (metadata.atomics.some((a) => a.type === "string") ? 1 : 0) +
43
- metadata.templates.length +
44
- metadata.constants
45
- .filter((c) => c.type === "string")
46
- .map((c) => c.values.length)
47
- .reduce((a, b) => a + b, 0);
48
- if (expected === 0 || expected !== metadata.size())
49
- insert(`only string type is allowed`);
50
- if (metadata.isRequired() === false)
51
- insert(`do not allow undefindable type`);
52
- if (metadata.nullable === true) insert(`do not allow nullable type`);
53
- else if (metadata.any === true) insert(`do not allow any type`);
54
-
55
- return errors;
56
- };
1
+ import ts from "typescript";
2
+ import { MetadataCollection } from "typia/lib/factories/MetadataCollection";
3
+ import { MetadataFactory } from "typia/lib/factories/MetadataFactory";
4
+ import { AssertProgrammer } from "typia/lib/programmers/AssertProgrammer";
5
+ import { Metadata } from "typia/lib/schemas/metadata/Metadata";
6
+ import { TransformerError } from "typia/lib/transformers/TransformerError";
7
+
8
+ import { INestiaTransformProject } from "../options/INestiaTransformProject";
9
+
10
+ export namespace PlainBodyProgrammer {
11
+ export const generate =
12
+ (project: INestiaTransformProject) =>
13
+ (modulo: ts.LeftHandSideExpression) =>
14
+ (type: ts.Type): ts.Expression => {
15
+ const result = MetadataFactory.analyze(project.checker)({
16
+ escape: false,
17
+ constant: true,
18
+ absorb: true,
19
+ validate,
20
+ })(new MetadataCollection())(type);
21
+ if (result.success === false)
22
+ throw TransformerError.from("@core.nestia.TypedParam")(result.errors);
23
+ return AssertProgrammer.write({
24
+ ...project,
25
+ options: {
26
+ numeric: false,
27
+ finite: false,
28
+ functional: false,
29
+ },
30
+ })(modulo)(false)(type);
31
+ };
32
+ }
33
+
34
+ const validate = (metadata: Metadata): string[] => {
35
+ const errors: string[] = [];
36
+ const insert = (msg: string) => errors.push(msg);
37
+
38
+ const expected: number =
39
+ (metadata.atomics.some((a) => a.type === "string") ? 1 : 0) +
40
+ metadata.templates.length +
41
+ metadata.constants
42
+ .filter((c) => c.type === "string")
43
+ .map((c) => c.values.length)
44
+ .reduce((a, b) => a + b, 0);
45
+ if (expected === 0 || expected !== metadata.size())
46
+ insert(`only string type is allowed`);
47
+ if (metadata.isRequired() === false) insert(`do not allow undefindable type`);
48
+ if (metadata.nullable === true) insert(`do not allow nullable type`);
49
+ else if (metadata.any === true) insert(`do not allow any type`);
50
+
51
+ return errors;
52
+ };
@@ -1,112 +1,108 @@
1
- import ts from "typescript";
2
-
3
- import { JsonMetadataFactory } from "typia/lib/factories/JsonMetadataFactory";
4
- import { AssertProgrammer } from "typia/lib/programmers/AssertProgrammer";
5
- import { IsProgrammer } from "typia/lib/programmers/IsProgrammer";
6
- import { ValidateProgrammer } from "typia/lib/programmers/ValidateProgrammer";
7
- import { MiscAssertCloneProgrammer } from "typia/lib/programmers/misc/MiscAssertCloneProgrammer";
8
- import { MiscAssertPruneProgrammer } from "typia/lib/programmers/misc/MiscAssertPruneProgrammer";
9
- import { MiscValidateCloneProgrammer } from "typia/lib/programmers/misc/MiscValidateCloneProgrammer";
10
- import { MiscValidatePruneProgrammer } from "typia/lib/programmers/misc/MiscValidatePruneProgrammer";
11
- import { IProject } from "typia/lib/transformers/IProject";
12
-
13
- import { INestiaTransformProject } from "../options/INestiaTransformProject";
14
- import { IRequestBodyValidator } from "../options/IRequestBodyValidator";
15
-
16
- export namespace TypedBodyProgrammer {
17
- export const generate =
18
- (project: INestiaTransformProject) =>
19
- (modulo: ts.LeftHandSideExpression) =>
20
- (type: ts.Type): ts.ObjectLiteralExpression => {
21
- // VALIDATE TYPE
22
- JsonMetadataFactory.analyze("@nestia.core.TypedBody")(
23
- project.checker,
24
- )(type);
25
-
26
- // GENERATE VALIDATION PLAN
27
- const check =
28
- (key: IRequestBodyValidator<any>["type"]) =>
29
- (equals: boolean) =>
30
- (
31
- programmer: (
32
- project: IProject,
33
- ) => (
34
- modulo: ts.LeftHandSideExpression,
35
- ) => (
36
- equals: boolean,
37
- ) => (type: ts.Type) => ts.ArrowFunction,
38
- ) =>
39
- ts.factory.createObjectLiteralExpression([
40
- ts.factory.createPropertyAssignment(
41
- ts.factory.createIdentifier("type"),
42
- ts.factory.createStringLiteral(key),
43
- ),
44
- ts.factory.createPropertyAssignment(
45
- ts.factory.createIdentifier(key),
46
- programmer({
47
- ...project,
48
- options: {
49
- numeric: false,
50
- finite: false,
51
- functional: false,
52
- },
53
- })(modulo)(equals)(type),
54
- ),
55
- ]);
56
- const misc =
57
- (key: IRequestBodyValidator<any>["type"]) =>
58
- (
59
- programmer: (
60
- project: IProject,
61
- ) => (
62
- modulo: ts.LeftHandSideExpression,
63
- ) => (type: ts.Type) => ts.ArrowFunction,
64
- ) =>
65
- ts.factory.createObjectLiteralExpression([
66
- ts.factory.createPropertyAssignment(
67
- ts.factory.createIdentifier("type"),
68
- ts.factory.createStringLiteral(key),
69
- ),
70
- ts.factory.createPropertyAssignment(
71
- ts.factory.createIdentifier(key),
72
- programmer({
73
- ...project,
74
- options: {
75
- numeric: false,
76
- finite: false,
77
- functional: false,
78
- },
79
- })(modulo)(type),
80
- ),
81
- ]);
82
-
83
- //----
84
- // RETURNS
85
- //----
86
- const category = project.options.validate;
87
- // NORMAL
88
- if (category === "is")
89
- return check("is")(false)(IsProgrammer.write);
90
- else if (category === "validate")
91
- return check("validate")(false)(ValidateProgrammer.write);
92
- // STRICT
93
- else if (category === "validateEquals")
94
- return check("validate")(true)(ValidateProgrammer.write);
95
- else if (category === "equals")
96
- return check("is")(true)(IsProgrammer.write);
97
- else if (category === "assertEquals")
98
- return check("assert")(true)(AssertProgrammer.write);
99
- // CLONE
100
- else if (category === "assertClone")
101
- return misc("assert")(MiscAssertCloneProgrammer.write);
102
- else if (category === "validateClone")
103
- return misc("validate")(MiscValidateCloneProgrammer.write);
104
- // PRUNE
105
- else if (category === "assertPrune")
106
- return misc("assert")(MiscAssertPruneProgrammer.write);
107
- else if (category === "validatePrune")
108
- return misc("validate")(MiscValidatePruneProgrammer.write);
109
- // DEFAULT
110
- return check("assert")(false)(AssertProgrammer.write);
111
- };
112
- }
1
+ import ts from "typescript";
2
+ import { JsonMetadataFactory } from "typia/lib/factories/JsonMetadataFactory";
3
+ import { AssertProgrammer } from "typia/lib/programmers/AssertProgrammer";
4
+ import { IsProgrammer } from "typia/lib/programmers/IsProgrammer";
5
+ import { ValidateProgrammer } from "typia/lib/programmers/ValidateProgrammer";
6
+ import { MiscAssertCloneProgrammer } from "typia/lib/programmers/misc/MiscAssertCloneProgrammer";
7
+ import { MiscAssertPruneProgrammer } from "typia/lib/programmers/misc/MiscAssertPruneProgrammer";
8
+ import { MiscValidateCloneProgrammer } from "typia/lib/programmers/misc/MiscValidateCloneProgrammer";
9
+ import { MiscValidatePruneProgrammer } from "typia/lib/programmers/misc/MiscValidatePruneProgrammer";
10
+ import { IProject } from "typia/lib/transformers/IProject";
11
+
12
+ import { INestiaTransformProject } from "../options/INestiaTransformProject";
13
+ import { IRequestBodyValidator } from "../options/IRequestBodyValidator";
14
+
15
+ export namespace TypedBodyProgrammer {
16
+ export const generate =
17
+ (project: INestiaTransformProject) =>
18
+ (modulo: ts.LeftHandSideExpression) =>
19
+ (type: ts.Type): ts.ObjectLiteralExpression => {
20
+ // VALIDATE TYPE
21
+ JsonMetadataFactory.analyze("@nestia.core.TypedBody")(project.checker)(
22
+ type,
23
+ );
24
+
25
+ // GENERATE VALIDATION PLAN
26
+ const check =
27
+ (key: IRequestBodyValidator<any>["type"]) =>
28
+ (equals: boolean) =>
29
+ (
30
+ programmer: (
31
+ project: IProject,
32
+ ) => (
33
+ modulo: ts.LeftHandSideExpression,
34
+ ) => (equals: boolean) => (type: ts.Type) => ts.ArrowFunction,
35
+ ) =>
36
+ ts.factory.createObjectLiteralExpression([
37
+ ts.factory.createPropertyAssignment(
38
+ ts.factory.createIdentifier("type"),
39
+ ts.factory.createStringLiteral(key),
40
+ ),
41
+ ts.factory.createPropertyAssignment(
42
+ ts.factory.createIdentifier(key),
43
+ programmer({
44
+ ...project,
45
+ options: {
46
+ numeric: false,
47
+ finite: false,
48
+ functional: false,
49
+ },
50
+ })(modulo)(equals)(type),
51
+ ),
52
+ ]);
53
+ const misc =
54
+ (key: IRequestBodyValidator<any>["type"]) =>
55
+ (
56
+ programmer: (
57
+ project: IProject,
58
+ ) => (
59
+ modulo: ts.LeftHandSideExpression,
60
+ ) => (type: ts.Type) => ts.ArrowFunction,
61
+ ) =>
62
+ ts.factory.createObjectLiteralExpression([
63
+ ts.factory.createPropertyAssignment(
64
+ ts.factory.createIdentifier("type"),
65
+ ts.factory.createStringLiteral(key),
66
+ ),
67
+ ts.factory.createPropertyAssignment(
68
+ ts.factory.createIdentifier(key),
69
+ programmer({
70
+ ...project,
71
+ options: {
72
+ numeric: false,
73
+ finite: false,
74
+ functional: false,
75
+ },
76
+ })(modulo)(type),
77
+ ),
78
+ ]);
79
+
80
+ //----
81
+ // RETURNS
82
+ //----
83
+ const category = project.options.validate;
84
+ // NORMAL
85
+ if (category === "is") return check("is")(false)(IsProgrammer.write);
86
+ else if (category === "validate")
87
+ return check("validate")(false)(ValidateProgrammer.write);
88
+ // STRICT
89
+ else if (category === "validateEquals")
90
+ return check("validate")(true)(ValidateProgrammer.write);
91
+ else if (category === "equals")
92
+ return check("is")(true)(IsProgrammer.write);
93
+ else if (category === "assertEquals")
94
+ return check("assert")(true)(AssertProgrammer.write);
95
+ // CLONE
96
+ else if (category === "assertClone")
97
+ return misc("assert")(MiscAssertCloneProgrammer.write);
98
+ else if (category === "validateClone")
99
+ return misc("validate")(MiscValidateCloneProgrammer.write);
100
+ // PRUNE
101
+ else if (category === "assertPrune")
102
+ return misc("assert")(MiscAssertPruneProgrammer.write);
103
+ else if (category === "validatePrune")
104
+ return misc("validate")(MiscValidatePruneProgrammer.write);
105
+ // DEFAULT
106
+ return check("assert")(false)(AssertProgrammer.write);
107
+ };
108
+ }
@@ -1,76 +1,72 @@
1
- import ts from "typescript";
2
-
3
- import { JsonMetadataFactory } from "typia/lib/factories/JsonMetadataFactory";
4
- import { TypeFactory } from "typia/lib/factories/TypeFactory";
5
- import { TransformerError } from "typia/lib/transformers/TransformerError";
6
-
7
- import { INestiaTransformProject } from "../options/INestiaTransformProject";
8
-
9
- export namespace TypedExceptionProgrammer {
10
- export const generate =
11
- ({ checker }: INestiaTransformProject) =>
12
- (expression: ts.CallExpression): ts.CallExpression => {
13
- // CHECK GENERIC ARGUMENT EXISTENCE
14
- if (!expression.typeArguments?.[0])
15
- throw TransformerError.from("@nestia.core.TypedException")([
16
- {
17
- name: "uknown",
18
- messages: [NOT_SPECIFIED],
19
- explore: {
20
- top: true,
21
- object: null,
22
- property: null,
23
- nested: null,
24
- escaped: false,
25
- aliased: false,
26
- },
27
- },
28
- ]);
29
-
30
- // GET TYPE INFO
31
- const node: ts.TypeNode = expression.typeArguments[0];
32
- const type: ts.Type = checker.getTypeFromTypeNode(node);
33
-
34
- // VALIDATE TYPE
35
- if (type.isTypeParameter())
36
- throw TransformerError.from("@nestia.core.TypedException")([
37
- {
38
- name: TypeFactory.getFullName(checker)(type),
39
- messages: [NO_GENERIC_ARGUMENT],
40
- explore: {
41
- top: true,
42
- object: null,
43
- property: null,
44
- nested: null,
45
- escaped: false,
46
- aliased: false,
47
- },
48
- },
49
- ]);
50
- JsonMetadataFactory.analyze("@nestia.core.TypedException")(checker)(
51
- type,
52
- );
53
-
54
- // CHECK DUPLICATED TRNASFORMATION
55
- if (expression.arguments.length === 3) return expression;
56
-
57
- // DO TRANSFORM
58
- const name: string = TypeFactory.getFullName(checker)(type);
59
- return ts.factory.updateCallExpression(
60
- expression,
61
- expression.expression,
62
- expression.typeArguments,
63
- [
64
- expression.arguments[0],
65
- expression.arguments[1] ??
66
- ts.factory.createIdentifier("undefined"),
67
- ts.factory.createStringLiteral(name),
68
- ],
69
- );
70
- };
71
- }
72
-
73
- const NOT_SPECIFIED =
74
- "Error on @nestia.core.TypedException(): generic argument is not specified.";
75
- const NO_GENERIC_ARGUMENT =
76
- "Error on @nestia.core.TypedException(): non-specified generic argument.";
1
+ import ts from "typescript";
2
+ import { JsonMetadataFactory } from "typia/lib/factories/JsonMetadataFactory";
3
+ import { TypeFactory } from "typia/lib/factories/TypeFactory";
4
+ import { TransformerError } from "typia/lib/transformers/TransformerError";
5
+
6
+ import { INestiaTransformProject } from "../options/INestiaTransformProject";
7
+
8
+ export namespace TypedExceptionProgrammer {
9
+ export const generate =
10
+ ({ checker }: INestiaTransformProject) =>
11
+ (expression: ts.CallExpression): ts.CallExpression => {
12
+ // CHECK GENERIC ARGUMENT EXISTENCE
13
+ if (!expression.typeArguments?.[0])
14
+ throw TransformerError.from("@nestia.core.TypedException")([
15
+ {
16
+ name: "uknown",
17
+ messages: [NOT_SPECIFIED],
18
+ explore: {
19
+ top: true,
20
+ object: null,
21
+ property: null,
22
+ nested: null,
23
+ escaped: false,
24
+ aliased: false,
25
+ },
26
+ },
27
+ ]);
28
+
29
+ // GET TYPE INFO
30
+ const node: ts.TypeNode = expression.typeArguments[0];
31
+ const type: ts.Type = checker.getTypeFromTypeNode(node);
32
+
33
+ // VALIDATE TYPE
34
+ if (type.isTypeParameter())
35
+ throw TransformerError.from("@nestia.core.TypedException")([
36
+ {
37
+ name: TypeFactory.getFullName(checker)(type),
38
+ messages: [NO_GENERIC_ARGUMENT],
39
+ explore: {
40
+ top: true,
41
+ object: null,
42
+ property: null,
43
+ nested: null,
44
+ escaped: false,
45
+ aliased: false,
46
+ },
47
+ },
48
+ ]);
49
+ JsonMetadataFactory.analyze("@nestia.core.TypedException")(checker)(type);
50
+
51
+ // CHECK DUPLICATED TRNASFORMATION
52
+ if (expression.arguments.length === 3) return expression;
53
+
54
+ // DO TRANSFORM
55
+ const name: string = TypeFactory.getFullName(checker)(type);
56
+ return ts.factory.updateCallExpression(
57
+ expression,
58
+ expression.expression,
59
+ expression.typeArguments,
60
+ [
61
+ expression.arguments[0],
62
+ expression.arguments[1] ?? ts.factory.createIdentifier("undefined"),
63
+ ts.factory.createStringLiteral(name),
64
+ ],
65
+ );
66
+ };
67
+ }
68
+
69
+ const NOT_SPECIFIED =
70
+ "Error on @nestia.core.TypedException(): generic argument is not specified.";
71
+ const NO_GENERIC_ARGUMENT =
72
+ "Error on @nestia.core.TypedException(): non-specified generic argument.";
@@ -1,59 +1,56 @@
1
- import ts from "typescript";
2
-
3
- import { HttpAssertHeadersProgrammer } from "typia/lib/programmers/http/HttpAssertHeadersProgrammer";
4
- import { HttpIsHeadersProgrammer } from "typia/lib/programmers/http/HttpIsHeadersProgrammer";
5
- import { HttpValidateHeadersProgrammer } from "typia/lib/programmers/http/HttpValidateHeadersProgrammer";
6
- import { IProject } from "typia/lib/transformers/IProject";
7
-
8
- import { INestiaTransformProject } from "../options/INestiaTransformProject";
9
- import { IRequestHeadersValidator } from "../options/IRequestHeadersValidator";
10
-
11
- export namespace TypedHeadersProgrammer {
12
- export const generate =
13
- (project: INestiaTransformProject) =>
14
- (modulo: ts.LeftHandSideExpression) =>
15
- (type: ts.Type): ts.Expression => {
16
- // GENERATE VALIDATION PLAN
17
- const parameter =
18
- (key: IRequestHeadersValidator<any>["type"]) =>
19
- (
20
- programmer: (
21
- project: IProject,
22
- ) => (
23
- modulo: ts.LeftHandSideExpression,
24
- ) => (type: ts.Type) => ts.ArrowFunction,
25
- ) =>
26
- ts.factory.createObjectLiteralExpression([
27
- ts.factory.createPropertyAssignment(
28
- ts.factory.createIdentifier("type"),
29
- ts.factory.createStringLiteral(key),
30
- ),
31
- ts.factory.createPropertyAssignment(
32
- ts.factory.createIdentifier(key),
33
- programmer({
34
- ...project,
35
- options: {
36
- numeric: false,
37
- finite: false,
38
- functional: false,
39
- },
40
- })(modulo)(type),
41
- ),
42
- ]);
43
-
44
- // RETURNS
45
- const category = project.options.validate;
46
- if (category === "is" || category === "equals")
47
- return parameter("is")(HttpIsHeadersProgrammer.write);
48
- else if (
49
- category === "validate" ||
50
- category === "validateEquals" ||
51
- category === "validateClone" ||
52
- category === "validatePrune"
53
- )
54
- return parameter("validate")(
55
- HttpValidateHeadersProgrammer.write,
56
- );
57
- return parameter("assert")(HttpAssertHeadersProgrammer.write);
58
- };
59
- }
1
+ import ts from "typescript";
2
+ import { HttpAssertHeadersProgrammer } from "typia/lib/programmers/http/HttpAssertHeadersProgrammer";
3
+ import { HttpIsHeadersProgrammer } from "typia/lib/programmers/http/HttpIsHeadersProgrammer";
4
+ import { HttpValidateHeadersProgrammer } from "typia/lib/programmers/http/HttpValidateHeadersProgrammer";
5
+ import { IProject } from "typia/lib/transformers/IProject";
6
+
7
+ import { INestiaTransformProject } from "../options/INestiaTransformProject";
8
+ import { IRequestHeadersValidator } from "../options/IRequestHeadersValidator";
9
+
10
+ export namespace TypedHeadersProgrammer {
11
+ export const generate =
12
+ (project: INestiaTransformProject) =>
13
+ (modulo: ts.LeftHandSideExpression) =>
14
+ (type: ts.Type): ts.Expression => {
15
+ // GENERATE VALIDATION PLAN
16
+ const parameter =
17
+ (key: IRequestHeadersValidator<any>["type"]) =>
18
+ (
19
+ programmer: (
20
+ project: IProject,
21
+ ) => (
22
+ modulo: ts.LeftHandSideExpression,
23
+ ) => (type: ts.Type) => ts.ArrowFunction,
24
+ ) =>
25
+ ts.factory.createObjectLiteralExpression([
26
+ ts.factory.createPropertyAssignment(
27
+ ts.factory.createIdentifier("type"),
28
+ ts.factory.createStringLiteral(key),
29
+ ),
30
+ ts.factory.createPropertyAssignment(
31
+ ts.factory.createIdentifier(key),
32
+ programmer({
33
+ ...project,
34
+ options: {
35
+ numeric: false,
36
+ finite: false,
37
+ functional: false,
38
+ },
39
+ })(modulo)(type),
40
+ ),
41
+ ]);
42
+
43
+ // RETURNS
44
+ const category = project.options.validate;
45
+ if (category === "is" || category === "equals")
46
+ return parameter("is")(HttpIsHeadersProgrammer.write);
47
+ else if (
48
+ category === "validate" ||
49
+ category === "validateEquals" ||
50
+ category === "validateClone" ||
51
+ category === "validatePrune"
52
+ )
53
+ return parameter("validate")(HttpValidateHeadersProgrammer.write);
54
+ return parameter("assert")(HttpAssertHeadersProgrammer.write);
55
+ };
56
+ }