@payloadcms/db-postgres 0.1.0-beta.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (74) hide show
  1. package/dist/connect.js +82 -0
  2. package/dist/create.js +32 -0
  3. package/dist/createGlobal.js +32 -0
  4. package/dist/createGlobalVersion.js +48 -0
  5. package/dist/createMigration.js +85 -0
  6. package/dist/createVersion.js +54 -0
  7. package/dist/deleteMany.js +44 -0
  8. package/dist/deleteOne.js +47 -0
  9. package/dist/deleteVersions.js +46 -0
  10. package/dist/destroy.js +16 -0
  11. package/dist/find/buildFindManyArgs.js +61 -0
  12. package/dist/find/chainMethods.js +21 -0
  13. package/dist/find/findMany.js +197 -0
  14. package/dist/find/traverseFields.js +118 -0
  15. package/dist/find.js +35 -0
  16. package/dist/findGlobal.js +38 -0
  17. package/dist/findGlobalVersions.js +39 -0
  18. package/dist/findOne.js +49 -0
  19. package/dist/findVersions.js +39 -0
  20. package/dist/index.js +95 -0
  21. package/dist/init.js +74 -0
  22. package/dist/migrate.js +81 -0
  23. package/dist/migrateStatus.js +54 -0
  24. package/dist/mock.js +13 -0
  25. package/dist/queries/buildAndOrConditions.js +39 -0
  26. package/dist/queries/buildQuery.js +80 -0
  27. package/dist/queries/createJSONQuery/convertPathToJSONTraversal.js +24 -0
  28. package/dist/queries/createJSONQuery/formatJSONPathSegment.js +15 -0
  29. package/dist/queries/createJSONQuery/index.js +64 -0
  30. package/dist/queries/getTableColumnFromPath.js +333 -0
  31. package/dist/queries/operatorMap.js +34 -0
  32. package/dist/queries/parseParams.js +146 -0
  33. package/dist/queries/sanitizeQueryValue.js +79 -0
  34. package/dist/queryDrafts.js +56 -0
  35. package/dist/reference.js +76 -0
  36. package/dist/schema/build.js +245 -0
  37. package/dist/schema/createIndex.js +19 -0
  38. package/dist/schema/parentIDColumnMap.js +18 -0
  39. package/dist/schema/traverseFields.js +430 -0
  40. package/dist/schema/validateExistingBlockIsIdentical.js +34 -0
  41. package/dist/transactions/beginTransaction.js +51 -0
  42. package/dist/transactions/commitTransaction.js +24 -0
  43. package/dist/transactions/rollbackTransaction.js +20 -0
  44. package/dist/transform/read/hasManyNumber.js +20 -0
  45. package/dist/transform/read/index.js +42 -0
  46. package/dist/transform/read/relationship.js +74 -0
  47. package/dist/transform/read/traverseFields.js +325 -0
  48. package/dist/transform/write/array.js +55 -0
  49. package/dist/transform/write/blocks.js +56 -0
  50. package/dist/transform/write/index.js +46 -0
  51. package/dist/transform/write/numbers.js +21 -0
  52. package/dist/transform/write/relationships.js +33 -0
  53. package/dist/transform/write/selects.js +29 -0
  54. package/dist/transform/write/traverseFields.js +379 -0
  55. package/dist/transform/write/types.js +6 -0
  56. package/dist/types.js +6 -0
  57. package/dist/update.js +48 -0
  58. package/dist/updateGlobal.js +39 -0
  59. package/dist/updateGlobalVersion.js +50 -0
  60. package/dist/updateVersion.js +50 -0
  61. package/dist/upsertRow/deleteExistingArrayRows.js +20 -0
  62. package/dist/upsertRow/deleteExistingRowsByPath.js +43 -0
  63. package/dist/upsertRow/index.js +243 -0
  64. package/dist/upsertRow/insertArrays.js +64 -0
  65. package/dist/upsertRow/types.js +6 -0
  66. package/dist/utilities/appendPrefixToKeys.js +16 -0
  67. package/dist/utilities/createBlocksMap.js +39 -0
  68. package/dist/utilities/createMigrationTable.js +23 -0
  69. package/dist/utilities/createRelationshipMap.js +29 -0
  70. package/dist/utilities/hasLocalesTable.js +21 -0
  71. package/dist/utilities/isArrayOfRows.js +15 -0
  72. package/dist/utilities/migrationTableExists.js +19 -0
  73. package/dist/webpack.js +30 -0
  74. package/package.json +47 -0
@@ -0,0 +1,430 @@
1
+ /* eslint-disable no-param-reassign */ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "traverseFields", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return traverseFields;
9
+ }
10
+ });
11
+ const _drizzleorm = require("drizzle-orm");
12
+ const _pgcore = require("drizzle-orm/pg-core");
13
+ const _errors = require("payload/errors");
14
+ const _types = require("payload/types");
15
+ const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
16
+ const _hasLocalesTable = require("../utilities/hasLocalesTable");
17
+ const _build = require("./build");
18
+ const _createIndex = require("./createIndex");
19
+ const _parentIDColumnMap = require("./parentIDColumnMap");
20
+ const _validateExistingBlockIsIdentical = require("./validateExistingBlockIsIdentical");
21
+ function _interop_require_default(obj) {
22
+ return obj && obj.__esModule ? obj : {
23
+ default: obj
24
+ };
25
+ }
26
+ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, disableUnique = false, fieldPrefix, fields, forceLocalized, indexes, localesColumns, localesIndexes, newTableName, parentTableName, relationsToBuild, relationships, rootRelationsToBuild, rootTableIDColType, rootTableName })=>{
27
+ let hasLocalizedField = false;
28
+ let hasLocalizedRelationshipField = false;
29
+ let hasManyNumberField = false;
30
+ let hasLocalizedManyNumberField = false;
31
+ let parentIDColType = 'integer';
32
+ if (columns.id instanceof _pgcore.PgNumericBuilder) parentIDColType = 'numeric';
33
+ if (columns.id instanceof _pgcore.PgVarcharBuilder) parentIDColType = 'varchar';
34
+ fields.forEach((field)=>{
35
+ if ('name' in field && field.name === 'id') return;
36
+ let columnName;
37
+ let fieldName;
38
+ let targetTable = columns;
39
+ let targetIndexes = indexes;
40
+ if ((0, _types.fieldAffectsData)(field)) {
41
+ columnName = `${columnPrefix || ''}${field.name[0] === '_' ? '_' : ''}${(0, _tosnakecase.default)(field.name)}`;
42
+ fieldName = `${fieldPrefix || ''}${field.name}`;
43
+ // If field is localized,
44
+ // add the column to the locale table instead of main table
45
+ if (adapter.payload.config.localization && (field.localized || forceLocalized)) {
46
+ hasLocalizedField = true;
47
+ targetTable = localesColumns;
48
+ targetIndexes = localesIndexes;
49
+ }
50
+ if ((field.unique || field.index) && ![
51
+ 'array',
52
+ 'blocks',
53
+ 'group',
54
+ 'point',
55
+ 'relationship',
56
+ 'upload'
57
+ ].includes(field.type) && !(field.type === 'number' && field.hasMany === true)) {
58
+ targetIndexes[`${field.name}Idx`] = (0, _createIndex.createIndex)({
59
+ name: fieldName,
60
+ columnName,
61
+ unique: disableUnique !== true && field.unique
62
+ });
63
+ }
64
+ }
65
+ switch(field.type){
66
+ case 'text':
67
+ case 'email':
68
+ case 'code':
69
+ case 'textarea':
70
+ {
71
+ targetTable[fieldName] = (0, _pgcore.varchar)(columnName);
72
+ break;
73
+ }
74
+ case 'number':
75
+ {
76
+ if (field.hasMany) {
77
+ if (field.localized) {
78
+ hasLocalizedManyNumberField = true;
79
+ }
80
+ if (field.index) {
81
+ hasManyNumberField = 'index';
82
+ } else if (!hasManyNumberField) {
83
+ hasManyNumberField = true;
84
+ }
85
+ if (field.unique) {
86
+ throw new _errors.InvalidConfiguration('Unique is not supported in Postgres for hasMany number fields.');
87
+ }
88
+ } else {
89
+ targetTable[fieldName] = (0, _pgcore.numeric)(columnName);
90
+ }
91
+ break;
92
+ }
93
+ case 'richText':
94
+ case 'json':
95
+ {
96
+ targetTable[fieldName] = (0, _pgcore.jsonb)(columnName);
97
+ break;
98
+ }
99
+ case 'date':
100
+ {
101
+ targetTable[fieldName] = (0, _pgcore.timestamp)(columnName, {
102
+ mode: 'string',
103
+ precision: 3,
104
+ withTimezone: true
105
+ });
106
+ break;
107
+ }
108
+ case 'point':
109
+ {
110
+ break;
111
+ }
112
+ case 'radio':
113
+ case 'select':
114
+ {
115
+ const enumName = `enum_${newTableName}_${columnPrefix || ''}${(0, _tosnakecase.default)(field.name)}`;
116
+ adapter.enums[enumName] = (0, _pgcore.pgEnum)(enumName, field.options.map((option)=>{
117
+ if ((0, _types.optionIsObject)(option)) {
118
+ return option.value;
119
+ }
120
+ return option;
121
+ }));
122
+ if (field.type === 'select' && field.hasMany) {
123
+ const baseColumns = {
124
+ order: (0, _pgcore.integer)('order').notNull(),
125
+ parent: _parentIDColumnMap.parentIDColumnMap[parentIDColType]('parent_id').references(()=>adapter.tables[parentTableName].id, {
126
+ onDelete: 'cascade'
127
+ }).notNull(),
128
+ value: adapter.enums[enumName]('value')
129
+ };
130
+ const baseExtraConfig = {};
131
+ if (field.localized) {
132
+ baseColumns.locale = adapter.enums.enum__locales('locale').notNull();
133
+ baseExtraConfig.parentOrderLocale = (cols)=>(0, _pgcore.unique)().on(cols.parent, cols.order, cols.locale);
134
+ } else {
135
+ baseExtraConfig.parent = (cols)=>(0, _pgcore.index)('parent_idx').on(cols.parent);
136
+ baseExtraConfig.order = (cols)=>(0, _pgcore.index)('order_idx').on(cols.order);
137
+ }
138
+ if (field.index) {
139
+ baseExtraConfig.value = (cols)=>(0, _pgcore.index)('value_idx').on(cols.value);
140
+ }
141
+ const selectTableName = `${newTableName}_${(0, _tosnakecase.default)(fieldName)}`;
142
+ (0, _build.buildTable)({
143
+ adapter,
144
+ baseColumns,
145
+ baseExtraConfig,
146
+ disableUnique,
147
+ fields: [],
148
+ tableName: selectTableName
149
+ });
150
+ relationsToBuild.set(fieldName, selectTableName);
151
+ const selectTableRelations = (0, _drizzleorm.relations)(adapter.tables[selectTableName], ({ one })=>{
152
+ const result = {
153
+ parent: one(adapter.tables[parentTableName], {
154
+ fields: [
155
+ adapter.tables[selectTableName].parent
156
+ ],
157
+ references: [
158
+ adapter.tables[parentTableName].id
159
+ ]
160
+ })
161
+ };
162
+ return result;
163
+ });
164
+ adapter.relations[`relation_${selectTableName}`] = selectTableRelations;
165
+ } else {
166
+ targetTable[fieldName] = adapter.enums[enumName](fieldName);
167
+ }
168
+ break;
169
+ }
170
+ case 'checkbox':
171
+ {
172
+ targetTable[fieldName] = (0, _pgcore.boolean)(columnName);
173
+ break;
174
+ }
175
+ case 'array':
176
+ {
177
+ const baseColumns = {
178
+ _order: (0, _pgcore.integer)('_order').notNull(),
179
+ _parentID: _parentIDColumnMap.parentIDColumnMap[parentIDColType]('_parent_id').references(()=>adapter.tables[parentTableName].id, {
180
+ onDelete: 'cascade'
181
+ }).notNull()
182
+ };
183
+ const baseExtraConfig = {};
184
+ if (field.localized && adapter.payload.config.localization) {
185
+ baseColumns._locale = adapter.enums.enum__locales('_locale').notNull();
186
+ baseExtraConfig._parentOrderLocale = (cols)=>(0, _pgcore.unique)().on(cols._parentID, cols._order, cols._locale);
187
+ } else {
188
+ baseExtraConfig._parentOrder = (cols)=>(0, _pgcore.unique)().on(cols._parentID, cols._order);
189
+ }
190
+ const arrayTableName = `${newTableName}_${(0, _tosnakecase.default)(field.name)}`;
191
+ const { relationsToBuild: subRelationsToBuild } = (0, _build.buildTable)({
192
+ adapter,
193
+ baseColumns,
194
+ baseExtraConfig,
195
+ disableUnique,
196
+ fields: field.fields,
197
+ rootRelationsToBuild,
198
+ rootTableIDColType,
199
+ rootTableName,
200
+ tableName: arrayTableName
201
+ });
202
+ relationsToBuild.set(fieldName, arrayTableName);
203
+ const arrayTableRelations = (0, _drizzleorm.relations)(adapter.tables[arrayTableName], ({ many, one })=>{
204
+ const result = {
205
+ _parentID: one(adapter.tables[parentTableName], {
206
+ fields: [
207
+ adapter.tables[arrayTableName]._parentID
208
+ ],
209
+ references: [
210
+ adapter.tables[parentTableName].id
211
+ ]
212
+ })
213
+ };
214
+ if ((0, _hasLocalesTable.hasLocalesTable)(field.fields)) {
215
+ result._locales = many(adapter.tables[`${arrayTableName}_locales`]);
216
+ }
217
+ subRelationsToBuild.forEach((val, key)=>{
218
+ result[key] = many(adapter.tables[val]);
219
+ });
220
+ return result;
221
+ });
222
+ adapter.relations[`relations_${arrayTableName}`] = arrayTableRelations;
223
+ break;
224
+ }
225
+ case 'blocks':
226
+ {
227
+ field.blocks.forEach((block)=>{
228
+ const blockTableName = `${rootTableName}_blocks_${(0, _tosnakecase.default)(block.slug)}`;
229
+ if (!adapter.tables[blockTableName]) {
230
+ const baseColumns = {
231
+ _order: (0, _pgcore.integer)('_order').notNull(),
232
+ _parentID: _parentIDColumnMap.parentIDColumnMap[rootTableIDColType]('_parent_id').references(()=>adapter.tables[rootTableName].id, {
233
+ onDelete: 'cascade'
234
+ }).notNull(),
235
+ _path: (0, _pgcore.text)('_path').notNull()
236
+ };
237
+ const baseExtraConfig = {};
238
+ if (field.localized && adapter.payload.config.localization) {
239
+ baseColumns._locale = adapter.enums.enum__locales('_locale').notNull();
240
+ baseExtraConfig._parentPathOrderLocale = (cols)=>(0, _pgcore.unique)().on(cols._parentID, cols._path, cols._order, cols._locale);
241
+ } else {
242
+ baseExtraConfig._parentPathOrder = (cols)=>(0, _pgcore.unique)().on(cols._parentID, cols._path, cols._order);
243
+ }
244
+ const { relationsToBuild: subRelationsToBuild } = (0, _build.buildTable)({
245
+ adapter,
246
+ baseColumns,
247
+ baseExtraConfig,
248
+ disableUnique,
249
+ fields: block.fields,
250
+ rootRelationsToBuild,
251
+ rootTableIDColType,
252
+ rootTableName,
253
+ tableName: blockTableName
254
+ });
255
+ const blockTableRelations = (0, _drizzleorm.relations)(adapter.tables[blockTableName], ({ many, one })=>{
256
+ const result = {
257
+ _parentID: one(adapter.tables[rootTableName], {
258
+ fields: [
259
+ adapter.tables[blockTableName]._parentID
260
+ ],
261
+ references: [
262
+ adapter.tables[rootTableName].id
263
+ ]
264
+ })
265
+ };
266
+ if ((0, _hasLocalesTable.hasLocalesTable)(block.fields)) {
267
+ result._locales = many(adapter.tables[`${blockTableName}_locales`]);
268
+ }
269
+ subRelationsToBuild.forEach((val, key)=>{
270
+ result[key] = many(adapter.tables[val]);
271
+ });
272
+ return result;
273
+ });
274
+ adapter.relations[`relations_${blockTableName}`] = blockTableRelations;
275
+ } else if (process.env.NODE_ENV !== 'production') {
276
+ (0, _validateExistingBlockIsIdentical.validateExistingBlockIsIdentical)({
277
+ block,
278
+ localized: field.localized,
279
+ rootTableName,
280
+ table: adapter.tables[blockTableName]
281
+ });
282
+ }
283
+ rootRelationsToBuild.set(`_blocks_${block.slug}`, blockTableName);
284
+ });
285
+ break;
286
+ }
287
+ case 'tab':
288
+ case 'group':
289
+ {
290
+ if (!('name' in field)) {
291
+ const { hasLocalizedField: groupHasLocalizedField, hasLocalizedManyNumberField: groupHasLocalizedManyNumberField, hasLocalizedRelationshipField: groupHasLocalizedRelationshipField, hasManyNumberField: groupHasManyNumberField } = traverseFields({
292
+ adapter,
293
+ buildRelationships,
294
+ columnPrefix,
295
+ columns,
296
+ disableUnique,
297
+ fieldPrefix,
298
+ fields: field.fields,
299
+ forceLocalized,
300
+ indexes,
301
+ localesColumns,
302
+ localesIndexes,
303
+ newTableName: parentTableName,
304
+ parentTableName,
305
+ relationsToBuild,
306
+ relationships,
307
+ rootRelationsToBuild,
308
+ rootTableIDColType,
309
+ rootTableName
310
+ });
311
+ if (groupHasLocalizedField) hasLocalizedField = true;
312
+ if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true;
313
+ if (groupHasManyNumberField) hasManyNumberField = true;
314
+ if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true;
315
+ break;
316
+ }
317
+ const { hasLocalizedField: groupHasLocalizedField, hasLocalizedManyNumberField: groupHasLocalizedManyNumberField, hasLocalizedRelationshipField: groupHasLocalizedRelationshipField, hasManyNumberField: groupHasManyNumberField } = traverseFields({
318
+ adapter,
319
+ buildRelationships,
320
+ columnPrefix: `${columnName}_`,
321
+ columns,
322
+ disableUnique,
323
+ fieldPrefix: `${fieldName}_`,
324
+ fields: field.fields,
325
+ forceLocalized: field.localized,
326
+ indexes,
327
+ localesColumns,
328
+ localesIndexes,
329
+ newTableName: `${parentTableName}_${columnName}`,
330
+ parentTableName,
331
+ relationsToBuild,
332
+ relationships,
333
+ rootRelationsToBuild,
334
+ rootTableIDColType,
335
+ rootTableName
336
+ });
337
+ if (groupHasLocalizedField) hasLocalizedField = true;
338
+ if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true;
339
+ if (groupHasManyNumberField) hasManyNumberField = true;
340
+ if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true;
341
+ break;
342
+ }
343
+ case 'tabs':
344
+ {
345
+ const { hasLocalizedField: tabHasLocalizedField, hasLocalizedManyNumberField: tabHasLocalizedManyNumberField, hasLocalizedRelationshipField: tabHasLocalizedRelationshipField, hasManyNumberField: tabHasManyNumberField } = traverseFields({
346
+ adapter,
347
+ buildRelationships,
348
+ columnPrefix,
349
+ columns,
350
+ disableUnique,
351
+ fieldPrefix,
352
+ fields: field.tabs.map((tab)=>({
353
+ ...tab,
354
+ type: 'tab'
355
+ })),
356
+ forceLocalized,
357
+ indexes,
358
+ localesColumns,
359
+ localesIndexes,
360
+ newTableName,
361
+ parentTableName,
362
+ relationsToBuild,
363
+ relationships,
364
+ rootRelationsToBuild,
365
+ rootTableIDColType,
366
+ rootTableName
367
+ });
368
+ if (tabHasLocalizedField) hasLocalizedField = true;
369
+ if (tabHasLocalizedRelationshipField) hasLocalizedRelationshipField = true;
370
+ if (tabHasManyNumberField) hasManyNumberField = true;
371
+ if (tabHasLocalizedManyNumberField) hasLocalizedManyNumberField = true;
372
+ break;
373
+ }
374
+ case 'row':
375
+ case 'collapsible':
376
+ {
377
+ const { hasLocalizedField: rowHasLocalizedField, hasLocalizedManyNumberField: rowHasLocalizedManyNumberField, hasLocalizedRelationshipField: rowHasLocalizedRelationshipField, hasManyNumberField: rowHasManyNumberField } = traverseFields({
378
+ adapter,
379
+ buildRelationships,
380
+ columnPrefix,
381
+ columns,
382
+ disableUnique,
383
+ fieldPrefix,
384
+ fields: field.fields,
385
+ forceLocalized,
386
+ indexes,
387
+ localesColumns,
388
+ localesIndexes,
389
+ newTableName: parentTableName,
390
+ parentTableName,
391
+ relationsToBuild,
392
+ relationships,
393
+ rootRelationsToBuild,
394
+ rootTableIDColType,
395
+ rootTableName
396
+ });
397
+ if (rowHasLocalizedField) hasLocalizedField = true;
398
+ if (rowHasLocalizedRelationshipField) hasLocalizedRelationshipField = true;
399
+ if (rowHasManyNumberField) hasManyNumberField = true;
400
+ if (rowHasLocalizedManyNumberField) hasLocalizedManyNumberField = true;
401
+ break;
402
+ }
403
+ case 'relationship':
404
+ case 'upload':
405
+ if (Array.isArray(field.relationTo)) {
406
+ field.relationTo.forEach((relation)=>relationships.add(relation));
407
+ } else {
408
+ relationships.add(field.relationTo);
409
+ }
410
+ if (field.localized && adapter.payload.config.localization) {
411
+ hasLocalizedRelationshipField = true;
412
+ }
413
+ break;
414
+ default:
415
+ break;
416
+ }
417
+ const condition = field.admin && field.admin.condition;
418
+ if (targetTable[fieldName] && 'required' in field && field.required && !condition) {
419
+ targetTable[fieldName].notNull();
420
+ }
421
+ });
422
+ return {
423
+ hasLocalizedField,
424
+ hasLocalizedManyNumberField,
425
+ hasLocalizedRelationshipField,
426
+ hasManyNumberField
427
+ };
428
+ };
429
+
430
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/schema/traverseFields.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Relation } from 'drizzle-orm'\nimport type { IndexBuilder, PgColumnBuilder, UniqueConstraintBuilder } from 'drizzle-orm/pg-core'\nimport type { Field, TabAsField } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport {\n  PgNumericBuilder,\n  PgVarcharBuilder,\n  boolean,\n  index,\n  integer,\n  jsonb,\n  numeric,\n  pgEnum,\n  text,\n  timestamp,\n  unique,\n  varchar,\n} from 'drizzle-orm/pg-core'\nimport { InvalidConfiguration } from 'payload/errors'\nimport { fieldAffectsData, optionIsObject } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, PostgresAdapter } from '../types'\n\nimport { hasLocalesTable } from '../utilities/hasLocalesTable'\nimport { buildTable } from './build'\nimport { createIndex } from './createIndex'\nimport { parentIDColumnMap } from './parentIDColumnMap'\nimport { validateExistingBlockIsIdentical } from './validateExistingBlockIsIdentical'\n\ntype Args = {\n  adapter: PostgresAdapter\n  buildRelationships: boolean\n  columnPrefix?: string\n  columns: Record<string, PgColumnBuilder>\n  disableUnique?: boolean\n  fieldPrefix?: string\n  fields: (Field | TabAsField)[]\n  forceLocalized?: boolean\n  indexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n  localesColumns: Record<string, PgColumnBuilder>\n  localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n  newTableName: string\n  parentTableName: string\n  relationsToBuild: Map<string, string>\n  relationships: Set<string>\n  rootRelationsToBuild?: Map<string, string>\n  rootTableIDColType: string\n  rootTableName: string\n}\n\ntype Result = {\n  hasLocalizedField: boolean\n  hasLocalizedManyNumberField: boolean\n  hasLocalizedRelationshipField: boolean\n  hasManyNumberField: 'index' | boolean\n}\n\nexport const traverseFields = ({\n  adapter,\n  buildRelationships,\n  columnPrefix,\n  columns,\n  disableUnique = false,\n  fieldPrefix,\n  fields,\n  forceLocalized,\n  indexes,\n  localesColumns,\n  localesIndexes,\n  newTableName,\n  parentTableName,\n  relationsToBuild,\n  relationships,\n  rootRelationsToBuild,\n  rootTableIDColType,\n  rootTableName,\n}: Args): Result => {\n  let hasLocalizedField = false\n  let hasLocalizedRelationshipField = false\n  let hasManyNumberField: 'index' | boolean = false\n  let hasLocalizedManyNumberField = false\n\n  let parentIDColType = 'integer'\n  if (columns.id instanceof PgNumericBuilder) parentIDColType = 'numeric'\n  if (columns.id instanceof PgVarcharBuilder) parentIDColType = 'varchar'\n\n  fields.forEach((field) => {\n    if ('name' in field && field.name === 'id') return\n    let columnName: string\n    let fieldName: string\n\n    let targetTable = columns\n    let targetIndexes = indexes\n\n    if (fieldAffectsData(field)) {\n      columnName = `${columnPrefix || ''}${field.name[0] === '_' ? '_' : ''}${toSnakeCase(\n        field.name,\n      )}`\n      fieldName = `${fieldPrefix || ''}${field.name}`\n\n      // If field is localized,\n      // add the column to the locale table instead of main table\n      if (adapter.payload.config.localization && (field.localized || forceLocalized)) {\n        hasLocalizedField = true\n        targetTable = localesColumns\n        targetIndexes = localesIndexes\n      }\n\n      if (\n        (field.unique || field.index) &&\n        !['array', 'blocks', 'group', 'point', 'relationship', 'upload'].includes(field.type) &&\n        !(field.type === 'number' && field.hasMany === true)\n      ) {\n        targetIndexes[`${field.name}Idx`] = createIndex({\n          name: fieldName,\n          columnName,\n          unique: disableUnique !== true && field.unique,\n        })\n      }\n    }\n\n    switch (field.type) {\n      case 'text':\n      case 'email':\n      case 'code':\n      case 'textarea': {\n        targetTable[fieldName] = varchar(columnName)\n        break\n      }\n\n      case 'number': {\n        if (field.hasMany) {\n          if (field.localized) {\n            hasLocalizedManyNumberField = true\n          }\n\n          if (field.index) {\n            hasManyNumberField = 'index'\n          } else if (!hasManyNumberField) {\n            hasManyNumberField = true\n          }\n\n          if (field.unique) {\n            throw new InvalidConfiguration(\n              'Unique is not supported in Postgres for hasMany number fields.',\n            )\n          }\n        } else {\n          targetTable[fieldName] = numeric(columnName)\n        }\n        break\n      }\n\n      case 'richText':\n      case 'json': {\n        targetTable[fieldName] = jsonb(columnName)\n        break\n      }\n\n      case 'date': {\n        targetTable[fieldName] = timestamp(columnName, {\n          mode: 'string',\n          precision: 3,\n          withTimezone: true,\n        })\n        break\n      }\n\n      case 'point': {\n        break\n      }\n\n      case 'radio':\n      case 'select': {\n        const enumName = `enum_${newTableName}_${columnPrefix || ''}${toSnakeCase(field.name)}`\n\n        adapter.enums[enumName] = pgEnum(\n          enumName,\n          field.options.map((option) => {\n            if (optionIsObject(option)) {\n              return option.value\n            }\n\n            return option\n          }) as [string, ...string[]],\n        )\n\n        if (field.type === 'select' && field.hasMany) {\n          const baseColumns: Record<string, PgColumnBuilder> = {\n            order: integer('order').notNull(),\n            parent: parentIDColumnMap[parentIDColType]('parent_id')\n              .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n              .notNull(),\n            value: adapter.enums[enumName]('value'),\n          }\n\n          const baseExtraConfig: Record<\n            string,\n            (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n          > = {}\n\n          if (field.localized) {\n            baseColumns.locale = adapter.enums.enum__locales('locale').notNull()\n            baseExtraConfig.parentOrderLocale = (cols) =>\n              unique().on(cols.parent, cols.order, cols.locale)\n          } else {\n            baseExtraConfig.parent = (cols) => index('parent_idx').on(cols.parent)\n            baseExtraConfig.order = (cols) => index('order_idx').on(cols.order)\n          }\n\n          if (field.index) {\n            baseExtraConfig.value = (cols) => index('value_idx').on(cols.value)\n          }\n\n          const selectTableName = `${newTableName}_${toSnakeCase(fieldName)}`\n\n          buildTable({\n            adapter,\n            baseColumns,\n            baseExtraConfig,\n            disableUnique,\n            fields: [],\n            tableName: selectTableName,\n          })\n\n          relationsToBuild.set(fieldName, selectTableName)\n\n          const selectTableRelations = relations(adapter.tables[selectTableName], ({ one }) => {\n            const result: Record<string, Relation<string>> = {\n              parent: one(adapter.tables[parentTableName], {\n                fields: [adapter.tables[selectTableName].parent],\n                references: [adapter.tables[parentTableName].id],\n              }),\n            }\n\n            return result\n          })\n\n          adapter.relations[`relation_${selectTableName}`] = selectTableRelations\n        } else {\n          targetTable[fieldName] = adapter.enums[enumName](fieldName)\n        }\n        break\n      }\n\n      case 'checkbox': {\n        targetTable[fieldName] = boolean(columnName)\n        break\n      }\n\n      case 'array': {\n        const baseColumns: Record<string, PgColumnBuilder> = {\n          _order: integer('_order').notNull(),\n          _parentID: parentIDColumnMap[parentIDColType]('_parent_id')\n            .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n            .notNull(),\n        }\n\n        const baseExtraConfig: Record<\n          string,\n          (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n        > = {}\n\n        if (field.localized && adapter.payload.config.localization) {\n          baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n          baseExtraConfig._parentOrderLocale = (cols) =>\n            unique().on(cols._parentID, cols._order, cols._locale)\n        } else {\n          baseExtraConfig._parentOrder = (cols) => unique().on(cols._parentID, cols._order)\n        }\n\n        const arrayTableName = `${newTableName}_${toSnakeCase(field.name)}`\n\n        const { relationsToBuild: subRelationsToBuild } = buildTable({\n          adapter,\n          baseColumns,\n          baseExtraConfig,\n          disableUnique,\n          fields: field.fields,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n          tableName: arrayTableName,\n        })\n\n        relationsToBuild.set(fieldName, arrayTableName)\n\n        const arrayTableRelations = relations(adapter.tables[arrayTableName], ({ many, one }) => {\n          const result: Record<string, Relation<string>> = {\n            _parentID: one(adapter.tables[parentTableName], {\n              fields: [adapter.tables[arrayTableName]._parentID],\n              references: [adapter.tables[parentTableName].id],\n            }),\n          }\n\n          if (hasLocalesTable(field.fields)) {\n            result._locales = many(adapter.tables[`${arrayTableName}_locales`])\n          }\n\n          subRelationsToBuild.forEach((val, key) => {\n            result[key] = many(adapter.tables[val])\n          })\n\n          return result\n        })\n\n        adapter.relations[`relations_${arrayTableName}`] = arrayTableRelations\n\n        break\n      }\n\n      case 'blocks': {\n        field.blocks.forEach((block) => {\n          const blockTableName = `${rootTableName}_blocks_${toSnakeCase(block.slug)}`\n          if (!adapter.tables[blockTableName]) {\n            const baseColumns: Record<string, PgColumnBuilder> = {\n              _order: integer('_order').notNull(),\n              _parentID: parentIDColumnMap[rootTableIDColType]('_parent_id')\n                .references(() => adapter.tables[rootTableName].id, { onDelete: 'cascade' })\n                .notNull(),\n              _path: text('_path').notNull(),\n            }\n\n            const baseExtraConfig: Record<\n              string,\n              (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n            > = {}\n\n            if (field.localized && adapter.payload.config.localization) {\n              baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n              baseExtraConfig._parentPathOrderLocale = (cols) =>\n                unique().on(cols._parentID, cols._path, cols._order, cols._locale)\n            } else {\n              baseExtraConfig._parentPathOrder = (cols) =>\n                unique().on(cols._parentID, cols._path, cols._order)\n            }\n\n            const { relationsToBuild: subRelationsToBuild } = buildTable({\n              adapter,\n              baseColumns,\n              baseExtraConfig,\n              disableUnique,\n              fields: block.fields,\n              rootRelationsToBuild,\n              rootTableIDColType,\n              rootTableName,\n              tableName: blockTableName,\n            })\n\n            const blockTableRelations = relations(\n              adapter.tables[blockTableName],\n              ({ many, one }) => {\n                const result: Record<string, Relation<string>> = {\n                  _parentID: one(adapter.tables[rootTableName], {\n                    fields: [adapter.tables[blockTableName]._parentID],\n                    references: [adapter.tables[rootTableName].id],\n                  }),\n                }\n\n                if (hasLocalesTable(block.fields)) {\n                  result._locales = many(adapter.tables[`${blockTableName}_locales`])\n                }\n\n                subRelationsToBuild.forEach((val, key) => {\n                  result[key] = many(adapter.tables[val])\n                })\n\n                return result\n              },\n            )\n\n            adapter.relations[`relations_${blockTableName}`] = blockTableRelations\n          } else if (process.env.NODE_ENV !== 'production') {\n            validateExistingBlockIsIdentical({\n              block,\n              localized: field.localized,\n              rootTableName,\n              table: adapter.tables[blockTableName],\n            })\n          }\n\n          rootRelationsToBuild.set(`_blocks_${block.slug}`, blockTableName)\n        })\n\n        break\n      }\n\n      case 'tab':\n      case 'group': {\n        if (!('name' in field)) {\n          const {\n            hasLocalizedField: groupHasLocalizedField,\n            hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n            hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n            hasManyNumberField: groupHasManyNumberField,\n          } = traverseFields({\n            adapter,\n            buildRelationships,\n            columnPrefix,\n            columns,\n            disableUnique,\n            fieldPrefix,\n            fields: field.fields,\n            forceLocalized,\n            indexes,\n            localesColumns,\n            localesIndexes,\n            newTableName: parentTableName,\n            parentTableName,\n            relationsToBuild,\n            relationships,\n            rootRelationsToBuild,\n            rootTableIDColType,\n            rootTableName,\n          })\n\n          if (groupHasLocalizedField) hasLocalizedField = true\n          if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n          if (groupHasManyNumberField) hasManyNumberField = true\n          if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n          break\n        }\n\n        const {\n          hasLocalizedField: groupHasLocalizedField,\n          hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n          hasManyNumberField: groupHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildRelationships,\n          columnPrefix: `${columnName}_`,\n          columns,\n          disableUnique,\n          fieldPrefix: `${fieldName}_`,\n          fields: field.fields,\n          forceLocalized: field.localized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName: `${parentTableName}_${columnName}`,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (groupHasLocalizedField) hasLocalizedField = true\n        if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (groupHasManyNumberField) hasManyNumberField = true\n        if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n        break\n      }\n\n      case 'tabs': {\n        const {\n          hasLocalizedField: tabHasLocalizedField,\n          hasLocalizedManyNumberField: tabHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: tabHasLocalizedRelationshipField,\n          hasManyNumberField: tabHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildRelationships,\n          columnPrefix,\n          columns,\n          disableUnique,\n          fieldPrefix,\n          fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n          forceLocalized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (tabHasLocalizedField) hasLocalizedField = true\n        if (tabHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (tabHasManyNumberField) hasManyNumberField = true\n        if (tabHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n\n        break\n      }\n\n      case 'row':\n      case 'collapsible': {\n        const {\n          hasLocalizedField: rowHasLocalizedField,\n          hasLocalizedManyNumberField: rowHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: rowHasLocalizedRelationshipField,\n          hasManyNumberField: rowHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildRelationships,\n          columnPrefix,\n          columns,\n          disableUnique,\n          fieldPrefix,\n          fields: field.fields,\n          forceLocalized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName: parentTableName,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (rowHasLocalizedField) hasLocalizedField = true\n        if (rowHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (rowHasManyNumberField) hasManyNumberField = true\n        if (rowHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n        break\n      }\n\n      case 'relationship':\n      case 'upload':\n        if (Array.isArray(field.relationTo)) {\n          field.relationTo.forEach((relation) => relationships.add(relation))\n        } else {\n          relationships.add(field.relationTo)\n        }\n\n        if (field.localized && adapter.payload.config.localization) {\n          hasLocalizedRelationshipField = true\n        }\n        break\n\n      default:\n        break\n    }\n\n    const condition = field.admin && field.admin.condition\n\n    if (targetTable[fieldName] && 'required' in field && field.required && !condition) {\n      targetTable[fieldName].notNull()\n    }\n  })\n\n  return {\n    hasLocalizedField,\n    hasLocalizedManyNumberField,\n    hasLocalizedRelationshipField,\n    hasManyNumberField,\n  }\n}\n"],"names":["traverseFields","adapter","buildRelationships","columnPrefix","columns","disableUnique","fieldPrefix","fields","forceLocalized","indexes","localesColumns","localesIndexes","newTableName","parentTableName","relationsToBuild","relationships","rootRelationsToBuild","rootTableIDColType","rootTableName","hasLocalizedField","hasLocalizedRelationshipField","hasManyNumberField","hasLocalizedManyNumberField","parentIDColType","id","PgNumericBuilder","PgVarcharBuilder","forEach","field","name","columnName","fieldName","targetTable","targetIndexes","fieldAffectsData","toSnakeCase","payload","config","localization","localized","unique","index","includes","type","hasMany","createIndex","varchar","InvalidConfiguration","numeric","jsonb","timestamp","mode","precision","withTimezone","enumName","enums","pgEnum","options","map","option","optionIsObject","value","baseColumns","order","integer","notNull","parent","parentIDColumnMap","references","tables","onDelete","baseExtraConfig","locale","enum__locales","parentOrderLocale","cols","on","selectTableName","buildTable","tableName","set","selectTableRelations","relations","one","result","boolean","_order","_parentID","_locale","_parentOrderLocale","_parentOrder","arrayTableName","subRelationsToBuild","arrayTableRelations","many","hasLocalesTable","_locales","val","key","blocks","block","blockTableName","slug","_path","text","_parentPathOrderLocale","_parentPathOrder","blockTableRelations","process","env","NODE_ENV","validateExistingBlockIsIdentical","table","groupHasLocalizedField","groupHasLocalizedManyNumberField","groupHasLocalizedRelationshipField","groupHasManyNumberField","tabHasLocalizedField","tabHasLocalizedManyNumberField","tabHasLocalizedRelationshipField","tabHasManyNumberField","tabs","tab","rowHasLocalizedField","rowHasLocalizedManyNumberField","rowHasLocalizedRelationshipField","rowHasManyNumberField","Array","isArray","relationTo","relation","add","condition","admin","required"],"mappings":"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"}
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "validateExistingBlockIsIdentical", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return validateExistingBlockIsIdentical;
9
+ }
10
+ });
11
+ const _errors = require("payload/errors");
12
+ const _utilities = require("payload/utilities");
13
+ const validateExistingBlockIsIdentical = ({ block, localized, rootTableName, table })=>{
14
+ if (table) {
15
+ const fieldNames = (0, _utilities.flattenTopLevelFields)(block.fields).flatMap((field)=>field.name);
16
+ Object.keys(table).forEach((fieldName)=>{
17
+ if (![
18
+ '_locale',
19
+ '_order',
20
+ '_parentID',
21
+ '_path'
22
+ ].includes(fieldName)) {
23
+ if (fieldNames.indexOf(fieldName) === -1) {
24
+ throw new _errors.InvalidConfiguration(`The table ${rootTableName} has multiple blocks with slug ${block.slug}, but the schemas do not match. One block includes the field ${fieldName}, while the other block does not.`);
25
+ }
26
+ }
27
+ });
28
+ if (Boolean(localized) !== Boolean(table._locale)) {
29
+ throw new _errors.InvalidConfiguration(`The table ${rootTableName} has multiple blocks with slug ${block.slug}, but the schemas do not match. One is localized, but another is not. Block schemas of the same name must match exactly.`);
30
+ }
31
+ }
32
+ };
33
+
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY2hlbWEvdmFsaWRhdGVFeGlzdGluZ0Jsb2NrSXNJZGVudGljYWwudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBCbG9jayB9IGZyb20gJ3BheWxvYWQvdHlwZXMnXG5cbmltcG9ydCB7IEludmFsaWRDb25maWd1cmF0aW9uIH0gZnJvbSAncGF5bG9hZC9lcnJvcnMnXG5pbXBvcnQgeyBmbGF0dGVuVG9wTGV2ZWxGaWVsZHMgfSBmcm9tICdwYXlsb2FkL3V0aWxpdGllcydcblxuaW1wb3J0IHR5cGUgeyBHZW5lcmljVGFibGUgfSBmcm9tICcuLi90eXBlcydcblxudHlwZSBBcmdzID0ge1xuICBibG9jazogQmxvY2tcbiAgbG9jYWxpemVkOiBib29sZWFuXG4gIHJvb3RUYWJsZU5hbWU6IHN0cmluZ1xuICB0YWJsZTogR2VuZXJpY1RhYmxlXG59XG5cbmV4cG9ydCBjb25zdCB2YWxpZGF0ZUV4aXN0aW5nQmxvY2tJc0lkZW50aWNhbCA9ICh7XG4gIGJsb2NrLFxuICBsb2NhbGl6ZWQsXG4gIHJvb3RUYWJsZU5hbWUsXG4gIHRhYmxlLFxufTogQXJncyk6IHZvaWQgPT4ge1xuICBpZiAodGFibGUpIHtcbiAgICBjb25zdCBmaWVsZE5hbWVzID0gZmxhdHRlblRvcExldmVsRmllbGRzKGJsb2NrLmZpZWxkcykuZmxhdE1hcCgoZmllbGQpID0+IGZpZWxkLm5hbWUpXG5cbiAgICBPYmplY3Qua2V5cyh0YWJsZSkuZm9yRWFjaCgoZmllbGROYW1lKSA9PiB7XG4gICAgICBpZiAoIVsnX2xvY2FsZScsICdfb3JkZXInLCAnX3BhcmVudElEJywgJ19wYXRoJ10uaW5jbHVkZXMoZmllbGROYW1lKSkge1xuICAgICAgICBpZiAoZmllbGROYW1lcy5pbmRleE9mKGZpZWxkTmFtZSkgPT09IC0xKSB7XG4gICAgICAgICAgdGhyb3cgbmV3IEludmFsaWRDb25maWd1cmF0aW9uKFxuICAgICAgICAgICAgYFRoZSB0YWJsZSAke3Jvb3RUYWJsZU5hbWV9IGhhcyBtdWx0aXBsZSBibG9ja3Mgd2l0aCBzbHVnICR7YmxvY2suc2x1Z30sIGJ1dCB0aGUgc2NoZW1hcyBkbyBub3QgbWF0Y2guIE9uZSBibG9jayBpbmNsdWRlcyB0aGUgZmllbGQgJHtmaWVsZE5hbWV9LCB3aGlsZSB0aGUgb3RoZXIgYmxvY2sgZG9lcyBub3QuYCxcbiAgICAgICAgICApXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9KVxuXG4gICAgaWYgKEJvb2xlYW4obG9jYWxpemVkKSAhPT0gQm9vbGVhbih0YWJsZS5fbG9jYWxlKSkge1xuICAgICAgdGhyb3cgbmV3IEludmFsaWRDb25maWd1cmF0aW9uKFxuICAgICAgICBgVGhlIHRhYmxlICR7cm9vdFRhYmxlTmFtZX0gaGFzIG11bHRpcGxlIGJsb2NrcyB3aXRoIHNsdWcgJHtibG9jay5zbHVnfSwgYnV0IHRoZSBzY2hlbWFzIGRvIG5vdCBtYXRjaC4gT25lIGlzIGxvY2FsaXplZCwgYnV0IGFub3RoZXIgaXMgbm90LiBCbG9jayBzY2hlbWFzIG9mIHRoZSBzYW1lIG5hbWUgbXVzdCBtYXRjaCBleGFjdGx5LmAsXG4gICAgICApXG4gICAgfVxuICB9XG59XG4iXSwibmFtZXMiOlsidmFsaWRhdGVFeGlzdGluZ0Jsb2NrSXNJZGVudGljYWwiLCJibG9jayIsImxvY2FsaXplZCIsInJvb3RUYWJsZU5hbWUiLCJ0YWJsZSIsImZpZWxkTmFtZXMiLCJmbGF0dGVuVG9wTGV2ZWxGaWVsZHMiLCJmaWVsZHMiLCJmbGF0TWFwIiwiZmllbGQiLCJuYW1lIiwiT2JqZWN0Iiwia2V5cyIsImZvckVhY2giLCJmaWVsZE5hbWUiLCJpbmNsdWRlcyIsImluZGV4T2YiLCJJbnZhbGlkQ29uZmlndXJhdGlvbiIsInNsdWciLCJCb29sZWFuIiwiX2xvY2FsZSJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFjYUE7OztlQUFBQTs7O3dCQVp3QjsyQkFDQztBQVcvQixNQUFNQSxtQ0FBbUMsQ0FBQyxFQUMvQ0MsS0FBSyxFQUNMQyxTQUFTLEVBQ1RDLGFBQWEsRUFDYkMsS0FBSyxFQUNBO0lBQ0wsSUFBSUEsT0FBTztRQUNULE1BQU1DLGFBQWFDLElBQUFBLGdDQUFxQixFQUFDTCxNQUFNTSxNQUFNLEVBQUVDLE9BQU8sQ0FBQyxDQUFDQyxRQUFVQSxNQUFNQyxJQUFJO1FBRXBGQyxPQUFPQyxJQUFJLENBQUNSLE9BQU9TLE9BQU8sQ0FBQyxDQUFDQztZQUMxQixJQUFJLENBQUM7Z0JBQUM7Z0JBQVc7Z0JBQVU7Z0JBQWE7YUFBUSxDQUFDQyxRQUFRLENBQUNELFlBQVk7Z0JBQ3BFLElBQUlULFdBQVdXLE9BQU8sQ0FBQ0YsZUFBZSxDQUFDLEdBQUc7b0JBQ3hDLE1BQU0sSUFBSUcsNEJBQW9CLENBQzVCLENBQUMsVUFBVSxFQUFFZCxjQUFjLCtCQUErQixFQUFFRixNQUFNaUIsSUFBSSxDQUFDLDZEQUE2RCxFQUFFSixVQUFVLGlDQUFpQyxDQUFDO2dCQUV0TDtZQUNGO1FBQ0Y7UUFFQSxJQUFJSyxRQUFRakIsZUFBZWlCLFFBQVFmLE1BQU1nQixPQUFPLEdBQUc7WUFDakQsTUFBTSxJQUFJSCw0QkFBb0IsQ0FDNUIsQ0FBQyxVQUFVLEVBQUVkLGNBQWMsK0JBQStCLEVBQUVGLE1BQU1pQixJQUFJLENBQUMsd0hBQXdILENBQUM7UUFFcE07SUFDRjtBQUNGIn0=
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "beginTransaction", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return beginTransaction;
9
+ }
10
+ });
11
+ const _uuid = require("uuid");
12
+ const beginTransaction = async function beginTransaction() {
13
+ let id;
14
+ try {
15
+ id = (0, _uuid.v4)();
16
+ let reject;
17
+ let resolve;
18
+ let transaction;
19
+ let transactionReady;
20
+ // Drizzle only exposes a transactions API that is sufficient if you
21
+ // can directly pass around the `tx` argument. But our operations are spread
22
+ // over many files and we don't want to pass the `tx` around like that,
23
+ // so instead, we "lift" up the `resolve` and `reject` methods
24
+ // and will call them in our respective transaction methods
25
+ // eslint-disable-next-line @typescript-eslint/no-floating-promises
26
+ this.db.transaction(async (tx)=>{
27
+ transaction = tx;
28
+ await new Promise((res, rej)=>{
29
+ transactionReady();
30
+ resolve = res;
31
+ reject = rej;
32
+ });
33
+ }).catch(()=>{
34
+ // swallow
35
+ });
36
+ // Need to wait until the transaction is ready
37
+ // before binding its `resolve` and `reject` methods below
38
+ await new Promise((resolve)=>transactionReady = resolve);
39
+ this.sessions[id] = {
40
+ db: transaction,
41
+ reject,
42
+ resolve
43
+ };
44
+ } catch (err) {
45
+ this.payload.logger.error(`Error: cannot begin transaction: ${err.message}`, err);
46
+ process.exit(1);
47
+ }
48
+ return id;
49
+ };
50
+
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90cmFuc2FjdGlvbnMvYmVnaW5UcmFuc2FjdGlvbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEJlZ2luVHJhbnNhY3Rpb24gfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuXG5pbXBvcnQgeyB2NCBhcyB1dWlkIH0gZnJvbSAndXVpZCdcblxuaW1wb3J0IHR5cGUgeyBEcml6emxlVHJhbnNhY3Rpb24sIFBvc3RncmVzQWRhcHRlciB9IGZyb20gJy4uL3R5cGVzJ1xuXG5leHBvcnQgY29uc3QgYmVnaW5UcmFuc2FjdGlvbjogQmVnaW5UcmFuc2FjdGlvbiA9IGFzeW5jIGZ1bmN0aW9uIGJlZ2luVHJhbnNhY3Rpb24oXG4gIHRoaXM6IFBvc3RncmVzQWRhcHRlcixcbikge1xuICBsZXQgaWRcbiAgdHJ5IHtcbiAgICBpZCA9IHV1aWQoKVxuXG4gICAgbGV0IHJlamVjdDogKHZhbHVlPzogdW5rbm93bikgPT4gdm9pZFxuICAgIGxldCByZXNvbHZlOiAodmFsdWU/OiB1bmtub3duKSA9PiB2b2lkXG4gICAgbGV0IHRyYW5zYWN0aW9uOiBEcml6emxlVHJhbnNhY3Rpb25cblxuICAgIGxldCB0cmFuc2FjdGlvblJlYWR5OiAodmFsdWU/OiB1bmtub3duKSA9PiB2b2lkXG5cbiAgICAvLyBEcml6emxlIG9ubHkgZXhwb3NlcyBhIHRyYW5zYWN0aW9ucyBBUEkgdGhhdCBpcyBzdWZmaWNpZW50IGlmIHlvdVxuICAgIC8vIGNhbiBkaXJlY3RseSBwYXNzIGFyb3VuZCB0aGUgYHR4YCBhcmd1bWVudC4gQnV0IG91ciBvcGVyYXRpb25zIGFyZSBzcHJlYWRcbiAgICAvLyBvdmVyIG1hbnkgZmlsZXMgYW5kIHdlIGRvbid0IHdhbnQgdG8gcGFzcyB0aGUgYHR4YCBhcm91bmQgbGlrZSB0aGF0LFxuICAgIC8vIHNvIGluc3RlYWQsIHdlIFwibGlmdFwiIHVwIHRoZSBgcmVzb2x2ZWAgYW5kIGByZWplY3RgIG1ldGhvZHNcbiAgICAvLyBhbmQgd2lsbCBjYWxsIHRoZW0gaW4gb3VyIHJlc3BlY3RpdmUgdHJhbnNhY3Rpb24gbWV0aG9kc1xuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1mbG9hdGluZy1wcm9taXNlc1xuICAgIHRoaXMuZGJcbiAgICAgIC50cmFuc2FjdGlvbihhc3luYyAodHgpID0+IHtcbiAgICAgICAgdHJhbnNhY3Rpb24gPSB0eFxuICAgICAgICBhd2FpdCBuZXcgUHJvbWlzZSgocmVzLCByZWopID0+IHtcbiAgICAgICAgICB0cmFuc2FjdGlvblJlYWR5KClcbiAgICAgICAgICByZXNvbHZlID0gcmVzXG4gICAgICAgICAgcmVqZWN0ID0gcmVqXG4gICAgICAgIH0pXG4gICAgICB9KVxuICAgICAgLmNhdGNoKCgpID0+IHtcbiAgICAgICAgLy8gc3dhbGxvd1xuICAgICAgfSlcblxuICAgIC8vIE5lZWQgdG8gd2FpdCB1bnRpbCB0aGUgdHJhbnNhY3Rpb24gaXMgcmVhZHlcbiAgICAvLyBiZWZvcmUgYmluZGluZyBpdHMgYHJlc29sdmVgIGFuZCBgcmVqZWN0YCBtZXRob2RzIGJlbG93XG4gICAgYXdhaXQgbmV3IFByb21pc2UoKHJlc29sdmUpID0+ICh0cmFuc2FjdGlvblJlYWR5ID0gcmVzb2x2ZSkpXG5cbiAgICB0aGlzLnNlc3Npb25zW2lkXSA9IHtcbiAgICAgIGRiOiB0cmFuc2FjdGlvbixcbiAgICAgIHJlamVjdCxcbiAgICAgIHJlc29sdmUsXG4gICAgfVxuICB9IGNhdGNoIChlcnIpIHtcbiAgICB0aGlzLnBheWxvYWQubG9nZ2VyLmVycm9yKGBFcnJvcjogY2Fubm90IGJlZ2luIHRyYW5zYWN0aW9uOiAke2Vyci5tZXNzYWdlfWAsIGVycilcbiAgICBwcm9jZXNzLmV4aXQoMSlcbiAgfVxuXG4gIHJldHVybiBpZFxufVxuIl0sIm5hbWVzIjpbImJlZ2luVHJhbnNhY3Rpb24iLCJpZCIsInV1aWQiLCJyZWplY3QiLCJyZXNvbHZlIiwidHJhbnNhY3Rpb24iLCJ0cmFuc2FjdGlvblJlYWR5IiwiZGIiLCJ0eCIsIlByb21pc2UiLCJyZXMiLCJyZWoiLCJjYXRjaCIsInNlc3Npb25zIiwiZXJyIiwicGF5bG9hZCIsImxvZ2dlciIsImVycm9yIiwibWVzc2FnZSIsInByb2Nlc3MiLCJleGl0Il0sIm1hcHBpbmdzIjoiOzs7OytCQU1hQTs7O2VBQUFBOzs7c0JBSmM7QUFJcEIsTUFBTUEsbUJBQXFDLGVBQWVBO0lBRy9ELElBQUlDO0lBQ0osSUFBSTtRQUNGQSxLQUFLQyxJQUFBQSxRQUFJO1FBRVQsSUFBSUM7UUFDSixJQUFJQztRQUNKLElBQUlDO1FBRUosSUFBSUM7UUFFSixvRUFBb0U7UUFDcEUsNEVBQTRFO1FBQzVFLHVFQUF1RTtRQUN2RSw4REFBOEQ7UUFDOUQsMkRBQTJEO1FBRTNELG1FQUFtRTtRQUNuRSxJQUFJLENBQUNDLEVBQUUsQ0FDSkYsV0FBVyxDQUFDLE9BQU9HO1lBQ2xCSCxjQUFjRztZQUNkLE1BQU0sSUFBSUMsUUFBUSxDQUFDQyxLQUFLQztnQkFDdEJMO2dCQUNBRixVQUFVTTtnQkFDVlAsU0FBU1E7WUFDWDtRQUNGLEdBQ0NDLEtBQUssQ0FBQztRQUNMLFVBQVU7UUFDWjtRQUVGLDhDQUE4QztRQUM5QywwREFBMEQ7UUFDMUQsTUFBTSxJQUFJSCxRQUFRLENBQUNMLFVBQWFFLG1CQUFtQkY7UUFFbkQsSUFBSSxDQUFDUyxRQUFRLENBQUNaLEdBQUcsR0FBRztZQUNsQk0sSUFBSUY7WUFDSkY7WUFDQUM7UUFDRjtJQUNGLEVBQUUsT0FBT1UsS0FBSztRQUNaLElBQUksQ0FBQ0MsT0FBTyxDQUFDQyxNQUFNLENBQUNDLEtBQUssQ0FBQyxDQUFDLGlDQUFpQyxFQUFFSCxJQUFJSSxPQUFPLENBQUMsQ0FBQyxFQUFFSjtRQUM3RUssUUFBUUMsSUFBSSxDQUFDO0lBQ2Y7SUFFQSxPQUFPbkI7QUFDVCJ9
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "commitTransaction", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return commitTransaction;
9
+ }
10
+ });
11
+ const commitTransaction = async function commitTransaction(id) {
12
+ if (!this.sessions[id]) {
13
+ this.payload.logger.warn('commitTransaction called when no transaction exists');
14
+ return;
15
+ }
16
+ try {
17
+ this.sessions[id].resolve();
18
+ } catch (err) {
19
+ this.sessions[id].reject();
20
+ }
21
+ delete this.sessions[id];
22
+ };
23
+
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90cmFuc2FjdGlvbnMvY29tbWl0VHJhbnNhY3Rpb24udHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDb21taXRUcmFuc2FjdGlvbiB9IGZyb20gJ3BheWxvYWQvZGF0YWJhc2UnXG5cbmV4cG9ydCBjb25zdCBjb21taXRUcmFuc2FjdGlvbjogQ29tbWl0VHJhbnNhY3Rpb24gPSBhc3luYyBmdW5jdGlvbiBjb21taXRUcmFuc2FjdGlvbihpZCkge1xuICBpZiAoIXRoaXMuc2Vzc2lvbnNbaWRdKSB7XG4gICAgdGhpcy5wYXlsb2FkLmxvZ2dlci53YXJuKCdjb21taXRUcmFuc2FjdGlvbiBjYWxsZWQgd2hlbiBubyB0cmFuc2FjdGlvbiBleGlzdHMnKVxuICAgIHJldHVyblxuICB9XG5cbiAgdHJ5IHtcbiAgICB0aGlzLnNlc3Npb25zW2lkXS5yZXNvbHZlKClcbiAgfSBjYXRjaCAoZXJyOiB1bmtub3duKSB7XG4gICAgdGhpcy5zZXNzaW9uc1tpZF0ucmVqZWN0KClcbiAgfVxuXG4gIGRlbGV0ZSB0aGlzLnNlc3Npb25zW2lkXVxufVxuIl0sIm5hbWVzIjpbImNvbW1pdFRyYW5zYWN0aW9uIiwiaWQiLCJzZXNzaW9ucyIsInBheWxvYWQiLCJsb2dnZXIiLCJ3YXJuIiwicmVzb2x2ZSIsImVyciIsInJlamVjdCJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFFYUE7OztlQUFBQTs7O0FBQU4sTUFBTUEsb0JBQXVDLGVBQWVBLGtCQUFrQkMsRUFBRTtJQUNyRixJQUFJLENBQUMsSUFBSSxDQUFDQyxRQUFRLENBQUNELEdBQUcsRUFBRTtRQUN0QixJQUFJLENBQUNFLE9BQU8sQ0FBQ0MsTUFBTSxDQUFDQyxJQUFJLENBQUM7UUFDekI7SUFDRjtJQUVBLElBQUk7UUFDRixJQUFJLENBQUNILFFBQVEsQ0FBQ0QsR0FBRyxDQUFDSyxPQUFPO0lBQzNCLEVBQUUsT0FBT0MsS0FBYztRQUNyQixJQUFJLENBQUNMLFFBQVEsQ0FBQ0QsR0FBRyxDQUFDTyxNQUFNO0lBQzFCO0lBRUEsT0FBTyxJQUFJLENBQUNOLFFBQVEsQ0FBQ0QsR0FBRztBQUMxQiJ9