@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.
- package/dist/connect.js +82 -0
- package/dist/create.js +32 -0
- package/dist/createGlobal.js +32 -0
- package/dist/createGlobalVersion.js +48 -0
- package/dist/createMigration.js +85 -0
- package/dist/createVersion.js +54 -0
- package/dist/deleteMany.js +44 -0
- package/dist/deleteOne.js +47 -0
- package/dist/deleteVersions.js +46 -0
- package/dist/destroy.js +16 -0
- package/dist/find/buildFindManyArgs.js +61 -0
- package/dist/find/chainMethods.js +21 -0
- package/dist/find/findMany.js +197 -0
- package/dist/find/traverseFields.js +118 -0
- package/dist/find.js +35 -0
- package/dist/findGlobal.js +38 -0
- package/dist/findGlobalVersions.js +39 -0
- package/dist/findOne.js +49 -0
- package/dist/findVersions.js +39 -0
- package/dist/index.js +95 -0
- package/dist/init.js +74 -0
- package/dist/migrate.js +81 -0
- package/dist/migrateStatus.js +54 -0
- package/dist/mock.js +13 -0
- package/dist/queries/buildAndOrConditions.js +39 -0
- package/dist/queries/buildQuery.js +80 -0
- package/dist/queries/createJSONQuery/convertPathToJSONTraversal.js +24 -0
- package/dist/queries/createJSONQuery/formatJSONPathSegment.js +15 -0
- package/dist/queries/createJSONQuery/index.js +64 -0
- package/dist/queries/getTableColumnFromPath.js +333 -0
- package/dist/queries/operatorMap.js +34 -0
- package/dist/queries/parseParams.js +146 -0
- package/dist/queries/sanitizeQueryValue.js +79 -0
- package/dist/queryDrafts.js +56 -0
- package/dist/reference.js +76 -0
- package/dist/schema/build.js +245 -0
- package/dist/schema/createIndex.js +19 -0
- package/dist/schema/parentIDColumnMap.js +18 -0
- package/dist/schema/traverseFields.js +430 -0
- package/dist/schema/validateExistingBlockIsIdentical.js +34 -0
- package/dist/transactions/beginTransaction.js +51 -0
- package/dist/transactions/commitTransaction.js +24 -0
- package/dist/transactions/rollbackTransaction.js +20 -0
- package/dist/transform/read/hasManyNumber.js +20 -0
- package/dist/transform/read/index.js +42 -0
- package/dist/transform/read/relationship.js +74 -0
- package/dist/transform/read/traverseFields.js +325 -0
- package/dist/transform/write/array.js +55 -0
- package/dist/transform/write/blocks.js +56 -0
- package/dist/transform/write/index.js +46 -0
- package/dist/transform/write/numbers.js +21 -0
- package/dist/transform/write/relationships.js +33 -0
- package/dist/transform/write/selects.js +29 -0
- package/dist/transform/write/traverseFields.js +379 -0
- package/dist/transform/write/types.js +6 -0
- package/dist/types.js +6 -0
- package/dist/update.js +48 -0
- package/dist/updateGlobal.js +39 -0
- package/dist/updateGlobalVersion.js +50 -0
- package/dist/updateVersion.js +50 -0
- package/dist/upsertRow/deleteExistingArrayRows.js +20 -0
- package/dist/upsertRow/deleteExistingRowsByPath.js +43 -0
- package/dist/upsertRow/index.js +243 -0
- package/dist/upsertRow/insertArrays.js +64 -0
- package/dist/upsertRow/types.js +6 -0
- package/dist/utilities/appendPrefixToKeys.js +16 -0
- package/dist/utilities/createBlocksMap.js +39 -0
- package/dist/utilities/createMigrationTable.js +23 -0
- package/dist/utilities/createRelationshipMap.js +29 -0
- package/dist/utilities/hasLocalesTable.js +21 -0
- package/dist/utilities/isArrayOfRows.js +15 -0
- package/dist/utilities/migrationTableExists.js +19 -0
- package/dist/webpack.js +30 -0
- 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
|