@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,333 @@
|
|
1
|
+
/* eslint-disable no-param-reassign */ "use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
3
|
+
value: true
|
4
|
+
});
|
5
|
+
Object.defineProperty(exports, "getTableColumnFromPath", {
|
6
|
+
enumerable: true,
|
7
|
+
get: function() {
|
8
|
+
return getTableColumnFromPath;
|
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 _utilities = require("payload/utilities");
|
16
|
+
const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
|
17
|
+
const _uuid = require("uuid");
|
18
|
+
function _interop_require_default(obj) {
|
19
|
+
return obj && obj.__esModule ? obj : {
|
20
|
+
default: obj
|
21
|
+
};
|
22
|
+
}
|
23
|
+
const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPrefix = '', constraints = [], fields, joinAliases, joins, locale: incomingLocale, pathSegments: incomingSegments, selectFields, tableName })=>{
|
24
|
+
const fieldPath = incomingSegments[0];
|
25
|
+
let locale = incomingLocale;
|
26
|
+
const field = (0, _utilities.flattenTopLevelFields)(fields).find((fieldToFind)=>(0, _types.fieldAffectsData)(fieldToFind) && fieldToFind.name === fieldPath);
|
27
|
+
let newTableName = tableName;
|
28
|
+
if (!field && fieldPath === 'id') {
|
29
|
+
selectFields.id = adapter.tables[newTableName].id;
|
30
|
+
return {
|
31
|
+
columnName: 'id',
|
32
|
+
constraints,
|
33
|
+
field: {
|
34
|
+
name: 'id',
|
35
|
+
type: 'number'
|
36
|
+
},
|
37
|
+
table: adapter.tables[newTableName]
|
38
|
+
};
|
39
|
+
}
|
40
|
+
if (field) {
|
41
|
+
const pathSegments = [
|
42
|
+
...incomingSegments
|
43
|
+
];
|
44
|
+
// If next segment is a locale,
|
45
|
+
// we need to take it out and use it as the locale from this point on
|
46
|
+
if ('localized' in field && field.localized && adapter.payload.config.localization) {
|
47
|
+
const matchedLocale = adapter.payload.config.localization.localeCodes.find((locale)=>locale === pathSegments[1]);
|
48
|
+
if (matchedLocale) {
|
49
|
+
locale = matchedLocale;
|
50
|
+
pathSegments.splice(1, 1);
|
51
|
+
}
|
52
|
+
}
|
53
|
+
switch(field.type){
|
54
|
+
case 'tabs':
|
55
|
+
{
|
56
|
+
return getTableColumnFromPath({
|
57
|
+
adapter,
|
58
|
+
aliasTable,
|
59
|
+
collectionPath,
|
60
|
+
columnPrefix,
|
61
|
+
constraints,
|
62
|
+
fields: field.tabs.map((tab)=>({
|
63
|
+
...tab,
|
64
|
+
type: 'tab'
|
65
|
+
})),
|
66
|
+
joinAliases,
|
67
|
+
joins,
|
68
|
+
locale,
|
69
|
+
pathSegments: pathSegments.slice(1),
|
70
|
+
selectFields,
|
71
|
+
tableName: newTableName
|
72
|
+
});
|
73
|
+
}
|
74
|
+
case 'tab':
|
75
|
+
{
|
76
|
+
if ((0, _types.tabHasName)(field)) {
|
77
|
+
return getTableColumnFromPath({
|
78
|
+
adapter,
|
79
|
+
aliasTable,
|
80
|
+
collectionPath,
|
81
|
+
columnPrefix: `${columnPrefix}${field.name}_`,
|
82
|
+
constraints,
|
83
|
+
fields: field.fields,
|
84
|
+
joinAliases,
|
85
|
+
joins,
|
86
|
+
locale,
|
87
|
+
pathSegments: pathSegments.slice(1),
|
88
|
+
selectFields,
|
89
|
+
tableName: newTableName
|
90
|
+
});
|
91
|
+
}
|
92
|
+
return getTableColumnFromPath({
|
93
|
+
adapter,
|
94
|
+
aliasTable,
|
95
|
+
collectionPath,
|
96
|
+
columnPrefix,
|
97
|
+
constraints,
|
98
|
+
fields: field.fields,
|
99
|
+
joinAliases,
|
100
|
+
joins,
|
101
|
+
locale,
|
102
|
+
pathSegments: pathSegments.slice(1),
|
103
|
+
selectFields,
|
104
|
+
tableName: newTableName
|
105
|
+
});
|
106
|
+
}
|
107
|
+
case 'group':
|
108
|
+
{
|
109
|
+
if (locale && field.localized && adapter.payload.config.localization) {
|
110
|
+
newTableName = `${tableName}_locales`;
|
111
|
+
joins[tableName] = (0, _drizzleorm.eq)(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID);
|
112
|
+
if (locale !== 'all') {
|
113
|
+
constraints.push({
|
114
|
+
columnName: '_locale',
|
115
|
+
table: adapter.tables[newTableName],
|
116
|
+
value: locale
|
117
|
+
});
|
118
|
+
}
|
119
|
+
}
|
120
|
+
return getTableColumnFromPath({
|
121
|
+
adapter,
|
122
|
+
aliasTable,
|
123
|
+
collectionPath,
|
124
|
+
columnPrefix: `${columnPrefix}${field.name}_`,
|
125
|
+
constraints,
|
126
|
+
fields: field.fields,
|
127
|
+
joinAliases,
|
128
|
+
joins,
|
129
|
+
locale,
|
130
|
+
pathSegments: pathSegments.slice(1),
|
131
|
+
selectFields,
|
132
|
+
tableName: newTableName
|
133
|
+
});
|
134
|
+
}
|
135
|
+
case 'array':
|
136
|
+
{
|
137
|
+
newTableName = `${tableName}_${(0, _tosnakecase.default)(field.name)}`;
|
138
|
+
if (locale && field.localized && adapter.payload.config.localization) {
|
139
|
+
joins[newTableName] = (0, _drizzleorm.and)((0, _drizzleorm.eq)(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID), (0, _drizzleorm.eq)(adapter.tables[newTableName]._locale, locale));
|
140
|
+
if (locale !== 'all') {
|
141
|
+
constraints.push({
|
142
|
+
columnName: '_locale',
|
143
|
+
table: adapter.tables[newTableName],
|
144
|
+
value: locale
|
145
|
+
});
|
146
|
+
}
|
147
|
+
} else {
|
148
|
+
joins[newTableName] = (0, _drizzleorm.eq)(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID);
|
149
|
+
}
|
150
|
+
return getTableColumnFromPath({
|
151
|
+
adapter,
|
152
|
+
collectionPath,
|
153
|
+
constraints,
|
154
|
+
fields: field.fields,
|
155
|
+
joinAliases,
|
156
|
+
joins,
|
157
|
+
locale,
|
158
|
+
pathSegments: pathSegments.slice(1),
|
159
|
+
selectFields,
|
160
|
+
tableName: newTableName
|
161
|
+
});
|
162
|
+
}
|
163
|
+
case 'blocks':
|
164
|
+
{
|
165
|
+
let blockTableColumn;
|
166
|
+
let newTableName;
|
167
|
+
const hasBlockField = field.blocks.some((block)=>{
|
168
|
+
newTableName = `${tableName}_blocks_${(0, _tosnakecase.default)(block.slug)}`;
|
169
|
+
let result;
|
170
|
+
const blockConstraints = [];
|
171
|
+
const blockSelectFields = {};
|
172
|
+
try {
|
173
|
+
result = getTableColumnFromPath({
|
174
|
+
adapter,
|
175
|
+
collectionPath,
|
176
|
+
constraints: blockConstraints,
|
177
|
+
fields: block.fields,
|
178
|
+
joinAliases,
|
179
|
+
joins,
|
180
|
+
locale,
|
181
|
+
pathSegments: pathSegments.slice(1),
|
182
|
+
selectFields: blockSelectFields,
|
183
|
+
tableName: newTableName
|
184
|
+
});
|
185
|
+
} catch (error) {
|
186
|
+
// this is fine, not every block will have the field
|
187
|
+
}
|
188
|
+
if (!result) {
|
189
|
+
return;
|
190
|
+
}
|
191
|
+
blockTableColumn = result;
|
192
|
+
constraints = constraints.concat(blockConstraints);
|
193
|
+
selectFields = {
|
194
|
+
...selectFields,
|
195
|
+
...blockSelectFields
|
196
|
+
};
|
197
|
+
if (field.localized && adapter.payload.config.localization) {
|
198
|
+
joins[newTableName] = (0, _drizzleorm.and)((0, _drizzleorm.eq)(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID), (0, _drizzleorm.eq)(adapter.tables[newTableName]._locale, locale));
|
199
|
+
if (locale) {
|
200
|
+
constraints.push({
|
201
|
+
columnName: '_locale',
|
202
|
+
table: adapter.tables[newTableName],
|
203
|
+
value: locale
|
204
|
+
});
|
205
|
+
}
|
206
|
+
} else {
|
207
|
+
joins[newTableName] = (0, _drizzleorm.eq)(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID);
|
208
|
+
}
|
209
|
+
return result;
|
210
|
+
});
|
211
|
+
if (hasBlockField) {
|
212
|
+
return {
|
213
|
+
columnName: blockTableColumn.columnName,
|
214
|
+
constraints,
|
215
|
+
field: blockTableColumn.field,
|
216
|
+
pathSegments: pathSegments.slice(1),
|
217
|
+
rawColumn: blockTableColumn.rawColumn,
|
218
|
+
table: adapter.tables[newTableName]
|
219
|
+
};
|
220
|
+
}
|
221
|
+
break;
|
222
|
+
}
|
223
|
+
case 'relationship':
|
224
|
+
case 'upload':
|
225
|
+
{
|
226
|
+
let relationshipFields;
|
227
|
+
const relationTableName = `${tableName}_relationships`;
|
228
|
+
const newCollectionPath = pathSegments.slice(1).join('.');
|
229
|
+
const aliasRelationshipTableName = (0, _uuid.v4)();
|
230
|
+
const aliasRelationshipTable = (0, _pgcore.alias)(adapter.tables[relationTableName], aliasRelationshipTableName);
|
231
|
+
// Join in the relationships table
|
232
|
+
joinAliases.push({
|
233
|
+
condition: (0, _drizzleorm.eq)((aliasTable || adapter.tables[tableName]).id, aliasRelationshipTable.parent),
|
234
|
+
table: aliasRelationshipTable
|
235
|
+
});
|
236
|
+
selectFields[`${relationTableName}.path`] = aliasRelationshipTable.path;
|
237
|
+
constraints.push({
|
238
|
+
columnName: 'path',
|
239
|
+
table: aliasRelationshipTable,
|
240
|
+
value: field.name
|
241
|
+
});
|
242
|
+
let newAliasTable;
|
243
|
+
if (typeof field.relationTo === 'string') {
|
244
|
+
newTableName = `${(0, _tosnakecase.default)(field.relationTo)}`;
|
245
|
+
// parent to relationship join table
|
246
|
+
relationshipFields = adapter.payload.collections[field.relationTo].config.fields;
|
247
|
+
newAliasTable = (0, _pgcore.alias)(adapter.tables[newTableName], (0, _tosnakecase.default)((0, _uuid.v4)()));
|
248
|
+
joinAliases.push({
|
249
|
+
condition: (0, _drizzleorm.eq)(newAliasTable.id, aliasRelationshipTable[`${field.relationTo}ID`]),
|
250
|
+
table: newAliasTable
|
251
|
+
});
|
252
|
+
if (newCollectionPath === '') {
|
253
|
+
return {
|
254
|
+
columnName: `${field.relationTo}ID`,
|
255
|
+
constraints,
|
256
|
+
field,
|
257
|
+
table: aliasRelationshipTable
|
258
|
+
};
|
259
|
+
}
|
260
|
+
} else if (newCollectionPath === 'value') {
|
261
|
+
const tableColumnsNames = field.relationTo.map((relationTo)=>`"${aliasRelationshipTableName}"."${(0, _tosnakecase.default)(relationTo)}_id"`);
|
262
|
+
return {
|
263
|
+
constraints,
|
264
|
+
field,
|
265
|
+
rawColumn: _drizzleorm.sql.raw(`COALESCE(${tableColumnsNames.join(', ')})`),
|
266
|
+
table: aliasRelationshipTable
|
267
|
+
};
|
268
|
+
} else if (newCollectionPath === 'relationTo') {
|
269
|
+
const relationTo = Array.isArray(field.relationTo) ? field.relationTo : [
|
270
|
+
field.relationTo
|
271
|
+
];
|
272
|
+
return {
|
273
|
+
constraints,
|
274
|
+
field,
|
275
|
+
getNotNullColumnByValue: (val)=>{
|
276
|
+
const matchedRelation = relationTo.find((relation)=>relation === val);
|
277
|
+
if (matchedRelation) return `${matchedRelation}ID`;
|
278
|
+
return undefined;
|
279
|
+
},
|
280
|
+
table: aliasRelationshipTable
|
281
|
+
};
|
282
|
+
} else {
|
283
|
+
throw new _errors.APIError('Not supported');
|
284
|
+
}
|
285
|
+
return getTableColumnFromPath({
|
286
|
+
adapter,
|
287
|
+
aliasTable: newAliasTable,
|
288
|
+
collectionPath: newCollectionPath,
|
289
|
+
constraints,
|
290
|
+
fields: relationshipFields,
|
291
|
+
joinAliases,
|
292
|
+
joins,
|
293
|
+
locale,
|
294
|
+
pathSegments: pathSegments.slice(1),
|
295
|
+
selectFields,
|
296
|
+
tableName: newTableName
|
297
|
+
});
|
298
|
+
}
|
299
|
+
default:
|
300
|
+
{
|
301
|
+
if ((0, _types.fieldAffectsData)(field)) {
|
302
|
+
if (field.localized && adapter.payload.config.localization) {
|
303
|
+
// If localized, we go to localized table and set aliasTable to undefined
|
304
|
+
// so it is not picked up below to be used as targetTable
|
305
|
+
newTableName = `${tableName}_locales`;
|
306
|
+
const parentTable = aliasTable || adapter.tables[tableName];
|
307
|
+
joins[newTableName] = (0, _drizzleorm.eq)(parentTable.id, adapter.tables[newTableName]._parentID);
|
308
|
+
aliasTable = undefined;
|
309
|
+
if (locale !== 'all') {
|
310
|
+
constraints.push({
|
311
|
+
columnName: '_locale',
|
312
|
+
table: adapter.tables[newTableName],
|
313
|
+
value: locale
|
314
|
+
});
|
315
|
+
}
|
316
|
+
}
|
317
|
+
const targetTable = aliasTable || adapter.tables[newTableName];
|
318
|
+
selectFields[`${newTableName}.${columnPrefix}${field.name}`] = targetTable[`${columnPrefix}${field.name}`];
|
319
|
+
return {
|
320
|
+
columnName: `${columnPrefix}${field.name}`,
|
321
|
+
constraints,
|
322
|
+
field,
|
323
|
+
pathSegments: pathSegments,
|
324
|
+
table: targetTable
|
325
|
+
};
|
326
|
+
}
|
327
|
+
}
|
328
|
+
}
|
329
|
+
}
|
330
|
+
throw new _errors.APIError(`Cannot find field for path at ${fieldPath}`);
|
331
|
+
};
|
332
|
+
|
333
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/getTableColumnFromPath.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { SQL } from 'drizzle-orm'\nimport type { Field, FieldAffectingData, TabAsField } from 'payload/types'\n\nimport { and, eq, sql } from 'drizzle-orm'\nimport { alias } from 'drizzle-orm/pg-core'\nimport { APIError } from 'payload/errors'\nimport { fieldAffectsData, tabHasName } from 'payload/types'\nimport { flattenTopLevelFields } from 'payload/utilities'\nimport toSnakeCase from 'to-snake-case'\nimport { v4 as uuid } from 'uuid'\n\nimport type { GenericColumn, GenericTable, PostgresAdapter } from '../types'\nimport type { BuildQueryJoinAliases, BuildQueryJoins } from './buildQuery'\n\ntype Constraint = {\n  columnName: string\n  table: GenericTable\n  value: unknown\n}\n\ntype TableColumn = {\n  columnName?: string\n  constraints: Constraint[]\n  field: FieldAffectingData\n  getNotNullColumnByValue?: (val: unknown) => string\n  pathSegments?: string[]\n  rawColumn?: SQL\n  table: GenericTable\n}\n\ntype Args = {\n  adapter: PostgresAdapter\n  aliasTable?: GenericTable\n  collectionPath: string\n  columnPrefix?: string\n  constraints?: Constraint[]\n  fields: (Field | TabAsField)[]\n  joinAliases: BuildQueryJoinAliases\n  joins: BuildQueryJoins\n  locale?: string\n  pathSegments: string[]\n  selectFields: Record<string, GenericColumn>\n  tableName: string\n}\n/**\n * Transforms path to table and column name\n * Adds tables to `join`\n * @returns TableColumn\n */\nexport const getTableColumnFromPath = ({\n  adapter,\n  aliasTable,\n  collectionPath,\n  columnPrefix = '',\n  constraints = [],\n  fields,\n  joinAliases,\n  joins,\n  locale: incomingLocale,\n  pathSegments: incomingSegments,\n  selectFields,\n  tableName,\n}: Args): TableColumn => {\n  const fieldPath = incomingSegments[0]\n  let locale = incomingLocale\n  const field = flattenTopLevelFields(fields as Field[]).find(\n    (fieldToFind) => fieldAffectsData(fieldToFind) && fieldToFind.name === fieldPath,\n  ) as Field | TabAsField\n  let newTableName = tableName\n\n  if (!field && fieldPath === 'id') {\n    selectFields.id = adapter.tables[newTableName].id\n    return {\n      columnName: 'id',\n      constraints,\n      field: {\n        name: 'id',\n        type: 'number',\n      },\n      table: adapter.tables[newTableName],\n    }\n  }\n\n  if (field) {\n    const pathSegments = [...incomingSegments]\n\n    // If next segment is a locale,\n    // we need to take it out and use it as the locale from this point on\n    if ('localized' in field && field.localized && adapter.payload.config.localization) {\n      const matchedLocale = adapter.payload.config.localization.localeCodes.find(\n        (locale) => locale === pathSegments[1],\n      )\n\n      if (matchedLocale) {\n        locale = matchedLocale\n        pathSegments.splice(1, 1)\n      }\n    }\n\n    switch (field.type) {\n      case 'tabs': {\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix,\n          constraints,\n          fields: field.tabs.map((tab) => ({\n            ...tab,\n            type: 'tab',\n          })),\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n      case 'tab': {\n        if (tabHasName(field)) {\n          return getTableColumnFromPath({\n            adapter,\n            aliasTable,\n            collectionPath,\n            columnPrefix: `${columnPrefix}${field.name}_`,\n            constraints,\n            fields: field.fields,\n            joinAliases,\n            joins,\n            locale,\n            pathSegments: pathSegments.slice(1),\n            selectFields,\n            tableName: newTableName,\n          })\n        }\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      case 'group': {\n        if (locale && field.localized && adapter.payload.config.localization) {\n          newTableName = `${tableName}_locales`\n\n          joins[tableName] = eq(\n            adapter.tables[tableName].id,\n            adapter.tables[newTableName]._parentID,\n          )\n          if (locale !== 'all') {\n            constraints.push({\n              columnName: '_locale',\n              table: adapter.tables[newTableName],\n              value: locale,\n            })\n          }\n        }\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix: `${columnPrefix}${field.name}_`,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      case 'array': {\n        newTableName = `${tableName}_${toSnakeCase(field.name)}`\n        if (locale && field.localized && adapter.payload.config.localization) {\n          joins[newTableName] = and(\n            eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n            eq(adapter.tables[newTableName]._locale, locale),\n          )\n          if (locale !== 'all') {\n            constraints.push({\n              columnName: '_locale',\n              table: adapter.tables[newTableName],\n              value: locale,\n            })\n          }\n        } else {\n          joins[newTableName] = eq(\n            adapter.tables[tableName].id,\n            adapter.tables[newTableName]._parentID,\n          )\n        }\n        return getTableColumnFromPath({\n          adapter,\n          collectionPath,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      case 'blocks': {\n        let blockTableColumn: TableColumn\n        let newTableName: string\n        const hasBlockField = field.blocks.some((block) => {\n          newTableName = `${tableName}_blocks_${toSnakeCase(block.slug)}`\n          let result\n          const blockConstraints = []\n          const blockSelectFields = {}\n          try {\n            result = getTableColumnFromPath({\n              adapter,\n              collectionPath,\n              constraints: blockConstraints,\n              fields: block.fields,\n              joinAliases,\n              joins,\n              locale,\n              pathSegments: pathSegments.slice(1),\n              selectFields: blockSelectFields,\n              tableName: newTableName,\n            })\n          } catch (error) {\n            // this is fine, not every block will have the field\n          }\n          if (!result) {\n            return\n          }\n          blockTableColumn = result\n          constraints = constraints.concat(blockConstraints)\n          selectFields = { ...selectFields, ...blockSelectFields }\n          if (field.localized && adapter.payload.config.localization) {\n            joins[newTableName] = and(\n              eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n              eq(adapter.tables[newTableName]._locale, locale),\n            )\n            if (locale) {\n              constraints.push({\n                columnName: '_locale',\n                table: adapter.tables[newTableName],\n                value: locale,\n              })\n            }\n          } else {\n            joins[newTableName] = eq(\n              adapter.tables[tableName].id,\n              adapter.tables[newTableName]._parentID,\n            )\n          }\n          return result\n        })\n        if (hasBlockField) {\n          return {\n            columnName: blockTableColumn.columnName,\n            constraints,\n            field: blockTableColumn.field,\n            pathSegments: pathSegments.slice(1),\n            rawColumn: blockTableColumn.rawColumn,\n            table: adapter.tables[newTableName],\n          }\n        }\n        break\n      }\n\n      case 'relationship':\n      case 'upload': {\n        let relationshipFields\n        const relationTableName = `${tableName}_relationships`\n        const newCollectionPath = pathSegments.slice(1).join('.')\n\n        const aliasRelationshipTableName = uuid()\n        const aliasRelationshipTable = alias(\n          adapter.tables[relationTableName],\n          aliasRelationshipTableName,\n        )\n\n        // Join in the relationships table\n        joinAliases.push({\n          condition: eq(\n            (aliasTable || adapter.tables[tableName]).id,\n            aliasRelationshipTable.parent,\n          ),\n          table: aliasRelationshipTable,\n        })\n\n        selectFields[`${relationTableName}.path`] = aliasRelationshipTable.path\n\n        constraints.push({\n          columnName: 'path',\n          table: aliasRelationshipTable,\n          value: field.name,\n        })\n\n        let newAliasTable\n\n        if (typeof field.relationTo === 'string') {\n          newTableName = `${toSnakeCase(field.relationTo)}`\n          // parent to relationship join table\n          relationshipFields = adapter.payload.collections[field.relationTo].config.fields\n\n          newAliasTable = alias(adapter.tables[newTableName], toSnakeCase(uuid()))\n\n          joinAliases.push({\n            condition: eq(newAliasTable.id, aliasRelationshipTable[`${field.relationTo}ID`]),\n            table: newAliasTable,\n          })\n\n          if (newCollectionPath === '') {\n            return {\n              columnName: `${field.relationTo}ID`,\n              constraints,\n              field,\n              table: aliasRelationshipTable,\n            }\n          }\n        } else if (newCollectionPath === 'value') {\n          const tableColumnsNames = field.relationTo.map(\n            (relationTo) => `\"${aliasRelationshipTableName}\".\"${toSnakeCase(relationTo)}_id\"`,\n          )\n          return {\n            constraints,\n            field,\n            rawColumn: sql.raw(`COALESCE(${tableColumnsNames.join(', ')})`),\n            table: aliasRelationshipTable,\n          }\n        } else if (newCollectionPath === 'relationTo') {\n          const relationTo = Array.isArray(field.relationTo) ? field.relationTo : [field.relationTo]\n\n          return {\n            constraints,\n            field,\n            getNotNullColumnByValue: (val) => {\n              const matchedRelation = relationTo.find((relation) => relation === val)\n              if (matchedRelation) return `${matchedRelation}ID`\n              return undefined\n            },\n            table: aliasRelationshipTable,\n          }\n        } else {\n          throw new APIError('Not supported')\n        }\n\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable: newAliasTable,\n          collectionPath: newCollectionPath,\n          constraints,\n          fields: relationshipFields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      default: {\n        if (fieldAffectsData(field)) {\n          if (field.localized && adapter.payload.config.localization) {\n            // If localized, we go to localized table and set aliasTable to undefined\n            // so it is not picked up below to be used as targetTable\n            newTableName = `${tableName}_locales`\n\n            const parentTable = aliasTable || adapter.tables[tableName]\n\n            joins[newTableName] = eq(parentTable.id, adapter.tables[newTableName]._parentID)\n\n            aliasTable = undefined\n\n            if (locale !== 'all') {\n              constraints.push({\n                columnName: '_locale',\n                table: adapter.tables[newTableName],\n                value: locale,\n              })\n            }\n          }\n\n          const targetTable = aliasTable || adapter.tables[newTableName]\n\n          selectFields[`${newTableName}.${columnPrefix}${field.name}`] =\n            targetTable[`${columnPrefix}${field.name}`]\n\n          return {\n            columnName: `${columnPrefix}${field.name}`,\n            constraints,\n            field,\n            pathSegments: pathSegments,\n            table: targetTable,\n          }\n        }\n      }\n    }\n  }\n\n  throw new APIError(`Cannot find field for path at ${fieldPath}`)\n}\n"],"names":["getTableColumnFromPath","adapter","aliasTable","collectionPath","columnPrefix","constraints","fields","joinAliases","joins","locale","incomingLocale","pathSegments","incomingSegments","selectFields","tableName","fieldPath","field","flattenTopLevelFields","find","fieldToFind","fieldAffectsData","name","newTableName","id","tables","columnName","type","table","localized","payload","config","localization","matchedLocale","localeCodes","splice","tabs","map","tab","slice","tabHasName","eq","_parentID","push","value","toSnakeCase","and","_locale","blockTableColumn","hasBlockField","blocks","some","block","slug","result","blockConstraints","blockSelectFields","error","concat","rawColumn","relationshipFields","relationTableName","newCollectionPath","join","aliasRelationshipTableName","uuid","aliasRelationshipTable","alias","condition","parent","path","newAliasTable","relationTo","collections","tableColumnsNames","sql","raw","Array","isArray","getNotNullColumnByValue","val","matchedRelation","relation","undefined","APIError","parentTable","targetTable"],"mappings":"AAAA,oCAAoC;;;;+BAkDvBA;;;eAAAA;;;4BA9CgB;wBACP;wBACG;uBACoB;2BACP;oEACd;sBACG;;;;;;AAwCpB,MAAMA,yBAAyB,CAAC,EACrCC,OAAO,EACPC,UAAU,EACVC,cAAc,EACdC,eAAe,EAAE,EACjBC,cAAc,EAAE,EAChBC,MAAM,EACNC,WAAW,EACXC,KAAK,EACLC,QAAQC,cAAc,EACtBC,cAAcC,gBAAgB,EAC9BC,YAAY,EACZC,SAAS,EACJ;IACL,MAAMC,YAAYH,gBAAgB,CAAC,EAAE;IACrC,IAAIH,SAASC;IACb,MAAMM,QAAQC,IAAAA,gCAAqB,EAACX,QAAmBY,IAAI,CACzD,CAACC,cAAgBC,IAAAA,uBAAgB,EAACD,gBAAgBA,YAAYE,IAAI,KAAKN;IAEzE,IAAIO,eAAeR;IAEnB,IAAI,CAACE,SAASD,cAAc,MAAM;QAChCF,aAAaU,EAAE,GAAGtB,QAAQuB,MAAM,CAACF,aAAa,CAACC,EAAE;QACjD,OAAO;YACLE,YAAY;YACZpB;YACAW,OAAO;gBACLK,MAAM;gBACNK,MAAM;YACR;YACAC,OAAO1B,QAAQuB,MAAM,CAACF,aAAa;QACrC;IACF;IAEA,IAAIN,OAAO;QACT,MAAML,eAAe;eAAIC;SAAiB;QAE1C,+BAA+B;QAC/B,qEAAqE;QACrE,IAAI,eAAeI,SAASA,MAAMY,SAAS,IAAI3B,QAAQ4B,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;YAClF,MAAMC,gBAAgB/B,QAAQ4B,OAAO,CAACC,MAAM,CAACC,YAAY,CAACE,WAAW,CAACf,IAAI,CACxE,CAACT,SAAWA,WAAWE,YAAY,CAAC,EAAE;YAGxC,IAAIqB,eAAe;gBACjBvB,SAASuB;gBACTrB,aAAauB,MAAM,CAAC,GAAG;YACzB;QACF;QAEA,OAAQlB,MAAMU,IAAI;YAChB,KAAK;gBAAQ;oBACX,OAAO1B,uBAAuB;wBAC5BC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC,QAAQU,MAAMmB,IAAI,CAACC,GAAG,CAAC,CAACC,MAAS,CAAA;gCAC/B,GAAGA,GAAG;gCACNX,MAAM;4BACR,CAAA;wBACAnB;wBACAC;wBACAC;wBACAE,cAAcA,aAAa2B,KAAK,CAAC;wBACjCzB;wBACAC,WAAWQ;oBACb;gBACF;YACA,KAAK;gBAAO;oBACV,IAAIiB,IAAAA,iBAAU,EAACvB,QAAQ;wBACrB,OAAOhB,uBAAuB;4BAC5BC;4BACAC;4BACAC;4BACAC,cAAc,CAAC,EAAEA,aAAa,EAAEY,MAAMK,IAAI,CAAC,CAAC,CAAC;4BAC7ChB;4BACAC,QAAQU,MAAMV,MAAM;4BACpBC;4BACAC;4BACAC;4BACAE,cAAcA,aAAa2B,KAAK,CAAC;4BACjCzB;4BACAC,WAAWQ;wBACb;oBACF;oBACA,OAAOtB,uBAAuB;wBAC5BC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC,QAAQU,MAAMV,MAAM;wBACpBC;wBACAC;wBACAC;wBACAE,cAAcA,aAAa2B,KAAK,CAAC;wBACjCzB;wBACAC,WAAWQ;oBACb;gBACF;YAEA,KAAK;gBAAS;oBACZ,IAAIb,UAAUO,MAAMY,SAAS,IAAI3B,QAAQ4B,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;wBACpET,eAAe,CAAC,EAAER,UAAU,QAAQ,CAAC;wBAErCN,KAAK,CAACM,UAAU,GAAG0B,IAAAA,cAAE,EACnBvC,QAAQuB,MAAM,CAACV,UAAU,CAACS,EAAE,EAC5BtB,QAAQuB,MAAM,CAACF,aAAa,CAACmB,SAAS;wBAExC,IAAIhC,WAAW,OAAO;4BACpBJ,YAAYqC,IAAI,CAAC;gCACfjB,YAAY;gCACZE,OAAO1B,QAAQuB,MAAM,CAACF,aAAa;gCACnCqB,OAAOlC;4BACT;wBACF;oBACF;oBACA,OAAOT,uBAAuB;wBAC5BC;wBACAC;wBACAC;wBACAC,cAAc,CAAC,EAAEA,aAAa,EAAEY,MAAMK,IAAI,CAAC,CAAC,CAAC;wBAC7ChB;wBACAC,QAAQU,MAAMV,MAAM;wBACpBC;wBACAC;wBACAC;wBACAE,cAAcA,aAAa2B,KAAK,CAAC;wBACjCzB;wBACAC,WAAWQ;oBACb;gBACF;YAEA,KAAK;gBAAS;oBACZA,eAAe,CAAC,EAAER,UAAU,CAAC,EAAE8B,IAAAA,oBAAW,EAAC5B,MAAMK,IAAI,EAAE,CAAC;oBACxD,IAAIZ,UAAUO,MAAMY,SAAS,IAAI3B,QAAQ4B,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;wBACpEvB,KAAK,CAACc,aAAa,GAAGuB,IAAAA,eAAG,EACvBL,IAAAA,cAAE,EAACvC,QAAQuB,MAAM,CAACV,UAAU,CAACS,EAAE,EAAEtB,QAAQuB,MAAM,CAACF,aAAa,CAACmB,SAAS,GACvED,IAAAA,cAAE,EAACvC,QAAQuB,MAAM,CAACF,aAAa,CAACwB,OAAO,EAAErC;wBAE3C,IAAIA,WAAW,OAAO;4BACpBJ,YAAYqC,IAAI,CAAC;gCACfjB,YAAY;gCACZE,OAAO1B,QAAQuB,MAAM,CAACF,aAAa;gCACnCqB,OAAOlC;4BACT;wBACF;oBACF,OAAO;wBACLD,KAAK,CAACc,aAAa,GAAGkB,IAAAA,cAAE,EACtBvC,QAAQuB,MAAM,CAACV,UAAU,CAACS,EAAE,EAC5BtB,QAAQuB,MAAM,CAACF,aAAa,CAACmB,SAAS;oBAE1C;oBACA,OAAOzC,uBAAuB;wBAC5BC;wBACAE;wBACAE;wBACAC,QAAQU,MAAMV,MAAM;wBACpBC;wBACAC;wBACAC;wBACAE,cAAcA,aAAa2B,KAAK,CAAC;wBACjCzB;wBACAC,WAAWQ;oBACb;gBACF;YAEA,KAAK;gBAAU;oBACb,IAAIyB;oBACJ,IAAIzB;oBACJ,MAAM0B,gBAAgBhC,MAAMiC,MAAM,CAACC,IAAI,CAAC,CAACC;wBACvC7B,eAAe,CAAC,EAAER,UAAU,QAAQ,EAAE8B,IAAAA,oBAAW,EAACO,MAAMC,IAAI,EAAE,CAAC;wBAC/D,IAAIC;wBACJ,MAAMC,mBAAmB,EAAE;wBAC3B,MAAMC,oBAAoB,CAAC;wBAC3B,IAAI;4BACFF,SAASrD,uBAAuB;gCAC9BC;gCACAE;gCACAE,aAAaiD;gCACbhD,QAAQ6C,MAAM7C,MAAM;gCACpBC;gCACAC;gCACAC;gCACAE,cAAcA,aAAa2B,KAAK,CAAC;gCACjCzB,cAAc0C;gCACdzC,WAAWQ;4BACb;wBACF,EAAE,OAAOkC,OAAO;wBACd,oDAAoD;wBACtD;wBACA,IAAI,CAACH,QAAQ;4BACX;wBACF;wBACAN,mBAAmBM;wBACnBhD,cAAcA,YAAYoD,MAAM,CAACH;wBACjCzC,eAAe;4BAAE,GAAGA,YAAY;4BAAE,GAAG0C,iBAAiB;wBAAC;wBACvD,IAAIvC,MAAMY,SAAS,IAAI3B,QAAQ4B,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;4BAC1DvB,KAAK,CAACc,aAAa,GAAGuB,IAAAA,eAAG,EACvBL,IAAAA,cAAE,EAACvC,QAAQuB,MAAM,CAACV,UAAU,CAACS,EAAE,EAAEtB,QAAQuB,MAAM,CAACF,aAAa,CAACmB,SAAS,GACvED,IAAAA,cAAE,EAACvC,QAAQuB,MAAM,CAACF,aAAa,CAACwB,OAAO,EAAErC;4BAE3C,IAAIA,QAAQ;gCACVJ,YAAYqC,IAAI,CAAC;oCACfjB,YAAY;oCACZE,OAAO1B,QAAQuB,MAAM,CAACF,aAAa;oCACnCqB,OAAOlC;gCACT;4BACF;wBACF,OAAO;4BACLD,KAAK,CAACc,aAAa,GAAGkB,IAAAA,cAAE,EACtBvC,QAAQuB,MAAM,CAACV,UAAU,CAACS,EAAE,EAC5BtB,QAAQuB,MAAM,CAACF,aAAa,CAACmB,SAAS;wBAE1C;wBACA,OAAOY;oBACT;oBACA,IAAIL,eAAe;wBACjB,OAAO;4BACLvB,YAAYsB,iBAAiBtB,UAAU;4BACvCpB;4BACAW,OAAO+B,iBAAiB/B,KAAK;4BAC7BL,cAAcA,aAAa2B,KAAK,CAAC;4BACjCoB,WAAWX,iBAAiBW,SAAS;4BACrC/B,OAAO1B,QAAQuB,MAAM,CAACF,aAAa;wBACrC;oBACF;oBACA;gBACF;YAEA,KAAK;YACL,KAAK;gBAAU;oBACb,IAAIqC;oBACJ,MAAMC,oBAAoB,CAAC,EAAE9C,UAAU,cAAc,CAAC;oBACtD,MAAM+C,oBAAoBlD,aAAa2B,KAAK,CAAC,GAAGwB,IAAI,CAAC;oBAErD,MAAMC,6BAA6BC,IAAAA,QAAI;oBACvC,MAAMC,yBAAyBC,IAAAA,aAAK,EAClCjE,QAAQuB,MAAM,CAACoC,kBAAkB,EACjCG;oBAGF,kCAAkC;oBAClCxD,YAAYmC,IAAI,CAAC;wBACfyB,WAAW3B,IAAAA,cAAE,EACX,AAACtC,CAAAA,cAAcD,QAAQuB,MAAM,CAACV,UAAU,AAAD,EAAGS,EAAE,EAC5C0C,uBAAuBG,MAAM;wBAE/BzC,OAAOsC;oBACT;oBAEApD,YAAY,CAAC,CAAC,EAAE+C,kBAAkB,KAAK,CAAC,CAAC,GAAGK,uBAAuBI,IAAI;oBAEvEhE,YAAYqC,IAAI,CAAC;wBACfjB,YAAY;wBACZE,OAAOsC;wBACPtB,OAAO3B,MAAMK,IAAI;oBACnB;oBAEA,IAAIiD;oBAEJ,IAAI,OAAOtD,MAAMuD,UAAU,KAAK,UAAU;wBACxCjD,eAAe,CAAC,EAAEsB,IAAAA,oBAAW,EAAC5B,MAAMuD,UAAU,EAAE,CAAC;wBACjD,oCAAoC;wBACpCZ,qBAAqB1D,QAAQ4B,OAAO,CAAC2C,WAAW,CAACxD,MAAMuD,UAAU,CAAC,CAACzC,MAAM,CAACxB,MAAM;wBAEhFgE,gBAAgBJ,IAAAA,aAAK,EAACjE,QAAQuB,MAAM,CAACF,aAAa,EAAEsB,IAAAA,oBAAW,EAACoB,IAAAA,QAAI;wBAEpEzD,YAAYmC,IAAI,CAAC;4BACfyB,WAAW3B,IAAAA,cAAE,EAAC8B,cAAc/C,EAAE,EAAE0C,sBAAsB,CAAC,CAAC,EAAEjD,MAAMuD,UAAU,CAAC,EAAE,CAAC,CAAC;4BAC/E5C,OAAO2C;wBACT;wBAEA,IAAIT,sBAAsB,IAAI;4BAC5B,OAAO;gCACLpC,YAAY,CAAC,EAAET,MAAMuD,UAAU,CAAC,EAAE,CAAC;gCACnClE;gCACAW;gCACAW,OAAOsC;4BACT;wBACF;oBACF,OAAO,IAAIJ,sBAAsB,SAAS;wBACxC,MAAMY,oBAAoBzD,MAAMuD,UAAU,CAACnC,GAAG,CAC5C,CAACmC,aAAe,CAAC,CAAC,EAAER,2BAA2B,GAAG,EAAEnB,IAAAA,oBAAW,EAAC2B,YAAY,IAAI,CAAC;wBAEnF,OAAO;4BACLlE;4BACAW;4BACA0C,WAAWgB,eAAG,CAACC,GAAG,CAAC,CAAC,SAAS,EAAEF,kBAAkBX,IAAI,CAAC,MAAM,CAAC,CAAC;4BAC9DnC,OAAOsC;wBACT;oBACF,OAAO,IAAIJ,sBAAsB,cAAc;wBAC7C,MAAMU,aAAaK,MAAMC,OAAO,CAAC7D,MAAMuD,UAAU,IAAIvD,MAAMuD,UAAU,GAAG;4BAACvD,MAAMuD,UAAU;yBAAC;wBAE1F,OAAO;4BACLlE;4BACAW;4BACA8D,yBAAyB,CAACC;gCACxB,MAAMC,kBAAkBT,WAAWrD,IAAI,CAAC,CAAC+D,WAAaA,aAAaF;gCACnE,IAAIC,iBAAiB,OAAO,CAAC,EAAEA,gBAAgB,EAAE,CAAC;gCAClD,OAAOE;4BACT;4BACAvD,OAAOsC;wBACT;oBACF,OAAO;wBACL,MAAM,IAAIkB,gBAAQ,CAAC;oBACrB;oBAEA,OAAOnF,uBAAuB;wBAC5BC;wBACAC,YAAYoE;wBACZnE,gBAAgB0D;wBAChBxD;wBACAC,QAAQqD;wBACRpD;wBACAC;wBACAC;wBACAE,cAAcA,aAAa2B,KAAK,CAAC;wBACjCzB;wBACAC,WAAWQ;oBACb;gBACF;YAEA;gBAAS;oBACP,IAAIF,IAAAA,uBAAgB,EAACJ,QAAQ;wBAC3B,IAAIA,MAAMY,SAAS,IAAI3B,QAAQ4B,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;4BAC1D,yEAAyE;4BACzE,yDAAyD;4BACzDT,eAAe,CAAC,EAAER,UAAU,QAAQ,CAAC;4BAErC,MAAMsE,cAAclF,cAAcD,QAAQuB,MAAM,CAACV,UAAU;4BAE3DN,KAAK,CAACc,aAAa,GAAGkB,IAAAA,cAAE,EAAC4C,YAAY7D,EAAE,EAAEtB,QAAQuB,MAAM,CAACF,aAAa,CAACmB,SAAS;4BAE/EvC,aAAagF;4BAEb,IAAIzE,WAAW,OAAO;gCACpBJ,YAAYqC,IAAI,CAAC;oCACfjB,YAAY;oCACZE,OAAO1B,QAAQuB,MAAM,CAACF,aAAa;oCACnCqB,OAAOlC;gCACT;4BACF;wBACF;wBAEA,MAAM4E,cAAcnF,cAAcD,QAAQuB,MAAM,CAACF,aAAa;wBAE9DT,YAAY,CAAC,CAAC,EAAES,aAAa,CAAC,EAAElB,aAAa,EAAEY,MAAMK,IAAI,CAAC,CAAC,CAAC,GAC1DgE,WAAW,CAAC,CAAC,EAAEjF,aAAa,EAAEY,MAAMK,IAAI,CAAC,CAAC,CAAC;wBAE7C,OAAO;4BACLI,YAAY,CAAC,EAAErB,aAAa,EAAEY,MAAMK,IAAI,CAAC,CAAC;4BAC1ChB;4BACAW;4BACAL,cAAcA;4BACdgB,OAAO0D;wBACT;oBACF;gBACF;QACF;IACF;IAEA,MAAM,IAAIF,gBAAQ,CAAC,CAAC,8BAA8B,EAAEpE,UAAU,CAAC;AACjE"}
|
@@ -0,0 +1,34 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
3
|
+
value: true
|
4
|
+
});
|
5
|
+
Object.defineProperty(exports, "operatorMap", {
|
6
|
+
enumerable: true,
|
7
|
+
get: function() {
|
8
|
+
return operatorMap;
|
9
|
+
}
|
10
|
+
});
|
11
|
+
const _drizzleorm = require("drizzle-orm");
|
12
|
+
const operatorMap = {
|
13
|
+
// intersects: intersects,
|
14
|
+
and: _drizzleorm.and,
|
15
|
+
contains: _drizzleorm.ilike,
|
16
|
+
equals: _drizzleorm.eq,
|
17
|
+
exists: _drizzleorm.isNotNull,
|
18
|
+
greater_than: _drizzleorm.gt,
|
19
|
+
greater_than_equal: _drizzleorm.gte,
|
20
|
+
in: _drizzleorm.inArray,
|
21
|
+
isNull: _drizzleorm.isNull,
|
22
|
+
less_than: _drizzleorm.lt,
|
23
|
+
less_than_equal: _drizzleorm.lte,
|
24
|
+
like: _drizzleorm.ilike,
|
25
|
+
not_equals: _drizzleorm.ne,
|
26
|
+
// TODO: geojson queries
|
27
|
+
// near: near,
|
28
|
+
// within: within,
|
29
|
+
// all: all,
|
30
|
+
not_in: _drizzleorm.notInArray,
|
31
|
+
or: _drizzleorm.or
|
32
|
+
};
|
33
|
+
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWVyaWVzL29wZXJhdG9yTWFwLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIGFuZCxcbiAgZXEsXG4gIGd0LFxuICBndGUsXG4gIGlsaWtlLFxuICBpbkFycmF5LFxuICBpc05vdE51bGwsXG4gIGlzTnVsbCxcbiAgbHQsXG4gIGx0ZSxcbiAgbmUsXG4gIG5vdEluQXJyYXksXG4gIG9yLFxufSBmcm9tICdkcml6emxlLW9ybSdcblxuZXhwb3J0IGNvbnN0IG9wZXJhdG9yTWFwID0ge1xuICAvLyBpbnRlcnNlY3RzOiBpbnRlcnNlY3RzLFxuICBhbmQsXG4gIGNvbnRhaW5zOiBpbGlrZSxcbiAgZXF1YWxzOiBlcSxcbiAgZXhpc3RzOiBpc05vdE51bGwsXG4gIGdyZWF0ZXJfdGhhbjogZ3QsXG4gIGdyZWF0ZXJfdGhhbl9lcXVhbDogZ3RlLFxuICBpbjogaW5BcnJheSxcbiAgaXNOdWxsLCAvLyBoYW5kbGVzIGV4aXN0czogZmFsc2VcbiAgbGVzc190aGFuOiBsdCxcbiAgbGVzc190aGFuX2VxdWFsOiBsdGUsXG4gIGxpa2U6IGlsaWtlLFxuICBub3RfZXF1YWxzOiBuZSxcbiAgLy8gVE9ETzogZ2VvanNvbiBxdWVyaWVzXG4gIC8vIG5lYXI6IG5lYXIsXG4gIC8vIHdpdGhpbjogd2l0aGluLFxuICAvLyBhbGw6IGFsbCxcbiAgbm90X2luOiBub3RJbkFycmF5LFxuICBvcixcbn1cbiJdLCJuYW1lcyI6WyJvcGVyYXRvck1hcCIsImFuZCIsImNvbnRhaW5zIiwiaWxpa2UiLCJlcXVhbHMiLCJlcSIsImV4aXN0cyIsImlzTm90TnVsbCIsImdyZWF0ZXJfdGhhbiIsImd0IiwiZ3JlYXRlcl90aGFuX2VxdWFsIiwiZ3RlIiwiaW4iLCJpbkFycmF5IiwiaXNOdWxsIiwibGVzc190aGFuIiwibHQiLCJsZXNzX3RoYW5fZXF1YWwiLCJsdGUiLCJsaWtlIiwibm90X2VxdWFscyIsIm5lIiwibm90X2luIiwibm90SW5BcnJheSIsIm9yIl0sIm1hcHBpbmdzIjoiOzs7OytCQWdCYUE7OztlQUFBQTs7OzRCQUZOO0FBRUEsTUFBTUEsY0FBYztJQUN6QiwwQkFBMEI7SUFDMUJDLEtBQUFBLGVBQUc7SUFDSEMsVUFBVUMsaUJBQUs7SUFDZkMsUUFBUUMsY0FBRTtJQUNWQyxRQUFRQyxxQkFBUztJQUNqQkMsY0FBY0MsY0FBRTtJQUNoQkMsb0JBQW9CQyxlQUFHO0lBQ3ZCQyxJQUFJQyxtQkFBTztJQUNYQyxRQUFBQSxrQkFBTTtJQUNOQyxXQUFXQyxjQUFFO0lBQ2JDLGlCQUFpQkMsZUFBRztJQUNwQkMsTUFBTWhCLGlCQUFLO0lBQ1hpQixZQUFZQyxjQUFFO0lBQ2Qsd0JBQXdCO0lBQ3hCLGNBQWM7SUFDZCxrQkFBa0I7SUFDbEIsWUFBWTtJQUNaQyxRQUFRQyxzQkFBVTtJQUNsQkMsSUFBQUEsY0FBRTtBQUNKIn0=
|
@@ -0,0 +1,146 @@
|
|
1
|
+
/* eslint-disable no-await-in-loop */ "use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
3
|
+
value: true
|
4
|
+
});
|
5
|
+
Object.defineProperty(exports, "parseParams", {
|
6
|
+
enumerable: true,
|
7
|
+
get: function() {
|
8
|
+
return parseParams;
|
9
|
+
}
|
10
|
+
});
|
11
|
+
const _drizzleorm = require("drizzle-orm");
|
12
|
+
const _errors = require("payload/errors");
|
13
|
+
const _types = require("payload/types");
|
14
|
+
const _buildAndOrConditions = require("./buildAndOrConditions");
|
15
|
+
const _createJSONQuery = require("./createJSONQuery");
|
16
|
+
const _convertPathToJSONTraversal = require("./createJSONQuery/convertPathToJSONTraversal");
|
17
|
+
const _getTableColumnFromPath = require("./getTableColumnFromPath");
|
18
|
+
const _operatorMap = require("./operatorMap");
|
19
|
+
const _sanitizeQueryValue = require("./sanitizeQueryValue");
|
20
|
+
async function parseParams({ adapter, fields, joinAliases, joins, locale, selectFields, tableName, where }) {
|
21
|
+
let result;
|
22
|
+
const constraints = [];
|
23
|
+
if (typeof where === 'object' && Object.keys(where).length > 0) {
|
24
|
+
// We need to determine if the whereKey is an AND, OR, or a schema path
|
25
|
+
for (const relationOrPath of Object.keys(where)){
|
26
|
+
if (relationOrPath) {
|
27
|
+
const condition = where[relationOrPath];
|
28
|
+
let conditionOperator;
|
29
|
+
if (relationOrPath.toLowerCase() === 'and') {
|
30
|
+
conditionOperator = 'and';
|
31
|
+
} else if (relationOrPath.toLowerCase() === 'or') {
|
32
|
+
conditionOperator = 'or';
|
33
|
+
}
|
34
|
+
if (Array.isArray(condition)) {
|
35
|
+
const builtConditions = await (0, _buildAndOrConditions.buildAndOrConditions)({
|
36
|
+
adapter,
|
37
|
+
fields,
|
38
|
+
joinAliases,
|
39
|
+
joins,
|
40
|
+
locale,
|
41
|
+
selectFields,
|
42
|
+
tableName,
|
43
|
+
where: condition
|
44
|
+
});
|
45
|
+
if (builtConditions.length > 0) {
|
46
|
+
if (result) {
|
47
|
+
result = _operatorMap.operatorMap[conditionOperator](result, ...builtConditions);
|
48
|
+
} else {
|
49
|
+
result = _operatorMap.operatorMap[conditionOperator](...builtConditions);
|
50
|
+
}
|
51
|
+
}
|
52
|
+
} else {
|
53
|
+
// It's a path - and there can be multiple comparisons on a single path.
|
54
|
+
// For example - title like 'test' and title not equal to 'tester'
|
55
|
+
// So we need to loop on keys again here to handle each operator independently
|
56
|
+
const pathOperators = where[relationOrPath];
|
57
|
+
if (typeof pathOperators === 'object') {
|
58
|
+
for (const operator of Object.keys(pathOperators)){
|
59
|
+
if (_types.validOperators.includes(operator)) {
|
60
|
+
const { columnName, constraints: queryConstraints, field, getNotNullColumnByValue, pathSegments, rawColumn, table } = (0, _getTableColumnFromPath.getTableColumnFromPath)({
|
61
|
+
adapter,
|
62
|
+
collectionPath: relationOrPath,
|
63
|
+
fields,
|
64
|
+
joinAliases,
|
65
|
+
joins,
|
66
|
+
locale,
|
67
|
+
pathSegments: relationOrPath.replace(/__/g, '.').split('.'),
|
68
|
+
selectFields,
|
69
|
+
tableName
|
70
|
+
});
|
71
|
+
const val = where[relationOrPath][operator];
|
72
|
+
queryConstraints.forEach(({ columnName: col, table: constraintTable, value })=>{
|
73
|
+
constraints.push(_operatorMap.operatorMap.equals(constraintTable[col], value));
|
74
|
+
});
|
75
|
+
if ([
|
76
|
+
'json',
|
77
|
+
'richText'
|
78
|
+
].includes(field.type) && Array.isArray(pathSegments)) {
|
79
|
+
const segments = pathSegments.slice(1);
|
80
|
+
segments.unshift(table[columnName].name);
|
81
|
+
if (field.type === 'richText') {
|
82
|
+
const jsonQuery = (0, _createJSONQuery.createJSONQuery)({
|
83
|
+
operator,
|
84
|
+
pathSegments: segments,
|
85
|
+
treatAsArray: [
|
86
|
+
'children'
|
87
|
+
],
|
88
|
+
treatRootAsArray: true,
|
89
|
+
value: val
|
90
|
+
});
|
91
|
+
constraints.push(_drizzleorm.sql.raw(jsonQuery));
|
92
|
+
}
|
93
|
+
if (field.type === 'json') {
|
94
|
+
const jsonQuery = (0, _convertPathToJSONTraversal.convertPathToJSONTraversal)(pathSegments);
|
95
|
+
constraints.push(_drizzleorm.sql.raw(`${table[columnName].name}${jsonQuery} = '%${val}%'`));
|
96
|
+
}
|
97
|
+
break;
|
98
|
+
}
|
99
|
+
if (getNotNullColumnByValue) {
|
100
|
+
const columnName = getNotNullColumnByValue(val);
|
101
|
+
if (columnName) {
|
102
|
+
constraints.push((0, _drizzleorm.isNotNull)(table[columnName]));
|
103
|
+
} else {
|
104
|
+
throw new _errors.QueryError([
|
105
|
+
{
|
106
|
+
path: relationOrPath
|
107
|
+
}
|
108
|
+
]);
|
109
|
+
}
|
110
|
+
break;
|
111
|
+
}
|
112
|
+
if (operator === 'like') {
|
113
|
+
constraints.push((0, _drizzleorm.and)(...val.split(' ').map((word)=>(0, _drizzleorm.ilike)(table[columnName], `%${word}%`))));
|
114
|
+
break;
|
115
|
+
}
|
116
|
+
const { operator: queryOperator, value: queryValue } = (0, _sanitizeQueryValue.sanitizeQueryValue)({
|
117
|
+
field,
|
118
|
+
operator,
|
119
|
+
val
|
120
|
+
});
|
121
|
+
if (queryOperator === 'not_equals' && queryValue !== null) {
|
122
|
+
constraints.push((0, _drizzleorm.or)((0, _drizzleorm.isNull)(rawColumn || table[columnName]), /* eslint-disable @typescript-eslint/no-explicit-any */ (0, _drizzleorm.ne)(rawColumn || table[columnName], queryValue)));
|
123
|
+
} else {
|
124
|
+
constraints.push(_operatorMap.operatorMap[queryOperator](rawColumn || table[columnName], queryValue));
|
125
|
+
}
|
126
|
+
}
|
127
|
+
}
|
128
|
+
}
|
129
|
+
}
|
130
|
+
}
|
131
|
+
}
|
132
|
+
}
|
133
|
+
if (constraints.length > 0) {
|
134
|
+
if (result) {
|
135
|
+
result = (0, _drizzleorm.and)(result, ...constraints);
|
136
|
+
} else {
|
137
|
+
result = (0, _drizzleorm.and)(...constraints);
|
138
|
+
}
|
139
|
+
}
|
140
|
+
if (constraints.length === 1 && !result) {
|
141
|
+
[result] = constraints;
|
142
|
+
}
|
143
|
+
return result;
|
144
|
+
}
|
145
|
+
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/parseParams.ts"],"sourcesContent":["/* eslint-disable no-await-in-loop */\nimport type { SQL } from 'drizzle-orm'\nimport type { Field, Operator, Where } from 'payload/types'\n\nimport { and, ilike, isNotNull, isNull, ne, or, sql } from 'drizzle-orm'\nimport { QueryError } from 'payload/errors'\nimport { validOperators } from 'payload/types'\n\nimport type { GenericColumn, PostgresAdapter } from '../types'\nimport type { BuildQueryJoinAliases, BuildQueryJoins } from './buildQuery'\n\nimport { buildAndOrConditions } from './buildAndOrConditions'\nimport { createJSONQuery } from './createJSONQuery'\nimport { convertPathToJSONTraversal } from './createJSONQuery/convertPathToJSONTraversal'\nimport { getTableColumnFromPath } from './getTableColumnFromPath'\nimport { operatorMap } from './operatorMap'\nimport { sanitizeQueryValue } from './sanitizeQueryValue'\n\ntype Args = {\n  adapter: PostgresAdapter\n  fields: Field[]\n  joinAliases: BuildQueryJoinAliases\n  joins: BuildQueryJoins\n  locale: string\n  selectFields: Record<string, GenericColumn>\n  tableName: string\n  where: Where\n}\n\nexport async function parseParams ({\n  adapter,\n  fields,\n  joinAliases,\n  joins,\n  locale,\n  selectFields,\n  tableName,\n  where,\n}: Args): Promise<SQL> {\n  let result: SQL\n  const constraints: SQL[] = []\n\n  if (typeof where === 'object' && Object.keys(where).length > 0) {\n    // We need to determine if the whereKey is an AND, OR, or a schema path\n    for (const relationOrPath of Object.keys(where)) {\n      if (relationOrPath) {\n        const condition = where[relationOrPath]\n        let conditionOperator: 'and' | 'or'\n        if (relationOrPath.toLowerCase() === 'and') {\n          conditionOperator = 'and'\n        } else if (relationOrPath.toLowerCase() === 'or') {\n          conditionOperator = 'or'\n        }\n        if (Array.isArray(condition)) {\n          const builtConditions = await buildAndOrConditions({\n            adapter,\n            fields,\n            joinAliases,\n            joins,\n            locale,\n            selectFields,\n            tableName,\n            where: condition,\n          })\n          if (builtConditions.length > 0) {\n            if (result) {\n              result = operatorMap[conditionOperator](result, ...builtConditions)\n            } else {\n              result = operatorMap[conditionOperator](...builtConditions)\n            }\n          }\n        } else {\n          // It's a path - and there can be multiple comparisons on a single path.\n          // For example - title like 'test' and title not equal to 'tester'\n          // So we need to loop on keys again here to handle each operator independently\n          const pathOperators = where[relationOrPath]\n          if (typeof pathOperators === 'object') {\n            for (const operator of Object.keys(pathOperators)) {\n              if (validOperators.includes(operator as Operator)) {\n                const {\n                  columnName,\n                  constraints: queryConstraints,\n                  field,\n                  getNotNullColumnByValue,\n                  pathSegments,\n                  rawColumn,\n                  table,\n                } = getTableColumnFromPath({\n                  adapter,\n                  collectionPath: relationOrPath,\n                  fields,\n                  joinAliases,\n                  joins,\n                  locale,\n                  pathSegments: relationOrPath.replace(/__/g, '.').split('.'),\n                  selectFields,\n                  tableName,\n                })\n\n                const val = where[relationOrPath][operator]\n\n                queryConstraints.forEach(({ columnName: col, table: constraintTable, value }) => {\n                  constraints.push(operatorMap.equals(constraintTable[col], value))\n                })\n\n                if (['json', 'richText'].includes(field.type) && Array.isArray(pathSegments)) {\n                  const segments = pathSegments.slice(1)\n                  segments.unshift(table[columnName].name)\n\n                  if (field.type === 'richText') {\n                    const jsonQuery = createJSONQuery({\n                      operator,\n                      pathSegments: segments,\n                      treatAsArray: ['children'],\n                      treatRootAsArray: true,\n                      value: val,\n                    })\n\n                    constraints.push(sql.raw(jsonQuery))\n                  }\n\n                  if (field.type === 'json') {\n                    const jsonQuery = convertPathToJSONTraversal(pathSegments)\n                    constraints.push(sql.raw(`${table[columnName].name}${jsonQuery} = '%${val}%'`))\n                  }\n\n                  break\n                }\n\n                if (getNotNullColumnByValue) {\n                  const columnName = getNotNullColumnByValue(val)\n                  if (columnName) {\n                    constraints.push(isNotNull(table[columnName]))\n                  } else {\n                    throw new QueryError([{ path: relationOrPath }])\n                  }\n                  break\n                }\n\n                if (operator === 'like') {\n                  constraints.push(\n                    and(...val.split(' ').map((word) => ilike(table[columnName], `%${word}%`))),\n                  )\n                  break\n                }\n\n                const { operator: queryOperator, value: queryValue } = sanitizeQueryValue({\n                  field,\n                  operator,\n                  val,\n                })\n\n                if (queryOperator === 'not_equals' && queryValue !== null) {\n                  constraints.push(\n                    or(\n                      isNull(rawColumn || table[columnName]),\n                      /* eslint-disable @typescript-eslint/no-explicit-any */\n                      ne<any>(rawColumn || table[columnName], queryValue),\n                    )\n                  )\n                } else {\n                  constraints.push(\n                    operatorMap[queryOperator](rawColumn || table[columnName], queryValue),\n                  )\n                }\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n  if (constraints.length > 0) {\n    if (result) {\n      result = and(result, ...constraints)\n    } else {\n      result = and(...constraints)\n    }\n  }\n  if (constraints.length === 1 && !result) {\n    ;[result] = constraints\n  }\n\n  return result\n}\n"],"names":["parseParams","adapter","fields","joinAliases","joins","locale","selectFields","tableName","where","result","constraints","Object","keys","length","relationOrPath","condition","conditionOperator","toLowerCase","Array","isArray","builtConditions","buildAndOrConditions","operatorMap","pathOperators","operator","validOperators","includes","columnName","queryConstraints","field","getNotNullColumnByValue","pathSegments","rawColumn","table","getTableColumnFromPath","collectionPath","replace","split","val","forEach","col","constraintTable","value","push","equals","type","segments","slice","unshift","name","jsonQuery","createJSONQuery","treatAsArray","treatRootAsArray","sql","raw","convertPathToJSONTraversal","isNotNull","QueryError","path","and","map","word","ilike","queryOperator","queryValue","sanitizeQueryValue","or","isNull","ne"],"mappings":"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"}
|