@nestia/core 4.4.0 → 4.4.1-dev.20241216

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 (89) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +87 -87
  3. package/lib/options/INestiaTransformOptions.d.ts +7 -0
  4. package/lib/programmers/TypedBodyProgrammer.js +11 -0
  5. package/lib/programmers/TypedBodyProgrammer.js.map +1 -1
  6. package/lib/programmers/TypedQueryBodyProgrammer.js +36 -0
  7. package/lib/programmers/TypedQueryBodyProgrammer.js.map +1 -1
  8. package/lib/programmers/TypedQueryProgrammer.js +36 -0
  9. package/lib/programmers/TypedQueryProgrammer.js.map +1 -1
  10. package/lib/programmers/TypedQueryRouteProgrammer.js +36 -0
  11. package/lib/programmers/TypedQueryRouteProgrammer.js.map +1 -1
  12. package/lib/programmers/TypedRouteProgrammer.js +18 -0
  13. package/lib/programmers/TypedRouteProgrammer.js.map +1 -1
  14. package/lib/programmers/internal/LlmValidatePredicator.d.ts +5 -0
  15. package/lib/programmers/internal/LlmValidatePredicator.js +18 -0
  16. package/lib/programmers/internal/LlmValidatePredicator.js.map +1 -0
  17. package/package.json +6 -6
  18. package/src/adaptors/WebSocketAdaptor.ts +426 -426
  19. package/src/decorators/DynamicModule.ts +43 -43
  20. package/src/decorators/EncryptedBody.ts +101 -101
  21. package/src/decorators/EncryptedController.ts +38 -38
  22. package/src/decorators/EncryptedModule.ts +100 -100
  23. package/src/decorators/EncryptedRoute.ts +219 -219
  24. package/src/decorators/NoTransformConfigurationError.ts +32 -32
  25. package/src/decorators/PlainBody.ts +79 -79
  26. package/src/decorators/SwaggerCustomizer.ts +115 -115
  27. package/src/decorators/SwaggerExample.ts +100 -100
  28. package/src/decorators/TypedBody.ts +59 -59
  29. package/src/decorators/TypedException.ts +128 -128
  30. package/src/decorators/TypedFormData.ts +195 -195
  31. package/src/decorators/TypedHeaders.ts +64 -64
  32. package/src/decorators/TypedParam.ts +77 -77
  33. package/src/decorators/TypedQuery.ts +245 -245
  34. package/src/decorators/TypedRoute.ts +214 -214
  35. package/src/decorators/WebSocketRoute.ts +242 -242
  36. package/src/decorators/internal/EncryptedConstant.ts +4 -4
  37. package/src/decorators/internal/IWebSocketRouteReflect.ts +23 -23
  38. package/src/decorators/internal/NoTransformConfigureError.ts +2 -2
  39. package/src/decorators/internal/get_path_and_querify.ts +108 -108
  40. package/src/decorators/internal/get_path_and_stringify.ts +122 -122
  41. package/src/decorators/internal/get_text_body.ts +20 -20
  42. package/src/decorators/internal/headers_to_object.ts +13 -13
  43. package/src/decorators/internal/is_request_body_undefined.ts +14 -14
  44. package/src/decorators/internal/load_controller.ts +49 -49
  45. package/src/decorators/internal/route_error.ts +45 -45
  46. package/src/decorators/internal/validate_request_body.ts +74 -74
  47. package/src/decorators/internal/validate_request_form_data.ts +77 -77
  48. package/src/decorators/internal/validate_request_headers.ts +86 -86
  49. package/src/decorators/internal/validate_request_query.ts +74 -74
  50. package/src/index.ts +5 -5
  51. package/src/module.ts +21 -21
  52. package/src/options/INestiaTransformOptions.ts +38 -29
  53. package/src/options/INestiaTransformProject.ts +8 -8
  54. package/src/options/IRequestBodyValidator.ts +20 -20
  55. package/src/options/IRequestFormDataProps.ts +27 -27
  56. package/src/options/IRequestHeadersValidator.ts +22 -22
  57. package/src/options/IRequestQueryValidator.ts +20 -20
  58. package/src/options/IResponseBodyQuerifier.ts +25 -25
  59. package/src/options/IResponseBodyStringifier.ts +30 -30
  60. package/src/programmers/PlainBodyProgrammer.ts +70 -70
  61. package/src/programmers/TypedBodyProgrammer.ts +143 -132
  62. package/src/programmers/TypedFormDataBodyProgrammer.ts +118 -118
  63. package/src/programmers/TypedHeadersProgrammer.ts +63 -63
  64. package/src/programmers/TypedParamProgrammer.ts +33 -33
  65. package/src/programmers/TypedQueryBodyProgrammer.ts +106 -63
  66. package/src/programmers/TypedQueryProgrammer.ts +108 -65
  67. package/src/programmers/TypedQueryRouteProgrammer.ts +99 -56
  68. package/src/programmers/TypedRouteProgrammer.ts +95 -76
  69. package/src/programmers/http/HttpAssertQuerifyProgrammer.ts +72 -72
  70. package/src/programmers/http/HttpIsQuerifyProgrammer.ts +75 -75
  71. package/src/programmers/http/HttpQuerifyProgrammer.ts +108 -108
  72. package/src/programmers/http/HttpValidateQuerifyProgrammer.ts +76 -76
  73. package/src/programmers/internal/CoreMetadataUtil.ts +21 -21
  74. package/src/programmers/internal/LlmValidatePredicator.ts +16 -0
  75. package/src/transform.ts +35 -35
  76. package/src/transformers/FileTransformer.ts +110 -110
  77. package/src/transformers/MethodTransformer.ts +103 -103
  78. package/src/transformers/NodeTransformer.ts +23 -23
  79. package/src/transformers/ParameterDecoratorTransformer.ts +143 -143
  80. package/src/transformers/ParameterTransformer.ts +57 -57
  81. package/src/transformers/TypedRouteTransformer.ts +85 -85
  82. package/src/transformers/WebSocketRouteTransformer.ts +120 -120
  83. package/src/typings/Creator.ts +3 -3
  84. package/src/typings/get-function-location.d.ts +7 -7
  85. package/src/utils/ArrayUtil.ts +7 -7
  86. package/src/utils/ExceptionManager.ts +112 -112
  87. package/src/utils/Singleton.ts +20 -20
  88. package/src/utils/SourceFinder.ts +57 -57
  89. package/src/utils/VersioningStrategy.ts +27 -27
@@ -1,63 +1,63 @@
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 { ITypiaContext } from "typia/lib/transformers/ITypiaContext";
6
-
7
- import { INestiaTransformContext } from "../options/INestiaTransformProject";
8
- import { IRequestHeadersValidator } from "../options/IRequestHeadersValidator";
9
-
10
- export namespace TypedHeadersProgrammer {
11
- export const generate = (props: {
12
- context: INestiaTransformContext;
13
- modulo: ts.LeftHandSideExpression;
14
- type: ts.Type;
15
- }): ts.Expression => {
16
- // GENERATE VALIDATION PLAN
17
- const parameter =
18
- (key: IRequestHeadersValidator<any>["type"]) =>
19
- (
20
- programmer: (next: {
21
- context: ITypiaContext;
22
- modulo: ts.LeftHandSideExpression;
23
- type: ts.Type;
24
- name: string | undefined;
25
- }) => ts.Expression,
26
- ) =>
27
- ts.factory.createObjectLiteralExpression([
28
- ts.factory.createPropertyAssignment(
29
- ts.factory.createIdentifier("type"),
30
- ts.factory.createStringLiteral(key),
31
- ),
32
- ts.factory.createPropertyAssignment(
33
- ts.factory.createIdentifier(key),
34
- programmer({
35
- context: {
36
- ...props.context,
37
- options: {
38
- numeric: false,
39
- finite: false,
40
- functional: false,
41
- },
42
- },
43
- modulo: props.modulo,
44
- type: props.type,
45
- name: undefined,
46
- }),
47
- ),
48
- ]);
49
-
50
- // RETURNS
51
- const category = props.context.options.validate;
52
- if (category === "is" || category === "equals")
53
- return parameter("is")(HttpIsHeadersProgrammer.write);
54
- else if (
55
- category === "validate" ||
56
- category === "validateEquals" ||
57
- category === "validateClone" ||
58
- category === "validatePrune"
59
- )
60
- return parameter("validate")(HttpValidateHeadersProgrammer.write);
61
- return parameter("assert")(HttpAssertHeadersProgrammer.write);
62
- };
63
- }
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 { ITypiaContext } from "typia/lib/transformers/ITypiaContext";
6
+
7
+ import { INestiaTransformContext } from "../options/INestiaTransformProject";
8
+ import { IRequestHeadersValidator } from "../options/IRequestHeadersValidator";
9
+
10
+ export namespace TypedHeadersProgrammer {
11
+ export const generate = (props: {
12
+ context: INestiaTransformContext;
13
+ modulo: ts.LeftHandSideExpression;
14
+ type: ts.Type;
15
+ }): ts.Expression => {
16
+ // GENERATE VALIDATION PLAN
17
+ const parameter =
18
+ (key: IRequestHeadersValidator<any>["type"]) =>
19
+ (
20
+ programmer: (next: {
21
+ context: ITypiaContext;
22
+ modulo: ts.LeftHandSideExpression;
23
+ type: ts.Type;
24
+ name: string | undefined;
25
+ }) => ts.Expression,
26
+ ) =>
27
+ ts.factory.createObjectLiteralExpression([
28
+ ts.factory.createPropertyAssignment(
29
+ ts.factory.createIdentifier("type"),
30
+ ts.factory.createStringLiteral(key),
31
+ ),
32
+ ts.factory.createPropertyAssignment(
33
+ ts.factory.createIdentifier(key),
34
+ programmer({
35
+ context: {
36
+ ...props.context,
37
+ options: {
38
+ numeric: false,
39
+ finite: false,
40
+ functional: false,
41
+ },
42
+ },
43
+ modulo: props.modulo,
44
+ type: props.type,
45
+ name: undefined,
46
+ }),
47
+ ),
48
+ ]);
49
+
50
+ // RETURNS
51
+ const category = props.context.options.validate;
52
+ if (category === "is" || category === "equals")
53
+ return parameter("is")(HttpIsHeadersProgrammer.write);
54
+ else if (
55
+ category === "validate" ||
56
+ category === "validateEquals" ||
57
+ category === "validateClone" ||
58
+ category === "validatePrune"
59
+ )
60
+ return parameter("validate")(HttpValidateHeadersProgrammer.write);
61
+ return parameter("assert")(HttpAssertHeadersProgrammer.write);
62
+ };
63
+ }
@@ -1,33 +1,33 @@
1
- import ts from "typescript";
2
- import { HttpParameterProgrammer } from "typia/lib/programmers/http/HttpParameterProgrammer";
3
-
4
- import { INestiaTransformContext } from "../options/INestiaTransformProject";
5
-
6
- export namespace TypedParamProgrammer {
7
- export const generate = (props: {
8
- context: INestiaTransformContext;
9
- modulo: ts.LeftHandSideExpression;
10
- arguments: readonly ts.Expression[];
11
- type: ts.Type;
12
- }): readonly ts.Expression[] => {
13
- // ALREADY BEING TRANSFORMED
14
- if (props.arguments.length !== 1) return props.arguments;
15
- return [
16
- props.arguments[0],
17
- HttpParameterProgrammer.write({
18
- context: {
19
- ...props.context,
20
- options: {
21
- numeric: true,
22
- },
23
- },
24
- modulo: props.modulo,
25
- type: props.type,
26
- name: undefined,
27
- }),
28
- ...(props.context.options?.validate?.startsWith("validate")
29
- ? [ts.factory.createTrue()]
30
- : []),
31
- ];
32
- };
33
- }
1
+ import ts from "typescript";
2
+ import { HttpParameterProgrammer } from "typia/lib/programmers/http/HttpParameterProgrammer";
3
+
4
+ import { INestiaTransformContext } from "../options/INestiaTransformProject";
5
+
6
+ export namespace TypedParamProgrammer {
7
+ export const generate = (props: {
8
+ context: INestiaTransformContext;
9
+ modulo: ts.LeftHandSideExpression;
10
+ arguments: readonly ts.Expression[];
11
+ type: ts.Type;
12
+ }): readonly ts.Expression[] => {
13
+ // ALREADY BEING TRANSFORMED
14
+ if (props.arguments.length !== 1) return props.arguments;
15
+ return [
16
+ props.arguments[0],
17
+ HttpParameterProgrammer.write({
18
+ context: {
19
+ ...props.context,
20
+ options: {
21
+ numeric: true,
22
+ },
23
+ },
24
+ modulo: props.modulo,
25
+ type: props.type,
26
+ name: undefined,
27
+ }),
28
+ ...(props.context.options?.validate?.startsWith("validate")
29
+ ? [ts.factory.createTrue()]
30
+ : []),
31
+ ];
32
+ };
33
+ }
@@ -1,63 +1,106 @@
1
- import ts from "typescript";
2
- import { HttpAssertQueryProgrammer } from "typia/lib/programmers/http/HttpAssertQueryProgrammer";
3
- import { HttpIsQueryProgrammer } from "typia/lib/programmers/http/HttpIsQueryProgrammer";
4
- import { HttpValidateQueryProgrammer } from "typia/lib/programmers/http/HttpValidateQueryProgrammer";
5
- import { ITypiaContext } from "typia/lib/transformers/ITypiaContext";
6
-
7
- import { INestiaTransformContext } from "../options/INestiaTransformProject";
8
- import { IRequestQueryValidator } from "../options/IRequestQueryValidator";
9
-
10
- export namespace TypedQueryBodyProgrammer {
11
- export const generate = (props: {
12
- context: INestiaTransformContext;
13
- modulo: ts.LeftHandSideExpression;
14
- type: ts.Type;
15
- }): ts.ObjectLiteralExpression => {
16
- // GENERATE VALIDATION PLAN
17
- const parameter =
18
- (key: IRequestQueryValidator<any>["type"]) =>
19
- (
20
- programmer: (next: {
21
- context: ITypiaContext;
22
- modulo: ts.LeftHandSideExpression;
23
- type: ts.Type;
24
- name: string | undefined;
25
- }) => ts.Expression,
26
- ) =>
27
- ts.factory.createObjectLiteralExpression([
28
- ts.factory.createPropertyAssignment(
29
- ts.factory.createIdentifier("type"),
30
- ts.factory.createStringLiteral(key),
31
- ),
32
- ts.factory.createPropertyAssignment(
33
- ts.factory.createIdentifier(key),
34
- programmer({
35
- context: {
36
- ...props.context,
37
- options: {
38
- numeric: false,
39
- finite: false,
40
- functional: false,
41
- },
42
- },
43
- modulo: props.modulo,
44
- type: props.type,
45
- name: undefined,
46
- }),
47
- ),
48
- ]);
49
-
50
- // RETURNS
51
- const category = props.context.options.validate;
52
- if (category === "is" || category === "equals")
53
- return parameter("is")(HttpIsQueryProgrammer.write);
54
- else if (
55
- category === "validate" ||
56
- category === "validateEquals" ||
57
- category === "validateClone" ||
58
- category === "validatePrune"
59
- )
60
- return parameter("validate")(HttpValidateQueryProgrammer.write);
61
- return parameter("assert")(HttpAssertQueryProgrammer.write);
62
- };
63
- }
1
+ import ts from "typescript";
2
+ import { MetadataCollection } from "typia/lib/factories/MetadataCollection";
3
+ import { MetadataFactory } from "typia/lib/factories/MetadataFactory";
4
+ import { HttpAssertQueryProgrammer } from "typia/lib/programmers/http/HttpAssertQueryProgrammer";
5
+ import { HttpIsQueryProgrammer } from "typia/lib/programmers/http/HttpIsQueryProgrammer";
6
+ import { HttpQueryProgrammer } from "typia/lib/programmers/http/HttpQueryProgrammer";
7
+ import { HttpValidateQueryProgrammer } from "typia/lib/programmers/http/HttpValidateQueryProgrammer";
8
+ import { LlmSchemaProgrammer } from "typia/lib/programmers/llm/LlmSchemaProgrammer";
9
+ import { ITypiaContext } from "typia/lib/transformers/ITypiaContext";
10
+ import { TransformerError } from "typia/lib/transformers/TransformerError";
11
+
12
+ import { INestiaTransformContext } from "../options/INestiaTransformProject";
13
+ import { IRequestQueryValidator } from "../options/IRequestQueryValidator";
14
+ import { LlmValidatePredicator } from "./internal/LlmValidatePredicator";
15
+
16
+ export namespace TypedQueryBodyProgrammer {
17
+ export const generate = (props: {
18
+ context: INestiaTransformContext;
19
+ modulo: ts.LeftHandSideExpression;
20
+ type: ts.Type;
21
+ }): ts.ObjectLiteralExpression => {
22
+ // VALIDATE TYPE
23
+ if (LlmValidatePredicator.is(props.context.options.llm)) {
24
+ const result = MetadataFactory.analyze({
25
+ checker: props.context.checker,
26
+ transformer: props.context.transformer,
27
+ options: {
28
+ escape: false,
29
+ constant: true,
30
+ absorb: true,
31
+ validate: (meta, explore) => {
32
+ const errors: string[] = HttpQueryProgrammer.validate(
33
+ meta,
34
+ explore,
35
+ true,
36
+ );
37
+ errors.push(
38
+ ...LlmSchemaProgrammer.validate({
39
+ model: props.context.options.llm!.model,
40
+ config: {
41
+ strict: props.context.options.llm!.strict,
42
+ recursive: props.context.options.llm!.recursive,
43
+ },
44
+ })(meta),
45
+ );
46
+ return errors;
47
+ },
48
+ },
49
+ collection: new MetadataCollection(),
50
+ type: props.type,
51
+ });
52
+ if (result.success === false)
53
+ throw TransformerError.from({
54
+ code: "@nestia.core.TypedQuery.Body",
55
+ errors: result.errors,
56
+ });
57
+ }
58
+
59
+ // GENERATE VALIDATION PLAN
60
+ const parameter =
61
+ (key: IRequestQueryValidator<any>["type"]) =>
62
+ (
63
+ programmer: (next: {
64
+ context: ITypiaContext;
65
+ modulo: ts.LeftHandSideExpression;
66
+ type: ts.Type;
67
+ name: string | undefined;
68
+ }) => ts.Expression,
69
+ ) =>
70
+ ts.factory.createObjectLiteralExpression([
71
+ ts.factory.createPropertyAssignment(
72
+ ts.factory.createIdentifier("type"),
73
+ ts.factory.createStringLiteral(key),
74
+ ),
75
+ ts.factory.createPropertyAssignment(
76
+ ts.factory.createIdentifier(key),
77
+ programmer({
78
+ context: {
79
+ ...props.context,
80
+ options: {
81
+ numeric: false,
82
+ finite: false,
83
+ functional: false,
84
+ },
85
+ },
86
+ modulo: props.modulo,
87
+ type: props.type,
88
+ name: undefined,
89
+ }),
90
+ ),
91
+ ]);
92
+
93
+ // RETURNS
94
+ const category = props.context.options.validate;
95
+ if (category === "is" || category === "equals")
96
+ return parameter("is")(HttpIsQueryProgrammer.write);
97
+ else if (
98
+ category === "validate" ||
99
+ category === "validateEquals" ||
100
+ category === "validateClone" ||
101
+ category === "validatePrune"
102
+ )
103
+ return parameter("validate")(HttpValidateQueryProgrammer.write);
104
+ return parameter("assert")(HttpAssertQueryProgrammer.write);
105
+ };
106
+ }
@@ -1,65 +1,108 @@
1
- import ts from "typescript";
2
- import { HttpAssertQueryProgrammer } from "typia/lib/programmers/http/HttpAssertQueryProgrammer";
3
- import { HttpIsQueryProgrammer } from "typia/lib/programmers/http/HttpIsQueryProgrammer";
4
- import { HttpValidateQueryProgrammer } from "typia/lib/programmers/http/HttpValidateQueryProgrammer";
5
- import { ITypiaContext } from "typia/lib/transformers/ITypiaContext";
6
-
7
- import { INestiaTransformContext } from "../options/INestiaTransformProject";
8
- import { IRequestQueryValidator } from "../options/IRequestQueryValidator";
9
-
10
- export namespace TypedQueryProgrammer {
11
- export const generate = (props: {
12
- context: INestiaTransformContext;
13
- modulo: ts.LeftHandSideExpression;
14
- type: ts.Type;
15
- }): ts.Expression => {
16
- // GENERATE VALIDATION PLAN
17
- const parameter =
18
- (key: IRequestQueryValidator<any>["type"]) =>
19
- (
20
- programmer: (next: {
21
- context: ITypiaContext;
22
- modulo: ts.LeftHandSideExpression;
23
- type: ts.Type;
24
- name: string | undefined;
25
- allowOptional: boolean;
26
- }) => ts.Expression,
27
- ) =>
28
- ts.factory.createObjectLiteralExpression([
29
- ts.factory.createPropertyAssignment(
30
- ts.factory.createIdentifier("type"),
31
- ts.factory.createStringLiteral(key),
32
- ),
33
- ts.factory.createPropertyAssignment(
34
- ts.factory.createIdentifier(key),
35
- programmer({
36
- context: {
37
- ...props.context,
38
- options: {
39
- numeric: false,
40
- finite: false,
41
- functional: false,
42
- },
43
- },
44
- modulo: props.modulo,
45
- type: props.type,
46
- name: undefined,
47
- allowOptional: true,
48
- }),
49
- ),
50
- ]);
51
-
52
- // RETURNS
53
- const category = props.context.options.validate;
54
- if (category === "is" || category === "equals")
55
- return parameter("is")(HttpIsQueryProgrammer.write);
56
- else if (
57
- category === "validate" ||
58
- category === "validateEquals" ||
59
- category === "validateClone" ||
60
- category === "validatePrune"
61
- )
62
- return parameter("validate")(HttpValidateQueryProgrammer.write);
63
- return parameter("assert")(HttpAssertQueryProgrammer.write);
64
- };
65
- }
1
+ import ts from "typescript";
2
+ import { MetadataCollection } from "typia/lib/factories/MetadataCollection";
3
+ import { MetadataFactory } from "typia/lib/factories/MetadataFactory";
4
+ import { HttpAssertQueryProgrammer } from "typia/lib/programmers/http/HttpAssertQueryProgrammer";
5
+ import { HttpIsQueryProgrammer } from "typia/lib/programmers/http/HttpIsQueryProgrammer";
6
+ import { HttpQueryProgrammer } from "typia/lib/programmers/http/HttpQueryProgrammer";
7
+ import { HttpValidateQueryProgrammer } from "typia/lib/programmers/http/HttpValidateQueryProgrammer";
8
+ import { LlmSchemaProgrammer } from "typia/lib/programmers/llm/LlmSchemaProgrammer";
9
+ import { ITypiaContext } from "typia/lib/transformers/ITypiaContext";
10
+ import { TransformerError } from "typia/lib/transformers/TransformerError";
11
+
12
+ import { INestiaTransformContext } from "../options/INestiaTransformProject";
13
+ import { IRequestQueryValidator } from "../options/IRequestQueryValidator";
14
+ import { LlmValidatePredicator } from "./internal/LlmValidatePredicator";
15
+
16
+ export namespace TypedQueryProgrammer {
17
+ export const generate = (props: {
18
+ context: INestiaTransformContext;
19
+ modulo: ts.LeftHandSideExpression;
20
+ type: ts.Type;
21
+ }): ts.Expression => {
22
+ // VALIDATE TYPE
23
+ if (LlmValidatePredicator.is(props.context.options.llm)) {
24
+ const result = MetadataFactory.analyze({
25
+ checker: props.context.checker,
26
+ transformer: props.context.transformer,
27
+ options: {
28
+ escape: false,
29
+ constant: true,
30
+ absorb: true,
31
+ validate: (meta, explore) => {
32
+ const errors: string[] = HttpQueryProgrammer.validate(
33
+ meta,
34
+ explore,
35
+ true,
36
+ );
37
+ errors.push(
38
+ ...LlmSchemaProgrammer.validate({
39
+ model: props.context.options.llm!.model,
40
+ config: {
41
+ strict: props.context.options.llm!.strict,
42
+ recursive: props.context.options.llm!.recursive,
43
+ },
44
+ })(meta),
45
+ );
46
+ return errors;
47
+ },
48
+ },
49
+ collection: new MetadataCollection(),
50
+ type: props.type,
51
+ });
52
+ if (result.success === false)
53
+ throw TransformerError.from({
54
+ code: "@nestia.core.TypedQuery",
55
+ errors: result.errors,
56
+ });
57
+ }
58
+
59
+ // GENERATE VALIDATION PLAN
60
+ const parameter =
61
+ (key: IRequestQueryValidator<any>["type"]) =>
62
+ (
63
+ programmer: (next: {
64
+ context: ITypiaContext;
65
+ modulo: ts.LeftHandSideExpression;
66
+ type: ts.Type;
67
+ name: string | undefined;
68
+ allowOptional: boolean;
69
+ }) => ts.Expression,
70
+ ) =>
71
+ ts.factory.createObjectLiteralExpression([
72
+ ts.factory.createPropertyAssignment(
73
+ ts.factory.createIdentifier("type"),
74
+ ts.factory.createStringLiteral(key),
75
+ ),
76
+ ts.factory.createPropertyAssignment(
77
+ ts.factory.createIdentifier(key),
78
+ programmer({
79
+ context: {
80
+ ...props.context,
81
+ options: {
82
+ numeric: false,
83
+ finite: false,
84
+ functional: false,
85
+ },
86
+ },
87
+ modulo: props.modulo,
88
+ type: props.type,
89
+ name: undefined,
90
+ allowOptional: true,
91
+ }),
92
+ ),
93
+ ]);
94
+
95
+ // RETURNS
96
+ const category = props.context.options.validate;
97
+ if (category === "is" || category === "equals")
98
+ return parameter("is")(HttpIsQueryProgrammer.write);
99
+ else if (
100
+ category === "validate" ||
101
+ category === "validateEquals" ||
102
+ category === "validateClone" ||
103
+ category === "validatePrune"
104
+ )
105
+ return parameter("validate")(HttpValidateQueryProgrammer.write);
106
+ return parameter("assert")(HttpAssertQueryProgrammer.write);
107
+ };
108
+ }