@payloadcms/drizzle 3.0.0-canary.2c2c95f

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (290) hide show
  1. package/README.md +3 -0
  2. package/dist/count.d.ts +3 -0
  3. package/dist/count.d.ts.map +1 -0
  4. package/dist/count.js +25 -0
  5. package/dist/count.js.map +1 -0
  6. package/dist/create.d.ts +3 -0
  7. package/dist/create.d.ts.map +1 -0
  8. package/dist/create.js +19 -0
  9. package/dist/create.js.map +1 -0
  10. package/dist/createGlobal.d.ts +4 -0
  11. package/dist/createGlobal.d.ts.map +1 -0
  12. package/dist/createGlobal.js +19 -0
  13. package/dist/createGlobal.js.map +1 -0
  14. package/dist/createGlobalVersion.d.ts +4 -0
  15. package/dist/createGlobalVersion.d.ts.map +1 -0
  16. package/dist/createGlobalVersion.js +36 -0
  17. package/dist/createGlobalVersion.js.map +1 -0
  18. package/dist/createTableName.d.ts +31 -0
  19. package/dist/createTableName.d.ts.map +1 -0
  20. package/dist/createTableName.js +31 -0
  21. package/dist/createTableName.js.map +1 -0
  22. package/dist/createVersion.d.ts +4 -0
  23. package/dist/createVersion.d.ts.map +1 -0
  24. package/dist/createVersion.js +43 -0
  25. package/dist/createVersion.js.map +1 -0
  26. package/dist/deleteMany.d.ts +3 -0
  27. package/dist/deleteMany.d.ts.map +1 -0
  28. package/dist/deleteMany.js +32 -0
  29. package/dist/deleteMany.js.map +1 -0
  30. package/dist/deleteOne.d.ts +3 -0
  31. package/dist/deleteOne.d.ts.map +1 -0
  32. package/dist/deleteOne.js +63 -0
  33. package/dist/deleteOne.js.map +1 -0
  34. package/dist/deleteVersions.d.ts +3 -0
  35. package/dist/deleteVersions.d.ts.map +1 -0
  36. package/dist/deleteVersions.js +35 -0
  37. package/dist/deleteVersions.js.map +1 -0
  38. package/dist/destroy.d.ts +3 -0
  39. package/dist/destroy.d.ts.map +1 -0
  40. package/dist/destroy.js +15 -0
  41. package/dist/destroy.js.map +1 -0
  42. package/dist/find/buildFindManyArgs.d.ts +17 -0
  43. package/dist/find/buildFindManyArgs.d.ts.map +1 -0
  44. package/dist/find/buildFindManyArgs.js +65 -0
  45. package/dist/find/buildFindManyArgs.js.map +1 -0
  46. package/dist/find/chainMethods.d.ts +16 -0
  47. package/dist/find/chainMethods.d.ts.map +1 -0
  48. package/dist/find/chainMethods.js +12 -0
  49. package/dist/find/chainMethods.js.map +1 -0
  50. package/dist/find/findMany.d.ts +21 -0
  51. package/dist/find/findMany.d.ts.map +1 -0
  52. package/dist/find/findMany.js +141 -0
  53. package/dist/find/findMany.js.map +1 -0
  54. package/dist/find/traverseFields.d.ts +17 -0
  55. package/dist/find/traverseFields.d.ts.map +1 -0
  56. package/dist/find/traverseFields.js +156 -0
  57. package/dist/find/traverseFields.js.map +1 -0
  58. package/dist/find.d.ts +3 -0
  59. package/dist/find.d.ts.map +1 -0
  60. package/dist/find.js +21 -0
  61. package/dist/find.js.map +1 -0
  62. package/dist/findGlobal.d.ts +3 -0
  63. package/dist/findGlobal.d.ts.map +1 -0
  64. package/dist/findGlobal.js +23 -0
  65. package/dist/findGlobal.js.map +1 -0
  66. package/dist/findGlobalVersions.d.ts +3 -0
  67. package/dist/findGlobalVersions.d.ts.map +1 -0
  68. package/dist/findGlobalVersions.js +24 -0
  69. package/dist/findGlobalVersions.js.map +1 -0
  70. package/dist/findMigrationDir.d.ts +16 -0
  71. package/dist/findMigrationDir.d.ts.map +1 -0
  72. package/dist/findMigrationDir.js +36 -0
  73. package/dist/findMigrationDir.js.map +1 -0
  74. package/dist/findOne.d.ts +4 -0
  75. package/dist/findOne.d.ts.map +1 -0
  76. package/dist/findOne.js +21 -0
  77. package/dist/findOne.js.map +1 -0
  78. package/dist/findVersions.d.ts +3 -0
  79. package/dist/findVersions.d.ts.map +1 -0
  80. package/dist/findVersions.js +24 -0
  81. package/dist/findVersions.js.map +1 -0
  82. package/dist/index.d.ts +38 -0
  83. package/dist/index.d.ts.map +1 -0
  84. package/dist/index.js +38 -0
  85. package/dist/index.js.map +1 -0
  86. package/dist/migrate.d.ts +3 -0
  87. package/dist/migrate.d.ts.map +1 -0
  88. package/dist/migrate.js +97 -0
  89. package/dist/migrate.js.map +1 -0
  90. package/dist/migrateDown.d.ts +3 -0
  91. package/dist/migrateDown.d.ts.map +1 -0
  92. package/dist/migrateDown.js +63 -0
  93. package/dist/migrateDown.js.map +1 -0
  94. package/dist/migrateFresh.d.ts +8 -0
  95. package/dist/migrateFresh.d.ts.map +1 -0
  96. package/dist/migrateFresh.js +75 -0
  97. package/dist/migrateFresh.js.map +1 -0
  98. package/dist/migrateRefresh.d.ts +6 -0
  99. package/dist/migrateRefresh.d.ts.map +1 -0
  100. package/dist/migrateRefresh.js +102 -0
  101. package/dist/migrateRefresh.js.map +1 -0
  102. package/dist/migrateReset.d.ts +6 -0
  103. package/dist/migrateReset.d.ts.map +1 -0
  104. package/dist/migrateReset.js +82 -0
  105. package/dist/migrateReset.js.map +1 -0
  106. package/dist/migrateStatus.d.ts +3 -0
  107. package/dist/migrateStatus.d.ts.map +1 -0
  108. package/dist/migrateStatus.js +44 -0
  109. package/dist/migrateStatus.js.map +1 -0
  110. package/dist/queries/buildAndOrConditions.d.ts +16 -0
  111. package/dist/queries/buildAndOrConditions.d.ts.map +1 -0
  112. package/dist/queries/buildAndOrConditions.js +28 -0
  113. package/dist/queries/buildAndOrConditions.js.map +1 -0
  114. package/dist/queries/buildQuery.d.ts +29 -0
  115. package/dist/queries/buildQuery.d.ts.map +1 -0
  116. package/dist/queries/buildQuery.js +72 -0
  117. package/dist/queries/buildQuery.js.map +1 -0
  118. package/dist/queries/getTableAlias.d.ts +13 -0
  119. package/dist/queries/getTableAlias.d.ts.map +1 -0
  120. package/dist/queries/getTableAlias.js +20 -0
  121. package/dist/queries/getTableAlias.js.map +1 -0
  122. package/dist/queries/getTableColumnFromPath.d.ts +51 -0
  123. package/dist/queries/getTableColumnFromPath.d.ts.map +1 -0
  124. package/dist/queries/getTableColumnFromPath.js +532 -0
  125. package/dist/queries/getTableColumnFromPath.js.map +1 -0
  126. package/dist/queries/operatorMap.d.ts +6 -0
  127. package/dist/queries/operatorMap.d.ts.map +1 -0
  128. package/dist/queries/operatorMap.js +24 -0
  129. package/dist/queries/operatorMap.js.map +1 -0
  130. package/dist/queries/parseParams.d.ts +16 -0
  131. package/dist/queries/parseParams.d.ts.map +1 -0
  132. package/dist/queries/parseParams.js +188 -0
  133. package/dist/queries/parseParams.js.map +1 -0
  134. package/dist/queries/sanitizeQueryValue.d.ts +15 -0
  135. package/dist/queries/sanitizeQueryValue.d.ts.map +1 -0
  136. package/dist/queries/sanitizeQueryValue.js +120 -0
  137. package/dist/queries/sanitizeQueryValue.js.map +1 -0
  138. package/dist/queries/selectDistinct.d.ts +22 -0
  139. package/dist/queries/selectDistinct.d.ts.map +1 -0
  140. package/dist/queries/selectDistinct.js +38 -0
  141. package/dist/queries/selectDistinct.js.map +1 -0
  142. package/dist/queryDrafts.d.ts +3 -0
  143. package/dist/queryDrafts.d.ts.map +1 -0
  144. package/dist/queryDrafts.js +40 -0
  145. package/dist/queryDrafts.js.map +1 -0
  146. package/dist/transactions/beginTransaction.d.ts +3 -0
  147. package/dist/transactions/beginTransaction.d.ts.map +1 -0
  148. package/dist/transactions/beginTransaction.js +51 -0
  149. package/dist/transactions/beginTransaction.js.map +1 -0
  150. package/dist/transactions/commitTransaction.d.ts +3 -0
  151. package/dist/transactions/commitTransaction.d.ts.map +1 -0
  152. package/dist/transactions/commitTransaction.js +15 -0
  153. package/dist/transactions/commitTransaction.js.map +1 -0
  154. package/dist/transactions/rollbackTransaction.d.ts +3 -0
  155. package/dist/transactions/rollbackTransaction.d.ts.map +1 -0
  156. package/dist/transactions/rollbackTransaction.js +14 -0
  157. package/dist/transactions/rollbackTransaction.js.map +1 -0
  158. package/dist/transform/read/hasManyNumber.d.ts +10 -0
  159. package/dist/transform/read/hasManyNumber.d.ts.map +1 -0
  160. package/dist/transform/read/hasManyNumber.js +10 -0
  161. package/dist/transform/read/hasManyNumber.js.map +1 -0
  162. package/dist/transform/read/hasManyText.d.ts +10 -0
  163. package/dist/transform/read/hasManyText.d.ts.map +1 -0
  164. package/dist/transform/read/hasManyText.js +10 -0
  165. package/dist/transform/read/hasManyText.js.map +1 -0
  166. package/dist/transform/read/index.d.ts +13 -0
  167. package/dist/transform/read/index.d.ts.map +1 -0
  168. package/dist/transform/read/index.js +44 -0
  169. package/dist/transform/read/index.js.map +1 -0
  170. package/dist/transform/read/relationship.d.ts +10 -0
  171. package/dist/transform/read/relationship.d.ts.map +1 -0
  172. package/dist/transform/read/relationship.js +60 -0
  173. package/dist/transform/read/relationship.js.map +1 -0
  174. package/dist/transform/read/traverseFields.d.ts +57 -0
  175. package/dist/transform/read/traverseFields.d.ts.map +1 -0
  176. package/dist/transform/read/traverseFields.js +435 -0
  177. package/dist/transform/read/traverseFields.js.map +1 -0
  178. package/dist/transform/write/array.d.ts +26 -0
  179. package/dist/transform/write/array.d.ts.map +1 -0
  180. package/dist/transform/write/array.js +58 -0
  181. package/dist/transform/write/array.js.map +1 -0
  182. package/dist/transform/write/blocks.d.ts +25 -0
  183. package/dist/transform/write/blocks.d.ts.map +1 -0
  184. package/dist/transform/write/blocks.js +54 -0
  185. package/dist/transform/write/blocks.js.map +1 -0
  186. package/dist/transform/write/index.d.ts +13 -0
  187. package/dist/transform/write/index.d.ts.map +1 -0
  188. package/dist/transform/write/index.js +41 -0
  189. package/dist/transform/write/index.js.map +1 -0
  190. package/dist/transform/write/numbers.d.ts +8 -0
  191. package/dist/transform/write/numbers.d.ts.map +1 -0
  192. package/dist/transform/write/numbers.js +11 -0
  193. package/dist/transform/write/numbers.js.map +1 -0
  194. package/dist/transform/write/relationships.d.ts +10 -0
  195. package/dist/transform/write/relationships.d.ts.map +1 -0
  196. package/dist/transform/write/relationships.js +23 -0
  197. package/dist/transform/write/relationships.js.map +1 -0
  198. package/dist/transform/write/selects.d.ts +8 -0
  199. package/dist/transform/write/selects.d.ts.map +1 -0
  200. package/dist/transform/write/selects.js +20 -0
  201. package/dist/transform/write/selects.js.map +1 -0
  202. package/dist/transform/write/texts.d.ts +8 -0
  203. package/dist/transform/write/texts.d.ts.map +1 -0
  204. package/dist/transform/write/texts.js +11 -0
  205. package/dist/transform/write/texts.js.map +1 -0
  206. package/dist/transform/write/traverseFields.d.ts +50 -0
  207. package/dist/transform/write/traverseFields.d.ts.map +1 -0
  208. package/dist/transform/write/traverseFields.js +452 -0
  209. package/dist/transform/write/traverseFields.js.map +1 -0
  210. package/dist/transform/write/types.d.ts +43 -0
  211. package/dist/transform/write/types.d.ts.map +1 -0
  212. package/dist/transform/write/types.js +3 -0
  213. package/dist/transform/write/types.js.map +1 -0
  214. package/dist/types.d.ts +145 -0
  215. package/dist/types.d.ts.map +1 -0
  216. package/dist/types.js +3 -0
  217. package/dist/types.js.map +1 -0
  218. package/dist/update.d.ts +3 -0
  219. package/dist/update.d.ts.map +1 -0
  220. package/dist/update.js +54 -0
  221. package/dist/update.js.map +1 -0
  222. package/dist/updateGlobal.d.ts +4 -0
  223. package/dist/updateGlobal.d.ts.map +1 -0
  224. package/dist/updateGlobal.js +25 -0
  225. package/dist/updateGlobal.js.map +1 -0
  226. package/dist/updateGlobalVersion.d.ts +4 -0
  227. package/dist/updateGlobalVersion.d.ts.map +1 -0
  228. package/dist/updateGlobalVersion.js +36 -0
  229. package/dist/updateGlobalVersion.js.map +1 -0
  230. package/dist/updateVersion.d.ts +4 -0
  231. package/dist/updateVersion.d.ts.map +1 -0
  232. package/dist/updateVersion.js +36 -0
  233. package/dist/updateVersion.js.map +1 -0
  234. package/dist/upsertRow/deleteExistingArrayRows.d.ts +10 -0
  235. package/dist/upsertRow/deleteExistingArrayRows.d.ts.map +1 -0
  236. package/dist/upsertRow/deleteExistingArrayRows.js +14 -0
  237. package/dist/upsertRow/deleteExistingArrayRows.js.map +1 -0
  238. package/dist/upsertRow/deleteExistingRowsByPath.d.ts +14 -0
  239. package/dist/upsertRow/deleteExistingRowsByPath.d.ts.map +1 -0
  240. package/dist/upsertRow/deleteExistingRowsByPath.js +41 -0
  241. package/dist/upsertRow/deleteExistingRowsByPath.js.map +1 -0
  242. package/dist/upsertRow/index.d.ts +4 -0
  243. package/dist/upsertRow/index.d.ts.map +1 -0
  244. package/dist/upsertRow/index.js +337 -0
  245. package/dist/upsertRow/index.js.map +1 -0
  246. package/dist/upsertRow/insertArrays.d.ts +13 -0
  247. package/dist/upsertRow/insertArrays.d.ts.map +1 -0
  248. package/dist/upsertRow/insertArrays.js +76 -0
  249. package/dist/upsertRow/insertArrays.js.map +1 -0
  250. package/dist/upsertRow/types.d.ts +32 -0
  251. package/dist/upsertRow/types.d.ts.map +1 -0
  252. package/dist/upsertRow/types.js +3 -0
  253. package/dist/upsertRow/types.js.map +1 -0
  254. package/dist/utilities/appendPrefixToKeys.d.ts +2 -0
  255. package/dist/utilities/appendPrefixToKeys.d.ts.map +1 -0
  256. package/dist/utilities/appendPrefixToKeys.js +6 -0
  257. package/dist/utilities/appendPrefixToKeys.js.map +1 -0
  258. package/dist/utilities/createBlocksMap.d.ts +5 -0
  259. package/dist/utilities/createBlocksMap.d.ts.map +1 -0
  260. package/dist/utilities/createBlocksMap.js +29 -0
  261. package/dist/utilities/createBlocksMap.js.map +1 -0
  262. package/dist/utilities/createRelationshipMap.d.ts +2 -0
  263. package/dist/utilities/createRelationshipMap.d.ts.map +1 -0
  264. package/dist/utilities/createRelationshipMap.js +19 -0
  265. package/dist/utilities/createRelationshipMap.js.map +1 -0
  266. package/dist/utilities/hasLocalesTable.d.ts +3 -0
  267. package/dist/utilities/hasLocalesTable.d.ts.map +1 -0
  268. package/dist/utilities/hasLocalesTable.js +11 -0
  269. package/dist/utilities/hasLocalesTable.js.map +1 -0
  270. package/dist/utilities/isArrayOfRows.d.ts +2 -0
  271. package/dist/utilities/isArrayOfRows.d.ts.map +1 -0
  272. package/dist/utilities/isArrayOfRows.js +5 -0
  273. package/dist/utilities/isArrayOfRows.js.map +1 -0
  274. package/dist/utilities/migrationTableExists.d.ts +3 -0
  275. package/dist/utilities/migrationTableExists.d.ts.map +1 -0
  276. package/dist/utilities/migrationTableExists.js +25 -0
  277. package/dist/utilities/migrationTableExists.js.map +1 -0
  278. package/dist/utilities/parseError.d.ts +5 -0
  279. package/dist/utilities/parseError.d.ts.map +1 -0
  280. package/dist/utilities/parseError.js +15 -0
  281. package/dist/utilities/parseError.js.map +1 -0
  282. package/dist/utilities/pushDevSchema.d.ts +9 -0
  283. package/dist/utilities/pushDevSchema.d.ts.map +1 -0
  284. package/dist/utilities/pushDevSchema.js +53 -0
  285. package/dist/utilities/pushDevSchema.js.map +1 -0
  286. package/dist/utilities/validateExistingBlockIsIdentical.d.ts +11 -0
  287. package/dist/utilities/validateExistingBlockIsIdentical.d.ts.map +1 -0
  288. package/dist/utilities/validateExistingBlockIsIdentical.js +76 -0
  289. package/dist/utilities/validateExistingBlockIsIdentical.js.map +1 -0
  290. package/package.json +53 -0
@@ -0,0 +1,532 @@
1
+ import { and, eq, like, sql } from 'drizzle-orm';
2
+ import { APIError, flattenTopLevelFields } from 'payload';
3
+ import { fieldAffectsData, tabHasName } from 'payload/shared';
4
+ import toSnakeCase from 'to-snake-case';
5
+ import { getTableAlias } from './getTableAlias.js';
6
+ /**
7
+ * Transforms path to table and column name
8
+ * Adds tables to `join`
9
+ * @returns TableColumn
10
+ */ export const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPrefix = '', constraintPath: incomingConstraintPath, constraints = [], fields, joins, locale: incomingLocale, pathSegments: incomingSegments, rootTableName: incomingRootTableName, selectFields, tableName, tableNameSuffix = '', value })=>{
11
+ const fieldPath = incomingSegments[0];
12
+ let locale = incomingLocale;
13
+ const rootTableName = incomingRootTableName || tableName;
14
+ let constraintPath = incomingConstraintPath || '';
15
+ const field = flattenTopLevelFields(fields).find((fieldToFind)=>fieldAffectsData(fieldToFind) && fieldToFind.name === fieldPath);
16
+ let newTableName = tableName;
17
+ if (!field && fieldPath === 'id') {
18
+ selectFields.id = adapter.tables[newTableName].id;
19
+ return {
20
+ columnName: 'id',
21
+ constraints,
22
+ field: {
23
+ name: 'id',
24
+ type: adapter.idType === 'uuid' ? 'text' : 'number'
25
+ },
26
+ table: adapter.tables[newTableName]
27
+ };
28
+ }
29
+ if (field) {
30
+ const pathSegments = [
31
+ ...incomingSegments
32
+ ];
33
+ // If next segment is a locale,
34
+ // we need to take it out and use it as the locale from this point on
35
+ if ('localized' in field && field.localized && adapter.payload.config.localization) {
36
+ const matchedLocale = adapter.payload.config.localization.localeCodes.find((locale)=>locale === pathSegments[1]);
37
+ if (matchedLocale) {
38
+ locale = matchedLocale;
39
+ pathSegments.splice(1, 1);
40
+ }
41
+ }
42
+ switch(field.type){
43
+ case 'tabs':
44
+ {
45
+ return getTableColumnFromPath({
46
+ adapter,
47
+ aliasTable,
48
+ collectionPath,
49
+ columnPrefix,
50
+ constraintPath,
51
+ constraints,
52
+ fields: field.tabs.map((tab)=>({
53
+ ...tab,
54
+ type: 'tab'
55
+ })),
56
+ joins,
57
+ locale,
58
+ pathSegments: pathSegments.slice(1),
59
+ rootTableName,
60
+ selectFields,
61
+ tableName: newTableName,
62
+ tableNameSuffix,
63
+ value
64
+ });
65
+ }
66
+ case 'tab':
67
+ {
68
+ if (tabHasName(field)) {
69
+ return getTableColumnFromPath({
70
+ adapter,
71
+ aliasTable,
72
+ collectionPath,
73
+ columnPrefix: `${columnPrefix}${field.name}_`,
74
+ constraintPath: `${constraintPath}${field.name}.`,
75
+ constraints,
76
+ fields: field.fields,
77
+ joins,
78
+ locale,
79
+ pathSegments: pathSegments.slice(1),
80
+ rootTableName,
81
+ selectFields,
82
+ tableName: newTableName,
83
+ tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,
84
+ value
85
+ });
86
+ }
87
+ return getTableColumnFromPath({
88
+ adapter,
89
+ aliasTable,
90
+ collectionPath,
91
+ columnPrefix,
92
+ constraintPath,
93
+ constraints,
94
+ fields: field.fields,
95
+ joins,
96
+ locale,
97
+ pathSegments: pathSegments.slice(1),
98
+ rootTableName,
99
+ selectFields,
100
+ tableName: newTableName,
101
+ tableNameSuffix,
102
+ value
103
+ });
104
+ }
105
+ case 'group':
106
+ {
107
+ if (locale && field.localized && adapter.payload.config.localization) {
108
+ newTableName = `${tableName}${adapter.localesSuffix}`;
109
+ joins.push({
110
+ condition: eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),
111
+ table: adapter.tables[newTableName]
112
+ });
113
+ if (locale !== 'all') {
114
+ constraints.push({
115
+ columnName: '_locale',
116
+ table: adapter.tables[newTableName],
117
+ value: locale
118
+ });
119
+ }
120
+ }
121
+ return getTableColumnFromPath({
122
+ adapter,
123
+ aliasTable,
124
+ collectionPath,
125
+ columnPrefix: `${columnPrefix}${field.name}_`,
126
+ constraintPath: `${constraintPath}${field.name}.`,
127
+ constraints,
128
+ fields: field.fields,
129
+ joins,
130
+ locale,
131
+ pathSegments: pathSegments.slice(1),
132
+ rootTableName,
133
+ selectFields,
134
+ tableName: newTableName,
135
+ tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,
136
+ value
137
+ });
138
+ }
139
+ case 'select':
140
+ {
141
+ if (field.hasMany) {
142
+ const newTableName = adapter.tableNameMap.get(`${tableName}_${tableNameSuffix}${toSnakeCase(field.name)}`);
143
+ if (locale && field.localized && adapter.payload.config.localization) {
144
+ joins.push({
145
+ condition: and(eq(adapter.tables[tableName].id, adapter.tables[newTableName].parent), eq(adapter.tables[newTableName]._locale, locale)),
146
+ table: adapter.tables[newTableName]
147
+ });
148
+ if (locale !== 'all') {
149
+ constraints.push({
150
+ columnName: '_locale',
151
+ table: adapter.tables[newTableName],
152
+ value: locale
153
+ });
154
+ }
155
+ } else {
156
+ joins.push({
157
+ condition: eq(adapter.tables[tableName].id, adapter.tables[newTableName].parent),
158
+ table: adapter.tables[newTableName]
159
+ });
160
+ }
161
+ return {
162
+ columnName: 'value',
163
+ constraints,
164
+ field,
165
+ table: adapter.tables[newTableName]
166
+ };
167
+ }
168
+ break;
169
+ }
170
+ case 'text':
171
+ case 'number':
172
+ {
173
+ if (field.hasMany) {
174
+ let tableType = 'texts';
175
+ let columnName = 'text';
176
+ if (field.type === 'number') {
177
+ tableType = 'numbers';
178
+ columnName = 'number';
179
+ }
180
+ newTableName = `${tableName}_${tableType}`;
181
+ const joinConstraints = [
182
+ eq(adapter.tables[tableName].id, adapter.tables[newTableName].parent),
183
+ eq(adapter.tables[newTableName].path, `${constraintPath}${field.name}`)
184
+ ];
185
+ if (locale && field.localized && adapter.payload.config.localization) {
186
+ joins.push({
187
+ condition: and(...joinConstraints, eq(adapter.tables[newTableName]._locale, locale)),
188
+ table: adapter.tables[newTableName]
189
+ });
190
+ if (locale !== 'all') {
191
+ constraints.push({
192
+ columnName: 'locale',
193
+ table: adapter.tables[newTableName],
194
+ value: locale
195
+ });
196
+ }
197
+ } else {
198
+ joins.push({
199
+ condition: and(...joinConstraints),
200
+ table: adapter.tables[newTableName]
201
+ });
202
+ }
203
+ return {
204
+ columnName,
205
+ constraints,
206
+ field,
207
+ table: adapter.tables[newTableName]
208
+ };
209
+ }
210
+ break;
211
+ }
212
+ case 'array':
213
+ {
214
+ newTableName = adapter.tableNameMap.get(`${tableName}_${tableNameSuffix}${toSnakeCase(field.name)}`);
215
+ constraintPath = `${constraintPath}${field.name}.%.`;
216
+ if (locale && field.localized && adapter.payload.config.localization) {
217
+ joins.push({
218
+ condition: and(eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID), eq(adapter.tables[newTableName]._locale, locale)),
219
+ table: adapter.tables[newTableName]
220
+ });
221
+ if (locale !== 'all') {
222
+ constraints.push({
223
+ columnName: '_locale',
224
+ table: adapter.tables[newTableName],
225
+ value: locale
226
+ });
227
+ }
228
+ } else {
229
+ joins.push({
230
+ condition: eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),
231
+ table: adapter.tables[newTableName]
232
+ });
233
+ }
234
+ return getTableColumnFromPath({
235
+ adapter,
236
+ collectionPath,
237
+ constraintPath,
238
+ constraints,
239
+ fields: field.fields,
240
+ joins,
241
+ locale,
242
+ pathSegments: pathSegments.slice(1),
243
+ rootTableName,
244
+ selectFields,
245
+ tableName: newTableName,
246
+ value
247
+ });
248
+ }
249
+ case 'blocks':
250
+ {
251
+ let blockTableColumn;
252
+ let newTableName;
253
+ // handle blockType queries
254
+ if (pathSegments[1] === 'blockType') {
255
+ // find the block config using the value
256
+ const blockTypes = Array.isArray(value) ? value : [
257
+ value
258
+ ];
259
+ blockTypes.forEach((blockType)=>{
260
+ const block = field.blocks.find((block)=>block.slug === blockType);
261
+ newTableName = adapter.tableNameMap.get(`${tableName}_blocks_${toSnakeCase(block.slug)}`);
262
+ const { newAliasTable } = getTableAlias({
263
+ adapter,
264
+ tableName: newTableName
265
+ });
266
+ joins.push({
267
+ condition: eq(adapter.tables[tableName].id, newAliasTable._parentID),
268
+ table: newAliasTable
269
+ });
270
+ constraints.push({
271
+ columnName: '_path',
272
+ table: newAliasTable,
273
+ value: pathSegments[0]
274
+ });
275
+ });
276
+ return {
277
+ constraints,
278
+ field,
279
+ getNotNullColumnByValue: ()=>'id',
280
+ table: adapter.tables[tableName]
281
+ };
282
+ }
283
+ const hasBlockField = field.blocks.some((block)=>{
284
+ newTableName = adapter.tableNameMap.get(`${tableName}_blocks_${toSnakeCase(block.slug)}`);
285
+ constraintPath = `${constraintPath}${field.name}.%.`;
286
+ let result;
287
+ const blockConstraints = [];
288
+ const blockSelectFields = {};
289
+ try {
290
+ result = getTableColumnFromPath({
291
+ adapter,
292
+ collectionPath,
293
+ constraintPath,
294
+ constraints: blockConstraints,
295
+ fields: block.fields,
296
+ joins,
297
+ locale,
298
+ pathSegments: pathSegments.slice(1),
299
+ rootTableName,
300
+ selectFields: blockSelectFields,
301
+ tableName: newTableName,
302
+ value
303
+ });
304
+ } catch (error) {
305
+ // this is fine, not every block will have the field
306
+ }
307
+ if (!result) {
308
+ return;
309
+ }
310
+ blockTableColumn = result;
311
+ constraints = constraints.concat(blockConstraints);
312
+ selectFields = {
313
+ ...selectFields,
314
+ ...blockSelectFields
315
+ };
316
+ if (field.localized && adapter.payload.config.localization) {
317
+ joins.push({
318
+ condition: and(eq((aliasTable || adapter.tables[tableName]).id, adapter.tables[newTableName]._parentID), eq(adapter.tables[newTableName]._locale, locale)),
319
+ table: adapter.tables[newTableName]
320
+ });
321
+ if (locale) {
322
+ constraints.push({
323
+ columnName: '_locale',
324
+ table: adapter.tables[newTableName],
325
+ value: locale
326
+ });
327
+ }
328
+ } else {
329
+ joins.push({
330
+ condition: eq((aliasTable || adapter.tables[tableName]).id, adapter.tables[newTableName]._parentID),
331
+ table: adapter.tables[newTableName]
332
+ });
333
+ }
334
+ return true;
335
+ });
336
+ if (hasBlockField) {
337
+ return {
338
+ columnName: blockTableColumn.columnName,
339
+ constraints,
340
+ field: blockTableColumn.field,
341
+ pathSegments: pathSegments.slice(1),
342
+ rawColumn: blockTableColumn.rawColumn,
343
+ table: blockTableColumn.table
344
+ };
345
+ }
346
+ break;
347
+ }
348
+ case 'relationship':
349
+ case 'upload':
350
+ {
351
+ const newCollectionPath = pathSegments.slice(1).join('.');
352
+ if (Array.isArray(field.relationTo) || field.type === 'relationship' && field.hasMany) {
353
+ let relationshipFields;
354
+ const relationTableName = `${rootTableName}${adapter.relationshipsSuffix}`;
355
+ const { newAliasTable: aliasRelationshipTable, newAliasTableName: aliasRelationshipTableName } = getTableAlias({
356
+ adapter,
357
+ tableName: relationTableName
358
+ });
359
+ // Join in the relationships table
360
+ if (locale && field.localized && adapter.payload.config.localization) {
361
+ joins.push({
362
+ condition: and(eq((aliasTable || adapter.tables[rootTableName]).id, aliasRelationshipTable.parent), eq(aliasRelationshipTable.locale, locale), like(aliasRelationshipTable.path, `${constraintPath}${field.name}`)),
363
+ table: aliasRelationshipTable
364
+ });
365
+ if (locale !== 'all') {
366
+ constraints.push({
367
+ columnName: 'locale',
368
+ table: aliasRelationshipTable,
369
+ value: locale
370
+ });
371
+ }
372
+ } else {
373
+ // Join in the relationships table
374
+ joins.push({
375
+ condition: and(eq((aliasTable || adapter.tables[rootTableName]).id, aliasRelationshipTable.parent), like(aliasRelationshipTable.path, `${constraintPath}${field.name}`)),
376
+ table: aliasRelationshipTable
377
+ });
378
+ }
379
+ selectFields[`${relationTableName}.path`] = aliasRelationshipTable.path;
380
+ let newAliasTable;
381
+ if (typeof field.relationTo === 'string') {
382
+ const relationshipConfig = adapter.payload.collections[field.relationTo].config;
383
+ newTableName = adapter.tableNameMap.get(toSnakeCase(relationshipConfig.slug));
384
+ // parent to relationship join table
385
+ relationshipFields = relationshipConfig.fields;
386
+ ({ newAliasTable } = getTableAlias({
387
+ adapter,
388
+ tableName: newTableName
389
+ }));
390
+ joins.push({
391
+ condition: eq(newAliasTable.id, aliasRelationshipTable[`${field.relationTo}ID`]),
392
+ table: newAliasTable
393
+ });
394
+ if (newCollectionPath === '' || newCollectionPath === 'id') {
395
+ return {
396
+ columnName: `${field.relationTo}ID`,
397
+ constraints,
398
+ field,
399
+ table: aliasRelationshipTable
400
+ };
401
+ }
402
+ } else if (newCollectionPath === 'value') {
403
+ const tableColumnsNames = field.relationTo.map((relationTo)=>{
404
+ const relationTableName = adapter.tableNameMap.get(toSnakeCase(adapter.payload.collections[relationTo].config.slug));
405
+ return `"${aliasRelationshipTableName}"."${relationTableName}_id"`;
406
+ });
407
+ let column;
408
+ if (tableColumnsNames.length === 1) {
409
+ column = tableColumnsNames[0];
410
+ } else {
411
+ column = `COALESCE(${tableColumnsNames.join(', ')})`;
412
+ }
413
+ return {
414
+ constraints,
415
+ field,
416
+ rawColumn: sql.raw(`${column}`),
417
+ table: aliasRelationshipTable
418
+ };
419
+ } else if (newCollectionPath === 'relationTo') {
420
+ const relationTo = Array.isArray(field.relationTo) ? field.relationTo : [
421
+ field.relationTo
422
+ ];
423
+ return {
424
+ constraints,
425
+ field,
426
+ getNotNullColumnByValue: (val)=>{
427
+ const matchedRelation = relationTo.find((relation)=>relation === val);
428
+ if (matchedRelation) return `${matchedRelation}ID`;
429
+ return undefined;
430
+ },
431
+ table: aliasRelationshipTable
432
+ };
433
+ } else {
434
+ throw new APIError('Not supported');
435
+ }
436
+ return getTableColumnFromPath({
437
+ adapter,
438
+ aliasTable: newAliasTable,
439
+ collectionPath: newCollectionPath,
440
+ constraints,
441
+ fields: relationshipFields,
442
+ joins,
443
+ locale,
444
+ pathSegments: pathSegments.slice(1),
445
+ rootTableName: newTableName,
446
+ selectFields,
447
+ tableName: newTableName,
448
+ value
449
+ });
450
+ } else if (pathSegments.length > 1 && !(pathSegments.length === 2 && pathSegments[1] === 'id')) {
451
+ // simple relationships
452
+ const columnName = `${columnPrefix}${field.name}`;
453
+ const newTableName = adapter.tableNameMap.get(toSnakeCase(adapter.payload.collections[field.relationTo].config.slug));
454
+ const { newAliasTable } = getTableAlias({
455
+ adapter,
456
+ tableName: newTableName
457
+ });
458
+ if (field.localized && adapter.payload.config.localization) {
459
+ const { newAliasTable: aliasLocaleTable } = getTableAlias({
460
+ adapter,
461
+ tableName: `${rootTableName}${adapter.localesSuffix}`
462
+ });
463
+ joins.push({
464
+ condition: and(eq(aliasLocaleTable._parentID, adapter.tables[rootTableName].id), eq(aliasLocaleTable._locale, locale)),
465
+ table: aliasLocaleTable
466
+ });
467
+ joins.push({
468
+ condition: eq(aliasLocaleTable[columnName], newAliasTable.id),
469
+ table: newAliasTable
470
+ });
471
+ } else {
472
+ joins.push({
473
+ condition: eq(newAliasTable.id, aliasTable ? aliasTable[columnName] : adapter.tables[tableName][columnName]),
474
+ table: newAliasTable
475
+ });
476
+ }
477
+ return getTableColumnFromPath({
478
+ adapter,
479
+ aliasTable: newAliasTable,
480
+ collectionPath: newCollectionPath,
481
+ constraintPath: '',
482
+ constraints,
483
+ fields: adapter.payload.collections[field.relationTo].config.fields,
484
+ joins,
485
+ locale,
486
+ pathSegments: pathSegments.slice(1),
487
+ selectFields,
488
+ tableName: newTableName,
489
+ value
490
+ });
491
+ }
492
+ break;
493
+ }
494
+ default:
495
+ {
496
+ break;
497
+ }
498
+ }
499
+ if (fieldAffectsData(field)) {
500
+ if (field.localized && adapter.payload.config.localization) {
501
+ // If localized, we go to localized table and set aliasTable to undefined
502
+ // so it is not picked up below to be used as targetTable
503
+ const parentTable = aliasTable || adapter.tables[tableName];
504
+ newTableName = `${tableName}${adapter.localesSuffix}`;
505
+ joins.push({
506
+ condition: eq(parentTable.id, adapter.tables[newTableName]._parentID),
507
+ table: adapter.tables[newTableName]
508
+ });
509
+ aliasTable = undefined;
510
+ if (locale !== 'all') {
511
+ constraints.push({
512
+ columnName: '_locale',
513
+ table: adapter.tables[newTableName],
514
+ value: locale
515
+ });
516
+ }
517
+ }
518
+ const targetTable = aliasTable || adapter.tables[newTableName];
519
+ selectFields[`${newTableName}.${columnPrefix}${field.name}`] = targetTable[`${columnPrefix}${field.name}`];
520
+ return {
521
+ columnName: `${columnPrefix}${field.name}`,
522
+ constraints,
523
+ field,
524
+ pathSegments,
525
+ table: targetTable
526
+ };
527
+ }
528
+ }
529
+ throw new APIError(`Cannot find field for path at ${fieldPath}`);
530
+ };
531
+
532
+ //# sourceMappingURL=getTableColumnFromPath.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/queries/getTableColumnFromPath.ts"],"sourcesContent":["import type { SQL } from 'drizzle-orm'\nimport type { PgTableWithColumns } from 'drizzle-orm/pg-core'\nimport type { SQLiteTableWithColumns } from 'drizzle-orm/sqlite-core'\nimport type { Field, FieldAffectingData, NumberField, TabAsField, TextField } from 'payload'\n\nimport { and, eq, like, sql } from 'drizzle-orm'\nimport { APIError, flattenTopLevelFields } from 'payload'\nimport { fieldAffectsData, tabHasName } from 'payload/shared'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { DrizzleAdapter, GenericColumn } from '../types.js'\nimport type { BuildQueryJoinAliases } from './buildQuery.js'\n\nimport { getTableAlias } from './getTableAlias.js'\n\ntype Constraint = {\n columnName: string\n table: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\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: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n}\n\ntype Args = {\n adapter: DrizzleAdapter\n aliasTable?: PgTableWithColumns<any> | SQLiteTableWithColumns<any>\n collectionPath: string\n columnPrefix?: string\n constraintPath?: string\n constraints?: Constraint[]\n fields: (Field | TabAsField)[]\n joins: BuildQueryJoinAliases\n locale?: string\n pathSegments: string[]\n rootTableName?: string\n selectFields: Record<string, GenericColumn>\n tableName: string\n /**\n * If creating a new table name for arrays and blocks, this suffix should be appended to the table name\n */\n tableNameSuffix?: string\n /**\n * The raw value of the query before sanitization\n */\n value: unknown\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 constraintPath: incomingConstraintPath,\n constraints = [],\n fields,\n joins,\n locale: incomingLocale,\n pathSegments: incomingSegments,\n rootTableName: incomingRootTableName,\n selectFields,\n tableName,\n tableNameSuffix = '',\n value,\n}: Args): TableColumn => {\n const fieldPath = incomingSegments[0]\n let locale = incomingLocale\n const rootTableName = incomingRootTableName || tableName\n let constraintPath = incomingConstraintPath || ''\n\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: adapter.idType === 'uuid' ? 'text' : 'number',\n } as NumberField | TextField,\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 constraintPath,\n constraints,\n fields: field.tabs.map((tab) => ({\n ...tab,\n type: 'tab',\n })),\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n tableName: newTableName,\n tableNameSuffix,\n value,\n })\n }\n case 'tab': {\n if (tabHasName(field)) {\n return getTableColumnFromPath({\n adapter,\n aliasTable,\n collectionPath,\n columnPrefix: `${columnPrefix}${field.name}_`,\n constraintPath: `${constraintPath}${field.name}.`,\n constraints,\n fields: field.fields,\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n tableName: newTableName,\n tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,\n value,\n })\n }\n return getTableColumnFromPath({\n adapter,\n aliasTable,\n collectionPath,\n columnPrefix,\n constraintPath,\n constraints,\n fields: field.fields,\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n tableName: newTableName,\n tableNameSuffix,\n value,\n })\n }\n\n case 'group': {\n if (locale && field.localized && adapter.payload.config.localization) {\n newTableName = `${tableName}${adapter.localesSuffix}`\n\n joins.push({\n condition: eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n table: adapter.tables[newTableName],\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 constraintPath: `${constraintPath}${field.name}.`,\n constraints,\n fields: field.fields,\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n tableName: newTableName,\n tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,\n value,\n })\n }\n\n case 'select': {\n if (field.hasMany) {\n const newTableName = adapter.tableNameMap.get(\n `${tableName}_${tableNameSuffix}${toSnakeCase(field.name)}`,\n )\n\n if (locale && field.localized && adapter.payload.config.localization) {\n joins.push({\n condition: and(\n eq(adapter.tables[tableName].id, adapter.tables[newTableName].parent),\n eq(adapter.tables[newTableName]._locale, locale),\n ),\n table: adapter.tables[newTableName],\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.push({\n condition: eq(adapter.tables[tableName].id, adapter.tables[newTableName].parent),\n table: adapter.tables[newTableName],\n })\n }\n\n return {\n columnName: 'value',\n constraints,\n field,\n table: adapter.tables[newTableName],\n }\n }\n break\n }\n\n case 'text':\n case 'number': {\n if (field.hasMany) {\n let tableType = 'texts'\n let columnName = 'text'\n if (field.type === 'number') {\n tableType = 'numbers'\n columnName = 'number'\n }\n newTableName = `${tableName}_${tableType}`\n const joinConstraints = [\n eq(adapter.tables[tableName].id, adapter.tables[newTableName].parent),\n eq(adapter.tables[newTableName].path, `${constraintPath}${field.name}`),\n ]\n\n if (locale && field.localized && adapter.payload.config.localization) {\n joins.push({\n condition: and(...joinConstraints, eq(adapter.tables[newTableName]._locale, locale)),\n table: adapter.tables[newTableName],\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.push({\n condition: and(...joinConstraints),\n table: adapter.tables[newTableName],\n })\n }\n\n return {\n columnName,\n constraints,\n field,\n table: adapter.tables[newTableName],\n }\n }\n break\n }\n\n case 'array': {\n newTableName = adapter.tableNameMap.get(\n `${tableName}_${tableNameSuffix}${toSnakeCase(field.name)}`,\n )\n\n constraintPath = `${constraintPath}${field.name}.%.`\n if (locale && field.localized && adapter.payload.config.localization) {\n joins.push({\n condition: and(\n eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n eq(adapter.tables[newTableName]._locale, locale),\n ),\n table: adapter.tables[newTableName],\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.push({\n condition: eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n table: adapter.tables[newTableName],\n })\n }\n return getTableColumnFromPath({\n adapter,\n collectionPath,\n constraintPath,\n constraints,\n fields: field.fields,\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields,\n tableName: newTableName,\n value,\n })\n }\n\n case 'blocks': {\n let blockTableColumn: TableColumn\n let newTableName: string\n\n // handle blockType queries\n if (pathSegments[1] === 'blockType') {\n // find the block config using the value\n const blockTypes = Array.isArray(value) ? value : [value]\n blockTypes.forEach((blockType) => {\n const block = field.blocks.find((block) => block.slug === blockType)\n newTableName = adapter.tableNameMap.get(\n `${tableName}_blocks_${toSnakeCase(block.slug)}`,\n )\n\n const { newAliasTable } = getTableAlias({ adapter, tableName: newTableName })\n\n joins.push({\n condition: eq(adapter.tables[tableName].id, newAliasTable._parentID),\n table: newAliasTable,\n })\n constraints.push({\n columnName: '_path',\n table: newAliasTable,\n value: pathSegments[0],\n })\n })\n return {\n constraints,\n field,\n getNotNullColumnByValue: () => 'id',\n table: adapter.tables[tableName],\n }\n }\n\n const hasBlockField = field.blocks.some((block) => {\n newTableName = adapter.tableNameMap.get(`${tableName}_blocks_${toSnakeCase(block.slug)}`)\n constraintPath = `${constraintPath}${field.name}.%.`\n\n let result\n const blockConstraints = []\n const blockSelectFields = {}\n try {\n result = getTableColumnFromPath({\n adapter,\n collectionPath,\n constraintPath,\n constraints: blockConstraints,\n fields: block.fields,\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName,\n selectFields: blockSelectFields,\n tableName: newTableName,\n value,\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.push({\n condition: and(\n eq(\n (aliasTable || adapter.tables[tableName]).id,\n adapter.tables[newTableName]._parentID,\n ),\n eq(adapter.tables[newTableName]._locale, locale),\n ),\n table: adapter.tables[newTableName],\n })\n if (locale) {\n constraints.push({\n columnName: '_locale',\n table: adapter.tables[newTableName],\n value: locale,\n })\n }\n } else {\n joins.push({\n condition: eq(\n (aliasTable || adapter.tables[tableName]).id,\n adapter.tables[newTableName]._parentID,\n ),\n table: adapter.tables[newTableName],\n })\n }\n return true\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: blockTableColumn.table,\n }\n }\n break\n }\n\n case 'relationship':\n case 'upload': {\n const newCollectionPath = pathSegments.slice(1).join('.')\n if (Array.isArray(field.relationTo) || (field.type === 'relationship' && field.hasMany)) {\n let relationshipFields\n const relationTableName = `${rootTableName}${adapter.relationshipsSuffix}`\n const {\n newAliasTable: aliasRelationshipTable,\n newAliasTableName: aliasRelationshipTableName,\n } = getTableAlias({ adapter, tableName: relationTableName })\n\n // Join in the relationships table\n if (locale && field.localized && adapter.payload.config.localization) {\n joins.push({\n condition: and(\n eq((aliasTable || adapter.tables[rootTableName]).id, aliasRelationshipTable.parent),\n eq(aliasRelationshipTable.locale, locale),\n like(aliasRelationshipTable.path, `${constraintPath}${field.name}`),\n ),\n table: aliasRelationshipTable,\n })\n if (locale !== 'all') {\n constraints.push({\n columnName: 'locale',\n table: aliasRelationshipTable,\n value: locale,\n })\n }\n } else {\n // Join in the relationships table\n joins.push({\n condition: and(\n eq((aliasTable || adapter.tables[rootTableName]).id, aliasRelationshipTable.parent),\n like(aliasRelationshipTable.path, `${constraintPath}${field.name}`),\n ),\n table: aliasRelationshipTable,\n })\n }\n\n selectFields[`${relationTableName}.path`] = aliasRelationshipTable.path\n\n let newAliasTable\n\n if (typeof field.relationTo === 'string') {\n const relationshipConfig = adapter.payload.collections[field.relationTo].config\n\n newTableName = adapter.tableNameMap.get(toSnakeCase(relationshipConfig.slug))\n\n // parent to relationship join table\n relationshipFields = relationshipConfig.fields\n ;({ newAliasTable } = getTableAlias({ adapter, tableName: newTableName }))\n\n joins.push({\n condition: eq(newAliasTable.id, aliasRelationshipTable[`${field.relationTo}ID`]),\n table: newAliasTable,\n })\n\n if (newCollectionPath === '' || newCollectionPath === 'id') {\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((relationTo) => {\n const relationTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[relationTo].config.slug),\n )\n\n return `\"${aliasRelationshipTableName}\".\"${relationTableName}_id\"`\n })\n\n let column: string\n if (tableColumnsNames.length === 1) {\n column = tableColumnsNames[0]\n } else {\n column = `COALESCE(${tableColumnsNames.join(', ')})`\n }\n\n return {\n constraints,\n field,\n rawColumn: sql.raw(`${column}`),\n table: aliasRelationshipTable,\n }\n } else if (newCollectionPath === 'relationTo') {\n const relationTo = Array.isArray(field.relationTo)\n ? field.relationTo\n : [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 joins,\n locale,\n pathSegments: pathSegments.slice(1),\n rootTableName: newTableName,\n selectFields,\n tableName: newTableName,\n value,\n })\n } else if (\n pathSegments.length > 1 &&\n !(pathSegments.length === 2 && pathSegments[1] === 'id')\n ) {\n // simple relationships\n const columnName = `${columnPrefix}${field.name}`\n const newTableName = adapter.tableNameMap.get(\n toSnakeCase(adapter.payload.collections[field.relationTo].config.slug),\n )\n const { newAliasTable } = getTableAlias({ adapter, tableName: newTableName })\n\n if (field.localized && adapter.payload.config.localization) {\n const { newAliasTable: aliasLocaleTable } = getTableAlias({\n adapter,\n tableName: `${rootTableName}${adapter.localesSuffix}`,\n })\n\n joins.push({\n condition: and(\n eq(aliasLocaleTable._parentID, adapter.tables[rootTableName].id),\n eq(aliasLocaleTable._locale, locale),\n ),\n table: aliasLocaleTable,\n })\n joins.push({\n condition: eq(aliasLocaleTable[columnName], newAliasTable.id),\n table: newAliasTable,\n })\n } else {\n joins.push({\n condition: eq(\n newAliasTable.id,\n aliasTable ? aliasTable[columnName] : adapter.tables[tableName][columnName],\n ),\n table: newAliasTable,\n })\n }\n\n return getTableColumnFromPath({\n adapter,\n aliasTable: newAliasTable,\n collectionPath: newCollectionPath,\n constraintPath: '',\n constraints,\n fields: adapter.payload.collections[field.relationTo].config.fields,\n joins,\n locale,\n pathSegments: pathSegments.slice(1),\n selectFields,\n tableName: newTableName,\n value,\n })\n }\n break\n }\n\n default: {\n // fall through\n break\n }\n }\n\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 const parentTable = aliasTable || adapter.tables[tableName]\n newTableName = `${tableName}${adapter.localesSuffix}`\n\n joins.push({\n condition: eq(parentTable.id, adapter.tables[newTableName]._parentID),\n table: adapter.tables[newTableName],\n })\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,\n table: targetTable,\n }\n }\n }\n\n throw new APIError(`Cannot find field for path at ${fieldPath}`)\n}\n"],"names":["and","eq","like","sql","APIError","flattenTopLevelFields","fieldAffectsData","tabHasName","toSnakeCase","getTableAlias","getTableColumnFromPath","adapter","aliasTable","collectionPath","columnPrefix","constraintPath","incomingConstraintPath","constraints","fields","joins","locale","incomingLocale","pathSegments","incomingSegments","rootTableName","incomingRootTableName","selectFields","tableName","tableNameSuffix","value","fieldPath","field","find","fieldToFind","name","newTableName","id","tables","columnName","type","idType","table","localized","payload","config","localization","matchedLocale","localeCodes","splice","tabs","map","tab","slice","localesSuffix","push","condition","_parentID","hasMany","tableNameMap","get","parent","_locale","tableType","joinConstraints","path","blockTableColumn","blockTypes","Array","isArray","forEach","blockType","block","blocks","slug","newAliasTable","getNotNullColumnByValue","hasBlockField","some","result","blockConstraints","blockSelectFields","error","concat","rawColumn","newCollectionPath","join","relationTo","relationshipFields","relationTableName","relationshipsSuffix","aliasRelationshipTable","newAliasTableName","aliasRelationshipTableName","relationshipConfig","collections","tableColumnsNames","column","length","raw","val","matchedRelation","relation","undefined","aliasLocaleTable","parentTable","targetTable"],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import { type Column, type SQL, type SQLWrapper } from 'drizzle-orm';
2
+ type OperatorKeys = 'and' | 'contains' | 'equals' | 'exists' | 'greater_than' | 'greater_than_equal' | 'in' | 'isNull' | 'less_than' | 'less_than_equal' | 'like' | 'not_equals' | 'not_in' | 'or';
3
+ export type Operators = Record<OperatorKeys, (column: Column, value: SQLWrapper | unknown) => SQL>;
4
+ export declare const operatorMap: Operators;
5
+ export {};
6
+ //# sourceMappingURL=operatorMap.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"operatorMap.d.ts","sourceRoot":"","sources":["../../src/queries/operatorMap.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,MAAM,EACX,KAAK,GAAG,EACR,KAAK,UAAU,EAchB,MAAM,aAAa,CAAA;AAEpB,KAAK,YAAY,GACb,KAAK,GACL,UAAU,GACV,QAAQ,GACR,QAAQ,GACR,cAAc,GACd,oBAAoB,GACpB,IAAI,GACJ,QAAQ,GACR,WAAW,GACX,iBAAiB,GACjB,MAAM,GACN,YAAY,GACZ,QAAQ,GACR,IAAI,CAAA;AAER,MAAM,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,UAAU,GAAG,OAAO,KAAK,GAAG,CAAC,CAAA;AAElG,eAAO,MAAM,WAAW,EAAE,SAoBzB,CAAA"}
@@ -0,0 +1,24 @@
1
+ import { and, eq, gt, gte, ilike, inArray, isNotNull, isNull, lt, lte, ne, notInArray, or } from 'drizzle-orm';
2
+ export const operatorMap = {
3
+ and,
4
+ contains: ilike,
5
+ equals: eq,
6
+ exists: isNotNull,
7
+ greater_than: gt,
8
+ greater_than_equal: gte,
9
+ in: inArray,
10
+ isNull,
11
+ less_than: lt,
12
+ less_than_equal: lte,
13
+ like: ilike,
14
+ not_equals: ne,
15
+ // TODO: geojson queries
16
+ // intersects: intersects,
17
+ // near: near,
18
+ // within: within,
19
+ // all: all,
20
+ not_in: notInArray,
21
+ or
22
+ };
23
+
24
+ //# sourceMappingURL=operatorMap.js.map