@payloadcms/db-postgres 0.1.0-beta.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (74) hide show
  1. package/dist/connect.js +82 -0
  2. package/dist/create.js +32 -0
  3. package/dist/createGlobal.js +32 -0
  4. package/dist/createGlobalVersion.js +48 -0
  5. package/dist/createMigration.js +85 -0
  6. package/dist/createVersion.js +54 -0
  7. package/dist/deleteMany.js +44 -0
  8. package/dist/deleteOne.js +47 -0
  9. package/dist/deleteVersions.js +46 -0
  10. package/dist/destroy.js +16 -0
  11. package/dist/find/buildFindManyArgs.js +61 -0
  12. package/dist/find/chainMethods.js +21 -0
  13. package/dist/find/findMany.js +197 -0
  14. package/dist/find/traverseFields.js +118 -0
  15. package/dist/find.js +35 -0
  16. package/dist/findGlobal.js +38 -0
  17. package/dist/findGlobalVersions.js +39 -0
  18. package/dist/findOne.js +49 -0
  19. package/dist/findVersions.js +39 -0
  20. package/dist/index.js +95 -0
  21. package/dist/init.js +74 -0
  22. package/dist/migrate.js +81 -0
  23. package/dist/migrateStatus.js +54 -0
  24. package/dist/mock.js +13 -0
  25. package/dist/queries/buildAndOrConditions.js +39 -0
  26. package/dist/queries/buildQuery.js +80 -0
  27. package/dist/queries/createJSONQuery/convertPathToJSONTraversal.js +24 -0
  28. package/dist/queries/createJSONQuery/formatJSONPathSegment.js +15 -0
  29. package/dist/queries/createJSONQuery/index.js +64 -0
  30. package/dist/queries/getTableColumnFromPath.js +333 -0
  31. package/dist/queries/operatorMap.js +34 -0
  32. package/dist/queries/parseParams.js +146 -0
  33. package/dist/queries/sanitizeQueryValue.js +79 -0
  34. package/dist/queryDrafts.js +56 -0
  35. package/dist/reference.js +76 -0
  36. package/dist/schema/build.js +245 -0
  37. package/dist/schema/createIndex.js +19 -0
  38. package/dist/schema/parentIDColumnMap.js +18 -0
  39. package/dist/schema/traverseFields.js +430 -0
  40. package/dist/schema/validateExistingBlockIsIdentical.js +34 -0
  41. package/dist/transactions/beginTransaction.js +51 -0
  42. package/dist/transactions/commitTransaction.js +24 -0
  43. package/dist/transactions/rollbackTransaction.js +20 -0
  44. package/dist/transform/read/hasManyNumber.js +20 -0
  45. package/dist/transform/read/index.js +42 -0
  46. package/dist/transform/read/relationship.js +74 -0
  47. package/dist/transform/read/traverseFields.js +325 -0
  48. package/dist/transform/write/array.js +55 -0
  49. package/dist/transform/write/blocks.js +56 -0
  50. package/dist/transform/write/index.js +46 -0
  51. package/dist/transform/write/numbers.js +21 -0
  52. package/dist/transform/write/relationships.js +33 -0
  53. package/dist/transform/write/selects.js +29 -0
  54. package/dist/transform/write/traverseFields.js +379 -0
  55. package/dist/transform/write/types.js +6 -0
  56. package/dist/types.js +6 -0
  57. package/dist/update.js +48 -0
  58. package/dist/updateGlobal.js +39 -0
  59. package/dist/updateGlobalVersion.js +50 -0
  60. package/dist/updateVersion.js +50 -0
  61. package/dist/upsertRow/deleteExistingArrayRows.js +20 -0
  62. package/dist/upsertRow/deleteExistingRowsByPath.js +43 -0
  63. package/dist/upsertRow/index.js +243 -0
  64. package/dist/upsertRow/insertArrays.js +64 -0
  65. package/dist/upsertRow/types.js +6 -0
  66. package/dist/utilities/appendPrefixToKeys.js +16 -0
  67. package/dist/utilities/createBlocksMap.js +39 -0
  68. package/dist/utilities/createMigrationTable.js +23 -0
  69. package/dist/utilities/createRelationshipMap.js +29 -0
  70. package/dist/utilities/hasLocalesTable.js +21 -0
  71. package/dist/utilities/isArrayOfRows.js +15 -0
  72. package/dist/utilities/migrationTableExists.js +19 -0
  73. package/dist/webpack.js +30 -0
  74. package/package.json +47 -0
@@ -0,0 +1,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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"}