@baseplate-dev/fastify-generators 0.5.3 → 0.6.1
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/CHANGELOG.md +70 -0
- package/dist/constants/fastify-packages.d.ts +14 -14
- package/dist/constants/fastify-packages.js +14 -14
- package/dist/constants/fastify-packages.js.map +1 -1
- package/dist/generators/auth/auth-context/templates/module/types/auth-context.types.ts +1 -0
- package/dist/generators/auth/auth-context/templates/module/utils/auth-context.utils.ts +3 -1
- package/dist/generators/core/fastify/fastify.generator.d.ts.map +1 -1
- package/dist/generators/core/fastify/fastify.generator.js +3 -1
- package/dist/generators/core/fastify/fastify.generator.js.map +1 -1
- package/dist/generators/pothos/index.d.ts +1 -0
- package/dist/generators/pothos/index.d.ts.map +1 -1
- package/dist/generators/pothos/index.js +1 -0
- package/dist/generators/pothos/index.js.map +1 -1
- package/dist/generators/pothos/pothos-auth/pothos-auth.generator.d.ts +5 -0
- package/dist/generators/pothos/pothos-auth/pothos-auth.generator.d.ts.map +1 -1
- package/dist/generators/pothos/pothos-auth/pothos-auth.generator.js +8 -0
- package/dist/generators/pothos/pothos-auth/pothos-auth.generator.js.map +1 -1
- package/dist/generators/pothos/pothos-prisma-count-query/index.d.ts +2 -0
- package/dist/generators/pothos/pothos-prisma-count-query/index.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-prisma-count-query/index.js +2 -0
- package/dist/generators/pothos/pothos-prisma-count-query/index.js.map +1 -0
- package/dist/generators/pothos/pothos-prisma-count-query/pothos-prisma-count-query.generator.d.ts +16 -0
- package/dist/generators/pothos/pothos-prisma-count-query/pothos-prisma-count-query.generator.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-prisma-count-query/pothos-prisma-count-query.generator.js +104 -0
- package/dist/generators/pothos/pothos-prisma-count-query/pothos-prisma-count-query.generator.js.map +1 -0
- package/dist/generators/pothos/pothos-prisma-crud-mutation/pothos-prisma-crud-mutation.generator.d.ts.map +1 -1
- package/dist/generators/pothos/pothos-prisma-crud-mutation/pothos-prisma-crud-mutation.generator.js +2 -5
- package/dist/generators/pothos/pothos-prisma-crud-mutation/pothos-prisma-crud-mutation.generator.js.map +1 -1
- package/dist/generators/pothos/pothos-prisma-find-query/pothos-prisma-find-query.generator.d.ts +4 -0
- package/dist/generators/pothos/pothos-prisma-find-query/pothos-prisma-find-query.generator.d.ts.map +1 -1
- package/dist/generators/pothos/pothos-prisma-find-query/pothos-prisma-find-query.generator.js +52 -10
- package/dist/generators/pothos/pothos-prisma-find-query/pothos-prisma-find-query.generator.js.map +1 -1
- package/dist/generators/pothos/pothos-prisma-list-query/pothos-prisma-list-query.generator.d.ts +4 -0
- package/dist/generators/pothos/pothos-prisma-list-query/pothos-prisma-list-query.generator.d.ts.map +1 -1
- package/dist/generators/pothos/pothos-prisma-list-query/pothos-prisma-list-query.generator.js +39 -3
- package/dist/generators/pothos/pothos-prisma-list-query/pothos-prisma-list-query.generator.js.map +1 -1
- package/dist/generators/pothos/pothos-prisma-object/pothos-prisma-object.generator.d.ts +7 -1
- package/dist/generators/pothos/pothos-prisma-object/pothos-prisma-object.generator.d.ts.map +1 -1
- package/dist/generators/pothos/pothos-prisma-object/pothos-prisma-object.generator.js +73 -13
- package/dist/generators/pothos/pothos-prisma-object/pothos-prisma-object.generator.js.map +1 -1
- package/dist/generators/prisma/_shared/build-data-helpers/generate-authorize-fragment.d.ts +20 -0
- package/dist/generators/prisma/_shared/build-data-helpers/generate-authorize-fragment.d.ts.map +1 -0
- package/dist/generators/prisma/_shared/build-data-helpers/generate-authorize-fragment.js +28 -0
- package/dist/generators/prisma/_shared/build-data-helpers/generate-authorize-fragment.js.map +1 -0
- package/dist/generators/prisma/_shared/build-data-helpers/generate-operation-callbacks.d.ts +48 -55
- package/dist/generators/prisma/_shared/build-data-helpers/generate-operation-callbacks.d.ts.map +1 -1
- package/dist/generators/prisma/_shared/build-data-helpers/generate-operation-callbacks.js +130 -67
- package/dist/generators/prisma/_shared/build-data-helpers/generate-operation-callbacks.js.map +1 -1
- package/dist/generators/prisma/_shared/build-data-helpers/generate-relation-build-data.d.ts +2 -0
- package/dist/generators/prisma/_shared/build-data-helpers/generate-relation-build-data.d.ts.map +1 -1
- package/dist/generators/prisma/_shared/build-data-helpers/generate-relation-build-data.js +3 -3
- package/dist/generators/prisma/_shared/build-data-helpers/generate-relation-build-data.js.map +1 -1
- package/dist/generators/prisma/_shared/build-data-helpers/index.d.ts +1 -0
- package/dist/generators/prisma/_shared/build-data-helpers/index.d.ts.map +1 -1
- package/dist/generators/prisma/_shared/build-data-helpers/index.js +1 -0
- package/dist/generators/prisma/_shared/build-data-helpers/index.js.map +1 -1
- package/dist/generators/prisma/data-utils/data-utils.generator.d.ts +25 -6
- package/dist/generators/prisma/data-utils/data-utils.generator.d.ts.map +1 -1
- package/dist/generators/prisma/data-utils/generated/index.d.ts +78 -23
- package/dist/generators/prisma/data-utils/generated/index.d.ts.map +1 -1
- package/dist/generators/prisma/data-utils/generated/template-paths.d.ts +3 -1
- package/dist/generators/prisma/data-utils/generated/template-paths.d.ts.map +1 -1
- package/dist/generators/prisma/data-utils/generated/template-paths.js +3 -1
- package/dist/generators/prisma/data-utils/generated/template-paths.js.map +1 -1
- package/dist/generators/prisma/data-utils/generated/ts-import-providers.d.ts +75 -18
- package/dist/generators/prisma/data-utils/generated/ts-import-providers.d.ts.map +1 -1
- package/dist/generators/prisma/data-utils/generated/ts-import-providers.js +26 -8
- package/dist/generators/prisma/data-utils/generated/ts-import-providers.js.map +1 -1
- package/dist/generators/prisma/data-utils/generated/typed-templates.d.ts +106 -34
- package/dist/generators/prisma/data-utils/generated/typed-templates.d.ts.map +1 -1
- package/dist/generators/prisma/data-utils/generated/typed-templates.js +61 -14
- package/dist/generators/prisma/data-utils/generated/typed-templates.js.map +1 -1
- package/dist/generators/prisma/data-utils/templates/src/utils/data-operations/commit-operations.ts +366 -0
- package/dist/generators/prisma/data-utils/templates/src/utils/data-operations/compose-operations.ts +131 -0
- package/dist/generators/prisma/data-utils/templates/src/utils/data-operations/field-definitions.ts +26 -30
- package/dist/generators/prisma/data-utils/templates/src/utils/data-operations/field-utils.ts +201 -0
- package/dist/generators/prisma/data-utils/templates/src/utils/data-operations/prisma-types.ts +24 -20
- package/dist/generators/prisma/data-utils/templates/src/utils/data-operations/prisma-utils.ts +14 -6
- package/dist/generators/prisma/data-utils/templates/src/utils/data-operations/relation-helpers.ts +21 -26
- package/dist/generators/prisma/data-utils/templates/src/utils/data-operations/types.ts +374 -25
- package/dist/generators/prisma/index.d.ts +2 -0
- package/dist/generators/prisma/index.d.ts.map +1 -1
- package/dist/generators/prisma/index.js +2 -0
- package/dist/generators/prisma/index.js.map +1 -1
- package/dist/generators/prisma/prisma-authorizer-utils/generated/index.d.ts +50 -12
- package/dist/generators/prisma/prisma-authorizer-utils/generated/index.d.ts.map +1 -1
- package/dist/generators/prisma/prisma-authorizer-utils/generated/template-renderers.d.ts +25 -6
- package/dist/generators/prisma/prisma-authorizer-utils/generated/template-renderers.d.ts.map +1 -1
- package/dist/generators/prisma/prisma-authorizer-utils/generated/typed-templates.d.ts +50 -12
- package/dist/generators/prisma/prisma-authorizer-utils/generated/typed-templates.d.ts.map +1 -1
- package/dist/generators/prisma/prisma-authorizer-utils/prisma-authorizer-utils.generator.d.ts +25 -6
- package/dist/generators/prisma/prisma-authorizer-utils/prisma-authorizer-utils.generator.d.ts.map +1 -1
- package/dist/generators/prisma/prisma-data-create/prisma-data-create.generator.d.ts +26 -6
- package/dist/generators/prisma/prisma-data-create/prisma-data-create.generator.d.ts.map +1 -1
- package/dist/generators/prisma/prisma-data-create/prisma-data-create.generator.js +53 -25
- package/dist/generators/prisma/prisma-data-create/prisma-data-create.generator.js.map +1 -1
- package/dist/generators/prisma/prisma-data-delete/prisma-data-delete.generator.d.ts +31 -6
- package/dist/generators/prisma/prisma-data-delete/prisma-data-delete.generator.d.ts.map +1 -1
- package/dist/generators/prisma/prisma-data-delete/prisma-data-delete.generator.js +52 -15
- package/dist/generators/prisma/prisma-data-delete/prisma-data-delete.generator.js.map +1 -1
- package/dist/generators/prisma/prisma-data-nested-field/prisma-data-nested-field.generator.d.ts +25 -6
- package/dist/generators/prisma/prisma-data-nested-field/prisma-data-nested-field.generator.d.ts.map +1 -1
- package/dist/generators/prisma/prisma-data-service/prisma-data-service.generator.d.ts +25 -6
- package/dist/generators/prisma/prisma-data-service/prisma-data-service.generator.d.ts.map +1 -1
- package/dist/generators/prisma/prisma-data-update/prisma-data-update.generator.d.ts +31 -6
- package/dist/generators/prisma/prisma-data-update/prisma-data-update.generator.d.ts.map +1 -1
- package/dist/generators/prisma/prisma-data-update/prisma-data-update.generator.js +65 -23
- package/dist/generators/prisma/prisma-data-update/prisma-data-update.generator.js.map +1 -1
- package/dist/generators/prisma/prisma-model-authorizer/prisma-model-authorizer.generator.d.ts +2 -0
- package/dist/generators/prisma/prisma-model-authorizer/prisma-model-authorizer.generator.d.ts.map +1 -1
- package/dist/generators/prisma/prisma-model-authorizer/prisma-model-authorizer.generator.js +86 -53
- package/dist/generators/prisma/prisma-model-authorizer/prisma-model-authorizer.generator.js.map +1 -1
- package/dist/generators/prisma/prisma-model-query-filter/index.d.ts +2 -0
- package/dist/generators/prisma/prisma-model-query-filter/index.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-model-query-filter/index.js +2 -0
- package/dist/generators/prisma/prisma-model-query-filter/index.js.map +1 -0
- package/dist/generators/prisma/prisma-model-query-filter/prisma-model-query-filter.generator.d.ts +60 -0
- package/dist/generators/prisma/prisma-model-query-filter/prisma-model-query-filter.generator.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-model-query-filter/prisma-model-query-filter.generator.js +124 -0
- package/dist/generators/prisma/prisma-model-query-filter/prisma-model-query-filter.generator.js.map +1 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/index.d.ts +364 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/index.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/index.js +13 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/index.js.map +1 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/template-paths.d.ts +13 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/template-paths.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/template-paths.js +25 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/template-paths.js.map +1 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/template-renderers.d.ts +131 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/template-renderers.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/template-renderers.js +49 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/template-renderers.js.map +1 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/ts-import-providers.d.ts +66 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/ts-import-providers.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/ts-import-providers.js +40 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/ts-import-providers.js.map +1 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/typed-templates.d.ts +411 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/typed-templates.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/typed-templates.js +46 -0
- package/dist/generators/prisma/prisma-query-filter-utils/generated/typed-templates.js.map +1 -0
- package/dist/generators/prisma/prisma-query-filter-utils/index.d.ts +4 -0
- package/dist/generators/prisma/prisma-query-filter-utils/index.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-query-filter-utils/index.js +3 -0
- package/dist/generators/prisma/prisma-query-filter-utils/index.js.map +1 -0
- package/dist/generators/prisma/prisma-query-filter-utils/prisma-query-filter-utils.generator.d.ts +156 -0
- package/dist/generators/prisma/prisma-query-filter-utils/prisma-query-filter-utils.generator.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-query-filter-utils/prisma-query-filter-utils.generator.js +32 -0
- package/dist/generators/prisma/prisma-query-filter-utils/prisma-query-filter-utils.generator.js.map +1 -0
- package/dist/generators/prisma/prisma-query-filter-utils/templates/src/utils/query-filters.ts +209 -0
- package/dist/generators/prisma/prisma-query-filter-utils/templates/src/utils/query-helpers.ts +70 -0
- package/dist/generators/vitest/prisma-vitest/generated/index.d.ts +0 -6
- package/dist/generators/vitest/prisma-vitest/generated/index.d.ts.map +1 -1
- package/dist/generators/vitest/prisma-vitest/generated/template-renderers.d.ts.map +1 -1
- package/dist/generators/vitest/prisma-vitest/generated/template-renderers.js +0 -1
- package/dist/generators/vitest/prisma-vitest/generated/template-renderers.js.map +1 -1
- package/dist/generators/vitest/prisma-vitest/generated/typed-templates.d.ts +0 -6
- package/dist/generators/vitest/prisma-vitest/generated/typed-templates.d.ts.map +1 -1
- package/dist/generators/vitest/prisma-vitest/generated/typed-templates.js +1 -4
- package/dist/generators/vitest/prisma-vitest/generated/typed-templates.js.map +1 -1
- package/dist/generators/vitest/prisma-vitest/templates/src/tests/helpers/prisma.test-helper.ts +2 -10
- package/dist/types/service-dto-kinds.d.ts +0 -6
- package/dist/types/service-dto-kinds.d.ts.map +1 -1
- package/dist/types/service-dto-kinds.js +0 -6
- package/dist/types/service-dto-kinds.js.map +1 -1
- package/dist/writers/pothos/helpers.d.ts +1 -0
- package/dist/writers/pothos/helpers.d.ts.map +1 -1
- package/dist/writers/pothos/helpers.js +1 -0
- package/dist/writers/pothos/helpers.js.map +1 -1
- package/dist/writers/pothos/scalar-fields.d.ts +3 -1
- package/dist/writers/pothos/scalar-fields.d.ts.map +1 -1
- package/dist/writers/pothos/scalar-fields.js +1 -0
- package/dist/writers/pothos/scalar-fields.js.map +1 -1
- package/dist/writers/prisma-schema/fields.d.ts +1 -1
- package/dist/writers/prisma-schema/fields.js +2 -2
- package/dist/writers/prisma-schema/fields.js.map +1 -1
- package/package.json +8 -8
- package/dist/generators/prisma/data-utils/templates/src/utils/data-operations/define-operations.ts +0 -1134
|
@@ -18,13 +18,24 @@ export declare const mainGroup: {
|
|
|
18
18
|
AnyOperationHooks: {
|
|
19
19
|
isTypeOnly: true;
|
|
20
20
|
};
|
|
21
|
+
commitCreate: {};
|
|
22
|
+
commitDelete: {};
|
|
23
|
+
commitUpdate: {};
|
|
24
|
+
composeCreate: {};
|
|
25
|
+
composeUpdate: {};
|
|
21
26
|
createParentModelConfig: {};
|
|
27
|
+
DataCreateInput: {
|
|
28
|
+
isTypeOnly: true;
|
|
29
|
+
};
|
|
30
|
+
DataDeleteInput: {
|
|
31
|
+
isTypeOnly: true;
|
|
32
|
+
};
|
|
22
33
|
DataOperationType: {
|
|
23
34
|
isTypeOnly: true;
|
|
24
35
|
};
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
36
|
+
DataUpdateInput: {
|
|
37
|
+
isTypeOnly: true;
|
|
38
|
+
};
|
|
28
39
|
FieldContext: {
|
|
29
40
|
isTypeOnly: true;
|
|
30
41
|
};
|
|
@@ -37,6 +48,8 @@ export declare const mainGroup: {
|
|
|
37
48
|
FieldTransformResult: {
|
|
38
49
|
isTypeOnly: true;
|
|
39
50
|
};
|
|
51
|
+
generateCreateSchema: {};
|
|
52
|
+
generateUpdateSchema: {};
|
|
40
53
|
GetPayload: {
|
|
41
54
|
isTypeOnly: true;
|
|
42
55
|
};
|
|
@@ -46,6 +59,9 @@ export declare const mainGroup: {
|
|
|
46
59
|
InferInput: {
|
|
47
60
|
isTypeOnly: true;
|
|
48
61
|
};
|
|
62
|
+
ModelInclude: {
|
|
63
|
+
isTypeOnly: true;
|
|
64
|
+
};
|
|
49
65
|
ModelPropName: {
|
|
50
66
|
isTypeOnly: true;
|
|
51
67
|
};
|
|
@@ -66,14 +82,17 @@ export declare const mainGroup: {
|
|
|
66
82
|
ParentModelConfig: {
|
|
67
83
|
isTypeOnly: true;
|
|
68
84
|
};
|
|
69
|
-
PrismaTransaction: {
|
|
70
|
-
isTypeOnly: true;
|
|
71
|
-
};
|
|
72
85
|
relationHelpers: {};
|
|
73
86
|
scalarField: {};
|
|
74
87
|
TransactionalOperationContext: {
|
|
75
88
|
isTypeOnly: true;
|
|
76
89
|
};
|
|
90
|
+
WhereInput: {
|
|
91
|
+
isTypeOnly: true;
|
|
92
|
+
};
|
|
93
|
+
WhereUniqueInput: {
|
|
94
|
+
isTypeOnly: true;
|
|
95
|
+
};
|
|
77
96
|
}>>;
|
|
78
97
|
errorHandlerServiceImports: import("@baseplate-dev/sync").ProviderType<import("@baseplate-dev/core-generators").InferTsImportMapFromSchema<{
|
|
79
98
|
BadRequestError: {};
|
|
@@ -117,13 +136,24 @@ export declare const PRISMA_PRISMA_AUTHORIZER_UTILS_TEMPLATES: {
|
|
|
117
136
|
AnyOperationHooks: {
|
|
118
137
|
isTypeOnly: true;
|
|
119
138
|
};
|
|
139
|
+
commitCreate: {};
|
|
140
|
+
commitDelete: {};
|
|
141
|
+
commitUpdate: {};
|
|
142
|
+
composeCreate: {};
|
|
143
|
+
composeUpdate: {};
|
|
120
144
|
createParentModelConfig: {};
|
|
145
|
+
DataCreateInput: {
|
|
146
|
+
isTypeOnly: true;
|
|
147
|
+
};
|
|
148
|
+
DataDeleteInput: {
|
|
149
|
+
isTypeOnly: true;
|
|
150
|
+
};
|
|
121
151
|
DataOperationType: {
|
|
122
152
|
isTypeOnly: true;
|
|
123
153
|
};
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
154
|
+
DataUpdateInput: {
|
|
155
|
+
isTypeOnly: true;
|
|
156
|
+
};
|
|
127
157
|
FieldContext: {
|
|
128
158
|
isTypeOnly: true;
|
|
129
159
|
};
|
|
@@ -136,6 +166,8 @@ export declare const PRISMA_PRISMA_AUTHORIZER_UTILS_TEMPLATES: {
|
|
|
136
166
|
FieldTransformResult: {
|
|
137
167
|
isTypeOnly: true;
|
|
138
168
|
};
|
|
169
|
+
generateCreateSchema: {};
|
|
170
|
+
generateUpdateSchema: {};
|
|
139
171
|
GetPayload: {
|
|
140
172
|
isTypeOnly: true;
|
|
141
173
|
};
|
|
@@ -145,6 +177,9 @@ export declare const PRISMA_PRISMA_AUTHORIZER_UTILS_TEMPLATES: {
|
|
|
145
177
|
InferInput: {
|
|
146
178
|
isTypeOnly: true;
|
|
147
179
|
};
|
|
180
|
+
ModelInclude: {
|
|
181
|
+
isTypeOnly: true;
|
|
182
|
+
};
|
|
148
183
|
ModelPropName: {
|
|
149
184
|
isTypeOnly: true;
|
|
150
185
|
};
|
|
@@ -165,14 +200,17 @@ export declare const PRISMA_PRISMA_AUTHORIZER_UTILS_TEMPLATES: {
|
|
|
165
200
|
ParentModelConfig: {
|
|
166
201
|
isTypeOnly: true;
|
|
167
202
|
};
|
|
168
|
-
PrismaTransaction: {
|
|
169
|
-
isTypeOnly: true;
|
|
170
|
-
};
|
|
171
203
|
relationHelpers: {};
|
|
172
204
|
scalarField: {};
|
|
173
205
|
TransactionalOperationContext: {
|
|
174
206
|
isTypeOnly: true;
|
|
175
207
|
};
|
|
208
|
+
WhereInput: {
|
|
209
|
+
isTypeOnly: true;
|
|
210
|
+
};
|
|
211
|
+
WhereUniqueInput: {
|
|
212
|
+
isTypeOnly: true;
|
|
213
|
+
};
|
|
176
214
|
}>>;
|
|
177
215
|
errorHandlerServiceImports: import("@baseplate-dev/sync").ProviderType<import("@baseplate-dev/core-generators").InferTsImportMapFromSchema<{
|
|
178
216
|
BadRequestError: {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"typed-templates.d.ts","sourceRoot":"","sources":["../../../../../src/generators/prisma/prisma-authorizer-utils/generated/typed-templates.ts"],"names":[],"mappings":"AAoCA,eAAO,MAAM,SAAS
|
|
1
|
+
{"version":3,"file":"typed-templates.d.ts","sourceRoot":"","sources":["../../../../../src/generators/prisma/prisma-authorizer-utils/generated/typed-templates.ts"],"names":[],"mappings":"AAoCA,eAAO,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAAuB,CAAC;AAE9C,eAAO,MAAM,wCAAwC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAAgB,CAAC"}
|
package/dist/generators/prisma/prisma-authorizer-utils/prisma-authorizer-utils.generator.d.ts
CHANGED
|
@@ -51,13 +51,24 @@ export declare const prismaAuthorizerUtilsGenerator: import("@baseplate-dev/sync
|
|
|
51
51
|
AnyOperationHooks: {
|
|
52
52
|
isTypeOnly: true;
|
|
53
53
|
};
|
|
54
|
+
commitCreate: {};
|
|
55
|
+
commitDelete: {};
|
|
56
|
+
commitUpdate: {};
|
|
57
|
+
composeCreate: {};
|
|
58
|
+
composeUpdate: {};
|
|
54
59
|
createParentModelConfig: {};
|
|
60
|
+
DataCreateInput: {
|
|
61
|
+
isTypeOnly: true;
|
|
62
|
+
};
|
|
63
|
+
DataDeleteInput: {
|
|
64
|
+
isTypeOnly: true;
|
|
65
|
+
};
|
|
55
66
|
DataOperationType: {
|
|
56
67
|
isTypeOnly: true;
|
|
57
68
|
};
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
69
|
+
DataUpdateInput: {
|
|
70
|
+
isTypeOnly: true;
|
|
71
|
+
};
|
|
61
72
|
FieldContext: {
|
|
62
73
|
isTypeOnly: true;
|
|
63
74
|
};
|
|
@@ -70,6 +81,8 @@ export declare const prismaAuthorizerUtilsGenerator: import("@baseplate-dev/sync
|
|
|
70
81
|
FieldTransformResult: {
|
|
71
82
|
isTypeOnly: true;
|
|
72
83
|
};
|
|
84
|
+
generateCreateSchema: {};
|
|
85
|
+
generateUpdateSchema: {};
|
|
73
86
|
GetPayload: {
|
|
74
87
|
isTypeOnly: true;
|
|
75
88
|
};
|
|
@@ -79,6 +92,9 @@ export declare const prismaAuthorizerUtilsGenerator: import("@baseplate-dev/sync
|
|
|
79
92
|
InferInput: {
|
|
80
93
|
isTypeOnly: true;
|
|
81
94
|
};
|
|
95
|
+
ModelInclude: {
|
|
96
|
+
isTypeOnly: true;
|
|
97
|
+
};
|
|
82
98
|
ModelPropName: {
|
|
83
99
|
isTypeOnly: true;
|
|
84
100
|
};
|
|
@@ -99,14 +115,17 @@ export declare const prismaAuthorizerUtilsGenerator: import("@baseplate-dev/sync
|
|
|
99
115
|
ParentModelConfig: {
|
|
100
116
|
isTypeOnly: true;
|
|
101
117
|
};
|
|
102
|
-
PrismaTransaction: {
|
|
103
|
-
isTypeOnly: true;
|
|
104
|
-
};
|
|
105
118
|
relationHelpers: {};
|
|
106
119
|
scalarField: {};
|
|
107
120
|
TransactionalOperationContext: {
|
|
108
121
|
isTypeOnly: true;
|
|
109
122
|
};
|
|
123
|
+
WhereInput: {
|
|
124
|
+
isTypeOnly: true;
|
|
125
|
+
};
|
|
126
|
+
WhereUniqueInput: {
|
|
127
|
+
isTypeOnly: true;
|
|
128
|
+
};
|
|
110
129
|
}>>;
|
|
111
130
|
errorHandlerServiceImports: import("@baseplate-dev/sync").ProviderType<import("@baseplate-dev/core-generators").InferTsImportMapFromSchema<{
|
|
112
131
|
BadRequestError: {};
|
package/dist/generators/prisma/prisma-authorizer-utils/prisma-authorizer-utils.generator.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prisma-authorizer-utils.generator.d.ts","sourceRoot":"","sources":["../../../../src/generators/prisma/prisma-authorizer-utils/prisma-authorizer-utils.generator.ts"],"names":[],"mappings":"AAUA;;GAEG;AACH,eAAO,MAAM,8BAA8B
|
|
1
|
+
{"version":3,"file":"prisma-authorizer-utils.generator.d.ts","sourceRoot":"","sources":["../../../../src/generators/prisma/prisma-authorizer-utils/prisma-authorizer-utils.generator.ts"],"names":[],"mappings":"AAUA;;GAEG;AACH,eAAO,MAAM,8BAA8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAwCzC,CAAC"}
|
|
@@ -5,6 +5,7 @@ export declare const prismaDataCreateGenerator: import("@baseplate-dev/sync").Ge
|
|
|
5
5
|
name: string;
|
|
6
6
|
modelName: string;
|
|
7
7
|
fields: string[];
|
|
8
|
+
globalRoles?: string[] | undefined;
|
|
8
9
|
}, {
|
|
9
10
|
main: import("@baseplate-dev/sync").GeneratorTask<any, {
|
|
10
11
|
serviceFile: import("@baseplate-dev/sync").ProviderType<import("#src/generators/core/index.js").ServiceFileProvider>;
|
|
@@ -16,13 +17,24 @@ export declare const prismaDataCreateGenerator: import("@baseplate-dev/sync").Ge
|
|
|
16
17
|
AnyOperationHooks: {
|
|
17
18
|
isTypeOnly: true;
|
|
18
19
|
};
|
|
20
|
+
commitCreate: {};
|
|
21
|
+
commitDelete: {};
|
|
22
|
+
commitUpdate: {};
|
|
23
|
+
composeCreate: {};
|
|
24
|
+
composeUpdate: {};
|
|
19
25
|
createParentModelConfig: {};
|
|
26
|
+
DataCreateInput: {
|
|
27
|
+
isTypeOnly: true;
|
|
28
|
+
};
|
|
29
|
+
DataDeleteInput: {
|
|
30
|
+
isTypeOnly: true;
|
|
31
|
+
};
|
|
20
32
|
DataOperationType: {
|
|
21
33
|
isTypeOnly: true;
|
|
22
34
|
};
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
35
|
+
DataUpdateInput: {
|
|
36
|
+
isTypeOnly: true;
|
|
37
|
+
};
|
|
26
38
|
FieldContext: {
|
|
27
39
|
isTypeOnly: true;
|
|
28
40
|
};
|
|
@@ -35,6 +47,8 @@ export declare const prismaDataCreateGenerator: import("@baseplate-dev/sync").Ge
|
|
|
35
47
|
FieldTransformResult: {
|
|
36
48
|
isTypeOnly: true;
|
|
37
49
|
};
|
|
50
|
+
generateCreateSchema: {};
|
|
51
|
+
generateUpdateSchema: {};
|
|
38
52
|
GetPayload: {
|
|
39
53
|
isTypeOnly: true;
|
|
40
54
|
};
|
|
@@ -44,6 +58,9 @@ export declare const prismaDataCreateGenerator: import("@baseplate-dev/sync").Ge
|
|
|
44
58
|
InferInput: {
|
|
45
59
|
isTypeOnly: true;
|
|
46
60
|
};
|
|
61
|
+
ModelInclude: {
|
|
62
|
+
isTypeOnly: true;
|
|
63
|
+
};
|
|
47
64
|
ModelPropName: {
|
|
48
65
|
isTypeOnly: true;
|
|
49
66
|
};
|
|
@@ -64,14 +81,17 @@ export declare const prismaDataCreateGenerator: import("@baseplate-dev/sync").Ge
|
|
|
64
81
|
ParentModelConfig: {
|
|
65
82
|
isTypeOnly: true;
|
|
66
83
|
};
|
|
67
|
-
PrismaTransaction: {
|
|
68
|
-
isTypeOnly: true;
|
|
69
|
-
};
|
|
70
84
|
relationHelpers: {};
|
|
71
85
|
scalarField: {};
|
|
72
86
|
TransactionalOperationContext: {
|
|
73
87
|
isTypeOnly: true;
|
|
74
88
|
};
|
|
89
|
+
WhereInput: {
|
|
90
|
+
isTypeOnly: true;
|
|
91
|
+
};
|
|
92
|
+
WhereUniqueInput: {
|
|
93
|
+
isTypeOnly: true;
|
|
94
|
+
};
|
|
75
95
|
}>>;
|
|
76
96
|
prismaOutput: import("@baseplate-dev/sync").ProviderType<import("../prisma/prisma.generator.js").PrismaOutputProvider>;
|
|
77
97
|
}, any>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prisma-data-create.generator.d.ts","sourceRoot":"","sources":["../../../../src/generators/prisma/prisma-data-create/prisma-data-create.generator.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"prisma-data-create.generator.d.ts","sourceRoot":"","sources":["../../../../src/generators/prisma/prisma-data-create/prisma-data-create.generator.ts"],"names":[],"mappings":"AAoCA;;GAEG;AACH,eAAO,MAAM,yBAAyB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAuIpC,CAAC"}
|
|
@@ -3,10 +3,9 @@ import { createGenerator, createGeneratorTask } from '@baseplate-dev/sync';
|
|
|
3
3
|
import { lowercaseFirstChar, quot, uppercaseFirstChar, } from '@baseplate-dev/utils';
|
|
4
4
|
import { z } from 'zod';
|
|
5
5
|
import { serviceFileProvider } from '#src/generators/core/index.js';
|
|
6
|
-
import { contextKind, prismaQueryKind
|
|
6
|
+
import { contextKind, prismaQueryKind } from '#src/types/service-dto-kinds.js';
|
|
7
7
|
import { createServiceOutputDtoInjectedArg, prismaToServiceOutputDto, } from '#src/types/service-output.js';
|
|
8
|
-
import {
|
|
9
|
-
import { generateGetWhereUniqueFragment } from '../_shared/crud-method/primary-key-input.js';
|
|
8
|
+
import { generateAuthorizeFragment, generateCreateExecuteCallback, } from '../_shared/build-data-helpers/index.js';
|
|
10
9
|
import { dataUtilsImportsProvider } from '../data-utils/index.js';
|
|
11
10
|
import { prismaDataServiceProvider } from '../prisma-data-service/prisma-data-service.generator.js';
|
|
12
11
|
import { prismaOutputProvider } from '../prisma/prisma.generator.js';
|
|
@@ -14,6 +13,7 @@ const descriptorSchema = z.object({
|
|
|
14
13
|
name: z.string().min(1),
|
|
15
14
|
modelName: z.string().min(1),
|
|
16
15
|
fields: z.array(z.string().min(1)),
|
|
16
|
+
globalRoles: z.array(z.string().min(1)).optional(),
|
|
17
17
|
});
|
|
18
18
|
/**
|
|
19
19
|
* Generator for prisma/prisma-data-create
|
|
@@ -22,7 +22,7 @@ export const prismaDataCreateGenerator = createGenerator({
|
|
|
22
22
|
name: 'prisma/prisma-data-create',
|
|
23
23
|
generatorFileUrl: import.meta.url,
|
|
24
24
|
descriptorSchema,
|
|
25
|
-
buildTasks: ({ name, modelName, fields }) => ({
|
|
25
|
+
buildTasks: ({ name, modelName, fields, globalRoles }) => ({
|
|
26
26
|
main: createGeneratorTask({
|
|
27
27
|
dependencies: {
|
|
28
28
|
serviceFile: serviceFileProvider,
|
|
@@ -38,34 +38,67 @@ export const prismaDataCreateGenerator = createGenerator({
|
|
|
38
38
|
}
|
|
39
39
|
return {
|
|
40
40
|
build: () => {
|
|
41
|
-
const
|
|
41
|
+
const modelVar = lowercaseFirstChar(modelName);
|
|
42
|
+
const useAllFields = fields.length === serviceFields.length;
|
|
43
|
+
const fieldsVariableName = useAllFields
|
|
42
44
|
? prismaDataService.getFieldsVariableName()
|
|
45
|
+
: `${modelVar}CreateFields`;
|
|
46
|
+
const fieldsDeclarationFragment = useAllFields
|
|
47
|
+
? ''
|
|
43
48
|
: tsTemplateWithImports([
|
|
44
49
|
tsImportBuilder(['pick']).from('es-toolkit'),
|
|
45
|
-
]) `pick(${prismaDataService.getFieldsVariableName()}, [${fields.map((field) => quot(field)).join(', ')}] as const)`;
|
|
46
|
-
// Generate
|
|
50
|
+
]) `const ${fieldsVariableName} = pick(${prismaDataService.getFieldsVariableName()}, [${fields.map((field) => quot(field)).join(', ')}] as const);\n`;
|
|
51
|
+
// Generate execute callback that transforms FK fields into relations
|
|
47
52
|
const prismaModel = prismaOutput.getPrismaModel(modelName);
|
|
48
|
-
const {
|
|
53
|
+
const { executeCallbackFragment } = generateCreateExecuteCallback({
|
|
49
54
|
prismaModel,
|
|
50
55
|
inputFieldNames: fields,
|
|
51
56
|
dataUtilsImports,
|
|
52
|
-
modelVariableName:
|
|
57
|
+
modelVariableName: modelVar,
|
|
53
58
|
});
|
|
54
|
-
// Generate
|
|
55
|
-
const
|
|
56
|
-
const
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
59
|
+
// Generate the schema export and create function together
|
|
60
|
+
const schemaName = `${modelVar}CreateSchema`;
|
|
61
|
+
const authorizeFragment = generateAuthorizeFragment({
|
|
62
|
+
modelName,
|
|
63
|
+
methodType: 'Create',
|
|
64
|
+
globalRoles,
|
|
65
|
+
modelAuthorizer: undefined,
|
|
66
|
+
});
|
|
67
|
+
const createFunction = tsTemplate `
|
|
68
|
+
${fieldsDeclarationFragment}\nexport const ${schemaName} = ${dataUtilsImports.generateCreateSchema.fragment()}(${fieldsVariableName});
|
|
69
|
+
|
|
70
|
+
export async function ${name}<
|
|
71
|
+
TIncludeArgs extends ${dataUtilsImports.ModelInclude.typeFragment()}<${quot(modelVar)}> = ${dataUtilsImports.ModelInclude.typeFragment()}<${quot(modelVar)}>,
|
|
72
|
+
>({
|
|
73
|
+
data: input,
|
|
74
|
+
query,
|
|
75
|
+
context,
|
|
76
|
+
}: ${dataUtilsImports.DataCreateInput.typeFragment()}<
|
|
77
|
+
${quot(modelVar)},
|
|
78
|
+
typeof ${fieldsVariableName},
|
|
79
|
+
TIncludeArgs
|
|
80
|
+
>): Promise<${dataUtilsImports.GetPayload.typeFragment()}<${quot(modelVar)}, TIncludeArgs>> {
|
|
81
|
+
const plan = await ${dataUtilsImports.composeCreate.fragment()}({
|
|
82
|
+
model: ${quot(modelVar)},
|
|
83
|
+
fields: ${fieldsVariableName},
|
|
84
|
+
input,
|
|
85
|
+
context,${authorizeFragment}
|
|
86
|
+
});
|
|
87
|
+
|
|
88
|
+
const item = await ${dataUtilsImports.commitCreate.fragment()}(plan, {
|
|
89
|
+
query,
|
|
90
|
+
execute: ${executeCallbackFragment},
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
return item;
|
|
94
|
+
}
|
|
63
95
|
`;
|
|
64
96
|
const methodFragment = TsCodeUtils.importFragment(name, serviceFile.getServicePath());
|
|
97
|
+
const schemaMethodFragment = TsCodeUtils.importFragment(schemaName, serviceFile.getServicePath());
|
|
65
98
|
prismaDataService.registerMethod({
|
|
66
99
|
name,
|
|
67
100
|
type: 'create',
|
|
68
|
-
fragment:
|
|
101
|
+
fragment: createFunction,
|
|
69
102
|
outputMethod: {
|
|
70
103
|
name,
|
|
71
104
|
referenceFragment: methodFragment,
|
|
@@ -77,7 +110,7 @@ export const prismaDataCreateGenerator = createGenerator({
|
|
|
77
110
|
name: `${uppercaseFirstChar(name)}Data`,
|
|
78
111
|
fields: usedFields.map((field) => field.outputDtoField),
|
|
79
112
|
},
|
|
80
|
-
zodSchemaFragment:
|
|
113
|
+
zodSchemaFragment: schemaMethodFragment,
|
|
81
114
|
},
|
|
82
115
|
createServiceOutputDtoInjectedArg({
|
|
83
116
|
type: 'injected',
|
|
@@ -89,11 +122,6 @@ export const prismaDataCreateGenerator = createGenerator({
|
|
|
89
122
|
name: 'query',
|
|
90
123
|
kind: prismaQueryKind,
|
|
91
124
|
}),
|
|
92
|
-
createServiceOutputDtoInjectedArg({
|
|
93
|
-
type: 'injected',
|
|
94
|
-
name: 'skipValidation',
|
|
95
|
-
kind: skipValidationKind,
|
|
96
|
-
}),
|
|
97
125
|
],
|
|
98
126
|
returnType: prismaToServiceOutputDto(prismaOutput.getPrismaModel(modelName), (enumName) => prismaOutput.getServiceEnum(enumName)),
|
|
99
127
|
},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prisma-data-create.generator.js","sourceRoot":"","sources":["../../../../src/generators/prisma/prisma-data-create/prisma-data-create.generator.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,WAAW,EACX,eAAe,EACf,UAAU,EACV,qBAAqB,GACtB,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,eAAe,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC3E,OAAO,EACL,kBAAkB,EAClB,IAAI,EACJ,kBAAkB,GACnB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AACpE,OAAO,
|
|
1
|
+
{"version":3,"file":"prisma-data-create.generator.js","sourceRoot":"","sources":["../../../../src/generators/prisma/prisma-data-create/prisma-data-create.generator.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,6 +4,8 @@
|
|
|
4
4
|
export declare const prismaDataDeleteGenerator: import("@baseplate-dev/sync").GeneratorBundleCreator<{
|
|
5
5
|
name: string;
|
|
6
6
|
modelName: string;
|
|
7
|
+
globalRoles?: string[] | undefined;
|
|
8
|
+
instanceRoles?: string[] | undefined;
|
|
7
9
|
}, {
|
|
8
10
|
main: import("@baseplate-dev/sync").GeneratorTask<any, {
|
|
9
11
|
serviceFile: import("@baseplate-dev/sync").ProviderType<import("#src/generators/core/index.js").ServiceFileProvider>;
|
|
@@ -15,13 +17,24 @@ export declare const prismaDataDeleteGenerator: import("@baseplate-dev/sync").Ge
|
|
|
15
17
|
AnyOperationHooks: {
|
|
16
18
|
isTypeOnly: true;
|
|
17
19
|
};
|
|
20
|
+
commitCreate: {};
|
|
21
|
+
commitDelete: {};
|
|
22
|
+
commitUpdate: {};
|
|
23
|
+
composeCreate: {};
|
|
24
|
+
composeUpdate: {};
|
|
18
25
|
createParentModelConfig: {};
|
|
26
|
+
DataCreateInput: {
|
|
27
|
+
isTypeOnly: true;
|
|
28
|
+
};
|
|
29
|
+
DataDeleteInput: {
|
|
30
|
+
isTypeOnly: true;
|
|
31
|
+
};
|
|
19
32
|
DataOperationType: {
|
|
20
33
|
isTypeOnly: true;
|
|
21
34
|
};
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
35
|
+
DataUpdateInput: {
|
|
36
|
+
isTypeOnly: true;
|
|
37
|
+
};
|
|
25
38
|
FieldContext: {
|
|
26
39
|
isTypeOnly: true;
|
|
27
40
|
};
|
|
@@ -34,6 +47,8 @@ export declare const prismaDataDeleteGenerator: import("@baseplate-dev/sync").Ge
|
|
|
34
47
|
FieldTransformResult: {
|
|
35
48
|
isTypeOnly: true;
|
|
36
49
|
};
|
|
50
|
+
generateCreateSchema: {};
|
|
51
|
+
generateUpdateSchema: {};
|
|
37
52
|
GetPayload: {
|
|
38
53
|
isTypeOnly: true;
|
|
39
54
|
};
|
|
@@ -43,6 +58,9 @@ export declare const prismaDataDeleteGenerator: import("@baseplate-dev/sync").Ge
|
|
|
43
58
|
InferInput: {
|
|
44
59
|
isTypeOnly: true;
|
|
45
60
|
};
|
|
61
|
+
ModelInclude: {
|
|
62
|
+
isTypeOnly: true;
|
|
63
|
+
};
|
|
46
64
|
ModelPropName: {
|
|
47
65
|
isTypeOnly: true;
|
|
48
66
|
};
|
|
@@ -63,16 +81,23 @@ export declare const prismaDataDeleteGenerator: import("@baseplate-dev/sync").Ge
|
|
|
63
81
|
ParentModelConfig: {
|
|
64
82
|
isTypeOnly: true;
|
|
65
83
|
};
|
|
66
|
-
PrismaTransaction: {
|
|
67
|
-
isTypeOnly: true;
|
|
68
|
-
};
|
|
69
84
|
relationHelpers: {};
|
|
70
85
|
scalarField: {};
|
|
71
86
|
TransactionalOperationContext: {
|
|
72
87
|
isTypeOnly: true;
|
|
73
88
|
};
|
|
89
|
+
WhereInput: {
|
|
90
|
+
isTypeOnly: true;
|
|
91
|
+
};
|
|
92
|
+
WhereUniqueInput: {
|
|
93
|
+
isTypeOnly: true;
|
|
94
|
+
};
|
|
74
95
|
}>>;
|
|
75
96
|
prismaOutput: import("@baseplate-dev/sync").ProviderType<import("../prisma/prisma.generator.js").PrismaOutputProvider>;
|
|
97
|
+
prismaImports: import("@baseplate-dev/sync").ProviderType<import("@baseplate-dev/core-generators").InferTsImportMapFromSchema<{
|
|
98
|
+
prisma: {};
|
|
99
|
+
}>>;
|
|
100
|
+
modelAuthorizer: import("@baseplate-dev/sync").ProviderDependency<import("../prisma-model-authorizer/prisma-model-authorizer.generator.js").PrismaModelAuthorizerProvider | undefined>;
|
|
76
101
|
}, any>;
|
|
77
102
|
}>;
|
|
78
103
|
//# sourceMappingURL=prisma-data-delete.generator.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prisma-data-delete.generator.d.ts","sourceRoot":"","sources":["../../../../src/generators/prisma/prisma-data-delete/prisma-data-delete.generator.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"prisma-data-delete.generator.d.ts","sourceRoot":"","sources":["../../../../src/generators/prisma/prisma-data-delete/prisma-data-delete.generator.ts"],"names":[],"mappings":"AAmCA;;GAEG;AACH,eAAO,MAAM,yBAAyB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAkHpC,CAAC"}
|
|
@@ -5,13 +5,16 @@ import { z } from 'zod';
|
|
|
5
5
|
import { serviceFileProvider } from '#src/generators/core/index.js';
|
|
6
6
|
import { contextKind, prismaQueryKind, prismaWhereUniqueInputKind, } from '#src/types/service-dto-kinds.js';
|
|
7
7
|
import { createServiceOutputDtoInjectedArg, prismaToServiceOutputDto, } from '#src/types/service-output.js';
|
|
8
|
-
import {
|
|
8
|
+
import { generateAuthorizeFragment, generateDeleteExecuteCallback, } from '../_shared/build-data-helpers/index.js';
|
|
9
9
|
import { dataUtilsImportsProvider } from '../data-utils/index.js';
|
|
10
10
|
import { prismaDataServiceProvider } from '../prisma-data-service/prisma-data-service.generator.js';
|
|
11
|
-
import {
|
|
11
|
+
import { prismaModelAuthorizerProvider } from '../prisma-model-authorizer/index.js';
|
|
12
|
+
import { prismaImportsProvider, prismaOutputProvider, } from '../prisma/index.js';
|
|
12
13
|
const descriptorSchema = z.object({
|
|
13
14
|
name: z.string().min(1),
|
|
14
15
|
modelName: z.string().min(1),
|
|
16
|
+
globalRoles: z.array(z.string().min(1)).optional(),
|
|
17
|
+
instanceRoles: z.array(z.string().min(1)).optional(),
|
|
15
18
|
});
|
|
16
19
|
/**
|
|
17
20
|
* Generator for prisma/prisma-data-delete
|
|
@@ -20,33 +23,67 @@ export const prismaDataDeleteGenerator = createGenerator({
|
|
|
20
23
|
name: 'prisma/prisma-data-delete',
|
|
21
24
|
generatorFileUrl: import.meta.url,
|
|
22
25
|
descriptorSchema,
|
|
23
|
-
buildTasks: ({ name, modelName }) => ({
|
|
26
|
+
buildTasks: ({ name, modelName, globalRoles, instanceRoles }) => ({
|
|
24
27
|
main: createGeneratorTask({
|
|
25
28
|
dependencies: {
|
|
26
29
|
serviceFile: serviceFileProvider,
|
|
27
30
|
prismaDataService: prismaDataServiceProvider,
|
|
28
31
|
dataUtilsImports: dataUtilsImportsProvider,
|
|
29
32
|
prismaOutput: prismaOutputProvider,
|
|
33
|
+
prismaImports: prismaImportsProvider,
|
|
34
|
+
modelAuthorizer: prismaModelAuthorizerProvider
|
|
35
|
+
.dependency()
|
|
36
|
+
.optionalReference(modelName),
|
|
30
37
|
},
|
|
31
|
-
run({ serviceFile, prismaDataService, dataUtilsImports, prismaOutput }) {
|
|
38
|
+
run({ serviceFile, prismaDataService, dataUtilsImports, prismaOutput, prismaImports, modelAuthorizer, }) {
|
|
32
39
|
return {
|
|
33
40
|
build: () => {
|
|
34
|
-
|
|
35
|
-
const
|
|
36
|
-
|
|
41
|
+
const modelVar = lowercaseFirstChar(modelName);
|
|
42
|
+
const prismaModel = prismaOutput.getPrismaModel(modelName);
|
|
43
|
+
// Generate execute callback
|
|
44
|
+
const { executeCallbackFragment } = generateDeleteExecuteCallback({
|
|
45
|
+
prismaModel,
|
|
46
|
+
modelVariableName: modelVar,
|
|
47
|
+
});
|
|
48
|
+
// Build authorize array from global + instance roles
|
|
49
|
+
const authorizeFragment = generateAuthorizeFragment({
|
|
50
|
+
modelName,
|
|
51
|
+
methodType: 'Delete',
|
|
52
|
+
globalRoles,
|
|
53
|
+
instanceRoles,
|
|
54
|
+
modelAuthorizer,
|
|
37
55
|
});
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
56
|
+
// Instance roles require loadExisting to fetch the model instance
|
|
57
|
+
const hasInstanceRoles = instanceRoles != null && instanceRoles.length > 0;
|
|
58
|
+
const loadExistingFragment = hasInstanceRoles
|
|
59
|
+
? tsTemplate `
|
|
60
|
+
loadExisting: () => ${prismaImports.prisma.fragment()}.${modelVar}.findUniqueOrThrow({ where }),`
|
|
61
|
+
: '';
|
|
62
|
+
// Generate the delete function
|
|
63
|
+
const deleteFunction = tsTemplate `
|
|
64
|
+
export async function ${name}<
|
|
65
|
+
TIncludeArgs extends ${dataUtilsImports.ModelInclude.typeFragment()}<${quot(modelVar)}> = ${dataUtilsImports.ModelInclude.typeFragment()}<${quot(modelVar)}>,
|
|
66
|
+
>({
|
|
67
|
+
where,
|
|
68
|
+
query,
|
|
69
|
+
context,
|
|
70
|
+
}: ${dataUtilsImports.DataDeleteInput.typeFragment()}<${quot(modelVar)}, TIncludeArgs>): Promise<
|
|
71
|
+
${dataUtilsImports.GetPayload.typeFragment()}<${quot(modelVar)}, TIncludeArgs>
|
|
72
|
+
> {
|
|
73
|
+
const item = await ${dataUtilsImports.commitDelete.fragment()}({
|
|
74
|
+
model: ${quot(modelVar)},
|
|
75
|
+
query,
|
|
76
|
+
context,
|
|
77
|
+
execute: ${executeCallbackFragment},${authorizeFragment}${loadExistingFragment}
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
return item;
|
|
81
|
+
}
|
|
43
82
|
`;
|
|
44
|
-
serviceFile.getServicePath();
|
|
45
|
-
const prismaModel = prismaOutput.getPrismaModel(modelName);
|
|
46
83
|
prismaDataService.registerMethod({
|
|
47
84
|
name,
|
|
48
85
|
type: 'delete',
|
|
49
|
-
fragment:
|
|
86
|
+
fragment: deleteFunction,
|
|
50
87
|
outputMethod: {
|
|
51
88
|
name,
|
|
52
89
|
referenceFragment: TsCodeUtils.importFragment(name, serviceFile.getServicePath()),
|