@zenstackhq/runtime 0.6.0-pre.2 → 1.0.0-alpha.20

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 (120) hide show
  1. package/constants.d.ts +4 -0
  2. package/constants.js +8 -0
  3. package/constants.js.map +1 -0
  4. package/enhancements/index.d.ts +4 -0
  5. package/enhancements/index.js +21 -0
  6. package/enhancements/index.js.map +1 -0
  7. package/enhancements/model-meta.d.ts +9 -0
  8. package/enhancements/model-meta.js +25 -0
  9. package/enhancements/model-meta.js.map +1 -0
  10. package/enhancements/nested-write-vistor.d.ts +65 -0
  11. package/enhancements/nested-write-vistor.js +155 -0
  12. package/enhancements/nested-write-vistor.js.map +1 -0
  13. package/enhancements/omit.d.ts +5 -0
  14. package/enhancements/omit.js +60 -0
  15. package/enhancements/omit.js.map +1 -0
  16. package/enhancements/password.d.ts +5 -0
  17. package/enhancements/password.js +66 -0
  18. package/enhancements/password.js.map +1 -0
  19. package/enhancements/policy/handler.d.ts +36 -0
  20. package/enhancements/policy/handler.js +278 -0
  21. package/enhancements/policy/handler.js.map +1 -0
  22. package/enhancements/policy/index.d.ts +17 -0
  23. package/enhancements/policy/index.js +31 -0
  24. package/enhancements/policy/index.js.map +1 -0
  25. package/{lib/proxy → enhancements/policy}/logger.d.ts +3 -0
  26. package/{lib/proxy → enhancements/policy}/logger.js +4 -0
  27. package/enhancements/policy/logger.js.map +1 -0
  28. package/enhancements/policy/policy-utils.d.ts +78 -0
  29. package/enhancements/policy/policy-utils.js +575 -0
  30. package/enhancements/policy/policy-utils.js.map +1 -0
  31. package/enhancements/preset.d.ts +16 -0
  32. package/enhancements/preset.js +24 -0
  33. package/enhancements/preset.js.map +1 -0
  34. package/enhancements/proxy.d.ts +75 -0
  35. package/enhancements/proxy.js +196 -0
  36. package/enhancements/proxy.js.map +1 -0
  37. package/enhancements/types.d.ts +24 -0
  38. package/{lib/config.js → enhancements/types.js} +1 -1
  39. package/enhancements/types.js.map +1 -0
  40. package/enhancements/utils.d.ts +16 -0
  41. package/enhancements/utils.js +31 -0
  42. package/enhancements/utils.js.map +1 -0
  43. package/error.d.ts +10 -0
  44. package/error.js +17 -0
  45. package/error.js.map +1 -0
  46. package/index.d.ts +5 -0
  47. package/{lib/index.js → index.js} +3 -4
  48. package/index.js.map +1 -0
  49. package/package.json +7 -5
  50. package/{lib/serialization-utils.d.ts → serialization-utils.d.ts} +0 -0
  51. package/{lib/serialization-utils.js → serialization-utils.js} +0 -0
  52. package/serialization-utils.js.map +1 -0
  53. package/types.d.ts +73 -0
  54. package/types.js +14 -0
  55. package/types.js.map +1 -0
  56. package/{lib/validation.d.ts → validation.d.ts} +0 -0
  57. package/{lib/validation.js → validation.js} +0 -0
  58. package/validation.js.map +1 -0
  59. package/{lib/version.d.ts → version.d.ts} +0 -0
  60. package/{lib/version.js → version.js} +6 -1
  61. package/version.js.map +1 -0
  62. package/client/index.d.ts +0 -3
  63. package/client/index.js +0 -11
  64. package/lib/config.d.ts +0 -14
  65. package/lib/config.js.map +0 -1
  66. package/lib/constants.d.ts +0 -12
  67. package/lib/constants.js +0 -16
  68. package/lib/constants.js.map +0 -1
  69. package/lib/handler/data/crud.d.ts +0 -17
  70. package/lib/handler/data/crud.js +0 -255
  71. package/lib/handler/data/crud.js.map +0 -1
  72. package/lib/handler/data/handler.d.ts +0 -20
  73. package/lib/handler/data/handler.js +0 -150
  74. package/lib/handler/data/handler.js.map +0 -1
  75. package/lib/handler/data/nested-write-vistor.d.ts +0 -31
  76. package/lib/handler/data/nested-write-vistor.js +0 -67
  77. package/lib/handler/data/nested-write-vistor.js.map +0 -1
  78. package/lib/handler/data/policy-utils.d.ts +0 -73
  79. package/lib/handler/data/policy-utils.js +0 -447
  80. package/lib/handler/data/policy-utils.js.map +0 -1
  81. package/lib/handler/index.d.ts +0 -1
  82. package/lib/handler/index.js +0 -9
  83. package/lib/handler/index.js.map +0 -1
  84. package/lib/handler/types.d.ts +0 -28
  85. package/lib/handler/types.js +0 -36
  86. package/lib/handler/types.js.map +0 -1
  87. package/lib/index.d.ts +0 -6
  88. package/lib/index.js.map +0 -1
  89. package/lib/policy.d.ts +0 -11
  90. package/lib/policy.js +0 -10
  91. package/lib/policy.js.map +0 -1
  92. package/lib/proxy/handler.d.ts +0 -37
  93. package/lib/proxy/handler.js +0 -333
  94. package/lib/proxy/handler.js.map +0 -1
  95. package/lib/proxy/logger.js.map +0 -1
  96. package/lib/proxy/nested-write-vistor.d.ts +0 -30
  97. package/lib/proxy/nested-write-vistor.js +0 -69
  98. package/lib/proxy/nested-write-vistor.js.map +0 -1
  99. package/lib/proxy/policy-utils.d.ts +0 -78
  100. package/lib/proxy/policy-utils.js +0 -508
  101. package/lib/proxy/policy-utils.js.map +0 -1
  102. package/lib/request-handler.d.ts +0 -21
  103. package/lib/request-handler.js +0 -37
  104. package/lib/request-handler.js.map +0 -1
  105. package/lib/request.d.ts +0 -37
  106. package/lib/request.js +0 -164
  107. package/lib/request.js.map +0 -1
  108. package/lib/serialization-utils.js.map +0 -1
  109. package/lib/service.d.ts +0 -32
  110. package/lib/service.js +0 -184
  111. package/lib/service.js.map +0 -1
  112. package/lib/types.d.ts +0 -185
  113. package/lib/types.js +0 -71
  114. package/lib/types.js.map +0 -1
  115. package/lib/validation.js.map +0 -1
  116. package/lib/version.js.map +0 -1
  117. package/server/index.d.ts +0 -16
  118. package/server/index.js +0 -6
  119. package/types/index.d.ts +0 -1
  120. package/types/index.js +0 -3
@@ -1,508 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- var __importDefault = (this && this.__importDefault) || function (mod) {
12
- return (mod && mod.__esModule) ? mod : { "default": mod };
13
- };
14
- Object.defineProperty(exports, "__esModule", { value: true });
15
- exports.validateModelPayload = exports.preprocessWritePayload = exports.injectTransactionId = exports.checkPolicyForFilter = exports.checkPolicyForIds = exports.preUpdateCheck = exports.readWithCheck = exports.ensureAuthGuard = exports.getAuthGuard = exports.queryIds = exports.ensureArray = exports.or = exports.and = void 0;
16
- /* eslint-disable @typescript-eslint/explicit-module-boundary-types */
17
- /* eslint-disable @typescript-eslint/no-explicit-any */
18
- const bcryptjs_1 = require("bcryptjs");
19
- const deepcopy_1 = __importDefault(require("deepcopy"));
20
- const superjson_1 = __importDefault(require("superjson"));
21
- const constants_1 = require("../constants");
22
- const nested_write_vistor_1 = require("./nested-write-vistor");
23
- const runtime_1 = require("@prisma/client/runtime");
24
- const version_1 = require("../version");
25
- const change_case_1 = require("change-case");
26
- //#region General helpers
27
- /**
28
- * Creates a conjunction of a list of query conditions.
29
- */
30
- function and(...conditions) {
31
- const filtered = conditions.filter((c) => !!c);
32
- if (filtered.length === 0) {
33
- return undefined;
34
- }
35
- else if (filtered.length === 1) {
36
- return filtered[0];
37
- }
38
- else {
39
- return { AND: filtered };
40
- }
41
- }
42
- exports.and = and;
43
- /**
44
- * Creates a disjunction of a list of query conditions.
45
- */
46
- function or(...conditions) {
47
- const filtered = conditions.filter((c) => !!c);
48
- if (filtered.length === 0) {
49
- return undefined;
50
- }
51
- else if (filtered.length === 1) {
52
- return filtered[0];
53
- }
54
- else {
55
- return { OR: filtered };
56
- }
57
- }
58
- exports.or = or;
59
- /**
60
- * Wraps a value into array if it's not already one
61
- */
62
- function ensureArray(value) {
63
- return Array.isArray(value) ? value : [value];
64
- }
65
- exports.ensureArray = ensureArray;
66
- /**
67
- * Given a where condition, queries db and returns IDs of result entities
68
- */
69
- function queryIds(model, db, where) {
70
- return __awaiter(this, void 0, void 0, function* () {
71
- const r = yield db[model].findMany({ select: { id: true }, where });
72
- return r.map((item) => item.id);
73
- });
74
- }
75
- exports.queryIds = queryIds;
76
- //#endregion
77
- //#region Policy enforcement helpers
78
- function getAuthGuard(policy, model, operation, user) {
79
- var _a;
80
- return __awaiter(this, void 0, void 0, function* () {
81
- // const metaModule = await loadMetaModule();
82
- const provider = (_a = policy.guard[(0, change_case_1.camelCase)(model)]) === null || _a === void 0 ? void 0 : _a[operation];
83
- if (!provider) {
84
- // eslint-disable-next-line no-debugger
85
- debugger;
86
- throw new runtime_1.PrismaClientUnknownRequestError(`zenstack: unable to load authorization query function for ${model}`, { clientVersion: (0, version_1.getVersion)() });
87
- }
88
- return provider({ user });
89
- });
90
- }
91
- exports.getAuthGuard = getAuthGuard;
92
- function resolveField(policy, model, field) {
93
- var _a;
94
- return __awaiter(this, void 0, void 0, function* () {
95
- const fieldInfo = (_a = policy.fieldMapping[(0, change_case_1.camelCase)(model)]) === null || _a === void 0 ? void 0 : _a[field];
96
- if (!fieldInfo) {
97
- // eslint-disable-next-line no-debugger
98
- debugger;
99
- throw new runtime_1.PrismaClientUnknownRequestError(`zenstack: unable to load model field ${model}.${field}`, { clientVersion: (0, version_1.getVersion)() });
100
- }
101
- return fieldInfo;
102
- });
103
- }
104
- function ensureAuthGuard(args, model, operation, user, policy) {
105
- return __awaiter(this, void 0, void 0, function* () {
106
- const guard = yield getAuthGuard(policy, model, operation, user);
107
- return Object.assign(Object.assign({}, args), { where: and(args.where, guard) });
108
- });
109
- }
110
- exports.ensureAuthGuard = ensureAuthGuard;
111
- /**
112
- * Read model entities w.r.t the given query args. The result list
113
- * are guaranteed to fully satisfy 'read' policy rules recursively.
114
- *
115
- * For to-many relations involved, items not satisfying policy are
116
- * silently trimmed. For to-one relation, if relation data fails policy
117
- * an CRUDError is thrown.
118
- *
119
- * @param model the model to query for
120
- * @param queryArgs the Prisma query args
121
- * @param service the ZenStack service
122
- * @param context the query context
123
- * @param db the db (or transaction)
124
- * @returns
125
- */
126
- function readWithCheck(model, queryArgs, user, db, policy, logger) {
127
- return __awaiter(this, void 0, void 0, function* () {
128
- const args = queryArgs ? (0, deepcopy_1.default)(queryArgs) : {};
129
- args.where = and(args.where, yield getAuthGuard(policy, model, 'read', user));
130
- // recursively inject read guard conditions into the query args
131
- yield injectNestedReadConditions(policy, model, args, user);
132
- logger.info(`Reading with validation for ${model}: ${superjson_1.default.stringify(args)}`);
133
- const result = yield db[model].findMany(args);
134
- yield Promise.all(result.map((item) => postProcessForRead(item, model, args, user, db, policy, 'read', logger)));
135
- return result;
136
- });
137
- }
138
- exports.readWithCheck = readWithCheck;
139
- function injectNestedReadConditions(policy, model, args, user) {
140
- var _a, _b, _c, _d;
141
- return __awaiter(this, void 0, void 0, function* () {
142
- const injectTarget = (_a = args.select) !== null && _a !== void 0 ? _a : args.include;
143
- if (!injectTarget) {
144
- return;
145
- }
146
- for (const field of Object.keys(injectTarget)) {
147
- const fieldInfo = yield resolveField(policy, model, field);
148
- if (!fieldInfo || !fieldInfo.isDataModel) {
149
- // only care about relation fields
150
- continue;
151
- }
152
- if (fieldInfo.isArray) {
153
- if (typeof injectTarget[field] !== 'object') {
154
- injectTarget[field] = {};
155
- }
156
- // inject extra condition for to-many relation
157
- injectTarget[field].where = and(injectTarget.where, yield getAuthGuard(policy, fieldInfo.type, 'read', user));
158
- }
159
- else {
160
- // there's no way of injecting condition for to-one relation, so we
161
- // make sure 'id' field is selected and check them against query result
162
- if (((_b = injectTarget[field]) === null || _b === void 0 ? void 0 : _b.select) &&
163
- ((_d = (_c = injectTarget[field]) === null || _c === void 0 ? void 0 : _c.select) === null || _d === void 0 ? void 0 : _d.id) !== true) {
164
- injectTarget[field].select.id = true;
165
- }
166
- }
167
- // recurse
168
- yield injectNestedReadConditions(policy, fieldInfo.type, injectTarget[field], user);
169
- }
170
- });
171
- }
172
- /**
173
- * Post processing checks for read model entities.
174
- * Validates to-one relations (which can't be trimmed
175
- * at query time) and removes fields that should be
176
- * omitted.
177
- */
178
- function postProcessForRead(entityData, model, args, user, db, policy, operation, logger) {
179
- var _a, _b;
180
- return __awaiter(this, void 0, void 0, function* () {
181
- if (!(entityData === null || entityData === void 0 ? void 0 : entityData.id)) {
182
- return;
183
- }
184
- for (const field of Object.keys(entityData)) {
185
- if (yield shouldOmit(policy, model, field)) {
186
- delete entityData[field];
187
- }
188
- }
189
- const injectTarget = (_a = args.select) !== null && _a !== void 0 ? _a : args.include;
190
- if (!injectTarget) {
191
- return;
192
- }
193
- // to-one relation data cannot be trimmed by injected guards, we have to
194
- // post-check them
195
- for (const field of Object.keys(injectTarget)) {
196
- const fieldInfo = yield resolveField(policy, model, field);
197
- if (!fieldInfo ||
198
- !fieldInfo.isDataModel ||
199
- fieldInfo.isArray ||
200
- !((_b = entityData === null || entityData === void 0 ? void 0 : entityData[field]) === null || _b === void 0 ? void 0 : _b.id)) {
201
- continue;
202
- }
203
- logger.info(`Validating read of to-one relation: ${fieldInfo.type}#${entityData[field].id}`);
204
- yield checkPolicyForIds(fieldInfo.type, [entityData[field].id], operation, user, db, policy, logger);
205
- // recurse
206
- yield postProcessForRead(entityData[field], fieldInfo.type, injectTarget[field], user, db, policy, operation, logger);
207
- }
208
- });
209
- }
210
- /**
211
- * Validates that a model entity satisfies 'update' policy rules
212
- * before conducting an update
213
- *
214
- * @param model model under update
215
- * @param updateArgs Prisma update args
216
- * @param service the ZenStack service
217
- * @param context the query context
218
- * @param transaction the db transaction context
219
- */
220
- function preUpdateCheck(model, updateArgs, user, transaction, policy, logger) {
221
- return __awaiter(this, void 0, void 0, function* () {
222
- // check the entity directly under update first
223
- yield checkPolicyForFilter(model, updateArgs.where, 'update', user, transaction, policy, logger);
224
- // We need to ensure that all nested updates respect policy rules of
225
- // the corresponding model.
226
- //
227
- // Here we use a visitor to collect all necessary
228
- // checkes. During visiting, for every update we meet against a relation,
229
- // we collect its path (starting from the root object). If the relation
230
- // is a to-many one, it can carry filter condition that we collect as well.
231
- //
232
- // After the visiting, we validate that each collected path satisfies
233
- // corresponding policy rules by making separate queries.
234
- const visitor = new nested_write_vistor_1.NestedWriteVisitor((model, field) => resolveField(policy, model, field));
235
- const state = [];
236
- const checks = [];
237
- const visitAction = (fieldInfo, action, fieldData, _parentData, state) => __awaiter(this, void 0, void 0, function* () {
238
- if (!fieldInfo.isDataModel) {
239
- return state;
240
- }
241
- if (![
242
- 'update',
243
- 'updateMany',
244
- 'upsert',
245
- 'delete',
246
- 'deleteMany',
247
- ].includes(action)) {
248
- // no more nested writes inside, stop recursion
249
- return undefined;
250
- }
251
- // for to-many relation, a filter condition can be attached
252
- let condition = undefined;
253
- if (fieldInfo.isArray) {
254
- switch (action) {
255
- case 'update':
256
- case 'updateMany':
257
- case 'upsert':
258
- // condition is wrapped in 'where'
259
- condition = or(...ensureArray(fieldData).map((d) => d.where));
260
- break;
261
- case 'delete':
262
- case 'deleteMany':
263
- // condition is not wrapped
264
- condition = or(...ensureArray(fieldData));
265
- break;
266
- }
267
- }
268
- // build up a new segment of path
269
- const selectionPath = [
270
- ...state,
271
- { field: fieldInfo, where: condition },
272
- ];
273
- const operation = [
274
- 'update',
275
- 'updateMany',
276
- 'upsert',
277
- ].includes(action)
278
- ? 'update'
279
- : 'delete';
280
- // collect an asynchronous check action
281
- checks.push(checkPolicyForSelectionPath(model, updateArgs.where, selectionPath, operation, transaction, policy, user, logger));
282
- // recurse down with the current path as the new state
283
- return selectionPath;
284
- });
285
- yield visitor.visit(model, updateArgs.data, undefined, state, visitAction);
286
- yield Promise.all(checks);
287
- });
288
- }
289
- exports.preUpdateCheck = preUpdateCheck;
290
- /**
291
- * Given a list of ids for a model, check if they all match policy rules, and if not,
292
- * throw a CRUDError.
293
- *
294
- * @param model the model
295
- * @param ids the entity ids
296
- * @param operation the operation to check for
297
- * @param service the ZenStack service
298
- * @param context the query context
299
- * @param db the db or transaction
300
- */
301
- function checkPolicyForIds(model, ids, operation, user, db, policy, logger) {
302
- return __awaiter(this, void 0, void 0, function* () {
303
- logger.info(`Checking policy for ${model}#[${ids.join(', ')}] for ${operation}`);
304
- // build a query condition with policy injected
305
- const idCondition = ids.length > 1 ? { id: { in: ids } } : { id: ids[0] };
306
- const query = {
307
- where: and(idCondition, yield getAuthGuard(policy, model, operation, user)),
308
- select: { id: true },
309
- };
310
- // query with policy injected
311
- const filteredResult = (yield db[model].findMany(query));
312
- // see if we get fewer items with policy, if so, reject with an throw
313
- const filteredIds = filteredResult.map((item) => item.id);
314
- if (filteredIds.length < ids.length) {
315
- const gap = ids.filter((id) => !filteredIds.includes(id));
316
- throw new runtime_1.PrismaClientKnownRequestError(`denied by policy: entities failed '${operation}' check, ${model}#[${gap.join(', ')}]`, { clientVersion: (0, version_1.getVersion)(), code: 'P2004' });
317
- }
318
- });
319
- }
320
- exports.checkPolicyForIds = checkPolicyForIds;
321
- function checkPolicyForFilter(model, filter, operation, user, db, policy, logger) {
322
- return __awaiter(this, void 0, void 0, function* () {
323
- logger.info(`Checking policy for ${model}#${JSON.stringify(filter)} for ${operation}`);
324
- const count = yield db[model].count({ where: filter });
325
- // build a query condition with policy injected
326
- const guardedQuery = {
327
- where: and(filter, yield getAuthGuard(policy, model, operation, user)),
328
- };
329
- // query with policy injected
330
- const guardedCount = yield db[model].count(guardedQuery);
331
- // see if we get fewer items with policy, if so, reject with an throw
332
- if (guardedCount < count) {
333
- throw new runtime_1.PrismaClientKnownRequestError(`denied by policy: entities of ${model} failed '${operation}' check, ${count - guardedCount} entities failed policy check`, { clientVersion: (0, version_1.getVersion)(), code: 'P2004' });
334
- }
335
- });
336
- }
337
- exports.checkPolicyForFilter = checkPolicyForFilter;
338
- /**
339
- * Given a selection path, check if the entities at the end of path satisfy
340
- * policy rules. If not, throw an error.
341
- */
342
- function checkPolicyForSelectionPath(model, rootFilter, selectionPath, operation, db, policy, user, logger) {
343
- return __awaiter(this, void 0, void 0, function* () {
344
- const targetField = selectionPath[selectionPath.length - 1].field;
345
- // build a Prisma query for the path
346
- const query = buildChainedSelectQuery(rootFilter, selectionPath);
347
- logger.info(`Query for selection path: model ${model}, path ${superjson_1.default.stringify(selectionPath)}, query ${superjson_1.default.stringify(query)}`);
348
- const r = yield db[model].findUnique(query);
349
- // collect ids at the end of the path
350
- const ids = collectTerminalEntityIds(selectionPath, r);
351
- logger.info(`Collected leaf ids: ${superjson_1.default.stringify(ids)}`);
352
- if (ids.length === 0) {
353
- return;
354
- }
355
- // check policies for the collected ids
356
- yield checkPolicyForIds(targetField.type, ids, operation, user, db, policy, logger);
357
- });
358
- }
359
- /**
360
- * Builds a Prisma query for the given selection path
361
- */
362
- function buildChainedSelectQuery(rootFilter, selectionPath) {
363
- const query = { where: rootFilter, select: { id: true } };
364
- let currSelect = query.select;
365
- for (const path of selectionPath) {
366
- const nextSelect = { select: { id: true } };
367
- currSelect[path.field.name] = nextSelect;
368
- if (path.where) {
369
- currSelect[path.field.name].where = path.where;
370
- }
371
- currSelect = nextSelect.select;
372
- }
373
- return query;
374
- }
375
- function collectTerminalEntityIds(selectionPath, data) {
376
- let curr = data;
377
- for (const path of selectionPath) {
378
- curr = curr[path.field.name];
379
- }
380
- if (!curr) {
381
- throw new Error('an unexpected error occurred');
382
- }
383
- return Array.isArray(curr)
384
- ? curr.map((item) => item.id)
385
- : [curr.id];
386
- }
387
- /**
388
- * Injects assignment of zenstack_transaction field for all nested
389
- * update/create in a Prisma update args recursively.
390
- *
391
- * @return a tuple containing all model types that are involved in
392
- * creation or updating, respectively
393
- */
394
- function injectTransactionId(model, args, operation, transactionId, policy) {
395
- return __awaiter(this, void 0, void 0, function* () {
396
- const updatedModels = new Set();
397
- const createdModels = new Set();
398
- // if (args.data) {
399
- // args.data[TRANSACTION_FIELD_NAME] = `${transactionId}:${operation}`;
400
- // updatedModels.add(model);
401
- // }
402
- args[constants_1.TRANSACTION_FIELD_NAME] = `${transactionId}:${operation}`;
403
- if (operation === 'create') {
404
- createdModels.add(model);
405
- }
406
- else {
407
- updatedModels.add(model);
408
- }
409
- const visitAction = (fieldInfo, action, fieldData) => __awaiter(this, void 0, void 0, function* () {
410
- if (fieldInfo.isDataModel && fieldData) {
411
- switch (action) {
412
- case 'update':
413
- case 'updateMany':
414
- ensureArray(fieldData).forEach((item) => {
415
- if (fieldInfo.isArray && item.data) {
416
- item.data[constants_1.TRANSACTION_FIELD_NAME] = `${transactionId}:update`;
417
- }
418
- else {
419
- item[constants_1.TRANSACTION_FIELD_NAME] = `${transactionId}:update`;
420
- }
421
- updatedModels.add(fieldInfo.type);
422
- });
423
- break;
424
- case 'upsert':
425
- ensureArray(fieldData).forEach((item) => {
426
- item.create[constants_1.TRANSACTION_FIELD_NAME] = `${transactionId}:create`;
427
- createdModels.add(fieldInfo.type);
428
- item.update[constants_1.TRANSACTION_FIELD_NAME] = `${transactionId}:update`;
429
- updatedModels.add(fieldInfo.type);
430
- });
431
- break;
432
- case 'create':
433
- case 'createMany':
434
- ensureArray(fieldData).forEach((item) => {
435
- item[constants_1.TRANSACTION_FIELD_NAME] = `${transactionId}:create`;
436
- createdModels.add(fieldInfo.type);
437
- });
438
- break;
439
- case 'connectOrCreate':
440
- ensureArray(fieldData).forEach((item) => {
441
- item.create[constants_1.TRANSACTION_FIELD_NAME] = `${transactionId}:create`;
442
- createdModels.add(fieldInfo.type);
443
- });
444
- break;
445
- }
446
- }
447
- return true;
448
- });
449
- const visitor = new nested_write_vistor_1.NestedWriteVisitor((model, field) => resolveField(policy, model, field));
450
- yield visitor.visit(model, args, undefined, undefined, visitAction);
451
- return {
452
- createdModels: Array.from(createdModels),
453
- updatedModels: Array.from(updatedModels),
454
- };
455
- });
456
- }
457
- exports.injectTransactionId = injectTransactionId;
458
- /**
459
- * Preprocesses the given write args to modify field values (in place) based on
460
- * attributes like @password
461
- */
462
- function preprocessWritePayload(policy, model, args) {
463
- return __awaiter(this, void 0, void 0, function* () {
464
- const visitAction = (fieldInfo, _action, fieldData, parentData) => __awaiter(this, void 0, void 0, function* () {
465
- var _a, _b, _c;
466
- // process @password field
467
- const pwdAttr = (_a = fieldInfo.attributes) === null || _a === void 0 ? void 0 : _a.find((attr) => attr.name === '@password');
468
- if (pwdAttr && fieldInfo.type === 'String') {
469
- // hash password value
470
- let salt = (_b = pwdAttr.args.find((arg) => arg.name === 'salt')) === null || _b === void 0 ? void 0 : _b.value;
471
- if (!salt) {
472
- salt = (_c = pwdAttr.args.find((arg) => arg.name === 'saltLength')) === null || _c === void 0 ? void 0 : _c.value;
473
- }
474
- if (!salt) {
475
- salt = constants_1.DEFAULT_PASSWORD_SALT_LENGTH;
476
- }
477
- parentData[fieldInfo.name] = (0, bcryptjs_1.hashSync)(fieldData, salt);
478
- }
479
- return true;
480
- });
481
- const visitor = new nested_write_vistor_1.NestedWriteVisitor((model, field) => resolveField(policy, model, field));
482
- yield visitor.visit(model, args, undefined, undefined, visitAction);
483
- });
484
- }
485
- exports.preprocessWritePayload = preprocessWritePayload;
486
- function shouldOmit(policy, model, field) {
487
- return __awaiter(this, void 0, void 0, function* () {
488
- if ([constants_1.TRANSACTION_FIELD_NAME, constants_1.GUARD_FIELD_NAME].includes(field)) {
489
- return true;
490
- }
491
- const fieldInfo = yield resolveField(policy, model, field);
492
- return !!(fieldInfo && fieldInfo.attributes.find((attr) => attr.name === '@omit'));
493
- });
494
- }
495
- function validateModelPayload(
496
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
497
- model,
498
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
499
- mode,
500
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
501
- payload) {
502
- return __awaiter(this, void 0, void 0, function* () {
503
- return;
504
- });
505
- }
506
- exports.validateModelPayload = validateModelPayload;
507
- //#endregion
508
- //# sourceMappingURL=policy-utils.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"policy-utils.js","sourceRoot":"","sources":["../../../src/proxy/policy-utils.ts"],"names":[],"mappings":"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"}
@@ -1,21 +0,0 @@
1
- import { NextApiRequest, NextApiResponse } from 'next';
2
- import { AuthUser, Service } from './types';
3
- /**
4
- * Options for initializing a Next.js API endpoint request handler. This type is re-exported in @zenstackhq/runtime/server.
5
- * @see requestHandler
6
- */
7
- export type RequestHandlerOptions = {
8
- /**
9
- * Hook method for providing current login user from session.
10
- */
11
- getServerUser: (req: NextApiRequest, res: NextApiResponse) => Promise<AuthUser | undefined>;
12
- };
13
- /**
14
- * Creates a Next.js API endpoint request handler which encapsulates RESTful APIs generated by ZenStack.
15
- * The created handler should be mounted at /api/zenstack endpoint.
16
- *
17
- * @param service ZenStack service which wraps a Prisma db client inside
18
- * @param options Options for initialization
19
- * @returns An API endpoint request handler
20
- */
21
- export declare function requestHandler<DbClient>(service: Service<DbClient>, options: RequestHandlerOptions): (req: NextApiRequest, res: NextApiResponse) => Promise<void>;
@@ -1,37 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.requestHandler = void 0;
13
- const handler_1 = require("./handler");
14
- /**
15
- * Creates a Next.js API endpoint request handler which encapsulates RESTful APIs generated by ZenStack.
16
- * The created handler should be mounted at /api/zenstack endpoint.
17
- *
18
- * @param service ZenStack service which wraps a Prisma db client inside
19
- * @param options Options for initialization
20
- * @returns An API endpoint request handler
21
- */
22
- function requestHandler(service, options) {
23
- const dataHandler = new handler_1.DataHandler(service, options);
24
- return (req, res) => __awaiter(this, void 0, void 0, function* () {
25
- const [route, ...rest] = req.query.path;
26
- switch (route) {
27
- // "/data" route is for handling data-access requests
28
- case 'data':
29
- return dataHandler.handle(req, res, rest);
30
- default:
31
- service.warn(`Unknown route: ${route}`);
32
- res.status(404).json({ error: `Unknown route: ${route}` });
33
- }
34
- });
35
- }
36
- exports.requestHandler = requestHandler;
37
- //# sourceMappingURL=request-handler.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"request-handler.js","sourceRoot":"","sources":["../../src/request-handler.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,uCAAwC;AAiBxC;;;;;;;GAOG;AACH,SAAgB,cAAc,CAC1B,OAA0B,EAC1B,OAA8B;IAE9B,MAAM,WAAW,GAAG,IAAI,qBAAW,CAC/B,OAAoC,EACpC,OAAO,CACV,CAAC;IACF,OAAO,CAAO,GAAmB,EAAE,GAAoB,EAAE,EAAE;QACvD,MAAM,CAAC,KAAK,EAAE,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,IAAgB,CAAC;QACpD,QAAQ,KAAK,EAAE;YACX,qDAAqD;YACrD,KAAK,MAAM;gBACP,OAAO,WAAW,CAAC,MAAM,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;YAE9C;gBACI,OAAO,CAAC,IAAI,CAAC,kBAAkB,KAAK,EAAE,CAAC,CAAC;gBACxC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,kBAAkB,KAAK,EAAE,EAAE,CAAC,CAAC;SAClE;IACL,CAAC,CAAA,CAAC;AACN,CAAC;AApBD,wCAoBC"}
package/lib/request.d.ts DELETED
@@ -1,37 +0,0 @@
1
- import type { MutatorCallback, MutatorOptions, SWRResponse } from 'swr/dist/types';
2
- import { RequestOptions } from './types';
3
- /**
4
- * Makes a GET request with SWR.
5
- *
6
- * @param url The request URL.
7
- * @param args The request args object, which will be superjson-stringified and appended as "?q=" parameter
8
- * @returns SWR response
9
- */
10
- export declare function get<Data, Error = any>(url: string | null, args?: unknown, options?: RequestOptions<Data>): SWRResponse<Data, Error>;
11
- /**
12
- * Makes a POST request.
13
- *
14
- * @param url The request URL.
15
- * @param data The request data.
16
- * @param mutate Mutator for invalidating cache.
17
- */
18
- export declare function post<Data, Result>(url: string, data: Data, mutate: Mutator): Promise<Result>;
19
- /**
20
- * Makes a PUT request.
21
- *
22
- * @param url The request URL.
23
- * @param data The request data.
24
- * @param mutate Mutator for invalidating cache.
25
- */
26
- export declare function put<Data, Result>(url: string, data: Data, mutate: Mutator): Promise<Result>;
27
- /**
28
- * Makes a DELETE request.
29
- *
30
- * @param url The request URL.
31
- * @param args The request args object, which will be superjson-stringified and appended as "?q=" parameter
32
- * @param mutate Mutator for invalidating cache.
33
- */
34
- export declare function del<Result>(url: string, args: unknown, mutate: Mutator): Promise<Result>;
35
- type Mutator = (key: string, prefix: boolean, data?: unknown | Promise<unknown> | MutatorCallback, opts?: boolean | MutatorOptions) => Promise<unknown[]>;
36
- export declare function getMutate(): Mutator;
37
- export {};