@payloadcms/db-postgres 3.0.0-canary.f83d96a → 3.0.0-canary.fb81f02

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