@nestia/core 8.1.0 → 9.0.0-dev.20251107

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 (75) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +93 -93
  3. package/package.json +7 -8
  4. package/src/adaptors/WebSocketAdaptor.ts +429 -429
  5. package/src/decorators/DynamicModule.ts +44 -44
  6. package/src/decorators/EncryptedBody.ts +97 -97
  7. package/src/decorators/EncryptedController.ts +40 -40
  8. package/src/decorators/EncryptedModule.ts +98 -98
  9. package/src/decorators/EncryptedRoute.ts +213 -213
  10. package/src/decorators/HumanRoute.ts +22 -22
  11. package/src/decorators/NoTransformConfigurationError.ts +34 -34
  12. package/src/decorators/PlainBody.ts +76 -76
  13. package/src/decorators/SwaggerCustomizer.ts +97 -97
  14. package/src/decorators/SwaggerExample.ts +100 -100
  15. package/src/decorators/TypedBody.ts +57 -57
  16. package/src/decorators/TypedException.ts +147 -147
  17. package/src/decorators/TypedFormData.ts +195 -195
  18. package/src/decorators/TypedHeaders.ts +66 -66
  19. package/src/decorators/TypedParam.ts +77 -77
  20. package/src/decorators/TypedQuery.ts +234 -234
  21. package/src/decorators/TypedRoute.ts +196 -196
  22. package/src/decorators/WebSocketRoute.ts +242 -242
  23. package/src/decorators/internal/EncryptedConstant.ts +2 -2
  24. package/src/decorators/internal/IWebSocketRouteReflect.ts +23 -23
  25. package/src/decorators/internal/NoTransformConfigureError.ts +2 -2
  26. package/src/decorators/internal/get_path_and_querify.ts +94 -94
  27. package/src/decorators/internal/get_path_and_stringify.ts +110 -110
  28. package/src/decorators/internal/get_text_body.ts +16 -16
  29. package/src/decorators/internal/headers_to_object.ts +11 -11
  30. package/src/decorators/internal/is_request_body_undefined.ts +12 -12
  31. package/src/decorators/internal/load_controller.ts +45 -45
  32. package/src/decorators/internal/route_error.ts +43 -43
  33. package/src/decorators/internal/validate_request_body.ts +64 -64
  34. package/src/decorators/internal/validate_request_form_data.ts +67 -67
  35. package/src/decorators/internal/validate_request_headers.ts +76 -76
  36. package/src/decorators/internal/validate_request_query.ts +64 -64
  37. package/src/index.ts +5 -5
  38. package/src/module.ts +22 -22
  39. package/src/options/INestiaTransformOptions.ts +38 -38
  40. package/src/options/INestiaTransformProject.ts +8 -8
  41. package/src/options/IRequestBodyValidator.ts +20 -20
  42. package/src/options/IRequestFormDataProps.ts +27 -27
  43. package/src/options/IRequestHeadersValidator.ts +22 -22
  44. package/src/options/IRequestQueryValidator.ts +20 -20
  45. package/src/options/IResponseBodyQuerifier.ts +25 -25
  46. package/src/options/IResponseBodyStringifier.ts +30 -30
  47. package/src/programmers/PlainBodyProgrammer.ts +70 -70
  48. package/src/programmers/TypedBodyProgrammer.ts +142 -142
  49. package/src/programmers/TypedFormDataBodyProgrammer.ts +118 -118
  50. package/src/programmers/TypedHeadersProgrammer.ts +63 -63
  51. package/src/programmers/TypedParamProgrammer.ts +33 -33
  52. package/src/programmers/TypedQueryBodyProgrammer.ts +112 -112
  53. package/src/programmers/TypedQueryProgrammer.ts +114 -114
  54. package/src/programmers/TypedQueryRouteProgrammer.ts +105 -105
  55. package/src/programmers/TypedRouteProgrammer.ts +94 -94
  56. package/src/programmers/http/HttpAssertQuerifyProgrammer.ts +72 -72
  57. package/src/programmers/http/HttpIsQuerifyProgrammer.ts +75 -75
  58. package/src/programmers/http/HttpQuerifyProgrammer.ts +108 -108
  59. package/src/programmers/http/HttpValidateQuerifyProgrammer.ts +76 -76
  60. package/src/programmers/internal/CoreMetadataUtil.ts +21 -21
  61. package/src/transform.ts +35 -35
  62. package/src/transformers/FileTransformer.ts +110 -110
  63. package/src/transformers/MethodTransformer.ts +103 -103
  64. package/src/transformers/NodeTransformer.ts +23 -23
  65. package/src/transformers/ParameterDecoratorTransformer.ts +143 -143
  66. package/src/transformers/ParameterTransformer.ts +57 -57
  67. package/src/transformers/TypedRouteTransformer.ts +85 -85
  68. package/src/transformers/WebSocketRouteTransformer.ts +120 -120
  69. package/src/typings/Creator.ts +3 -3
  70. package/src/typings/get-function-location.d.ts +7 -7
  71. package/src/utils/ArrayUtil.ts +7 -7
  72. package/src/utils/ExceptionManager.ts +115 -115
  73. package/src/utils/Singleton.ts +16 -16
  74. package/src/utils/SourceFinder.ts +54 -54
  75. package/src/utils/VersioningStrategy.ts +27 -27
@@ -1,142 +1,142 @@
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 { LlmSchemaProgrammer } from "typia/lib/programmers/llm/LlmSchemaProgrammer";
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 { ITypiaContext } from "typia/lib/transformers/ITypiaContext";
12
-
13
- import { INestiaTransformContext } from "../options/INestiaTransformProject";
14
- import { IRequestBodyValidator } from "../options/IRequestBodyValidator";
15
-
16
- export namespace TypedBodyProgrammer {
17
- export const generate = (props: {
18
- context: INestiaTransformContext;
19
- modulo: ts.LeftHandSideExpression;
20
- type: ts.Type;
21
- }): ts.ObjectLiteralExpression => {
22
- // VALIDATE TYPE
23
- JsonMetadataFactory.analyze({
24
- method: "@nestia.core.TypedBody",
25
- checker: props.context.checker,
26
- transformer: props.context.transformer,
27
- type: props.type,
28
- validate: props.context.options.llm
29
- ? LlmSchemaProgrammer.validate({
30
- model: props.context.options.llm.model,
31
- config: {
32
- strict: props.context.options.llm.strict,
33
- recursive: props.context.options.llm.recursive,
34
- },
35
- })
36
- : undefined,
37
- });
38
-
39
- // GENERATE VALIDATION PLAN
40
- const check =
41
- (key: IRequestBodyValidator<any>["type"]) =>
42
- (equals: boolean) =>
43
- (
44
- programmer: (next: {
45
- context: ITypiaContext;
46
- modulo: ts.LeftHandSideExpression;
47
- config: {
48
- equals: boolean;
49
- guard: boolean;
50
- };
51
- type: ts.Type;
52
- name: string | undefined;
53
- }) => ts.Expression,
54
- ) =>
55
- ts.factory.createObjectLiteralExpression([
56
- ts.factory.createPropertyAssignment(
57
- ts.factory.createIdentifier("type"),
58
- ts.factory.createStringLiteral(key),
59
- ),
60
- ts.factory.createPropertyAssignment(
61
- ts.factory.createIdentifier(key),
62
- programmer({
63
- context: {
64
- ...props.context,
65
- options: {
66
- numeric: false,
67
- finite: false,
68
- functional: false,
69
- },
70
- },
71
- modulo: props.modulo,
72
- config: {
73
- equals,
74
- guard: false,
75
- },
76
- type: props.type,
77
- name: undefined,
78
- }),
79
- ),
80
- ]);
81
- const misc =
82
- (key: IRequestBodyValidator<any>["type"]) =>
83
- (
84
- programmer: (next: {
85
- context: ITypiaContext;
86
- modulo: ts.LeftHandSideExpression;
87
- type: ts.Type;
88
- name: string | undefined;
89
- }) => ts.Expression,
90
- ) =>
91
- ts.factory.createObjectLiteralExpression([
92
- ts.factory.createPropertyAssignment(
93
- ts.factory.createIdentifier("type"),
94
- ts.factory.createStringLiteral(key),
95
- ),
96
- ts.factory.createPropertyAssignment(
97
- ts.factory.createIdentifier(key),
98
- programmer({
99
- context: {
100
- ...props.context,
101
- options: {
102
- numeric: false,
103
- finite: false,
104
- functional: false,
105
- },
106
- },
107
- modulo: props.modulo,
108
- type: props.type,
109
- name: undefined,
110
- }),
111
- ),
112
- ]);
113
-
114
- //----
115
- // RETURNS
116
- //----
117
- const category = props.context.options.validate;
118
- // NORMAL
119
- if (category === "assert")
120
- return check("assert")(false)(AssertProgrammer.write);
121
- else if (category === "is") return check("is")(false)(IsProgrammer.write);
122
- // STRICT
123
- else if (category === "validateEquals")
124
- return check("validate")(true)(ValidateProgrammer.write);
125
- else if (category === "equals")
126
- return check("is")(true)(IsProgrammer.write);
127
- else if (category === "assertEquals")
128
- return check("assert")(true)(AssertProgrammer.write);
129
- // CLONE
130
- else if (category === "assertClone")
131
- return misc("assert")(MiscAssertCloneProgrammer.write);
132
- else if (category === "validateClone")
133
- return misc("validate")(MiscValidateCloneProgrammer.write);
134
- // PRUNE
135
- else if (category === "assertPrune")
136
- return misc("assert")(MiscAssertPruneProgrammer.write);
137
- else if (category === "validatePrune")
138
- return misc("validate")(MiscValidatePruneProgrammer.write);
139
- // DEFAULT
140
- return check("validate")(false)(ValidateProgrammer.write);
141
- };
142
- }
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 { LlmSchemaProgrammer } from "typia/lib/programmers/llm/LlmSchemaProgrammer";
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 { ITypiaContext } from "typia/lib/transformers/ITypiaContext";
12
+
13
+ import { INestiaTransformContext } from "../options/INestiaTransformProject";
14
+ import { IRequestBodyValidator } from "../options/IRequestBodyValidator";
15
+
16
+ export namespace TypedBodyProgrammer {
17
+ export const generate = (props: {
18
+ context: INestiaTransformContext;
19
+ modulo: ts.LeftHandSideExpression;
20
+ type: ts.Type;
21
+ }): ts.ObjectLiteralExpression => {
22
+ // VALIDATE TYPE
23
+ JsonMetadataFactory.analyze({
24
+ method: "@nestia.core.TypedBody",
25
+ checker: props.context.checker,
26
+ transformer: props.context.transformer,
27
+ type: props.type,
28
+ validate: props.context.options.llm
29
+ ? LlmSchemaProgrammer.validate({
30
+ model: props.context.options.llm.model,
31
+ config: {
32
+ strict: props.context.options.llm.strict,
33
+ recursive: props.context.options.llm.recursive,
34
+ },
35
+ })
36
+ : undefined,
37
+ });
38
+
39
+ // GENERATE VALIDATION PLAN
40
+ const check =
41
+ (key: IRequestBodyValidator<any>["type"]) =>
42
+ (equals: boolean) =>
43
+ (
44
+ programmer: (next: {
45
+ context: ITypiaContext;
46
+ modulo: ts.LeftHandSideExpression;
47
+ config: {
48
+ equals: boolean;
49
+ guard: boolean;
50
+ };
51
+ type: ts.Type;
52
+ name: string | undefined;
53
+ }) => ts.Expression,
54
+ ) =>
55
+ ts.factory.createObjectLiteralExpression([
56
+ ts.factory.createPropertyAssignment(
57
+ ts.factory.createIdentifier("type"),
58
+ ts.factory.createStringLiteral(key),
59
+ ),
60
+ ts.factory.createPropertyAssignment(
61
+ ts.factory.createIdentifier(key),
62
+ programmer({
63
+ context: {
64
+ ...props.context,
65
+ options: {
66
+ numeric: false,
67
+ finite: false,
68
+ functional: false,
69
+ },
70
+ },
71
+ modulo: props.modulo,
72
+ config: {
73
+ equals,
74
+ guard: false,
75
+ },
76
+ type: props.type,
77
+ name: undefined,
78
+ }),
79
+ ),
80
+ ]);
81
+ const misc =
82
+ (key: IRequestBodyValidator<any>["type"]) =>
83
+ (
84
+ programmer: (next: {
85
+ context: ITypiaContext;
86
+ modulo: ts.LeftHandSideExpression;
87
+ type: ts.Type;
88
+ name: string | undefined;
89
+ }) => ts.Expression,
90
+ ) =>
91
+ ts.factory.createObjectLiteralExpression([
92
+ ts.factory.createPropertyAssignment(
93
+ ts.factory.createIdentifier("type"),
94
+ ts.factory.createStringLiteral(key),
95
+ ),
96
+ ts.factory.createPropertyAssignment(
97
+ ts.factory.createIdentifier(key),
98
+ programmer({
99
+ context: {
100
+ ...props.context,
101
+ options: {
102
+ numeric: false,
103
+ finite: false,
104
+ functional: false,
105
+ },
106
+ },
107
+ modulo: props.modulo,
108
+ type: props.type,
109
+ name: undefined,
110
+ }),
111
+ ),
112
+ ]);
113
+
114
+ //----
115
+ // RETURNS
116
+ //----
117
+ const category = props.context.options.validate;
118
+ // NORMAL
119
+ if (category === "assert")
120
+ return check("assert")(false)(AssertProgrammer.write);
121
+ else if (category === "is") return check("is")(false)(IsProgrammer.write);
122
+ // STRICT
123
+ else if (category === "validateEquals")
124
+ return check("validate")(true)(ValidateProgrammer.write);
125
+ else if (category === "equals")
126
+ return check("is")(true)(IsProgrammer.write);
127
+ else if (category === "assertEquals")
128
+ return check("assert")(true)(AssertProgrammer.write);
129
+ // CLONE
130
+ else if (category === "assertClone")
131
+ return misc("assert")(MiscAssertCloneProgrammer.write);
132
+ else if (category === "validateClone")
133
+ return misc("validate")(MiscValidateCloneProgrammer.write);
134
+ // PRUNE
135
+ else if (category === "assertPrune")
136
+ return misc("assert")(MiscAssertPruneProgrammer.write);
137
+ else if (category === "validatePrune")
138
+ return misc("validate")(MiscValidatePruneProgrammer.write);
139
+ // DEFAULT
140
+ return check("validate")(false)(ValidateProgrammer.write);
141
+ };
142
+ }
@@ -1,118 +1,118 @@
1
- import ts from "typescript";
2
- import { LiteralFactory } from "typia/lib/factories/LiteralFactory";
3
- import { MetadataCollection } from "typia/lib/factories/MetadataCollection";
4
- import { MetadataFactory } from "typia/lib/factories/MetadataFactory";
5
- import { HttpAssertFormDataProgrammer } from "typia/lib/programmers/http/HttpAssertFormDataProgrammer";
6
- import { HttpFormDataProgrammer } from "typia/lib/programmers/http/HttpFormDataProgrammer";
7
- import { HttpIsFormDataProgrammer } from "typia/lib/programmers/http/HttpIsFormDataProgrammer";
8
- import { HttpValidateFormDataProgrammer } from "typia/lib/programmers/http/HttpValidateFormDataProgrammer";
9
- import { Metadata } from "typia/lib/schemas/metadata/Metadata";
10
- import { ITypiaContext } from "typia/lib/transformers/ITypiaContext";
11
- import { TransformerError } from "typia/lib/transformers/TransformerError";
12
-
13
- import { INestiaTransformContext } from "../options/INestiaTransformProject";
14
- import { IRequestFormDataProps } from "../options/IRequestFormDataProps";
15
-
16
- export namespace TypedFormDataBodyProgrammer {
17
- export const generate = (props: {
18
- context: INestiaTransformContext;
19
- modulo: ts.LeftHandSideExpression;
20
- type: ts.Type;
21
- }): ts.ObjectLiteralExpression => {
22
- // VALIDATE TYPE
23
- const collection: MetadataCollection = new MetadataCollection();
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: HttpFormDataProgrammer.validate,
32
- },
33
- type: props.type,
34
- collection,
35
- });
36
- if (result.success === false)
37
- throw TransformerError.from({
38
- code: "nestia.core.TypedFormData.Body",
39
- errors: result.errors,
40
- });
41
-
42
- const files: IRequestFormDataProps.IFile[] =
43
- result.data.objects[0].type.properties
44
- .filter(
45
- (p) =>
46
- isFile(p.value) || p.value.arrays.some((a) => isFile(a.type.value)),
47
- )
48
- .map((p) => ({
49
- name: p.key.constants[0].values[0].value as string,
50
- limit: !!p.value.natives.length ? 1 : null,
51
- }));
52
-
53
- // GENERATE VALIDATION PLAN
54
- const parameter =
55
- (key: IRequestFormDataProps<any>["validator"]["type"]) =>
56
- (
57
- programmer: (next: {
58
- context: ITypiaContext;
59
- modulo: ts.LeftHandSideExpression;
60
- type: ts.Type;
61
- name: string | undefined;
62
- }) => ts.Expression,
63
- ) =>
64
- ts.factory.createObjectLiteralExpression(
65
- [
66
- ts.factory.createPropertyAssignment(
67
- ts.factory.createIdentifier("files"),
68
- LiteralFactory.write(files),
69
- ),
70
- ts.factory.createPropertyAssignment(
71
- ts.factory.createIdentifier("validator"),
72
- ts.factory.createObjectLiteralExpression(
73
- [
74
- ts.factory.createPropertyAssignment(
75
- ts.factory.createIdentifier("type"),
76
- ts.factory.createStringLiteral(key),
77
- ),
78
- ts.factory.createPropertyAssignment(
79
- ts.factory.createIdentifier(key),
80
- programmer({
81
- context: {
82
- ...props.context,
83
- options: {
84
- numeric: false,
85
- finite: false,
86
- functional: false,
87
- },
88
- },
89
- modulo: props.modulo,
90
- type: props.type,
91
- name: undefined,
92
- }),
93
- ),
94
- ],
95
- true,
96
- ),
97
- ),
98
- ],
99
- true,
100
- );
101
-
102
- // RETURNS
103
- const category = props.context.options.validate;
104
- if (category === "is" || category === "equals")
105
- return parameter("is")(HttpIsFormDataProgrammer.write);
106
- else if (
107
- category === "validate" ||
108
- category === "validateEquals" ||
109
- category === "validateClone" ||
110
- category === "validatePrune"
111
- )
112
- return parameter("validate")(HttpValidateFormDataProgrammer.write);
113
- return parameter("assert")(HttpAssertFormDataProgrammer.write);
114
- };
115
- }
116
-
117
- const isFile = (meta: Metadata) =>
118
- meta.natives.some(({ name }) => name === "File" || name === "Blob");
1
+ import ts from "typescript";
2
+ import { LiteralFactory } from "typia/lib/factories/LiteralFactory";
3
+ import { MetadataCollection } from "typia/lib/factories/MetadataCollection";
4
+ import { MetadataFactory } from "typia/lib/factories/MetadataFactory";
5
+ import { HttpAssertFormDataProgrammer } from "typia/lib/programmers/http/HttpAssertFormDataProgrammer";
6
+ import { HttpFormDataProgrammer } from "typia/lib/programmers/http/HttpFormDataProgrammer";
7
+ import { HttpIsFormDataProgrammer } from "typia/lib/programmers/http/HttpIsFormDataProgrammer";
8
+ import { HttpValidateFormDataProgrammer } from "typia/lib/programmers/http/HttpValidateFormDataProgrammer";
9
+ import { Metadata } from "typia/lib/schemas/metadata/Metadata";
10
+ import { ITypiaContext } from "typia/lib/transformers/ITypiaContext";
11
+ import { TransformerError } from "typia/lib/transformers/TransformerError";
12
+
13
+ import { INestiaTransformContext } from "../options/INestiaTransformProject";
14
+ import { IRequestFormDataProps } from "../options/IRequestFormDataProps";
15
+
16
+ export namespace TypedFormDataBodyProgrammer {
17
+ export const generate = (props: {
18
+ context: INestiaTransformContext;
19
+ modulo: ts.LeftHandSideExpression;
20
+ type: ts.Type;
21
+ }): ts.ObjectLiteralExpression => {
22
+ // VALIDATE TYPE
23
+ const collection: MetadataCollection = new MetadataCollection();
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: HttpFormDataProgrammer.validate,
32
+ },
33
+ type: props.type,
34
+ collection,
35
+ });
36
+ if (result.success === false)
37
+ throw TransformerError.from({
38
+ code: "nestia.core.TypedFormData.Body",
39
+ errors: result.errors,
40
+ });
41
+
42
+ const files: IRequestFormDataProps.IFile[] =
43
+ result.data.objects[0].type.properties
44
+ .filter(
45
+ (p) =>
46
+ isFile(p.value) || p.value.arrays.some((a) => isFile(a.type.value)),
47
+ )
48
+ .map((p) => ({
49
+ name: p.key.constants[0].values[0].value as string,
50
+ limit: !!p.value.natives.length ? 1 : null,
51
+ }));
52
+
53
+ // GENERATE VALIDATION PLAN
54
+ const parameter =
55
+ (key: IRequestFormDataProps<any>["validator"]["type"]) =>
56
+ (
57
+ programmer: (next: {
58
+ context: ITypiaContext;
59
+ modulo: ts.LeftHandSideExpression;
60
+ type: ts.Type;
61
+ name: string | undefined;
62
+ }) => ts.Expression,
63
+ ) =>
64
+ ts.factory.createObjectLiteralExpression(
65
+ [
66
+ ts.factory.createPropertyAssignment(
67
+ ts.factory.createIdentifier("files"),
68
+ LiteralFactory.write(files),
69
+ ),
70
+ ts.factory.createPropertyAssignment(
71
+ ts.factory.createIdentifier("validator"),
72
+ ts.factory.createObjectLiteralExpression(
73
+ [
74
+ ts.factory.createPropertyAssignment(
75
+ ts.factory.createIdentifier("type"),
76
+ ts.factory.createStringLiteral(key),
77
+ ),
78
+ ts.factory.createPropertyAssignment(
79
+ ts.factory.createIdentifier(key),
80
+ programmer({
81
+ context: {
82
+ ...props.context,
83
+ options: {
84
+ numeric: false,
85
+ finite: false,
86
+ functional: false,
87
+ },
88
+ },
89
+ modulo: props.modulo,
90
+ type: props.type,
91
+ name: undefined,
92
+ }),
93
+ ),
94
+ ],
95
+ true,
96
+ ),
97
+ ),
98
+ ],
99
+ true,
100
+ );
101
+
102
+ // RETURNS
103
+ const category = props.context.options.validate;
104
+ if (category === "is" || category === "equals")
105
+ return parameter("is")(HttpIsFormDataProgrammer.write);
106
+ else if (
107
+ category === "validate" ||
108
+ category === "validateEquals" ||
109
+ category === "validateClone" ||
110
+ category === "validatePrune"
111
+ )
112
+ return parameter("validate")(HttpValidateFormDataProgrammer.write);
113
+ return parameter("assert")(HttpAssertFormDataProgrammer.write);
114
+ };
115
+ }
116
+
117
+ const isFile = (meta: Metadata) =>
118
+ meta.natives.some(({ name }) => name === "File" || name === "Blob");
@@ -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
+ }