drizzle-orm 0.10.21 → 0.10.24

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 (481) hide show
  1. package/LICENSE +674 -0
  2. package/{builders → dist/builders}/aggregators/abstractAggregator.d.ts +0 -0
  3. package/{builders → dist/builders}/aggregators/abstractAggregator.js +0 -0
  4. package/{builders → dist/builders}/aggregators/deleteAggregator.d.ts +0 -0
  5. package/{builders → dist/builders}/aggregators/deleteAggregator.js +4 -1
  6. package/{builders → dist/builders}/aggregators/insertAggregator.d.ts +0 -0
  7. package/{builders → dist/builders}/aggregators/insertAggregator.js +4 -1
  8. package/{builders → dist/builders}/aggregators/selectAggregator.d.ts +0 -0
  9. package/{builders → dist/builders}/aggregators/selectAggregator.js +24 -9
  10. package/{builders → dist/builders}/aggregators/updateAggregator.d.ts +0 -0
  11. package/{builders → dist/builders}/aggregators/updateAggregator.js +4 -1
  12. package/{builders → dist/builders}/highLvlBuilders/abstractRequestBuilder.d.ts +0 -0
  13. package/{builders → dist/builders}/highLvlBuilders/abstractRequestBuilder.js +0 -0
  14. package/{builders → dist/builders}/highLvlBuilders/deleteRequestBuilder.d.ts +0 -0
  15. package/{builders → dist/builders}/highLvlBuilders/deleteRequestBuilder.js +26 -4
  16. package/{builders → dist/builders}/highLvlBuilders/insertRequestBuilder.d.ts +0 -0
  17. package/{builders → dist/builders}/highLvlBuilders/insertRequestBuilder.js +26 -4
  18. package/{builders → dist/builders}/highLvlBuilders/order.d.ts +0 -0
  19. package/{builders → dist/builders}/highLvlBuilders/order.js +0 -0
  20. package/{builders → dist/builders}/highLvlBuilders/selectRequestBuilder.d.ts +0 -0
  21. package/{builders → dist/builders}/highLvlBuilders/selectRequestBuilder.js +26 -4
  22. package/{builders → dist/builders}/highLvlBuilders/updateRequestBuilder.d.ts +0 -0
  23. package/{builders → dist/builders}/highLvlBuilders/updateRequestBuilder.js +26 -4
  24. package/{builders → dist/builders}/index.d.ts +0 -0
  25. package/{builders → dist/builders}/index.js +19 -16
  26. package/{builders → dist/builders}/joinBuilders/builders/abstractJoinBuilder.d.ts +0 -0
  27. package/{builders → dist/builders}/joinBuilders/builders/abstractJoinBuilder.js +25 -3
  28. package/{builders → dist/builders}/joinBuilders/builders/selectWithFiveJoins.d.ts +0 -0
  29. package/{builders → dist/builders}/joinBuilders/builders/selectWithFiveJoins.js +5 -2
  30. package/{builders → dist/builders}/joinBuilders/builders/selectWithFourJoins.d.ts +0 -0
  31. package/{builders → dist/builders}/joinBuilders/builders/selectWithFourJoins.js +7 -4
  32. package/{builders → dist/builders}/joinBuilders/builders/selectWithJoin.d.ts +0 -0
  33. package/{builders → dist/builders}/joinBuilders/builders/selectWithJoin.js +7 -4
  34. package/{builders → dist/builders}/joinBuilders/builders/selectWithThreeJoins.d.ts +0 -0
  35. package/{builders → dist/builders}/joinBuilders/builders/selectWithThreeJoins.js +7 -4
  36. package/{builders → dist/builders}/joinBuilders/builders/selectWithTwoJoins.d.ts +0 -0
  37. package/{builders → dist/builders}/joinBuilders/builders/selectWithTwoJoins.js +7 -4
  38. package/{builders → dist/builders}/joinBuilders/join.d.ts +0 -0
  39. package/{builders → dist/builders}/joinBuilders/join.js +0 -0
  40. package/{builders → dist/builders}/joinBuilders/joinWith.d.ts +0 -0
  41. package/{builders → dist/builders}/joinBuilders/joinWith.js +4 -1
  42. package/{builders → dist/builders}/joinBuilders/responses/selectResponseFiveJoins.d.ts +0 -0
  43. package/{builders → dist/builders}/joinBuilders/responses/selectResponseFiveJoins.js +0 -0
  44. package/{builders → dist/builders}/joinBuilders/responses/selectResponseFourJoins.d.ts +0 -0
  45. package/{builders → dist/builders}/joinBuilders/responses/selectResponseFourJoins.js +0 -0
  46. package/{builders → dist/builders}/joinBuilders/responses/selectResponseThreeJoins.d.ts +0 -0
  47. package/{builders → dist/builders}/joinBuilders/responses/selectResponseThreeJoins.js +0 -0
  48. package/{builders → dist/builders}/joinBuilders/responses/selectResponseTwoJoins.d.ts +0 -0
  49. package/{builders → dist/builders}/joinBuilders/responses/selectResponseTwoJoins.js +0 -0
  50. package/{builders → dist/builders}/joinBuilders/responses/selectResponseWithJoin.d.ts +0 -0
  51. package/{builders → dist/builders}/joinBuilders/responses/selectResponseWithJoin.js +0 -0
  52. package/{builders → dist/builders}/joinBuilders/static.d.ts +0 -0
  53. package/{builders → dist/builders}/joinBuilders/static.js +4 -1
  54. package/{builders → dist/builders}/lowLvlBuilders/alter.d.ts +0 -0
  55. package/{builders → dist/builders}/lowLvlBuilders/alter.js +0 -0
  56. package/{builders → dist/builders}/lowLvlBuilders/create.d.ts +0 -0
  57. package/{builders → dist/builders}/lowLvlBuilders/create.js +4 -1
  58. package/{builders → dist/builders}/lowLvlBuilders/delets/delete.d.ts +0 -0
  59. package/{builders → dist/builders}/lowLvlBuilders/delets/delete.js +5 -2
  60. package/{builders → dist/builders}/lowLvlBuilders/delets/deleteFilter.d.ts +0 -0
  61. package/{builders → dist/builders}/lowLvlBuilders/delets/deleteFilter.js +0 -0
  62. package/{builders → dist/builders}/lowLvlBuilders/delets/deleteFrom.d.ts +0 -0
  63. package/{builders → dist/builders}/lowLvlBuilders/delets/deleteFrom.js +4 -1
  64. package/{builders → dist/builders}/lowLvlBuilders/inserts/insert.d.ts +0 -0
  65. package/{builders → dist/builders}/lowLvlBuilders/inserts/insert.js +5 -2
  66. package/{builders → dist/builders}/lowLvlBuilders/inserts/insertInto.d.ts +0 -0
  67. package/{builders → dist/builders}/lowLvlBuilders/inserts/insertInto.js +4 -1
  68. package/{builders → dist/builders}/lowLvlBuilders/inserts/onConflictInsert.d.ts +0 -0
  69. package/{builders → dist/builders}/lowLvlBuilders/inserts/onConflictInsert.js +0 -0
  70. package/{builders → dist/builders}/lowLvlBuilders/inserts/valuesInsert.d.ts +0 -0
  71. package/{builders → dist/builders}/lowLvlBuilders/inserts/valuesInsert.js +4 -1
  72. package/{builders → dist/builders}/lowLvlBuilders/selects/select.d.ts +0 -0
  73. package/{builders → dist/builders}/lowLvlBuilders/selects/select.js +5 -2
  74. package/{builders → dist/builders}/lowLvlBuilders/selects/selectFrom.d.ts +0 -0
  75. package/{builders → dist/builders}/lowLvlBuilders/selects/selectFrom.js +5 -2
  76. package/{builders → dist/builders}/lowLvlBuilders/selects/selectJoined.d.ts +0 -0
  77. package/{builders → dist/builders}/lowLvlBuilders/selects/selectJoined.js +4 -1
  78. package/{builders → dist/builders}/lowLvlBuilders/selects/whereSelect.d.ts +0 -0
  79. package/{builders → dist/builders}/lowLvlBuilders/selects/whereSelect.js +0 -0
  80. package/{builders → dist/builders}/lowLvlBuilders/updates/update.d.ts +0 -0
  81. package/{builders → dist/builders}/lowLvlBuilders/updates/update.js +5 -2
  82. package/{builders → dist/builders}/lowLvlBuilders/updates/updateIn.d.ts +0 -0
  83. package/{builders → dist/builders}/lowLvlBuilders/updates/updateIn.js +4 -1
  84. package/{builders → dist/builders}/lowLvlBuilders/updates/whereSelect.d.ts +0 -0
  85. package/{builders → dist/builders}/lowLvlBuilders/updates/whereSelect.js +0 -0
  86. package/{builders → dist/builders}/lowLvlBuilders/updates/whereSet.d.ts +0 -0
  87. package/{builders → dist/builders}/lowLvlBuilders/updates/whereSet.js +4 -1
  88. package/{builders → dist/builders}/requestBuilders/updates/combine.d.ts +0 -0
  89. package/{builders → dist/builders}/requestBuilders/updates/combine.js +0 -0
  90. package/{builders → dist/builders}/requestBuilders/updates/increment.d.ts +0 -0
  91. package/{builders → dist/builders}/requestBuilders/updates/increment.js +0 -0
  92. package/{builders → dist/builders}/requestBuilders/updates/setObjects.d.ts +0 -0
  93. package/{builders → dist/builders}/requestBuilders/updates/setObjects.js +5 -2
  94. package/{builders → dist/builders}/requestBuilders/updates/static.d.ts +0 -0
  95. package/{builders → dist/builders}/requestBuilders/updates/static.js +6 -3
  96. package/{builders → dist/builders}/requestBuilders/updates/updates.d.ts +0 -0
  97. package/{builders → dist/builders}/requestBuilders/updates/updates.js +0 -0
  98. package/{builders → dist/builders}/requestBuilders/where/and.d.ts +0 -0
  99. package/{builders → dist/builders}/requestBuilders/where/and.js +4 -1
  100. package/{builders → dist/builders}/requestBuilders/where/const.d.ts +0 -0
  101. package/{builders → dist/builders}/requestBuilders/where/const.js +4 -1
  102. package/{builders → dist/builders}/requestBuilders/where/constArray.d.ts +0 -0
  103. package/{builders → dist/builders}/requestBuilders/where/constArray.js +4 -1
  104. package/{builders → dist/builders}/requestBuilders/where/eqWhere.d.ts +0 -0
  105. package/{builders → dist/builders}/requestBuilders/where/eqWhere.js +4 -1
  106. package/{builders → dist/builders}/requestBuilders/where/greater.d.ts +0 -0
  107. package/{builders → dist/builders}/requestBuilders/where/greater.js +4 -1
  108. package/{builders → dist/builders}/requestBuilders/where/greaterEq.d.ts +0 -0
  109. package/{builders → dist/builders}/requestBuilders/where/greaterEq.js +4 -1
  110. package/{builders → dist/builders}/requestBuilders/where/in.d.ts +0 -0
  111. package/{builders → dist/builders}/requestBuilders/where/in.js +4 -1
  112. package/{builders → dist/builders}/requestBuilders/where/isNotNull.d.ts +0 -0
  113. package/{builders → dist/builders}/requestBuilders/where/isNotNull.js +4 -1
  114. package/{builders → dist/builders}/requestBuilders/where/isNull.d.ts +0 -0
  115. package/{builders → dist/builders}/requestBuilders/where/isNull.js +4 -1
  116. package/{builders → dist/builders}/requestBuilders/where/less.d.ts +0 -0
  117. package/{builders → dist/builders}/requestBuilders/where/less.js +4 -1
  118. package/{builders → dist/builders}/requestBuilders/where/lessEq.d.ts +0 -0
  119. package/{builders → dist/builders}/requestBuilders/where/lessEq.js +4 -1
  120. package/{builders → dist/builders}/requestBuilders/where/like.d.ts +0 -0
  121. package/{builders → dist/builders}/requestBuilders/where/like.js +4 -1
  122. package/{builders → dist/builders}/requestBuilders/where/notEqWhere.d.ts +0 -0
  123. package/{builders → dist/builders}/requestBuilders/where/notEqWhere.js +4 -1
  124. package/{builders → dist/builders}/requestBuilders/where/or.d.ts +0 -0
  125. package/{builders → dist/builders}/requestBuilders/where/or.js +4 -1
  126. package/{builders → dist/builders}/requestBuilders/where/rawWhere.d.ts +0 -0
  127. package/{builders → dist/builders}/requestBuilders/where/rawWhere.js +4 -1
  128. package/{builders → dist/builders}/requestBuilders/where/static.d.ts +0 -0
  129. package/{builders → dist/builders}/requestBuilders/where/static.js +19 -16
  130. package/{builders → dist/builders}/requestBuilders/where/var.d.ts +0 -0
  131. package/{builders → dist/builders}/requestBuilders/where/var.js +4 -1
  132. package/{builders → dist/builders}/requestBuilders/where/where.d.ts +0 -0
  133. package/{builders → dist/builders}/requestBuilders/where/where.js +0 -0
  134. package/{builders → dist/builders}/transaction/transaction.d.ts +0 -0
  135. package/{builders → dist/builders}/transaction/transaction.js +0 -0
  136. package/{columns → dist/columns}/column.d.ts +0 -0
  137. package/{columns → dist/columns}/column.js +0 -0
  138. package/{columns → dist/columns}/index.d.ts +0 -0
  139. package/{columns → dist/columns}/index.js +12 -9
  140. package/{columns → dist/columns}/types/columnType.d.ts +0 -0
  141. package/{columns → dist/columns}/types/columnType.js +0 -0
  142. package/{columns → dist/columns}/types/pgBigDecimal.d.ts +0 -0
  143. package/{columns → dist/columns}/types/pgBigDecimal.js +4 -1
  144. package/{columns → dist/columns}/types/pgBigInt.d.ts +0 -0
  145. package/{columns → dist/columns}/types/pgBigInt.js +4 -1
  146. package/{columns → dist/columns}/types/pgBigSerial.d.ts +0 -0
  147. package/{columns → dist/columns}/types/pgBigSerial.js +4 -1
  148. package/{columns → dist/columns}/types/pgBoolean.d.ts +0 -0
  149. package/{columns → dist/columns}/types/pgBoolean.js +4 -1
  150. package/{columns → dist/columns}/types/pgEnum.d.ts +0 -0
  151. package/{columns → dist/columns}/types/pgEnum.js +4 -1
  152. package/{columns → dist/columns}/types/pgInteger.d.ts +0 -0
  153. package/{columns → dist/columns}/types/pgInteger.js +4 -1
  154. package/{columns → dist/columns}/types/pgJsonb.d.ts +0 -0
  155. package/{columns → dist/columns}/types/pgJsonb.js +4 -1
  156. package/{columns → dist/columns}/types/pgSerial.d.ts +0 -0
  157. package/{columns → dist/columns}/types/pgSerial.js +4 -1
  158. package/{columns → dist/columns}/types/pgSmallInt.d.ts +0 -0
  159. package/{columns → dist/columns}/types/pgSmallInt.js +4 -1
  160. package/{columns → dist/columns}/types/pgText.d.ts +0 -0
  161. package/{columns → dist/columns}/types/pgText.js +4 -1
  162. package/{columns → dist/columns}/types/pgTime.d.ts +0 -0
  163. package/{columns → dist/columns}/types/pgTime.js +4 -1
  164. package/{columns → dist/columns}/types/pgTimestamp.d.ts +0 -0
  165. package/{columns → dist/columns}/types/pgTimestamp.js +4 -1
  166. package/{columns → dist/columns}/types/pgTimestamptz.d.ts +0 -0
  167. package/{columns → dist/columns}/types/pgTimestamptz.js +4 -1
  168. package/{columns → dist/columns}/types/pgVarChar.d.ts +0 -0
  169. package/{columns → dist/columns}/types/pgVarChar.js +4 -1
  170. package/{db → dist/db}/db.d.ts +0 -0
  171. package/{db → dist/db}/db.js +0 -0
  172. package/{db → dist/db}/dbConnector.d.ts +0 -0
  173. package/{db → dist/db}/dbConnector.js +6 -3
  174. package/{db → dist/db}/dbStringConnector.d.ts +0 -0
  175. package/{db → dist/db}/dbStringConnector.js +5 -2
  176. package/{db → dist/db}/group_by.d.ts +0 -0
  177. package/{db → dist/db}/group_by.js +0 -0
  178. package/{db → dist/db}/index.d.ts +0 -0
  179. package/{db → dist/db}/index.js +6 -3
  180. package/{db → dist/db}/session.d.ts +0 -0
  181. package/{db → dist/db}/session.js +0 -0
  182. package/{docs → dist/docs}/cases/simple_delete.d.ts +0 -0
  183. package/{docs → dist/docs}/cases/simple_delete.js +7 -4
  184. package/{docs → dist/docs}/cases/simple_insert.d.ts +0 -0
  185. package/{docs → dist/docs}/cases/simple_insert.js +8 -5
  186. package/{docs → dist/docs}/cases/simple_join.d.ts +0 -0
  187. package/{docs → dist/docs}/cases/simple_join.js +8 -5
  188. package/{docs → dist/docs}/cases/simple_select.d.ts +0 -0
  189. package/{docs → dist/docs}/cases/simple_select.js +6 -3
  190. package/{docs → dist/docs}/cases/simple_update.d.ts +0 -0
  191. package/{docs → dist/docs}/cases/simple_update.js +7 -4
  192. package/{docs → dist/docs}/tables/citiesTable.d.ts +0 -0
  193. package/{docs → dist/docs}/tables/citiesTable.js +6 -2
  194. package/{docs → dist/docs}/tables/userGroupsTable.d.ts +0 -0
  195. package/{docs → dist/docs}/tables/userGroupsTable.js +4 -1
  196. package/{docs → dist/docs}/tables/usersTable.d.ts +0 -0
  197. package/{docs → dist/docs}/tables/usersTable.js +4 -1
  198. package/{docs → dist/docs}/tables/usersToUserGroups.d.ts +0 -0
  199. package/{docs → dist/docs}/tables/usersToUserGroups.js +6 -3
  200. package/{docs → dist/docs}/types/rolesType.d.ts +0 -0
  201. package/{docs → dist/docs}/types/rolesType.js +0 -0
  202. package/{errors → dist/errors}/baseError.d.ts +0 -0
  203. package/{errors → dist/errors}/baseError.js +0 -0
  204. package/{errors → dist/errors}/builderError.d.ts +0 -0
  205. package/{errors → dist/errors}/builderError.js +2 -1
  206. package/{errors → dist/errors}/dbErrors.d.ts +0 -0
  207. package/{errors → dist/errors}/dbErrors.js +0 -0
  208. package/{index.d.ts → dist/index.d.ts} +0 -0
  209. package/{index.js → dist/index.js} +4 -1
  210. package/{indexes → dist/indexes}/tableIndex.d.ts +0 -0
  211. package/{indexes → dist/indexes}/tableIndex.js +0 -0
  212. package/{logger → dist/logger}/abstractLogger.d.ts +0 -0
  213. package/{logger → dist/logger}/abstractLogger.js +0 -0
  214. package/{logger → dist/logger}/consoleLogger.d.ts +0 -0
  215. package/{logger → dist/logger}/consoleLogger.js +4 -1
  216. package/{mappers → dist/mappers}/index.d.ts +0 -0
  217. package/{mappers → dist/mappers}/index.js +0 -0
  218. package/{mappers → dist/mappers}/responseMapper.d.ts +0 -0
  219. package/{mappers → dist/mappers}/responseMapper.js +0 -0
  220. package/{migrator → dist/migrator}/index.d.ts +0 -0
  221. package/{migrator → dist/migrator}/index.js +0 -0
  222. package/{migrator → dist/migrator}/migrator.d.ts +0 -0
  223. package/{migrator → dist/migrator}/migrator.js +26 -4
  224. package/dist/serializer/serializer.d.ts +47 -0
  225. package/dist/serializer/serializer.js +258 -0
  226. package/dist/src/builders/aggregators/abstractAggregator.d.ts +11 -0
  227. package/dist/src/builders/aggregators/abstractAggregator.js +35 -0
  228. package/dist/src/builders/aggregators/deleteAggregator.d.ts +16 -0
  229. package/dist/src/builders/aggregators/deleteAggregator.js +42 -0
  230. package/dist/src/builders/aggregators/insertAggregator.d.ts +22 -0
  231. package/dist/src/builders/aggregators/insertAggregator.js +106 -0
  232. package/dist/src/builders/aggregators/selectAggregator.d.ts +39 -0
  233. package/dist/src/builders/aggregators/selectAggregator.js +143 -0
  234. package/dist/src/builders/aggregators/updateAggregator.d.ts +19 -0
  235. package/dist/src/builders/aggregators/updateAggregator.js +50 -0
  236. package/dist/src/builders/highLvlBuilders/abstractRequestBuilder.d.ts +27 -0
  237. package/dist/src/builders/highLvlBuilders/abstractRequestBuilder.js +32 -0
  238. package/dist/src/builders/highLvlBuilders/deleteRequestBuilder.d.ts +19 -0
  239. package/dist/src/builders/highLvlBuilders/deleteRequestBuilder.js +61 -0
  240. package/dist/src/builders/highLvlBuilders/insertRequestBuilder.d.ts +20 -0
  241. package/dist/src/builders/highLvlBuilders/insertRequestBuilder.js +73 -0
  242. package/dist/src/builders/highLvlBuilders/order.d.ts +5 -0
  243. package/dist/src/builders/highLvlBuilders/order.js +8 -0
  244. package/dist/src/builders/highLvlBuilders/selectRequestBuilder.d.ts +47 -0
  245. package/dist/src/builders/highLvlBuilders/selectRequestBuilder.js +128 -0
  246. package/dist/src/builders/highLvlBuilders/updateRequestBuilder.d.ts +22 -0
  247. package/dist/src/builders/highLvlBuilders/updateRequestBuilder.js +80 -0
  248. package/dist/src/builders/index.d.ts +18 -0
  249. package/dist/src/builders/index.js +54 -0
  250. package/dist/src/builders/joinBuilders/builders/abstractJoinBuilder.d.ts +40 -0
  251. package/dist/src/builders/joinBuilders/builders/abstractJoinBuilder.js +78 -0
  252. package/dist/src/builders/joinBuilders/builders/selectWithFiveJoins.d.ts +35 -0
  253. package/dist/src/builders/joinBuilders/builders/selectWithFiveJoins.js +45 -0
  254. package/dist/src/builders/joinBuilders/builders/selectWithFourJoins.d.ts +55 -0
  255. package/dist/src/builders/joinBuilders/builders/selectWithFourJoins.js +78 -0
  256. package/dist/src/builders/joinBuilders/builders/selectWithJoin.d.ts +49 -0
  257. package/dist/src/builders/joinBuilders/builders/selectWithJoin.js +64 -0
  258. package/dist/src/builders/joinBuilders/builders/selectWithThreeJoins.d.ts +53 -0
  259. package/dist/src/builders/joinBuilders/builders/selectWithThreeJoins.js +73 -0
  260. package/dist/src/builders/joinBuilders/builders/selectWithTwoJoins.d.ts +51 -0
  261. package/dist/src/builders/joinBuilders/builders/selectWithTwoJoins.js +68 -0
  262. package/dist/src/builders/joinBuilders/join.d.ts +23 -0
  263. package/dist/src/builders/joinBuilders/join.js +28 -0
  264. package/dist/src/builders/joinBuilders/joinWith.d.ts +14 -0
  265. package/dist/src/builders/joinBuilders/joinWith.js +14 -0
  266. package/dist/src/builders/joinBuilders/responses/selectResponseFiveJoins.d.ts +20 -0
  267. package/dist/src/builders/joinBuilders/responses/selectResponseFiveJoins.js +35 -0
  268. package/dist/src/builders/joinBuilders/responses/selectResponseFourJoins.d.ts +19 -0
  269. package/dist/src/builders/joinBuilders/responses/selectResponseFourJoins.js +34 -0
  270. package/dist/src/builders/joinBuilders/responses/selectResponseThreeJoins.d.ts +18 -0
  271. package/dist/src/builders/joinBuilders/responses/selectResponseThreeJoins.js +33 -0
  272. package/dist/src/builders/joinBuilders/responses/selectResponseTwoJoins.d.ts +17 -0
  273. package/dist/src/builders/joinBuilders/responses/selectResponseTwoJoins.js +32 -0
  274. package/dist/src/builders/joinBuilders/responses/selectResponseWithJoin.d.ts +16 -0
  275. package/dist/src/builders/joinBuilders/responses/selectResponseWithJoin.js +31 -0
  276. package/dist/src/builders/joinBuilders/static.d.ts +5 -0
  277. package/dist/src/builders/joinBuilders/static.js +9 -0
  278. package/dist/src/builders/lowLvlBuilders/alter.d.ts +0 -0
  279. package/dist/src/builders/lowLvlBuilders/alter.js +1 -0
  280. package/dist/src/builders/lowLvlBuilders/create.d.ts +12 -0
  281. package/dist/src/builders/lowLvlBuilders/create.js +100 -0
  282. package/dist/src/builders/lowLvlBuilders/delets/delete.d.ts +5 -0
  283. package/dist/src/builders/lowLvlBuilders/delets/delete.js +15 -0
  284. package/dist/src/builders/lowLvlBuilders/delets/deleteFilter.d.ts +11 -0
  285. package/dist/src/builders/lowLvlBuilders/delets/deleteFilter.js +13 -0
  286. package/dist/src/builders/lowLvlBuilders/delets/deleteFrom.d.ts +12 -0
  287. package/dist/src/builders/lowLvlBuilders/delets/deleteFrom.js +14 -0
  288. package/dist/src/builders/lowLvlBuilders/inserts/insert.d.ts +5 -0
  289. package/dist/src/builders/lowLvlBuilders/inserts/insert.js +15 -0
  290. package/dist/src/builders/lowLvlBuilders/inserts/insertInto.d.ts +13 -0
  291. package/dist/src/builders/lowLvlBuilders/inserts/insertInto.js +16 -0
  292. package/dist/src/builders/lowLvlBuilders/inserts/onConflictInsert.d.ts +12 -0
  293. package/dist/src/builders/lowLvlBuilders/inserts/onConflictInsert.js +13 -0
  294. package/dist/src/builders/lowLvlBuilders/inserts/valuesInsert.d.ts +16 -0
  295. package/dist/src/builders/lowLvlBuilders/inserts/valuesInsert.js +19 -0
  296. package/dist/src/builders/lowLvlBuilders/selects/select.d.ts +9 -0
  297. package/dist/src/builders/lowLvlBuilders/selects/select.js +16 -0
  298. package/dist/src/builders/lowLvlBuilders/selects/selectFrom.d.ts +28 -0
  299. package/dist/src/builders/lowLvlBuilders/selects/selectFrom.js +34 -0
  300. package/dist/src/builders/lowLvlBuilders/selects/selectJoined.d.ts +26 -0
  301. package/dist/src/builders/lowLvlBuilders/selects/selectJoined.js +30 -0
  302. package/dist/src/builders/lowLvlBuilders/selects/whereSelect.d.ts +17 -0
  303. package/dist/src/builders/lowLvlBuilders/selects/whereSelect.js +25 -0
  304. package/dist/src/builders/lowLvlBuilders/updates/update.d.ts +5 -0
  305. package/dist/src/builders/lowLvlBuilders/updates/update.js +15 -0
  306. package/dist/src/builders/lowLvlBuilders/updates/updateIn.d.ts +13 -0
  307. package/dist/src/builders/lowLvlBuilders/updates/updateIn.js +15 -0
  308. package/dist/src/builders/lowLvlBuilders/updates/whereSelect.d.ts +11 -0
  309. package/dist/src/builders/lowLvlBuilders/updates/whereSelect.js +13 -0
  310. package/dist/src/builders/lowLvlBuilders/updates/whereSet.d.ts +14 -0
  311. package/dist/src/builders/lowLvlBuilders/updates/whereSet.js +18 -0
  312. package/dist/src/builders/requestBuilders/updates/combine.d.ts +9 -0
  313. package/dist/src/builders/requestBuilders/updates/combine.js +26 -0
  314. package/dist/src/builders/requestBuilders/updates/increment.d.ts +13 -0
  315. package/dist/src/builders/requestBuilders/updates/increment.js +18 -0
  316. package/dist/src/builders/requestBuilders/updates/setObjects.d.ts +12 -0
  317. package/dist/src/builders/requestBuilders/updates/setObjects.js +19 -0
  318. package/dist/src/builders/requestBuilders/updates/static.d.ts +7 -0
  319. package/dist/src/builders/requestBuilders/updates/static.js +15 -0
  320. package/dist/src/builders/requestBuilders/updates/updates.d.ts +9 -0
  321. package/dist/src/builders/requestBuilders/updates/updates.js +10 -0
  322. package/dist/src/builders/requestBuilders/where/and.d.ts +11 -0
  323. package/dist/src/builders/requestBuilders/where/and.js +31 -0
  324. package/dist/src/builders/requestBuilders/where/const.d.ts +9 -0
  325. package/dist/src/builders/requestBuilders/where/const.js +25 -0
  326. package/dist/src/builders/requestBuilders/where/constArray.d.ts +9 -0
  327. package/dist/src/builders/requestBuilders/where/constArray.js +39 -0
  328. package/dist/src/builders/requestBuilders/where/eqWhere.d.ts +12 -0
  329. package/dist/src/builders/requestBuilders/where/eqWhere.js +20 -0
  330. package/dist/src/builders/requestBuilders/where/greater.d.ts +15 -0
  331. package/dist/src/builders/requestBuilders/where/greater.js +20 -0
  332. package/dist/src/builders/requestBuilders/where/greaterEq.d.ts +15 -0
  333. package/dist/src/builders/requestBuilders/where/greaterEq.js +20 -0
  334. package/dist/src/builders/requestBuilders/where/in.d.ts +12 -0
  335. package/dist/src/builders/requestBuilders/where/in.js +20 -0
  336. package/dist/src/builders/requestBuilders/where/isNotNull.d.ts +11 -0
  337. package/dist/src/builders/requestBuilders/where/isNotNull.js +18 -0
  338. package/dist/src/builders/requestBuilders/where/isNull.d.ts +11 -0
  339. package/dist/src/builders/requestBuilders/where/isNull.js +18 -0
  340. package/dist/src/builders/requestBuilders/where/less.d.ts +15 -0
  341. package/dist/src/builders/requestBuilders/where/less.js +20 -0
  342. package/dist/src/builders/requestBuilders/where/lessEq.d.ts +15 -0
  343. package/dist/src/builders/requestBuilders/where/lessEq.js +20 -0
  344. package/dist/src/builders/requestBuilders/where/like.d.ts +12 -0
  345. package/dist/src/builders/requestBuilders/where/like.js +20 -0
  346. package/dist/src/builders/requestBuilders/where/notEqWhere.d.ts +12 -0
  347. package/dist/src/builders/requestBuilders/where/notEqWhere.js +20 -0
  348. package/dist/src/builders/requestBuilders/where/or.d.ts +11 -0
  349. package/dist/src/builders/requestBuilders/where/or.js +31 -0
  350. package/dist/src/builders/requestBuilders/where/rawWhere.d.ts +9 -0
  351. package/dist/src/builders/requestBuilders/where/rawWhere.js +15 -0
  352. package/dist/src/builders/requestBuilders/where/static.d.ts +17 -0
  353. package/dist/src/builders/requestBuilders/where/static.js +49 -0
  354. package/dist/src/builders/requestBuilders/where/var.d.ts +13 -0
  355. package/dist/src/builders/requestBuilders/where/var.js +18 -0
  356. package/dist/src/builders/requestBuilders/where/where.d.ts +8 -0
  357. package/dist/src/builders/requestBuilders/where/where.js +6 -0
  358. package/dist/src/builders/transaction/transaction.d.ts +8 -0
  359. package/dist/src/builders/transaction/transaction.js +20 -0
  360. package/dist/src/columns/column.d.ts +72 -0
  361. package/dist/src/columns/column.js +101 -0
  362. package/dist/src/columns/index.d.ts +10 -0
  363. package/dist/src/columns/index.js +27 -0
  364. package/dist/src/columns/types/columnType.d.ts +7 -0
  365. package/dist/src/columns/types/columnType.js +6 -0
  366. package/dist/src/columns/types/pgBigDecimal.d.ts +10 -0
  367. package/dist/src/columns/types/pgBigDecimal.js +31 -0
  368. package/dist/src/columns/types/pgBigInt.d.ts +15 -0
  369. package/dist/src/columns/types/pgBigInt.js +32 -0
  370. package/dist/src/columns/types/pgBigSerial.d.ts +15 -0
  371. package/dist/src/columns/types/pgBigSerial.js +32 -0
  372. package/dist/src/columns/types/pgBoolean.d.ts +8 -0
  373. package/dist/src/columns/types/pgBoolean.js +18 -0
  374. package/dist/src/columns/types/pgEnum.d.ts +9 -0
  375. package/dist/src/columns/types/pgEnum.js +18 -0
  376. package/dist/src/columns/types/pgInteger.d.ts +8 -0
  377. package/dist/src/columns/types/pgInteger.js +21 -0
  378. package/dist/src/columns/types/pgJsonb.d.ts +9 -0
  379. package/dist/src/columns/types/pgJsonb.js +20 -0
  380. package/dist/src/columns/types/pgSerial.d.ts +8 -0
  381. package/dist/src/columns/types/pgSerial.js +18 -0
  382. package/dist/src/columns/types/pgSmallInt.d.ts +8 -0
  383. package/dist/src/columns/types/pgSmallInt.js +18 -0
  384. package/dist/src/columns/types/pgText.d.ts +8 -0
  385. package/dist/src/columns/types/pgText.js +18 -0
  386. package/dist/src/columns/types/pgTime.d.ts +8 -0
  387. package/dist/src/columns/types/pgTime.js +18 -0
  388. package/dist/src/columns/types/pgTimestamp.d.ts +8 -0
  389. package/dist/src/columns/types/pgTimestamp.js +18 -0
  390. package/dist/src/columns/types/pgTimestamptz.d.ts +8 -0
  391. package/dist/src/columns/types/pgTimestamptz.js +18 -0
  392. package/dist/src/columns/types/pgVarChar.d.ts +9 -0
  393. package/dist/src/columns/types/pgVarChar.js +24 -0
  394. package/dist/src/db/db.d.ts +18 -0
  395. package/dist/src/db/db.js +25 -0
  396. package/dist/src/db/dbConnector.d.ts +9 -0
  397. package/dist/src/db/dbConnector.js +32 -0
  398. package/dist/src/db/dbStringConnector.d.ts +6 -0
  399. package/dist/src/db/dbStringConnector.js +29 -0
  400. package/dist/src/db/group_by.d.ts +0 -0
  401. package/dist/src/db/group_by.js +68 -0
  402. package/dist/src/db/index.d.ts +4 -0
  403. package/dist/src/db/index.js +14 -0
  404. package/dist/src/db/session.d.ts +9 -0
  405. package/dist/src/db/session.js +16 -0
  406. package/{test.d.ts → dist/src/docs/cases/simple_delete.d.ts} +0 -0
  407. package/dist/src/docs/cases/simple_delete.js +35 -0
  408. package/dist/src/docs/cases/simple_insert.d.ts +1 -0
  409. package/dist/src/docs/cases/simple_insert.js +57 -0
  410. package/dist/src/docs/cases/simple_join.d.ts +1 -0
  411. package/dist/src/docs/cases/simple_join.js +115 -0
  412. package/dist/src/docs/cases/simple_select.d.ts +1 -0
  413. package/dist/src/docs/cases/simple_select.js +50 -0
  414. package/dist/src/docs/cases/simple_update.d.ts +1 -0
  415. package/dist/src/docs/cases/simple_update.js +39 -0
  416. package/dist/src/docs/tables/citiesTable.d.ts +14 -0
  417. package/dist/src/docs/tables/citiesTable.js +21 -0
  418. package/dist/src/docs/tables/userGroupsTable.d.ts +7 -0
  419. package/dist/src/docs/tables/userGroupsTable.js +18 -0
  420. package/dist/src/docs/tables/usersTable.d.ts +17 -0
  421. package/dist/src/docs/tables/usersTable.js +35 -0
  422. package/dist/src/docs/tables/usersToUserGroups.d.ts +7 -0
  423. package/dist/src/docs/tables/usersToUserGroups.js +20 -0
  424. package/dist/src/docs/types/rolesType.d.ts +1 -0
  425. package/dist/src/docs/types/rolesType.js +6 -0
  426. package/dist/src/errors/baseError.d.ts +22 -0
  427. package/dist/src/errors/baseError.js +35 -0
  428. package/dist/src/errors/builderError.d.ts +14 -0
  429. package/dist/src/errors/builderError.js +25 -0
  430. package/dist/src/errors/dbErrors.d.ts +12 -0
  431. package/dist/src/errors/dbErrors.js +28 -0
  432. package/dist/src/index.d.ts +11 -0
  433. package/dist/src/index.js +31 -0
  434. package/dist/src/indexes/tableIndex.d.ts +11 -0
  435. package/dist/src/indexes/tableIndex.js +17 -0
  436. package/dist/src/logger/abstractLogger.d.ts +4 -0
  437. package/dist/src/logger/abstractLogger.js +5 -0
  438. package/dist/src/logger/consoleLogger.d.ts +5 -0
  439. package/dist/src/logger/consoleLogger.js +15 -0
  440. package/dist/src/mappers/index.d.ts +0 -0
  441. package/dist/src/mappers/index.js +1 -0
  442. package/dist/src/mappers/responseMapper.d.ts +10 -0
  443. package/dist/src/mappers/responseMapper.js +35 -0
  444. package/dist/src/migrator/index.d.ts +0 -0
  445. package/dist/src/migrator/index.js +1 -0
  446. package/dist/src/migrator/migrator.d.ts +11 -0
  447. package/dist/src/migrator/migrator.js +105 -0
  448. package/{serializer → dist/src/serializer}/serializer.d.ts +0 -0
  449. package/{serializer → dist/src/serializer}/serializer.js +4 -1
  450. package/{tables → dist/src/tables}/abstractTable.d.ts +0 -0
  451. package/{tables → dist/src/tables}/abstractTable.js +41 -19
  452. package/{tables → dist/src/tables}/index.d.ts +0 -0
  453. package/{tables → dist/src/tables}/index.js +5 -2
  454. package/{tables → dist/src/tables}/inferTypes.d.ts +0 -0
  455. package/{tables → dist/src/tables}/inferTypes.js +0 -0
  456. package/{tables → dist/src/tables}/migrationsTable.d.ts +0 -0
  457. package/{tables → dist/src/tables}/migrationsTable.js +4 -1
  458. package/dist/src/test.d.ts +1 -0
  459. package/{test.js → dist/src/test.js} +23 -8
  460. package/{types → dist/src/types}/type.d.ts +0 -0
  461. package/{types → dist/src/types}/type.js +0 -0
  462. package/{utils → dist/src/utils}/ecranate.d.ts +0 -0
  463. package/{utils → dist/src/utils}/ecranate.js +0 -0
  464. package/dist/tables/abstractTable.d.ts +68 -0
  465. package/dist/tables/abstractTable.js +151 -0
  466. package/dist/tables/index.d.ts +3 -0
  467. package/dist/tables/index.js +11 -0
  468. package/dist/tables/inferTypes.d.ts +39 -0
  469. package/dist/tables/inferTypes.js +2 -0
  470. package/dist/tables/migrationsTable.d.ts +7 -0
  471. package/dist/tables/migrationsTable.js +18 -0
  472. package/dist/test.d.ts +1 -0
  473. package/dist/test.js +65 -0
  474. package/dist/tsconfig.tsbuildinfo +5054 -0
  475. package/dist/types/type.d.ts +10 -0
  476. package/dist/types/type.js +14 -0
  477. package/dist/utils/ecranate.d.ts +2 -0
  478. package/dist/utils/ecranate.js +8 -0
  479. package/package.json +18 -13
  480. package/tables/aggregators.d.ts +0 -27
  481. package/tables/aggregators.js +0 -56
@@ -0,0 +1,258 @@
1
+ "use strict";
2
+ /* eslint-disable max-classes-per-file */
3
+ /* eslint-disable import/no-named-as-default-member */
4
+ /* eslint-disable import/no-named-as-default */
5
+ /* eslint-disable no-param-reassign */
6
+ /* eslint-disable no-restricted-syntax */
7
+ var __importDefault = (this && this.__importDefault) || function (mod) {
8
+ return (mod && mod.__esModule) ? mod : { "default": mod };
9
+ };
10
+ Object.defineProperty(exports, "__esModule", { value: true });
11
+ const columns_1 = require("../columns");
12
+ const tableIndex_1 = __importDefault(require("../indexes/tableIndex"));
13
+ const serialiseForeignKey = (fkName, table, column, onDelete, onUpdate) => {
14
+ return `${fkName};${table};${column};${onDelete !== null && onDelete !== void 0 ? onDelete : ''};${onUpdate !== null && onUpdate !== void 0 ? onUpdate : ''}`;
15
+ };
16
+ class MigrationSerializer {
17
+ constructor() {
18
+ this.generate = (tables, enums) => {
19
+ const result = {};
20
+ for (const table of tables) {
21
+ const tableEntries = Object.entries(table);
22
+ const columnToReturn = {};
23
+ const indexToReturn = {};
24
+ for (const properties of tableEntries) {
25
+ const value = properties[1];
26
+ if (value instanceof tableIndex_1.default) {
27
+ const columns = value.getColumns();
28
+ const name = value.indexName();
29
+ const indexColumnToReturn = {};
30
+ for (const column of columns) {
31
+ const columnName = column.getColumnName();
32
+ indexColumnToReturn[columnName] = {
33
+ name: columnName,
34
+ };
35
+ }
36
+ indexToReturn[name] = {
37
+ name,
38
+ columns: indexColumnToReturn,
39
+ isUnique: value.isUnique(),
40
+ };
41
+ }
42
+ if (value instanceof columns_1.Column) {
43
+ columnToReturn[value.getColumnName()] = {
44
+ name: value.getColumnName(),
45
+ type: value.getColumnType().getDbName(),
46
+ primaryKey: !!value.primaryKeyName,
47
+ // unique: !!value.uniqueKeyName,
48
+ // default: value.getDefaultValue() === null ? undefined : value.getDefaultValue(),
49
+ notNull: !value.isNullableFlag,
50
+ };
51
+ if (value.getDefaultValue() !== undefined && value.getDefaultValue() !== null) {
52
+ columnToReturn[value.getColumnName()].default = value.getDefaultValue();
53
+ }
54
+ if (value.uniqueKeyName) {
55
+ const indexName = `${value.getParent().tableName()}_${value.getColumnName()}_index`;
56
+ const indexColumnToReturn = {};
57
+ indexColumnToReturn[value.getColumnName()] = {
58
+ name: value.getColumnName(),
59
+ };
60
+ indexToReturn[indexName] = {
61
+ name: indexName,
62
+ columns: indexColumnToReturn,
63
+ isUnique: true,
64
+ };
65
+ }
66
+ const referenced = value.getReferenced();
67
+ if (referenced) {
68
+ const fkName = `${value.getParent().tableName()}_${value.getColumnName()}_fkey`;
69
+ const table = referenced.getParentName();
70
+ const column = referenced.getColumnName();
71
+ const onDelete = value.getOnDelete();
72
+ const onUpdate = value.getOnUpdate();
73
+ const referenceString = serialiseForeignKey(fkName, table, column, onDelete, onUpdate);
74
+ columnToReturn[value.getColumnName()].references = referenceString;
75
+ }
76
+ }
77
+ }
78
+ result[table.tableName()] = {
79
+ name: table.tableName(),
80
+ columns: columnToReturn,
81
+ indexes: indexToReturn,
82
+ };
83
+ }
84
+ const enumsToReturn = enums.reduce((map, obj) => {
85
+ const key = obj.name;
86
+ const newValues = obj.values.reduce((mapped, value) => {
87
+ mapped[value] = value;
88
+ return mapped;
89
+ }, {});
90
+ map[key] = { name: obj.name, values: newValues };
91
+ return map;
92
+ }, {});
93
+ return { version: '2', tables: result, enums: enumsToReturn };
94
+ };
95
+ this.fromDatabase = async (db) => {
96
+ var _a;
97
+ const result = {};
98
+ const allTables = await db.session().execute('SELECT table_schema, table_name FROM information_schema.tables WHERE table_schema != \'pg_catalog\' and table_schema != \'information_schema\';');
99
+ for await (const row of allTables.rows) {
100
+ try {
101
+ // const tableSchema = row.table_schema;
102
+ const tableName = row.table_name;
103
+ const columnToReturn = {};
104
+ const indexToReturn = {};
105
+ const tableResponse = await db.session().execute(`SELECT a.attrelid::regclass::text, a.attname
106
+ , CASE WHEN a.atttypid = ANY ('{int,int8,int2}'::regtype[])
107
+ AND EXISTS (
108
+ SELECT FROM pg_attrdef ad
109
+ WHERE ad.adrelid = a.attrelid
110
+ AND ad.adnum = a.attnum
111
+ AND pg_get_expr(ad.adbin, ad.adrelid)
112
+ = 'nextval('''
113
+ || (pg_get_serial_sequence (a.attrelid::regclass::text
114
+ , a.attname))::regclass
115
+ || '''::regclass)'
116
+ )
117
+ THEN CASE a.atttypid
118
+ WHEN 'int'::regtype THEN 'serial'
119
+ WHEN 'int8'::regtype THEN 'bigserial'
120
+ WHEN 'int2'::regtype THEN 'smallserial'
121
+ END
122
+ ELSE format_type(a.atttypid, a.atttypmod)
123
+ END AS data_type, INFORMATION_SCHEMA.COLUMNS.table_name, INFORMATION_SCHEMA.COLUMNS.column_name, INFORMATION_SCHEMA.COLUMNS.column_default
124
+ FROM pg_attribute a
125
+ JOIN INFORMATION_SCHEMA.COLUMNS ON INFORMATION_SCHEMA.COLUMNS.column_name = a.attname
126
+ WHERE a.attrelid = '${tableName}'::regclass and INFORMATION_SCHEMA.COLUMNS.table_name = '${tableName}'
127
+ AND a.attnum > 0
128
+ AND NOT a.attisdropped
129
+ ORDER BY a.attnum;`);
130
+ const tableConstraints = await db.session().execute(`SELECT c.column_name, c.data_type, constraint_type, constraint_name
131
+ FROM information_schema.table_constraints tc
132
+ JOIN information_schema.constraint_column_usage AS ccu USING (constraint_schema, constraint_name)
133
+ JOIN information_schema.columns AS c ON c.table_schema = tc.constraint_schema
134
+ AND tc.table_name = c.table_name AND ccu.column_name = c.column_name
135
+ WHERE tc.table_name = '${tableName}';`);
136
+ const tableForeignKeys = await db.session().execute(`SELECT
137
+ tc.table_schema,
138
+ tc.constraint_name,
139
+ tc.table_name,
140
+ kcu.column_name,
141
+ ccu.table_schema AS foreign_table_schema,
142
+ ccu.table_name AS foreign_table_name,
143
+ ccu.column_name AS foreign_column_name,
144
+ rc.delete_rule, rc.update_rule
145
+ FROM
146
+ information_schema.table_constraints AS tc
147
+ JOIN information_schema.key_column_usage AS kcu
148
+ ON tc.constraint_name = kcu.constraint_name
149
+ AND tc.table_schema = kcu.table_schema
150
+ JOIN information_schema.constraint_column_usage AS ccu
151
+ ON ccu.constraint_name = tc.constraint_name
152
+ AND ccu.table_schema = tc.table_schema
153
+ JOIN information_schema.referential_constraints AS rc
154
+ ON ccu.constraint_name = rc.constraint_name
155
+ WHERE tc.constraint_type = 'FOREIGN KEY' AND tc.table_name='${tableName}';`);
156
+ const mappedRefernces = {};
157
+ for (const fk of tableForeignKeys.rows) {
158
+ // const tableFrom = fk.table_name;
159
+ const columnFrom = fk.column_name;
160
+ const tableTo = fk.foreign_table_name;
161
+ const columnTo = fk.foreign_column_name;
162
+ const foreignKeyName = fk.constraint_name;
163
+ const onUpdate = fk.update_rule;
164
+ const onDelete = fk.delete_rule;
165
+ const references = serialiseForeignKey(foreignKeyName, tableTo, columnTo, onDelete, onUpdate);
166
+ mappedRefernces[columnFrom] = references;
167
+ }
168
+ for (const columnResponse of tableResponse.rows) {
169
+ const columnName = columnResponse.attname;
170
+ const columnType = columnResponse.data_type;
171
+ const primaryKey = tableConstraints.rows.filter((mapRow) => columnName === mapRow.column_name && mapRow.constraint_type === 'PRIMARY KEY');
172
+ const uniqueKey = tableConstraints.rows.filter((mapRow) => columnName === mapRow.column_name && mapRow.constraint_type === 'UNIQUE');
173
+ const defaultValue = columnResponse.column_default === null
174
+ ? undefined : columnResponse.column_default;
175
+ const isSerial = columnType === 'serial';
176
+ columnToReturn[columnName] = {
177
+ name: columnName,
178
+ type: columnType,
179
+ primaryKey: !!primaryKey[0],
180
+ unique: !!uniqueKey[0],
181
+ default: isSerial ? undefined : defaultValue,
182
+ notNull: !columnResponse.is_nullable,
183
+ references: (_a = mappedRefernces[columnName]) !== null && _a !== void 0 ? _a : undefined,
184
+ };
185
+ }
186
+ const dbIndexes = await db.session().execute(`select
187
+ t.relname as table_name,
188
+ i.relname as index_name,
189
+ a.attname as column_name
190
+ from
191
+ pg_class t,
192
+ pg_class i,
193
+ pg_index ix,
194
+ pg_attribute a
195
+ where
196
+ t.oid = ix.indrelid
197
+ and i.oid = ix.indexrelid
198
+ and a.attrelid = t.oid
199
+ and a.attnum = ANY(ix.indkey)
200
+ and t.relkind = 'r'
201
+ and t.relname = '${tableName}'
202
+ order by
203
+ t.relname,
204
+ i.relname;`);
205
+ for (const dbIndex of dbIndexes.rows) {
206
+ const indexName = dbIndex.index_name;
207
+ const indexColumnName = dbIndex.column_name;
208
+ if (indexToReturn[indexName] !== undefined && indexToReturn[indexName] !== null) {
209
+ indexToReturn[indexName].columns[indexColumnName] = {
210
+ name: indexColumnName,
211
+ };
212
+ }
213
+ else {
214
+ indexToReturn[indexName] = {
215
+ name: indexName,
216
+ columns: {
217
+ [indexColumnName]: {
218
+ name: indexColumnName,
219
+ },
220
+ },
221
+ };
222
+ }
223
+ }
224
+ result[tableName] = {
225
+ name: tableName,
226
+ columns: columnToReturn,
227
+ indexes: indexToReturn,
228
+ };
229
+ }
230
+ catch (e) {
231
+ console.log(e);
232
+ }
233
+ }
234
+ const allEnums = await db.session().execute(`select n.nspname as enum_schema,
235
+ t.typname as enum_name,
236
+ e.enumlabel as enum_value
237
+ from pg_type t
238
+ join pg_enum e on t.oid = e.enumtypid
239
+ join pg_catalog.pg_namespace n ON n.oid = t.typnamespace;`);
240
+ const enumsToReturn = {};
241
+ for (const dbEnum of allEnums.rows) {
242
+ const enumName = dbEnum.enum_name;
243
+ const enumValue = dbEnum.enum_value;
244
+ if (enumsToReturn[enumName] !== undefined && enumsToReturn[enumName] !== null) {
245
+ enumsToReturn[enumName].values.push(enumValue);
246
+ }
247
+ else {
248
+ enumsToReturn[enumName] = {
249
+ name: enumName,
250
+ values: [enumValue],
251
+ };
252
+ }
253
+ }
254
+ return { version: '2', tables: result, enums: enumsToReturn };
255
+ };
256
+ }
257
+ }
258
+ exports.default = MigrationSerializer;
@@ -0,0 +1,11 @@
1
+ import { AbstractColumn } from '../../columns/column';
2
+ import ColumnType from '../../columns/types/columnType';
3
+ import { AbstractTable } from '../../tables';
4
+ export default class Aggregator {
5
+ protected _fields: Array<string>;
6
+ protected _table: AbstractTable<any>;
7
+ constructor(table: AbstractTable<any>, partial?: {
8
+ [name: string]: AbstractColumn<ColumnType<any>, boolean, boolean, AbstractTable<any>>;
9
+ });
10
+ protected generateSelectArray: (table: string, columns: AbstractColumn<ColumnType>[], id?: number | undefined) => string[];
11
+ }
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ /* eslint-disable max-len */
4
+ const column_1 = require("../../columns/column");
5
+ const ecranate_1 = require("../../utils/ecranate");
6
+ // eslint-disable-next-line max-len
7
+ class Aggregator {
8
+ constructor(table, partial) {
9
+ this._fields = [];
10
+ this.generateSelectArray = (table, columns, id) => {
11
+ const selectFields = [];
12
+ columns.forEach((field) => {
13
+ if (field instanceof column_1.Column) {
14
+ selectFields.push(' ');
15
+ selectFields.push(table);
16
+ selectFields.push('.');
17
+ selectFields.push(ecranate_1.ecranate(field.getColumnName()));
18
+ selectFields.push(' AS ');
19
+ selectFields.push(ecranate_1.ecranate(`${field.getAlias()}${id ? `_${id}` : ''}`));
20
+ selectFields.push(',');
21
+ }
22
+ });
23
+ selectFields.pop();
24
+ return selectFields;
25
+ };
26
+ this._table = table;
27
+ if (!partial) {
28
+ this._fields = this.generateSelectArray(this._table.tableName(), Object.values(this._table.mapServiceToDb()));
29
+ }
30
+ else {
31
+ this._fields = this.generateSelectArray(this._table.tableName(), Object.values(partial));
32
+ }
33
+ }
34
+ }
35
+ exports.default = Aggregator;
@@ -0,0 +1,16 @@
1
+ import { AbstractTable } from '../../tables';
2
+ import Expr from '../requestBuilders/where/where';
3
+ import Aggregator from './abstractAggregator';
4
+ export default class DeleteAggregator extends Aggregator {
5
+ private _from;
6
+ private _filters;
7
+ private _values;
8
+ private _delete;
9
+ constructor(table: AbstractTable<any>);
10
+ filters: (filters: Expr) => DeleteAggregator;
11
+ appendFrom: (tableName: string) => DeleteAggregator;
12
+ buildQuery: () => {
13
+ query: string;
14
+ values: Array<any>;
15
+ };
16
+ }
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const abstractAggregator_1 = __importDefault(require("./abstractAggregator"));
7
+ class DeleteAggregator extends abstractAggregator_1.default {
8
+ constructor(table) {
9
+ super(table);
10
+ this._from = [];
11
+ this._filters = [];
12
+ this._values = [];
13
+ this._delete = ['DELETE'];
14
+ this.filters = (filters) => {
15
+ if (filters) {
16
+ const filterQuery = filters.toQuery();
17
+ this._filters.push('WHERE ');
18
+ this._filters.push(filterQuery.query);
19
+ this._values = filterQuery.values;
20
+ }
21
+ return this;
22
+ };
23
+ this.appendFrom = (tableName) => {
24
+ this._from.push(' FROM ');
25
+ this._from.push(tableName);
26
+ return this;
27
+ };
28
+ this.buildQuery = () => {
29
+ // this._delete.push(this._fields.join(''));
30
+ this._delete.push('\n');
31
+ this._delete.push(this._from.join(''));
32
+ this._delete.push('\n');
33
+ this._delete.push(this._filters.join(''));
34
+ this._delete.push('\n');
35
+ this._delete.push('RETURNING');
36
+ this._delete.push('\n');
37
+ this._delete.push(this._fields.join(''));
38
+ return { query: this._delete.join(''), values: this._values };
39
+ };
40
+ }
41
+ }
42
+ exports.default = DeleteAggregator;
@@ -0,0 +1,22 @@
1
+ import { AbstractTable } from '../../tables';
2
+ import { Indexing } from '../../tables/inferTypes';
3
+ import { UpdateExpr } from '../requestBuilders/updates/updates';
4
+ import Aggregator from './abstractAggregator';
5
+ export default class InsertAggregator extends Aggregator {
6
+ private _onConflict;
7
+ private _columns;
8
+ private _query;
9
+ private _values;
10
+ private _from;
11
+ private _insert;
12
+ constructor(table: AbstractTable<any>);
13
+ appendColumns: () => void;
14
+ appendValues: (values: {
15
+ [name: string]: any;
16
+ }[]) => void;
17
+ appendOnConflict: (column: Indexing, updates?: UpdateExpr | undefined) => this;
18
+ buildQuery: () => {
19
+ query: string;
20
+ values: Array<any>;
21
+ };
22
+ }
@@ -0,0 +1,106 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ /* eslint-disable @typescript-eslint/no-loop-func */
7
+ const column_1 = require("../../columns/column");
8
+ const abstractAggregator_1 = __importDefault(require("./abstractAggregator"));
9
+ class InsertAggregator extends abstractAggregator_1.default {
10
+ constructor(table) {
11
+ super(table);
12
+ this._onConflict = [];
13
+ this._columns = [];
14
+ this._query = [];
15
+ this._values = [];
16
+ this._from = [];
17
+ this._insert = ['INSERT INTO'];
18
+ this.appendColumns = () => {
19
+ const mapper = this._table.mapServiceToDb();
20
+ const columns = Object.values(mapper);
21
+ for (let i = 0; i < columns.length; i += 1) {
22
+ const column = columns[i];
23
+ this._columns.push('"');
24
+ this._columns.push(column.getColumnName());
25
+ this._columns.push('"');
26
+ if (i < columns.length - 1) {
27
+ this._columns.push(', ');
28
+ }
29
+ }
30
+ };
31
+ this.appendValues = (values) => {
32
+ // @TODO Check if values not empty
33
+ const mapper = this._table.mapServiceToDb();
34
+ let position = 0;
35
+ for (let i = 0; i < values.length; i += 1) {
36
+ const value = values[i];
37
+ this._query.push('(');
38
+ const entries = Object.entries(mapper);
39
+ entries.forEach(([key], index) => {
40
+ const valueToInsert = value[key];
41
+ const isKeyExistsInValue = key.toString() in value;
42
+ const column = mapper[key];
43
+ if (isKeyExistsInValue) {
44
+ if (valueToInsert !== undefined && valueToInsert !== null) {
45
+ position += 1;
46
+ this._query.push(`$${position}`);
47
+ this._values.push(column.getColumnType().insertStrategy(valueToInsert));
48
+ }
49
+ else {
50
+ this._query.push('null');
51
+ }
52
+ }
53
+ else {
54
+ this._query.push('DEFAULT');
55
+ }
56
+ if (index < entries.length - 1) {
57
+ this._query.push(', ');
58
+ }
59
+ });
60
+ if (i < values.length - 1) {
61
+ this._query.push('),\n');
62
+ }
63
+ else {
64
+ this._query.push(')\n');
65
+ }
66
+ }
67
+ };
68
+ this.appendOnConflict = (column, updates) => {
69
+ if (column) {
70
+ const indexName = column instanceof column_1.IndexedColumn
71
+ ? column.getColumnName() : column.getColumns().map((it) => it.getColumnName()).join(',');
72
+ this._onConflict.push(`ON CONFLICT (${indexName})\n`);
73
+ if (updates) {
74
+ const currentPointerPosition = this._values.length > 0
75
+ ? this._values.length + 1 : undefined;
76
+ const updatesQuery = updates.toQuery(currentPointerPosition);
77
+ this._onConflict.push('DO UPDATE\n');
78
+ this._onConflict.push(`SET ${updatesQuery.query}`);
79
+ this._values.push(...updatesQuery.values);
80
+ }
81
+ else {
82
+ this._onConflict.push('DO NOTHING\n');
83
+ }
84
+ }
85
+ return this;
86
+ };
87
+ this.buildQuery = () => {
88
+ this._insert.push(this._from.join(''));
89
+ this._insert.push(' (');
90
+ this._insert.push(this._columns.join(''));
91
+ this._insert.push(') ');
92
+ this._insert.push('VALUES\n');
93
+ this._insert.push(this._query.join(''));
94
+ this._insert.push('\n');
95
+ this._insert.push(this._onConflict.join(''));
96
+ this._insert.push('\n');
97
+ this._insert.push('RETURNING');
98
+ this._insert.push('\n');
99
+ this._insert.push(this._fields.join(''));
100
+ return { query: this._insert.join(''), values: this._values };
101
+ };
102
+ this._from.push(' ');
103
+ this._from.push(table.tableName());
104
+ }
105
+ }
106
+ exports.default = InsertAggregator;
@@ -0,0 +1,39 @@
1
+ import { AbstractColumn } from '../../columns/column';
2
+ import ColumnType from '../../columns/types/columnType';
3
+ import { AbstractTable } from '../../tables';
4
+ import Order from '../highLvlBuilders/order';
5
+ import Join from '../joinBuilders/join';
6
+ import Expr from '../requestBuilders/where/where';
7
+ import Aggregator from './abstractAggregator';
8
+ export default class SelectAggregator extends Aggregator {
9
+ private _from;
10
+ private _filters;
11
+ private _select;
12
+ private _join;
13
+ private _limit;
14
+ private _offset;
15
+ private _distinct;
16
+ private _orderBy;
17
+ private _values;
18
+ private _joinCache;
19
+ constructor(table: AbstractTable<any>, partial?: {
20
+ [name: string]: AbstractColumn<ColumnType<any>, boolean, boolean, AbstractTable<any>>;
21
+ });
22
+ filters: (filters: Expr) => SelectAggregator;
23
+ limit: (limit?: number | undefined) => SelectAggregator;
24
+ offset: (offset?: number | undefined) => SelectAggregator;
25
+ orderBy: (column?: AbstractColumn<ColumnType<{}>, boolean, boolean, any> | undefined, order?: Order | undefined) => SelectAggregator;
26
+ distinct: (column?: AbstractColumn<ColumnType<{}>, boolean, boolean, any> | undefined) => SelectAggregator;
27
+ appendFrom: (tableName: string) => SelectAggregator;
28
+ join: (joins: {
29
+ join: Join<any>;
30
+ partial?: {
31
+ [name: string]: AbstractColumn<ColumnType<any>, boolean, boolean, any>;
32
+ } | undefined;
33
+ id?: number | undefined;
34
+ }[]) => SelectAggregator;
35
+ buildQuery: () => {
36
+ query: string;
37
+ values: Array<any>;
38
+ };
39
+ }