drizzle-orm 0.10.24 → 0.10.25

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 (479) hide show
  1. package/package.json +2 -3
  2. package/README.md +0 -439
  3. package/dist/builders/aggregators/abstractAggregator.d.ts +0 -11
  4. package/dist/builders/aggregators/abstractAggregator.js +0 -35
  5. package/dist/builders/aggregators/deleteAggregator.d.ts +0 -16
  6. package/dist/builders/aggregators/deleteAggregator.js +0 -42
  7. package/dist/builders/aggregators/insertAggregator.d.ts +0 -22
  8. package/dist/builders/aggregators/insertAggregator.js +0 -106
  9. package/dist/builders/aggregators/selectAggregator.d.ts +0 -39
  10. package/dist/builders/aggregators/selectAggregator.js +0 -143
  11. package/dist/builders/aggregators/updateAggregator.d.ts +0 -19
  12. package/dist/builders/aggregators/updateAggregator.js +0 -50
  13. package/dist/builders/highLvlBuilders/abstractRequestBuilder.d.ts +0 -27
  14. package/dist/builders/highLvlBuilders/abstractRequestBuilder.js +0 -32
  15. package/dist/builders/highLvlBuilders/deleteRequestBuilder.d.ts +0 -19
  16. package/dist/builders/highLvlBuilders/deleteRequestBuilder.js +0 -61
  17. package/dist/builders/highLvlBuilders/insertRequestBuilder.d.ts +0 -20
  18. package/dist/builders/highLvlBuilders/insertRequestBuilder.js +0 -73
  19. package/dist/builders/highLvlBuilders/order.d.ts +0 -5
  20. package/dist/builders/highLvlBuilders/order.js +0 -8
  21. package/dist/builders/highLvlBuilders/selectRequestBuilder.d.ts +0 -47
  22. package/dist/builders/highLvlBuilders/selectRequestBuilder.js +0 -128
  23. package/dist/builders/highLvlBuilders/updateRequestBuilder.d.ts +0 -22
  24. package/dist/builders/highLvlBuilders/updateRequestBuilder.js +0 -80
  25. package/dist/builders/index.d.ts +0 -18
  26. package/dist/builders/index.js +0 -54
  27. package/dist/builders/joinBuilders/builders/abstractJoinBuilder.d.ts +0 -40
  28. package/dist/builders/joinBuilders/builders/abstractJoinBuilder.js +0 -78
  29. package/dist/builders/joinBuilders/builders/selectWithFiveJoins.d.ts +0 -35
  30. package/dist/builders/joinBuilders/builders/selectWithFiveJoins.js +0 -45
  31. package/dist/builders/joinBuilders/builders/selectWithFourJoins.d.ts +0 -55
  32. package/dist/builders/joinBuilders/builders/selectWithFourJoins.js +0 -78
  33. package/dist/builders/joinBuilders/builders/selectWithJoin.d.ts +0 -49
  34. package/dist/builders/joinBuilders/builders/selectWithJoin.js +0 -64
  35. package/dist/builders/joinBuilders/builders/selectWithThreeJoins.d.ts +0 -53
  36. package/dist/builders/joinBuilders/builders/selectWithThreeJoins.js +0 -73
  37. package/dist/builders/joinBuilders/builders/selectWithTwoJoins.d.ts +0 -51
  38. package/dist/builders/joinBuilders/builders/selectWithTwoJoins.js +0 -68
  39. package/dist/builders/joinBuilders/join.d.ts +0 -23
  40. package/dist/builders/joinBuilders/join.js +0 -28
  41. package/dist/builders/joinBuilders/joinWith.d.ts +0 -14
  42. package/dist/builders/joinBuilders/joinWith.js +0 -14
  43. package/dist/builders/joinBuilders/responses/selectResponseFiveJoins.d.ts +0 -20
  44. package/dist/builders/joinBuilders/responses/selectResponseFiveJoins.js +0 -35
  45. package/dist/builders/joinBuilders/responses/selectResponseFourJoins.d.ts +0 -19
  46. package/dist/builders/joinBuilders/responses/selectResponseFourJoins.js +0 -34
  47. package/dist/builders/joinBuilders/responses/selectResponseThreeJoins.d.ts +0 -18
  48. package/dist/builders/joinBuilders/responses/selectResponseThreeJoins.js +0 -33
  49. package/dist/builders/joinBuilders/responses/selectResponseTwoJoins.d.ts +0 -17
  50. package/dist/builders/joinBuilders/responses/selectResponseTwoJoins.js +0 -32
  51. package/dist/builders/joinBuilders/responses/selectResponseWithJoin.d.ts +0 -16
  52. package/dist/builders/joinBuilders/responses/selectResponseWithJoin.js +0 -31
  53. package/dist/builders/joinBuilders/static.d.ts +0 -5
  54. package/dist/builders/joinBuilders/static.js +0 -9
  55. package/dist/builders/lowLvlBuilders/alter.d.ts +0 -0
  56. package/dist/builders/lowLvlBuilders/alter.js +0 -1
  57. package/dist/builders/lowLvlBuilders/create.d.ts +0 -12
  58. package/dist/builders/lowLvlBuilders/create.js +0 -100
  59. package/dist/builders/lowLvlBuilders/delets/delete.d.ts +0 -5
  60. package/dist/builders/lowLvlBuilders/delets/delete.js +0 -15
  61. package/dist/builders/lowLvlBuilders/delets/deleteFilter.d.ts +0 -11
  62. package/dist/builders/lowLvlBuilders/delets/deleteFilter.js +0 -13
  63. package/dist/builders/lowLvlBuilders/delets/deleteFrom.d.ts +0 -12
  64. package/dist/builders/lowLvlBuilders/delets/deleteFrom.js +0 -14
  65. package/dist/builders/lowLvlBuilders/inserts/insert.d.ts +0 -5
  66. package/dist/builders/lowLvlBuilders/inserts/insert.js +0 -15
  67. package/dist/builders/lowLvlBuilders/inserts/insertInto.d.ts +0 -13
  68. package/dist/builders/lowLvlBuilders/inserts/insertInto.js +0 -16
  69. package/dist/builders/lowLvlBuilders/inserts/onConflictInsert.d.ts +0 -12
  70. package/dist/builders/lowLvlBuilders/inserts/onConflictInsert.js +0 -13
  71. package/dist/builders/lowLvlBuilders/inserts/valuesInsert.d.ts +0 -16
  72. package/dist/builders/lowLvlBuilders/inserts/valuesInsert.js +0 -19
  73. package/dist/builders/lowLvlBuilders/selects/select.d.ts +0 -9
  74. package/dist/builders/lowLvlBuilders/selects/select.js +0 -16
  75. package/dist/builders/lowLvlBuilders/selects/selectFrom.d.ts +0 -28
  76. package/dist/builders/lowLvlBuilders/selects/selectFrom.js +0 -34
  77. package/dist/builders/lowLvlBuilders/selects/selectJoined.d.ts +0 -26
  78. package/dist/builders/lowLvlBuilders/selects/selectJoined.js +0 -30
  79. package/dist/builders/lowLvlBuilders/selects/whereSelect.d.ts +0 -17
  80. package/dist/builders/lowLvlBuilders/selects/whereSelect.js +0 -25
  81. package/dist/builders/lowLvlBuilders/updates/update.d.ts +0 -5
  82. package/dist/builders/lowLvlBuilders/updates/update.js +0 -15
  83. package/dist/builders/lowLvlBuilders/updates/updateIn.d.ts +0 -13
  84. package/dist/builders/lowLvlBuilders/updates/updateIn.js +0 -15
  85. package/dist/builders/lowLvlBuilders/updates/whereSelect.d.ts +0 -11
  86. package/dist/builders/lowLvlBuilders/updates/whereSelect.js +0 -13
  87. package/dist/builders/lowLvlBuilders/updates/whereSet.d.ts +0 -14
  88. package/dist/builders/lowLvlBuilders/updates/whereSet.js +0 -18
  89. package/dist/builders/requestBuilders/updates/combine.d.ts +0 -9
  90. package/dist/builders/requestBuilders/updates/combine.js +0 -26
  91. package/dist/builders/requestBuilders/updates/increment.d.ts +0 -13
  92. package/dist/builders/requestBuilders/updates/increment.js +0 -18
  93. package/dist/builders/requestBuilders/updates/setObjects.d.ts +0 -12
  94. package/dist/builders/requestBuilders/updates/setObjects.js +0 -19
  95. package/dist/builders/requestBuilders/updates/static.d.ts +0 -7
  96. package/dist/builders/requestBuilders/updates/static.js +0 -15
  97. package/dist/builders/requestBuilders/updates/updates.d.ts +0 -9
  98. package/dist/builders/requestBuilders/updates/updates.js +0 -10
  99. package/dist/builders/requestBuilders/where/and.d.ts +0 -11
  100. package/dist/builders/requestBuilders/where/and.js +0 -31
  101. package/dist/builders/requestBuilders/where/const.d.ts +0 -9
  102. package/dist/builders/requestBuilders/where/const.js +0 -25
  103. package/dist/builders/requestBuilders/where/constArray.d.ts +0 -9
  104. package/dist/builders/requestBuilders/where/constArray.js +0 -39
  105. package/dist/builders/requestBuilders/where/eqWhere.d.ts +0 -12
  106. package/dist/builders/requestBuilders/where/eqWhere.js +0 -20
  107. package/dist/builders/requestBuilders/where/greater.d.ts +0 -15
  108. package/dist/builders/requestBuilders/where/greater.js +0 -20
  109. package/dist/builders/requestBuilders/where/greaterEq.d.ts +0 -15
  110. package/dist/builders/requestBuilders/where/greaterEq.js +0 -20
  111. package/dist/builders/requestBuilders/where/in.d.ts +0 -12
  112. package/dist/builders/requestBuilders/where/in.js +0 -20
  113. package/dist/builders/requestBuilders/where/isNotNull.d.ts +0 -11
  114. package/dist/builders/requestBuilders/where/isNotNull.js +0 -18
  115. package/dist/builders/requestBuilders/where/isNull.d.ts +0 -11
  116. package/dist/builders/requestBuilders/where/isNull.js +0 -18
  117. package/dist/builders/requestBuilders/where/less.d.ts +0 -15
  118. package/dist/builders/requestBuilders/where/less.js +0 -20
  119. package/dist/builders/requestBuilders/where/lessEq.d.ts +0 -15
  120. package/dist/builders/requestBuilders/where/lessEq.js +0 -20
  121. package/dist/builders/requestBuilders/where/like.d.ts +0 -12
  122. package/dist/builders/requestBuilders/where/like.js +0 -20
  123. package/dist/builders/requestBuilders/where/notEqWhere.d.ts +0 -12
  124. package/dist/builders/requestBuilders/where/notEqWhere.js +0 -20
  125. package/dist/builders/requestBuilders/where/or.d.ts +0 -11
  126. package/dist/builders/requestBuilders/where/or.js +0 -31
  127. package/dist/builders/requestBuilders/where/rawWhere.d.ts +0 -9
  128. package/dist/builders/requestBuilders/where/rawWhere.js +0 -15
  129. package/dist/builders/requestBuilders/where/static.d.ts +0 -17
  130. package/dist/builders/requestBuilders/where/static.js +0 -49
  131. package/dist/builders/requestBuilders/where/var.d.ts +0 -13
  132. package/dist/builders/requestBuilders/where/var.js +0 -18
  133. package/dist/builders/requestBuilders/where/where.d.ts +0 -8
  134. package/dist/builders/requestBuilders/where/where.js +0 -6
  135. package/dist/builders/transaction/transaction.d.ts +0 -8
  136. package/dist/builders/transaction/transaction.js +0 -20
  137. package/dist/columns/column.d.ts +0 -72
  138. package/dist/columns/column.js +0 -101
  139. package/dist/columns/index.d.ts +0 -10
  140. package/dist/columns/index.js +0 -27
  141. package/dist/columns/types/columnType.d.ts +0 -7
  142. package/dist/columns/types/columnType.js +0 -6
  143. package/dist/columns/types/pgBigDecimal.d.ts +0 -10
  144. package/dist/columns/types/pgBigDecimal.js +0 -31
  145. package/dist/columns/types/pgBigInt.d.ts +0 -15
  146. package/dist/columns/types/pgBigInt.js +0 -32
  147. package/dist/columns/types/pgBigSerial.d.ts +0 -15
  148. package/dist/columns/types/pgBigSerial.js +0 -32
  149. package/dist/columns/types/pgBoolean.d.ts +0 -8
  150. package/dist/columns/types/pgBoolean.js +0 -18
  151. package/dist/columns/types/pgEnum.d.ts +0 -9
  152. package/dist/columns/types/pgEnum.js +0 -18
  153. package/dist/columns/types/pgInteger.d.ts +0 -8
  154. package/dist/columns/types/pgInteger.js +0 -21
  155. package/dist/columns/types/pgJsonb.d.ts +0 -9
  156. package/dist/columns/types/pgJsonb.js +0 -20
  157. package/dist/columns/types/pgSerial.d.ts +0 -8
  158. package/dist/columns/types/pgSerial.js +0 -18
  159. package/dist/columns/types/pgSmallInt.d.ts +0 -8
  160. package/dist/columns/types/pgSmallInt.js +0 -18
  161. package/dist/columns/types/pgText.d.ts +0 -8
  162. package/dist/columns/types/pgText.js +0 -18
  163. package/dist/columns/types/pgTime.d.ts +0 -8
  164. package/dist/columns/types/pgTime.js +0 -18
  165. package/dist/columns/types/pgTimestamp.d.ts +0 -8
  166. package/dist/columns/types/pgTimestamp.js +0 -18
  167. package/dist/columns/types/pgTimestamptz.d.ts +0 -8
  168. package/dist/columns/types/pgTimestamptz.js +0 -18
  169. package/dist/columns/types/pgVarChar.d.ts +0 -9
  170. package/dist/columns/types/pgVarChar.js +0 -24
  171. package/dist/db/db.d.ts +0 -18
  172. package/dist/db/db.js +0 -25
  173. package/dist/db/dbConnector.d.ts +0 -9
  174. package/dist/db/dbConnector.js +0 -32
  175. package/dist/db/dbStringConnector.d.ts +0 -6
  176. package/dist/db/dbStringConnector.js +0 -29
  177. package/dist/db/group_by.d.ts +0 -0
  178. package/dist/db/group_by.js +0 -68
  179. package/dist/db/index.d.ts +0 -4
  180. package/dist/db/index.js +0 -14
  181. package/dist/db/session.d.ts +0 -9
  182. package/dist/db/session.js +0 -16
  183. package/dist/docs/cases/simple_delete.d.ts +0 -1
  184. package/dist/docs/cases/simple_delete.js +0 -35
  185. package/dist/docs/cases/simple_insert.d.ts +0 -1
  186. package/dist/docs/cases/simple_insert.js +0 -57
  187. package/dist/docs/cases/simple_join.d.ts +0 -1
  188. package/dist/docs/cases/simple_join.js +0 -115
  189. package/dist/docs/cases/simple_select.d.ts +0 -1
  190. package/dist/docs/cases/simple_select.js +0 -50
  191. package/dist/docs/cases/simple_update.d.ts +0 -1
  192. package/dist/docs/cases/simple_update.js +0 -39
  193. package/dist/docs/tables/citiesTable.d.ts +0 -14
  194. package/dist/docs/tables/citiesTable.js +0 -21
  195. package/dist/docs/tables/userGroupsTable.d.ts +0 -7
  196. package/dist/docs/tables/userGroupsTable.js +0 -18
  197. package/dist/docs/tables/usersTable.d.ts +0 -17
  198. package/dist/docs/tables/usersTable.js +0 -35
  199. package/dist/docs/tables/usersToUserGroups.d.ts +0 -7
  200. package/dist/docs/tables/usersToUserGroups.js +0 -20
  201. package/dist/docs/types/rolesType.d.ts +0 -1
  202. package/dist/docs/types/rolesType.js +0 -6
  203. package/dist/errors/baseError.d.ts +0 -22
  204. package/dist/errors/baseError.js +0 -35
  205. package/dist/errors/builderError.d.ts +0 -14
  206. package/dist/errors/builderError.js +0 -25
  207. package/dist/errors/dbErrors.d.ts +0 -12
  208. package/dist/errors/dbErrors.js +0 -28
  209. package/dist/index.d.ts +0 -11
  210. package/dist/index.js +0 -31
  211. package/dist/indexes/tableIndex.d.ts +0 -11
  212. package/dist/indexes/tableIndex.js +0 -17
  213. package/dist/logger/abstractLogger.d.ts +0 -4
  214. package/dist/logger/abstractLogger.js +0 -5
  215. package/dist/logger/consoleLogger.d.ts +0 -5
  216. package/dist/logger/consoleLogger.js +0 -15
  217. package/dist/mappers/index.d.ts +0 -0
  218. package/dist/mappers/index.js +0 -1
  219. package/dist/mappers/responseMapper.d.ts +0 -10
  220. package/dist/mappers/responseMapper.js +0 -35
  221. package/dist/migrator/index.d.ts +0 -0
  222. package/dist/migrator/index.js +0 -1
  223. package/dist/migrator/migrator.d.ts +0 -11
  224. package/dist/migrator/migrator.js +0 -105
  225. package/dist/serializer/serializer.d.ts +0 -47
  226. package/dist/serializer/serializer.js +0 -258
  227. package/dist/src/builders/aggregators/abstractAggregator.d.ts +0 -11
  228. package/dist/src/builders/aggregators/abstractAggregator.js +0 -35
  229. package/dist/src/builders/aggregators/deleteAggregator.d.ts +0 -16
  230. package/dist/src/builders/aggregators/deleteAggregator.js +0 -42
  231. package/dist/src/builders/aggregators/insertAggregator.d.ts +0 -22
  232. package/dist/src/builders/aggregators/insertAggregator.js +0 -106
  233. package/dist/src/builders/aggregators/selectAggregator.d.ts +0 -39
  234. package/dist/src/builders/aggregators/selectAggregator.js +0 -143
  235. package/dist/src/builders/aggregators/updateAggregator.d.ts +0 -19
  236. package/dist/src/builders/aggregators/updateAggregator.js +0 -50
  237. package/dist/src/builders/highLvlBuilders/abstractRequestBuilder.d.ts +0 -27
  238. package/dist/src/builders/highLvlBuilders/abstractRequestBuilder.js +0 -32
  239. package/dist/src/builders/highLvlBuilders/deleteRequestBuilder.d.ts +0 -19
  240. package/dist/src/builders/highLvlBuilders/deleteRequestBuilder.js +0 -61
  241. package/dist/src/builders/highLvlBuilders/insertRequestBuilder.d.ts +0 -20
  242. package/dist/src/builders/highLvlBuilders/insertRequestBuilder.js +0 -73
  243. package/dist/src/builders/highLvlBuilders/order.d.ts +0 -5
  244. package/dist/src/builders/highLvlBuilders/order.js +0 -8
  245. package/dist/src/builders/highLvlBuilders/selectRequestBuilder.d.ts +0 -47
  246. package/dist/src/builders/highLvlBuilders/selectRequestBuilder.js +0 -128
  247. package/dist/src/builders/highLvlBuilders/updateRequestBuilder.d.ts +0 -22
  248. package/dist/src/builders/highLvlBuilders/updateRequestBuilder.js +0 -80
  249. package/dist/src/builders/index.d.ts +0 -18
  250. package/dist/src/builders/index.js +0 -54
  251. package/dist/src/builders/joinBuilders/builders/abstractJoinBuilder.d.ts +0 -40
  252. package/dist/src/builders/joinBuilders/builders/abstractJoinBuilder.js +0 -78
  253. package/dist/src/builders/joinBuilders/builders/selectWithFiveJoins.d.ts +0 -35
  254. package/dist/src/builders/joinBuilders/builders/selectWithFiveJoins.js +0 -45
  255. package/dist/src/builders/joinBuilders/builders/selectWithFourJoins.d.ts +0 -55
  256. package/dist/src/builders/joinBuilders/builders/selectWithFourJoins.js +0 -78
  257. package/dist/src/builders/joinBuilders/builders/selectWithJoin.d.ts +0 -49
  258. package/dist/src/builders/joinBuilders/builders/selectWithJoin.js +0 -64
  259. package/dist/src/builders/joinBuilders/builders/selectWithThreeJoins.d.ts +0 -53
  260. package/dist/src/builders/joinBuilders/builders/selectWithThreeJoins.js +0 -73
  261. package/dist/src/builders/joinBuilders/builders/selectWithTwoJoins.d.ts +0 -51
  262. package/dist/src/builders/joinBuilders/builders/selectWithTwoJoins.js +0 -68
  263. package/dist/src/builders/joinBuilders/join.d.ts +0 -23
  264. package/dist/src/builders/joinBuilders/join.js +0 -28
  265. package/dist/src/builders/joinBuilders/joinWith.d.ts +0 -14
  266. package/dist/src/builders/joinBuilders/joinWith.js +0 -14
  267. package/dist/src/builders/joinBuilders/responses/selectResponseFiveJoins.d.ts +0 -20
  268. package/dist/src/builders/joinBuilders/responses/selectResponseFiveJoins.js +0 -35
  269. package/dist/src/builders/joinBuilders/responses/selectResponseFourJoins.d.ts +0 -19
  270. package/dist/src/builders/joinBuilders/responses/selectResponseFourJoins.js +0 -34
  271. package/dist/src/builders/joinBuilders/responses/selectResponseThreeJoins.d.ts +0 -18
  272. package/dist/src/builders/joinBuilders/responses/selectResponseThreeJoins.js +0 -33
  273. package/dist/src/builders/joinBuilders/responses/selectResponseTwoJoins.d.ts +0 -17
  274. package/dist/src/builders/joinBuilders/responses/selectResponseTwoJoins.js +0 -32
  275. package/dist/src/builders/joinBuilders/responses/selectResponseWithJoin.d.ts +0 -16
  276. package/dist/src/builders/joinBuilders/responses/selectResponseWithJoin.js +0 -31
  277. package/dist/src/builders/joinBuilders/static.d.ts +0 -5
  278. package/dist/src/builders/joinBuilders/static.js +0 -9
  279. package/dist/src/builders/lowLvlBuilders/alter.d.ts +0 -0
  280. package/dist/src/builders/lowLvlBuilders/alter.js +0 -1
  281. package/dist/src/builders/lowLvlBuilders/create.d.ts +0 -12
  282. package/dist/src/builders/lowLvlBuilders/create.js +0 -100
  283. package/dist/src/builders/lowLvlBuilders/delets/delete.d.ts +0 -5
  284. package/dist/src/builders/lowLvlBuilders/delets/delete.js +0 -15
  285. package/dist/src/builders/lowLvlBuilders/delets/deleteFilter.d.ts +0 -11
  286. package/dist/src/builders/lowLvlBuilders/delets/deleteFilter.js +0 -13
  287. package/dist/src/builders/lowLvlBuilders/delets/deleteFrom.d.ts +0 -12
  288. package/dist/src/builders/lowLvlBuilders/delets/deleteFrom.js +0 -14
  289. package/dist/src/builders/lowLvlBuilders/inserts/insert.d.ts +0 -5
  290. package/dist/src/builders/lowLvlBuilders/inserts/insert.js +0 -15
  291. package/dist/src/builders/lowLvlBuilders/inserts/insertInto.d.ts +0 -13
  292. package/dist/src/builders/lowLvlBuilders/inserts/insertInto.js +0 -16
  293. package/dist/src/builders/lowLvlBuilders/inserts/onConflictInsert.d.ts +0 -12
  294. package/dist/src/builders/lowLvlBuilders/inserts/onConflictInsert.js +0 -13
  295. package/dist/src/builders/lowLvlBuilders/inserts/valuesInsert.d.ts +0 -16
  296. package/dist/src/builders/lowLvlBuilders/inserts/valuesInsert.js +0 -19
  297. package/dist/src/builders/lowLvlBuilders/selects/select.d.ts +0 -9
  298. package/dist/src/builders/lowLvlBuilders/selects/select.js +0 -16
  299. package/dist/src/builders/lowLvlBuilders/selects/selectFrom.d.ts +0 -28
  300. package/dist/src/builders/lowLvlBuilders/selects/selectFrom.js +0 -34
  301. package/dist/src/builders/lowLvlBuilders/selects/selectJoined.d.ts +0 -26
  302. package/dist/src/builders/lowLvlBuilders/selects/selectJoined.js +0 -30
  303. package/dist/src/builders/lowLvlBuilders/selects/whereSelect.d.ts +0 -17
  304. package/dist/src/builders/lowLvlBuilders/selects/whereSelect.js +0 -25
  305. package/dist/src/builders/lowLvlBuilders/updates/update.d.ts +0 -5
  306. package/dist/src/builders/lowLvlBuilders/updates/update.js +0 -15
  307. package/dist/src/builders/lowLvlBuilders/updates/updateIn.d.ts +0 -13
  308. package/dist/src/builders/lowLvlBuilders/updates/updateIn.js +0 -15
  309. package/dist/src/builders/lowLvlBuilders/updates/whereSelect.d.ts +0 -11
  310. package/dist/src/builders/lowLvlBuilders/updates/whereSelect.js +0 -13
  311. package/dist/src/builders/lowLvlBuilders/updates/whereSet.d.ts +0 -14
  312. package/dist/src/builders/lowLvlBuilders/updates/whereSet.js +0 -18
  313. package/dist/src/builders/requestBuilders/updates/combine.d.ts +0 -9
  314. package/dist/src/builders/requestBuilders/updates/combine.js +0 -26
  315. package/dist/src/builders/requestBuilders/updates/increment.d.ts +0 -13
  316. package/dist/src/builders/requestBuilders/updates/increment.js +0 -18
  317. package/dist/src/builders/requestBuilders/updates/setObjects.d.ts +0 -12
  318. package/dist/src/builders/requestBuilders/updates/setObjects.js +0 -19
  319. package/dist/src/builders/requestBuilders/updates/static.d.ts +0 -7
  320. package/dist/src/builders/requestBuilders/updates/static.js +0 -15
  321. package/dist/src/builders/requestBuilders/updates/updates.d.ts +0 -9
  322. package/dist/src/builders/requestBuilders/updates/updates.js +0 -10
  323. package/dist/src/builders/requestBuilders/where/and.d.ts +0 -11
  324. package/dist/src/builders/requestBuilders/where/and.js +0 -31
  325. package/dist/src/builders/requestBuilders/where/const.d.ts +0 -9
  326. package/dist/src/builders/requestBuilders/where/const.js +0 -25
  327. package/dist/src/builders/requestBuilders/where/constArray.d.ts +0 -9
  328. package/dist/src/builders/requestBuilders/where/constArray.js +0 -39
  329. package/dist/src/builders/requestBuilders/where/eqWhere.d.ts +0 -12
  330. package/dist/src/builders/requestBuilders/where/eqWhere.js +0 -20
  331. package/dist/src/builders/requestBuilders/where/greater.d.ts +0 -15
  332. package/dist/src/builders/requestBuilders/where/greater.js +0 -20
  333. package/dist/src/builders/requestBuilders/where/greaterEq.d.ts +0 -15
  334. package/dist/src/builders/requestBuilders/where/greaterEq.js +0 -20
  335. package/dist/src/builders/requestBuilders/where/in.d.ts +0 -12
  336. package/dist/src/builders/requestBuilders/where/in.js +0 -20
  337. package/dist/src/builders/requestBuilders/where/isNotNull.d.ts +0 -11
  338. package/dist/src/builders/requestBuilders/where/isNotNull.js +0 -18
  339. package/dist/src/builders/requestBuilders/where/isNull.d.ts +0 -11
  340. package/dist/src/builders/requestBuilders/where/isNull.js +0 -18
  341. package/dist/src/builders/requestBuilders/where/less.d.ts +0 -15
  342. package/dist/src/builders/requestBuilders/where/less.js +0 -20
  343. package/dist/src/builders/requestBuilders/where/lessEq.d.ts +0 -15
  344. package/dist/src/builders/requestBuilders/where/lessEq.js +0 -20
  345. package/dist/src/builders/requestBuilders/where/like.d.ts +0 -12
  346. package/dist/src/builders/requestBuilders/where/like.js +0 -20
  347. package/dist/src/builders/requestBuilders/where/notEqWhere.d.ts +0 -12
  348. package/dist/src/builders/requestBuilders/where/notEqWhere.js +0 -20
  349. package/dist/src/builders/requestBuilders/where/or.d.ts +0 -11
  350. package/dist/src/builders/requestBuilders/where/or.js +0 -31
  351. package/dist/src/builders/requestBuilders/where/rawWhere.d.ts +0 -9
  352. package/dist/src/builders/requestBuilders/where/rawWhere.js +0 -15
  353. package/dist/src/builders/requestBuilders/where/static.d.ts +0 -17
  354. package/dist/src/builders/requestBuilders/where/static.js +0 -49
  355. package/dist/src/builders/requestBuilders/where/var.d.ts +0 -13
  356. package/dist/src/builders/requestBuilders/where/var.js +0 -18
  357. package/dist/src/builders/requestBuilders/where/where.d.ts +0 -8
  358. package/dist/src/builders/requestBuilders/where/where.js +0 -6
  359. package/dist/src/builders/transaction/transaction.d.ts +0 -8
  360. package/dist/src/builders/transaction/transaction.js +0 -20
  361. package/dist/src/columns/column.d.ts +0 -72
  362. package/dist/src/columns/column.js +0 -101
  363. package/dist/src/columns/index.d.ts +0 -10
  364. package/dist/src/columns/index.js +0 -27
  365. package/dist/src/columns/types/columnType.d.ts +0 -7
  366. package/dist/src/columns/types/columnType.js +0 -6
  367. package/dist/src/columns/types/pgBigDecimal.d.ts +0 -10
  368. package/dist/src/columns/types/pgBigDecimal.js +0 -31
  369. package/dist/src/columns/types/pgBigInt.d.ts +0 -15
  370. package/dist/src/columns/types/pgBigInt.js +0 -32
  371. package/dist/src/columns/types/pgBigSerial.d.ts +0 -15
  372. package/dist/src/columns/types/pgBigSerial.js +0 -32
  373. package/dist/src/columns/types/pgBoolean.d.ts +0 -8
  374. package/dist/src/columns/types/pgBoolean.js +0 -18
  375. package/dist/src/columns/types/pgEnum.d.ts +0 -9
  376. package/dist/src/columns/types/pgEnum.js +0 -18
  377. package/dist/src/columns/types/pgInteger.d.ts +0 -8
  378. package/dist/src/columns/types/pgInteger.js +0 -21
  379. package/dist/src/columns/types/pgJsonb.d.ts +0 -9
  380. package/dist/src/columns/types/pgJsonb.js +0 -20
  381. package/dist/src/columns/types/pgSerial.d.ts +0 -8
  382. package/dist/src/columns/types/pgSerial.js +0 -18
  383. package/dist/src/columns/types/pgSmallInt.d.ts +0 -8
  384. package/dist/src/columns/types/pgSmallInt.js +0 -18
  385. package/dist/src/columns/types/pgText.d.ts +0 -8
  386. package/dist/src/columns/types/pgText.js +0 -18
  387. package/dist/src/columns/types/pgTime.d.ts +0 -8
  388. package/dist/src/columns/types/pgTime.js +0 -18
  389. package/dist/src/columns/types/pgTimestamp.d.ts +0 -8
  390. package/dist/src/columns/types/pgTimestamp.js +0 -18
  391. package/dist/src/columns/types/pgTimestamptz.d.ts +0 -8
  392. package/dist/src/columns/types/pgTimestamptz.js +0 -18
  393. package/dist/src/columns/types/pgVarChar.d.ts +0 -9
  394. package/dist/src/columns/types/pgVarChar.js +0 -24
  395. package/dist/src/db/db.d.ts +0 -18
  396. package/dist/src/db/db.js +0 -25
  397. package/dist/src/db/dbConnector.d.ts +0 -9
  398. package/dist/src/db/dbConnector.js +0 -32
  399. package/dist/src/db/dbStringConnector.d.ts +0 -6
  400. package/dist/src/db/dbStringConnector.js +0 -29
  401. package/dist/src/db/group_by.d.ts +0 -0
  402. package/dist/src/db/group_by.js +0 -68
  403. package/dist/src/db/index.d.ts +0 -4
  404. package/dist/src/db/index.js +0 -14
  405. package/dist/src/db/session.d.ts +0 -9
  406. package/dist/src/db/session.js +0 -16
  407. package/dist/src/docs/cases/simple_delete.d.ts +0 -1
  408. package/dist/src/docs/cases/simple_delete.js +0 -35
  409. package/dist/src/docs/cases/simple_insert.d.ts +0 -1
  410. package/dist/src/docs/cases/simple_insert.js +0 -57
  411. package/dist/src/docs/cases/simple_join.d.ts +0 -1
  412. package/dist/src/docs/cases/simple_join.js +0 -115
  413. package/dist/src/docs/cases/simple_select.d.ts +0 -1
  414. package/dist/src/docs/cases/simple_select.js +0 -50
  415. package/dist/src/docs/cases/simple_update.d.ts +0 -1
  416. package/dist/src/docs/cases/simple_update.js +0 -39
  417. package/dist/src/docs/tables/citiesTable.d.ts +0 -14
  418. package/dist/src/docs/tables/citiesTable.js +0 -21
  419. package/dist/src/docs/tables/userGroupsTable.d.ts +0 -7
  420. package/dist/src/docs/tables/userGroupsTable.js +0 -18
  421. package/dist/src/docs/tables/usersTable.d.ts +0 -17
  422. package/dist/src/docs/tables/usersTable.js +0 -35
  423. package/dist/src/docs/tables/usersToUserGroups.d.ts +0 -7
  424. package/dist/src/docs/tables/usersToUserGroups.js +0 -20
  425. package/dist/src/docs/types/rolesType.d.ts +0 -1
  426. package/dist/src/docs/types/rolesType.js +0 -6
  427. package/dist/src/errors/baseError.d.ts +0 -22
  428. package/dist/src/errors/baseError.js +0 -35
  429. package/dist/src/errors/builderError.d.ts +0 -14
  430. package/dist/src/errors/builderError.js +0 -25
  431. package/dist/src/errors/dbErrors.d.ts +0 -12
  432. package/dist/src/errors/dbErrors.js +0 -28
  433. package/dist/src/index.d.ts +0 -11
  434. package/dist/src/index.js +0 -31
  435. package/dist/src/indexes/tableIndex.d.ts +0 -11
  436. package/dist/src/indexes/tableIndex.js +0 -17
  437. package/dist/src/logger/abstractLogger.d.ts +0 -4
  438. package/dist/src/logger/abstractLogger.js +0 -5
  439. package/dist/src/logger/consoleLogger.d.ts +0 -5
  440. package/dist/src/logger/consoleLogger.js +0 -15
  441. package/dist/src/mappers/index.d.ts +0 -0
  442. package/dist/src/mappers/index.js +0 -1
  443. package/dist/src/mappers/responseMapper.d.ts +0 -10
  444. package/dist/src/mappers/responseMapper.js +0 -35
  445. package/dist/src/migrator/index.d.ts +0 -0
  446. package/dist/src/migrator/index.js +0 -1
  447. package/dist/src/migrator/migrator.d.ts +0 -11
  448. package/dist/src/migrator/migrator.js +0 -105
  449. package/dist/src/serializer/serializer.d.ts +0 -53
  450. package/dist/src/serializer/serializer.js +0 -260
  451. package/dist/src/tables/abstractTable.d.ts +0 -68
  452. package/dist/src/tables/abstractTable.js +0 -151
  453. package/dist/src/tables/index.d.ts +0 -3
  454. package/dist/src/tables/index.js +0 -11
  455. package/dist/src/tables/inferTypes.d.ts +0 -39
  456. package/dist/src/tables/inferTypes.js +0 -2
  457. package/dist/src/tables/migrationsTable.d.ts +0 -7
  458. package/dist/src/tables/migrationsTable.js +0 -18
  459. package/dist/src/test.d.ts +0 -1
  460. package/dist/src/test.js +0 -65
  461. package/dist/src/types/type.d.ts +0 -10
  462. package/dist/src/types/type.js +0 -14
  463. package/dist/src/utils/ecranate.d.ts +0 -2
  464. package/dist/src/utils/ecranate.js +0 -8
  465. package/dist/tables/abstractTable.d.ts +0 -68
  466. package/dist/tables/abstractTable.js +0 -151
  467. package/dist/tables/index.d.ts +0 -3
  468. package/dist/tables/index.js +0 -11
  469. package/dist/tables/inferTypes.d.ts +0 -39
  470. package/dist/tables/inferTypes.js +0 -2
  471. package/dist/tables/migrationsTable.d.ts +0 -7
  472. package/dist/tables/migrationsTable.js +0 -18
  473. package/dist/test.d.ts +0 -1
  474. package/dist/test.js +0 -65
  475. package/dist/tsconfig.tsbuildinfo +0 -5054
  476. package/dist/types/type.d.ts +0 -10
  477. package/dist/types/type.js +0 -14
  478. package/dist/utils/ecranate.d.ts +0 -2
  479. package/dist/utils/ecranate.js +0 -8
@@ -1,258 +0,0 @@
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;
@@ -1,11 +0,0 @@
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
- }
@@ -1,35 +0,0 @@
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;
@@ -1,16 +0,0 @@
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
- }
@@ -1,42 +0,0 @@
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;
@@ -1,22 +0,0 @@
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
- }
@@ -1,106 +0,0 @@
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;
@@ -1,39 +0,0 @@
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
- }