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,53 @@
1
+ import { QueryResult } from 'pg';
2
+ import { AbstractColumn } from '../../../columns/column';
3
+ import ColumnType from '../../../columns/types/columnType';
4
+ import DB from '../../../db/db';
5
+ import { ISession } from '../../../db/session';
6
+ import AbstractTable from '../../../tables/abstractTable';
7
+ import { CheckFourTypes, PartialFor } from '../../../tables/inferTypes';
8
+ import Order from '../../highLvlBuilders/order';
9
+ import Expr from '../../requestBuilders/where/where';
10
+ import Join from '../join';
11
+ import SelectResponseThreeJoins from '../responses/selectResponseThreeJoins';
12
+ import AbstractJoined from './abstractJoinBuilder';
13
+ import SelectTRBWithFourJoins from './selectWithFourJoins';
14
+ export default class SelectTRBWithThreeJoins<TTable extends AbstractTable<TTable>, TTable1 extends AbstractTable<TTable1>, TTable2 extends AbstractTable<TTable2>, TTable3 extends AbstractTable<TTable3>, TPartial extends PartialFor<TTable> = {}, TPartial1 extends PartialFor<TTable1> = {}, TPartial2 extends PartialFor<TTable2> = {}, TPartial3 extends PartialFor<TTable3> = {}> extends AbstractJoined<TTable, SelectResponseThreeJoins<TTable, TTable1, TTable2, TTable3, TPartial, TPartial1, TPartial2, TPartial3>, TPartial> {
15
+ private _join1;
16
+ private _join2;
17
+ private _join3;
18
+ private _joinedPartial?;
19
+ private _joinedPartial1?;
20
+ private _joinedPartial2?;
21
+ constructor(table: TTable, session: ISession, filter: Expr, join1: Join<TTable1>, join2: Join<TTable2>, join3: Join<TTable3>, props: {
22
+ limit?: number;
23
+ offset?: number;
24
+ }, orderBy?: AbstractColumn<ColumnType, boolean, boolean>, order?: Order, distinct?: AbstractColumn<ColumnType, boolean, boolean>, tablePartial?: TPartial, joinedPartial?: TPartial1, joinedPartial1?: TPartial2, joinedPartial2?: TPartial3);
25
+ innerJoin<InputTable extends AbstractTable<InputTable>, TColumn extends ColumnType, TToColumn extends ColumnType, IToTable extends AbstractTable<IToTable>, IToPartial extends PartialFor<IToTable> = {}>(fromTable: {
26
+ new (db: DB): InputTable;
27
+ }, table: {
28
+ new (db: DB): IToTable;
29
+ }, from: (table: CheckFourTypes<InputTable, TTable, TTable1, TTable2, TTable3>) => AbstractColumn<TColumn, boolean, boolean, CheckFourTypes<InputTable, TTable, TTable1, TTable2, TTable3>>, to: (table: IToTable) => AbstractColumn<TToColumn, boolean, boolean, IToTable>, partial?: IToPartial): SelectTRBWithFourJoins<TTable, TTable1, TTable2, TTable3, IToTable, TPartial, TPartial1, TPartial2, TPartial3, IToPartial>;
30
+ leftJoin<InputTable extends AbstractTable<InputTable>, TColumn extends ColumnType, TToColumn extends ColumnType, IToTable extends AbstractTable<IToTable>, IToPartial extends PartialFor<IToTable> = {}>(fromTable: {
31
+ new (db: DB): InputTable;
32
+ }, table: {
33
+ new (db: DB): IToTable;
34
+ }, from: (table: CheckFourTypes<InputTable, TTable, TTable1, TTable2, TTable3>) => AbstractColumn<TColumn, boolean, boolean, CheckFourTypes<InputTable, TTable, TTable1, TTable2, TTable3>>, to: (table: IToTable) => AbstractColumn<TToColumn, boolean, boolean, IToTable>, partial?: IToPartial): SelectTRBWithFourJoins<TTable, TTable1, TTable2, TTable3, IToTable, TPartial, TPartial1, TPartial2, TPartial3, IToPartial>;
35
+ rightJoin<InputTable extends AbstractTable<InputTable>, TColumn extends ColumnType, TToColumn extends ColumnType, IToTable extends AbstractTable<IToTable>, IToPartial extends PartialFor<IToTable> = {}>(fromTable: {
36
+ new (db: DB): InputTable;
37
+ }, table: {
38
+ new (db: DB): IToTable;
39
+ }, from: (table: CheckFourTypes<InputTable, TTable, TTable1, TTable2, TTable3>) => AbstractColumn<TColumn, boolean, boolean, CheckFourTypes<InputTable, TTable, TTable1, TTable2, TTable3>>, to: (table: IToTable) => AbstractColumn<TToColumn, boolean, boolean, IToTable>, partial?: IToPartial): SelectTRBWithFourJoins<TTable, TTable1, TTable2, TTable3, IToTable, TPartial, TPartial1, TPartial2, TPartial3, IToPartial>;
40
+ fullJoin<InputTable extends AbstractTable<InputTable>, TColumn extends ColumnType, TToColumn extends ColumnType, IToTable extends AbstractTable<IToTable>, IToPartial extends PartialFor<IToTable> = {}>(fromTable: {
41
+ new (db: DB): InputTable;
42
+ }, table: {
43
+ new (db: DB): IToTable;
44
+ }, from: (table: CheckFourTypes<InputTable, TTable, TTable1, TTable2, TTable3>) => AbstractColumn<TColumn, boolean, boolean, CheckFourTypes<InputTable, TTable, TTable1, TTable2, TTable3>>, to: (table: IToTable) => AbstractColumn<TToColumn, boolean, boolean, IToTable>, partial?: IToPartial): SelectTRBWithFourJoins<TTable, TTable1, TTable2, TTable3, IToTable, TPartial, TPartial1, TPartial2, TPartial3, IToPartial>;
45
+ protected mapResponse(result: QueryResult<any>): SelectResponseThreeJoins<TTable, TTable1, TTable2, TTable3, TPartial, TPartial1, TPartial2, TPartial3>;
46
+ protected joins(): Array<{
47
+ join: Join<any>;
48
+ partial?: {
49
+ [name: string]: AbstractColumn<ColumnType<any>, boolean, boolean, any>;
50
+ };
51
+ id?: number;
52
+ }>;
53
+ }
@@ -0,0 +1,73 @@
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 join_1 = require("../join");
7
+ const joinWith_1 = __importDefault(require("../joinWith"));
8
+ const selectResponseThreeJoins_1 = __importDefault(require("../responses/selectResponseThreeJoins"));
9
+ const abstractJoinBuilder_1 = __importDefault(require("./abstractJoinBuilder"));
10
+ const selectWithFourJoins_1 = __importDefault(require("./selectWithFourJoins"));
11
+ class SelectTRBWithThreeJoins extends abstractJoinBuilder_1.default {
12
+ constructor(table, session, filter, join1, join2, join3, props, orderBy, order, distinct, tablePartial, joinedPartial, joinedPartial1, joinedPartial2) {
13
+ super(table, filter, session, props, orderBy, order, distinct, tablePartial);
14
+ this._join1 = join1;
15
+ this._join2 = join2;
16
+ this._join3 = join3;
17
+ this._joinedPartial = joinedPartial;
18
+ this._joinedPartial1 = joinedPartial1;
19
+ this._joinedPartial2 = joinedPartial2;
20
+ }
21
+ innerJoin(fromTable, table, from, to, partial) {
22
+ const toTable = this._table.db.create(table);
23
+ const tableFrom = this._table.db.create(fromTable);
24
+ const fromColumn = from(tableFrom);
25
+ const toColumn = to(toTable);
26
+ const join = new joinWith_1.default(toTable.tableName(), toTable.mapServiceToDb())
27
+ .columns(fromColumn, toColumn).joinStrategy(join_1.JoinStrategy.INNER_JOIN);
28
+ return new selectWithFourJoins_1.default(this._table, this._session, this._filter, this._join1, this._join2, this._join3, join, this._props, this._orderBy, this._order, this._distinct, this._partial, this._joinedPartial, this._joinedPartial1, this._joinedPartial2, partial);
29
+ }
30
+ leftJoin(fromTable, table, from, to, partial) {
31
+ const toTable = this._table.db.create(table);
32
+ const tableFrom = this._table.db.create(fromTable);
33
+ const fromColumn = from(tableFrom);
34
+ const toColumn = to(toTable);
35
+ const join = new joinWith_1.default(toTable.tableName(), toTable.mapServiceToDb())
36
+ .columns(fromColumn, toColumn).joinStrategy(join_1.JoinStrategy.LEFT_JOIN);
37
+ return new selectWithFourJoins_1.default(this._table, this._session, this._filter, this._join1, this._join2, this._join3, join, this._props, this._orderBy, this._order, this._distinct, this._partial, this._joinedPartial, this._joinedPartial1, this._joinedPartial2, partial);
38
+ }
39
+ rightJoin(fromTable, table, from, to, partial) {
40
+ const toTable = this._table.db.create(table);
41
+ const tableFrom = this._table.db.create(fromTable);
42
+ const fromColumn = from(tableFrom);
43
+ const toColumn = to(toTable);
44
+ const join = new joinWith_1.default(toTable.tableName(), toTable.mapServiceToDb())
45
+ .columns(fromColumn, toColumn).joinStrategy(join_1.JoinStrategy.RIGHT_JOIN);
46
+ return new selectWithFourJoins_1.default(this._table, this._session, this._filter, this._join1, this._join2, this._join3, join, this._props, this._orderBy, this._order, this._distinct, this._partial, this._joinedPartial, this._joinedPartial1, this._joinedPartial2, partial);
47
+ }
48
+ fullJoin(fromTable, table, from, to, partial) {
49
+ const toTable = this._table.db.create(table);
50
+ const tableFrom = this._table.db.create(fromTable);
51
+ const fromColumn = from(tableFrom);
52
+ const toColumn = to(toTable);
53
+ const join = new joinWith_1.default(toTable.tableName(), toTable.mapServiceToDb())
54
+ .columns(fromColumn, toColumn).joinStrategy(join_1.JoinStrategy.FULL_JOIN);
55
+ return new selectWithFourJoins_1.default(this._table, this._session, this._filter, this._join1, this._join2, this._join3, join, this._props, this._orderBy, this._order, this._distinct, this._partial, this._joinedPartial, this._joinedPartial1, this._joinedPartial2, partial);
56
+ }
57
+ mapResponse(result) {
58
+ const parent = this._join1.mappedServiceToDb;
59
+ const parentTwo = this._join2.mappedServiceToDb;
60
+ const parentThree = this._join3.mappedServiceToDb;
61
+ const response = this.fullOrPartial(this._table.mapServiceToDb(), result, this._partial);
62
+ const objects = this.fullOrPartial(parent, result, this._joinedPartial, 1);
63
+ const objectsTwo = this.fullOrPartial(parentTwo, result, this._joinedPartial1, 2);
64
+ const objectsThree = this.fullOrPartial(parentThree, result, this._joinedPartial2, 3);
65
+ return new selectResponseThreeJoins_1.default(response, objects, objectsTwo, objectsThree);
66
+ }
67
+ joins() {
68
+ return [{ join: this._join1, partial: this._joinedPartial, id: 1 },
69
+ { join: this._join2, partial: this._joinedPartial1, id: 2 },
70
+ { join: this._join3, partial: this._joinedPartial2, id: 3 }];
71
+ }
72
+ }
73
+ exports.default = SelectTRBWithThreeJoins;
@@ -0,0 +1,51 @@
1
+ import { QueryResult } from 'pg';
2
+ import { AbstractColumn } from '../../../columns/column';
3
+ import ColumnType from '../../../columns/types/columnType';
4
+ import DB from '../../../db/db';
5
+ import { ISession } from '../../../db/session';
6
+ import AbstractTable from '../../../tables/abstractTable';
7
+ import { CheckThreeTypes, PartialFor } from '../../../tables/inferTypes';
8
+ import Order from '../../highLvlBuilders/order';
9
+ import Expr from '../../requestBuilders/where/where';
10
+ import Join from '../join';
11
+ import SelectResponseTwoJoins from '../responses/selectResponseTwoJoins';
12
+ import AbstractJoined from './abstractJoinBuilder';
13
+ import SelectTRBWithThreeJoins from './selectWithThreeJoins';
14
+ export default class SelectTRBWithTwoJoins<TTable extends AbstractTable<TTable>, TTable1 extends AbstractTable<TTable1>, TTable2 extends AbstractTable<TTable2>, TPartial extends PartialFor<TTable> = {}, TPartial1 extends PartialFor<TTable1> = {}, TPartial2 extends PartialFor<TTable2> = {}> extends AbstractJoined<TTable, SelectResponseTwoJoins<TTable, TTable1, TTable2, TPartial, TPartial1, TPartial2>, TPartial> {
15
+ private _join1;
16
+ private _join2;
17
+ private _joinedPartial?;
18
+ private _joinedPartial1?;
19
+ constructor(table: TTable, session: ISession, filter: Expr, join1: Join<TTable1>, join2: Join<TTable2>, props: {
20
+ limit?: number;
21
+ offset?: number;
22
+ }, orderBy?: AbstractColumn<ColumnType, boolean, boolean>, order?: Order, distinct?: AbstractColumn<ColumnType, boolean, boolean>, tablePartial?: TPartial, joinedPartial?: TPartial1, joinedPartial1?: TPartial2);
23
+ innerJoin<InputTable extends AbstractTable<InputTable>, TColumn extends ColumnType, TToColumn extends ColumnType, IToTable extends AbstractTable<IToTable>, IToPartial extends PartialFor<IToTable> = {}>(fromTable: {
24
+ new (db: DB): InputTable;
25
+ }, table: {
26
+ new (db: DB): IToTable;
27
+ }, from: (table: CheckThreeTypes<InputTable, TTable, TTable1, TTable2>) => AbstractColumn<TColumn, boolean, boolean, CheckThreeTypes<InputTable, TTable, TTable1, TTable2>>, to: (table: IToTable) => AbstractColumn<TToColumn, boolean, boolean, IToTable>, partial?: IToPartial): SelectTRBWithThreeJoins<TTable, TTable1, TTable2, IToTable, TPartial, TPartial1, TPartial2, IToPartial>;
28
+ leftJoin<InputTable extends AbstractTable<InputTable>, TColumn extends ColumnType, TToColumn extends ColumnType, IToTable extends AbstractTable<IToTable>, IToPartial extends PartialFor<IToTable> = {}>(fromTable: {
29
+ new (db: DB): InputTable;
30
+ }, table: {
31
+ new (db: DB): IToTable;
32
+ }, from: (table: CheckThreeTypes<InputTable, TTable, TTable1, TTable2>) => AbstractColumn<TColumn, boolean, boolean, CheckThreeTypes<InputTable, TTable, TTable1, TTable2>>, to: (table: IToTable) => AbstractColumn<TToColumn, boolean, boolean, IToTable>, partial?: IToPartial): SelectTRBWithThreeJoins<TTable, TTable1, TTable2, IToTable, TPartial, TPartial1, TPartial2, IToPartial>;
33
+ rightJoin<InputTable extends AbstractTable<InputTable>, TColumn extends ColumnType, TToColumn extends ColumnType, IToTable extends AbstractTable<IToTable>, IToPartial extends PartialFor<IToTable> = {}>(fromTable: {
34
+ new (db: DB): InputTable;
35
+ }, table: {
36
+ new (db: DB): IToTable;
37
+ }, from: (table: CheckThreeTypes<InputTable, TTable, TTable1, TTable2>) => AbstractColumn<TColumn, boolean, boolean, CheckThreeTypes<InputTable, TTable, TTable1, TTable2>>, to: (table: IToTable) => AbstractColumn<TToColumn, boolean, boolean, IToTable>, partial?: IToPartial): SelectTRBWithThreeJoins<TTable, TTable1, TTable2, IToTable, TPartial, TPartial1, TPartial2, IToPartial>;
38
+ fullJoin<InputTable extends AbstractTable<InputTable>, TColumn extends ColumnType, TToColumn extends ColumnType, IToTable extends AbstractTable<IToTable>, IToPartial extends PartialFor<IToTable> = {}>(fromTable: {
39
+ new (db: DB): InputTable;
40
+ }, table: {
41
+ new (db: DB): IToTable;
42
+ }, from: (table: CheckThreeTypes<InputTable, TTable, TTable1, TTable2>) => AbstractColumn<TColumn, boolean, boolean, CheckThreeTypes<InputTable, TTable, TTable1, TTable2>>, to: (table: IToTable) => AbstractColumn<TToColumn, boolean, boolean, IToTable>, partial?: IToPartial): SelectTRBWithThreeJoins<TTable, TTable1, TTable2, IToTable, TPartial, TPartial1, TPartial2, IToPartial>;
43
+ protected mapResponse(result: QueryResult<any>): SelectResponseTwoJoins<TTable, TTable1, TTable2, TPartial, TPartial1, TPartial2>;
44
+ protected joins(): Array<{
45
+ join: Join<any>;
46
+ partial?: {
47
+ [name: string]: AbstractColumn<ColumnType<any>, boolean, boolean, any>;
48
+ };
49
+ id?: number;
50
+ }>;
51
+ }
@@ -0,0 +1,68 @@
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 join_1 = require("../join");
7
+ const joinWith_1 = __importDefault(require("../joinWith"));
8
+ const selectResponseTwoJoins_1 = __importDefault(require("../responses/selectResponseTwoJoins"));
9
+ const abstractJoinBuilder_1 = __importDefault(require("./abstractJoinBuilder"));
10
+ const selectWithThreeJoins_1 = __importDefault(require("./selectWithThreeJoins"));
11
+ class SelectTRBWithTwoJoins extends abstractJoinBuilder_1.default {
12
+ constructor(table, session, filter, join1, join2, props, orderBy, order, distinct, tablePartial, joinedPartial, joinedPartial1) {
13
+ super(table, filter, session, props, orderBy, order, distinct, tablePartial);
14
+ this._join1 = join1;
15
+ this._join2 = join2;
16
+ this._joinedPartial = joinedPartial;
17
+ this._joinedPartial1 = joinedPartial1;
18
+ }
19
+ innerJoin(fromTable, table, from, to, partial) {
20
+ const toTable = this._table.db.create(table);
21
+ const tableFrom = this._table.db.create(fromTable);
22
+ const fromColumn = from(tableFrom);
23
+ const toColumn = to(toTable);
24
+ const join = new joinWith_1.default(toTable.tableName(), toTable.mapServiceToDb())
25
+ .columns(fromColumn, toColumn).joinStrategy(join_1.JoinStrategy.INNER_JOIN);
26
+ return new selectWithThreeJoins_1.default(this._table, this._session, this._filter, this._join1, this._join2, join, this._props, this._orderBy, this._order, this._distinct, this._partial, this._joinedPartial, this._joinedPartial1, partial);
27
+ }
28
+ leftJoin(fromTable, table, from, to, partial) {
29
+ const toTable = this._table.db.create(table);
30
+ const tableFrom = this._table.db.create(fromTable);
31
+ const fromColumn = from(tableFrom);
32
+ const toColumn = to(toTable);
33
+ const join = new joinWith_1.default(toTable.tableName(), toTable.mapServiceToDb())
34
+ .columns(fromColumn, toColumn).joinStrategy(join_1.JoinStrategy.LEFT_JOIN);
35
+ return new selectWithThreeJoins_1.default(this._table, this._session, this._filter, this._join1, this._join2, join, this._props, this._orderBy, this._order, this._distinct, this._partial, this._joinedPartial, this._joinedPartial1, partial);
36
+ }
37
+ rightJoin(fromTable, table, from, to, partial) {
38
+ const toTable = this._table.db.create(table);
39
+ const tableFrom = this._table.db.create(fromTable);
40
+ const fromColumn = from(tableFrom);
41
+ const toColumn = to(toTable);
42
+ const join = new joinWith_1.default(toTable.tableName(), toTable.mapServiceToDb())
43
+ .columns(fromColumn, toColumn).joinStrategy(join_1.JoinStrategy.RIGHT_JOIN);
44
+ return new selectWithThreeJoins_1.default(this._table, this._session, this._filter, this._join1, this._join2, join, this._props, this._orderBy, this._order, this._distinct, this._partial, this._joinedPartial, this._joinedPartial1, partial);
45
+ }
46
+ fullJoin(fromTable, table, from, to, partial) {
47
+ const toTable = this._table.db.create(table);
48
+ const tableFrom = this._table.db.create(fromTable);
49
+ const fromColumn = from(tableFrom);
50
+ const toColumn = to(toTable);
51
+ const join = new joinWith_1.default(toTable.tableName(), toTable.mapServiceToDb())
52
+ .columns(fromColumn, toColumn).joinStrategy(join_1.JoinStrategy.FULL_JOIN);
53
+ return new selectWithThreeJoins_1.default(this._table, this._session, this._filter, this._join1, this._join2, join, this._props, this._orderBy, this._order, this._distinct, this._partial, this._joinedPartial, this._joinedPartial1, partial);
54
+ }
55
+ mapResponse(result) {
56
+ const parent = this._join1.mappedServiceToDb;
57
+ const parentTwo = this._join2.mappedServiceToDb;
58
+ const response = this.fullOrPartial(this._table.mapServiceToDb(), result, this._partial);
59
+ const objects = this.fullOrPartial(parent, result, this._joinedPartial, 1);
60
+ const objectsTwo = this.fullOrPartial(parentTwo, result, this._joinedPartial1, 2);
61
+ return new selectResponseTwoJoins_1.default(response, objects, objectsTwo);
62
+ }
63
+ joins() {
64
+ return [{ join: this._join1, partial: this._joinedPartial, id: 1 },
65
+ { join: this._join2, partial: this._joinedPartial1, id: 2 }];
66
+ }
67
+ }
68
+ exports.default = SelectTRBWithTwoJoins;
@@ -0,0 +1,23 @@
1
+ import { AbstractColumn } from '../../columns/column';
2
+ import ColumnType from '../../columns/types/columnType';
3
+ import { ExtractModel } from '../../tables/inferTypes';
4
+ export default class Join<TTable> {
5
+ fromColumn: AbstractColumn<ColumnType, boolean, boolean>;
6
+ toColumn: AbstractColumn<ColumnType, boolean, boolean>;
7
+ joinTableName: string;
8
+ mappedServiceToDb: {
9
+ [name in keyof ExtractModel<TTable>]: AbstractColumn<ColumnType>;
10
+ };
11
+ type: JoinStrategy;
12
+ constructor(joinTableName: string, fromColumn: AbstractColumn<ColumnType, boolean, boolean>, toColumn: AbstractColumn<ColumnType, boolean, boolean>, mappedServiceToDb: {
13
+ [name in keyof ExtractModel<TTable>]: AbstractColumn<ColumnType>;
14
+ });
15
+ joinStrategy: (type: JoinStrategy) => Join<TTable>;
16
+ columns: (fromColumn: AbstractColumn<ColumnType>, toColumn: AbstractColumn<ColumnType>) => Join<TTable>;
17
+ }
18
+ export declare enum JoinStrategy {
19
+ INNER_JOIN = "INNER JOIN",
20
+ LEFT_JOIN = "LEFT JOIN",
21
+ RIGHT_JOIN = "RIGHT JOIN",
22
+ FULL_JOIN = "FULL JOIN"
23
+ }
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.JoinStrategy = void 0;
4
+ class Join {
5
+ constructor(joinTableName, fromColumn, toColumn, mappedServiceToDb) {
6
+ this.joinStrategy = (type) => {
7
+ this.type = type;
8
+ return this;
9
+ };
10
+ this.columns = (fromColumn, toColumn) => {
11
+ this.toColumn = toColumn;
12
+ this.fromColumn = fromColumn;
13
+ return this;
14
+ };
15
+ this.joinTableName = joinTableName;
16
+ this.toColumn = toColumn;
17
+ this.fromColumn = fromColumn;
18
+ this.mappedServiceToDb = mappedServiceToDb;
19
+ }
20
+ }
21
+ exports.default = Join;
22
+ var JoinStrategy;
23
+ (function (JoinStrategy) {
24
+ JoinStrategy["INNER_JOIN"] = "INNER JOIN";
25
+ JoinStrategy["LEFT_JOIN"] = "LEFT JOIN";
26
+ JoinStrategy["RIGHT_JOIN"] = "RIGHT JOIN";
27
+ JoinStrategy["FULL_JOIN"] = "FULL JOIN";
28
+ })(JoinStrategy = exports.JoinStrategy || (exports.JoinStrategy = {}));
@@ -0,0 +1,14 @@
1
+ import { AbstractColumn } from '../../columns/column';
2
+ import ColumnType from '../../columns/types/columnType';
3
+ import { ExtractModel } from '../../tables/inferTypes';
4
+ import Join from './join';
5
+ export default class JoinWith<TColumn extends ColumnType, TTable> {
6
+ joinTableName: string;
7
+ mappedServiceToDb: {
8
+ [name in keyof ExtractModel<TTable>]: AbstractColumn<TColumn>;
9
+ };
10
+ constructor(joinTableName: string, mappedServiceToDb: {
11
+ [name in keyof ExtractModel<TTable>]: AbstractColumn<TColumn>;
12
+ });
13
+ columns: (fromColumn: AbstractColumn<TColumn, boolean, boolean>, toColumn: AbstractColumn<TColumn, boolean, boolean>) => Join<TTable>;
14
+ }
@@ -0,0 +1,14 @@
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 join_1 = __importDefault(require("./join"));
7
+ class JoinWith {
8
+ constructor(joinTableName, mappedServiceToDb) {
9
+ this.columns = (fromColumn, toColumn) => new join_1.default(this.joinTableName, fromColumn, toColumn, this.mappedServiceToDb);
10
+ this.joinTableName = joinTableName;
11
+ this.mappedServiceToDb = mappedServiceToDb;
12
+ }
13
+ }
14
+ exports.default = JoinWith;
@@ -0,0 +1,20 @@
1
+ import AbstractTable from '../../../tables/abstractTable';
2
+ import { FullOrPartial, PartialFor } from '../../../tables/inferTypes';
3
+ export default class SelectResponseFiveJoins<T1 extends AbstractTable<T1>, T2 extends AbstractTable<T2>, T3 extends AbstractTable<T3>, T4 extends AbstractTable<T4>, T5 extends AbstractTable<T5>, T6 extends AbstractTable<T6>, TPartial1 extends PartialFor<T1>, TPartial2 extends PartialFor<T2>, TPartial3 extends PartialFor<T3>, TPartial4 extends PartialFor<T4>, TPartial5 extends PartialFor<T5>, TPartial6 extends PartialFor<T6>> {
4
+ _t1: Array<FullOrPartial<T1, TPartial1>>;
5
+ _t2: Array<FullOrPartial<T2, TPartial2>>;
6
+ _t3: Array<FullOrPartial<T3, TPartial3>>;
7
+ _t4: Array<FullOrPartial<T4, TPartial4>>;
8
+ _t5: Array<FullOrPartial<T5, TPartial5>>;
9
+ _t6: Array<FullOrPartial<T6, TPartial6>>;
10
+ constructor(t1: Array<FullOrPartial<T1, TPartial1>>, t2: Array<FullOrPartial<T2, TPartial2>>, t3: Array<FullOrPartial<T3, TPartial3>>, t4: Array<FullOrPartial<T4, TPartial4>>, t5: Array<FullOrPartial<T5, TPartial5>>, t6: Array<FullOrPartial<T6, TPartial6>>);
11
+ map: <M>(imac: (t1: FullOrPartial<T1, TPartial1>, t2: FullOrPartial<T2, TPartial2>, t3: FullOrPartial<T3, TPartial3>, t4: FullOrPartial<T4, TPartial4>, t5: FullOrPartial<T5, TPartial5>, t6: FullOrPartial<T6, TPartial6>) => M) => M[];
12
+ foreach: (imac: (t1: FullOrPartial<T1, TPartial1>, t2: FullOrPartial<T2, TPartial2>, t3: FullOrPartial<T3, TPartial3>, t4: FullOrPartial<T4, TPartial4>, t5: FullOrPartial<T5, TPartial5>, t6: FullOrPartial<T6, TPartial6>) => void) => void;
13
+ group: <TOne, TMany>({ one, many, }: {
14
+ one: (t1: FullOrPartial<T1, TPartial1>, t2: FullOrPartial<T2, TPartial2>, t3: FullOrPartial<T3, TPartial3>, t4: FullOrPartial<T4, TPartial4>, t5: FullOrPartial<T5, TPartial5>, t6: FullOrPartial<T6, TPartial6>) => TOne;
15
+ many: (t1: FullOrPartial<T1, TPartial1>, t2: FullOrPartial<T2, TPartial2>, t3: FullOrPartial<T3, TPartial3>, t4: FullOrPartial<T4, TPartial4>, t5: FullOrPartial<T5, TPartial5>, t6: FullOrPartial<T6, TPartial6>) => TMany;
16
+ }) => {
17
+ one: TOne;
18
+ many: TMany[];
19
+ };
20
+ }
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ class SelectResponseFiveJoins {
4
+ constructor(t1, t2, t3, t4, t5, t6) {
5
+ this.map = (imac) => {
6
+ const objects = new Array();
7
+ for (let i = 0; i < this._t1.length; i += 1) {
8
+ objects.push(imac(this._t1[i], this._t2[i], this._t3[i], this._t4[i], this._t5[i], this._t6[i]));
9
+ }
10
+ return objects;
11
+ };
12
+ this.foreach = (imac) => {
13
+ for (let i = 0; i < this._t1.length; i += 1) {
14
+ imac(this._t1[i], this._t2[i], this._t3[i], this._t4[i], this._t5[i], this._t6[i]);
15
+ }
16
+ };
17
+ this.group = ({ one, many, }) => {
18
+ const objects = new Array();
19
+ for (let i = 0; i < this._t1.length; i += 1) {
20
+ objects.push(many(this._t1[i], this._t2[i], this._t3[i], this._t4[i], this._t5[i], this._t6[i]));
21
+ }
22
+ return {
23
+ one: one(this._t1[0], this._t2[0], this._t3[0], this._t4[0], this._t5[0], this._t6[0]),
24
+ many: objects,
25
+ };
26
+ };
27
+ this._t1 = t1;
28
+ this._t2 = t2;
29
+ this._t3 = t3;
30
+ this._t4 = t4;
31
+ this._t5 = t5;
32
+ this._t6 = t6;
33
+ }
34
+ }
35
+ exports.default = SelectResponseFiveJoins;
@@ -0,0 +1,19 @@
1
+ import AbstractTable from '../../../tables/abstractTable';
2
+ import { FullOrPartial, PartialFor } from '../../../tables/inferTypes';
3
+ export default class SelectResponseFourJoins<T1 extends AbstractTable<T1>, T2 extends AbstractTable<T2>, T3 extends AbstractTable<T3>, T4 extends AbstractTable<T4>, T5 extends AbstractTable<T5>, TPartial1 extends PartialFor<T1>, TPartial2 extends PartialFor<T2>, TPartial3 extends PartialFor<T3>, TPartial4 extends PartialFor<T4>, TPartial5 extends PartialFor<T5>> {
4
+ _t1: Array<FullOrPartial<T1, TPartial1>>;
5
+ _t2: Array<FullOrPartial<T2, TPartial2>>;
6
+ _t3: Array<FullOrPartial<T3, TPartial3>>;
7
+ _t4: Array<FullOrPartial<T4, TPartial4>>;
8
+ _t5: Array<FullOrPartial<T5, TPartial5>>;
9
+ constructor(t1: Array<FullOrPartial<T1, TPartial1>>, t2: Array<FullOrPartial<T2, TPartial2>>, t3: Array<FullOrPartial<T3, TPartial3>>, t4: Array<FullOrPartial<T4, TPartial4>>, t5: Array<FullOrPartial<T5, TPartial5>>);
10
+ map: <M>(imac: (t1: FullOrPartial<T1, TPartial1>, t2: FullOrPartial<T2, TPartial2>, t3: FullOrPartial<T3, TPartial3>, t4: FullOrPartial<T4, TPartial4>, t5: FullOrPartial<T5, TPartial5>) => M) => M[];
11
+ foreach: (imac: (t1: FullOrPartial<T1, TPartial1>, t2: FullOrPartial<T2, TPartial2>, t3: FullOrPartial<T3, TPartial3>, t4: FullOrPartial<T4, TPartial4>, t5: FullOrPartial<T5, TPartial5>) => void) => void;
12
+ group: <TOne, TMany>({ one, many, }: {
13
+ one: (t1: FullOrPartial<T1, TPartial1>, t2: FullOrPartial<T2, TPartial2>, t3: FullOrPartial<T3, TPartial3>, t4: FullOrPartial<T4, TPartial4>, t5: FullOrPartial<T5, TPartial5>) => TOne;
14
+ many: (t1: FullOrPartial<T1, TPartial1>, t2: FullOrPartial<T2, TPartial2>, t3: FullOrPartial<T3, TPartial3>, t4: FullOrPartial<T4, TPartial4>, t5: FullOrPartial<T5, TPartial5>) => TMany;
15
+ }) => {
16
+ one: TOne;
17
+ many: TMany[];
18
+ };
19
+ }
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ class SelectResponseFourJoins {
4
+ constructor(t1, t2, t3, t4, t5) {
5
+ this.map = (imac) => {
6
+ const objects = new Array();
7
+ for (let i = 0; i < this._t1.length; i += 1) {
8
+ objects.push(imac(this._t1[i], this._t2[i], this._t3[i], this._t4[i], this._t5[i]));
9
+ }
10
+ return objects;
11
+ };
12
+ this.foreach = (imac) => {
13
+ for (let i = 0; i < this._t1.length; i += 1) {
14
+ imac(this._t1[i], this._t2[i], this._t3[i], this._t4[i], this._t5[i]);
15
+ }
16
+ };
17
+ this.group = ({ one, many, }) => {
18
+ const objects = new Array();
19
+ for (let i = 0; i < this._t1.length; i += 1) {
20
+ objects.push(many(this._t1[i], this._t2[i], this._t3[i], this._t4[i], this._t5[i]));
21
+ }
22
+ return {
23
+ one: one(this._t1[0], this._t2[0], this._t3[0], this._t4[0], this._t5[0]),
24
+ many: objects,
25
+ };
26
+ };
27
+ this._t1 = t1;
28
+ this._t2 = t2;
29
+ this._t3 = t3;
30
+ this._t4 = t4;
31
+ this._t5 = t5;
32
+ }
33
+ }
34
+ exports.default = SelectResponseFourJoins;
@@ -0,0 +1,18 @@
1
+ import AbstractTable from '../../../tables/abstractTable';
2
+ import { FullOrPartial, PartialFor } from '../../../tables/inferTypes';
3
+ export default class SelectResponseThreeJoins<T1 extends AbstractTable<T1>, T2 extends AbstractTable<T2>, T3 extends AbstractTable<T3>, T4 extends AbstractTable<T4>, TPartial1 extends PartialFor<T1>, TPartial2 extends PartialFor<T2>, TPartial3 extends PartialFor<T3>, TPartial4 extends PartialFor<T4>> {
4
+ private _t1;
5
+ private _t2;
6
+ private _t3;
7
+ private _t4;
8
+ constructor(t1: Array<FullOrPartial<T1, TPartial1>>, t2: Array<FullOrPartial<T2, TPartial2>>, t3: Array<FullOrPartial<T3, TPartial3>>, t4: Array<FullOrPartial<T4, TPartial4>>);
9
+ map: <M>(imac: (t1: FullOrPartial<T1, TPartial1>, t2: FullOrPartial<T2, TPartial2>, t3: FullOrPartial<T3, TPartial3>, t4: FullOrPartial<T4, TPartial4>) => M) => M[];
10
+ foreach: (imac: (t1: FullOrPartial<T1, TPartial1>, t2: FullOrPartial<T2, TPartial2>, t3: FullOrPartial<T3, TPartial3>, t4: FullOrPartial<T4, TPartial4>) => void) => void;
11
+ group: <TOne, TMany>({ one, many, }: {
12
+ one: (t1: FullOrPartial<T1, TPartial1>, t2: FullOrPartial<T2, TPartial2>, t3: FullOrPartial<T3, TPartial3>, t4: FullOrPartial<T4, TPartial4>) => TOne;
13
+ many: (t1: FullOrPartial<T1, TPartial1>, t2: FullOrPartial<T2, TPartial2>, t3: FullOrPartial<T3, TPartial3>, t4: FullOrPartial<T4, TPartial4>) => TMany;
14
+ }) => {
15
+ one: TOne;
16
+ many: TMany[];
17
+ };
18
+ }
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ class SelectResponseThreeJoins {
4
+ constructor(t1, t2, t3, t4) {
5
+ this.map = (imac) => {
6
+ const objects = new Array();
7
+ for (let i = 0; i < this._t1.length; i += 1) {
8
+ objects.push(imac(this._t1[i], this._t2[i], this._t3[i], this._t4[i]));
9
+ }
10
+ return objects;
11
+ };
12
+ this.foreach = (imac) => {
13
+ for (let i = 0; i < this._t1.length; i += 1) {
14
+ imac(this._t1[i], this._t2[i], this._t3[i], this._t4[i]);
15
+ }
16
+ };
17
+ this.group = ({ one, many, }) => {
18
+ const objects = new Array();
19
+ for (let i = 0; i < this._t1.length; i += 1) {
20
+ objects.push(many(this._t1[i], this._t2[i], this._t3[i], this._t4[i]));
21
+ }
22
+ return {
23
+ one: one(this._t1[0], this._t2[0], this._t3[0], this._t4[0]),
24
+ many: objects,
25
+ };
26
+ };
27
+ this._t1 = t1;
28
+ this._t2 = t2;
29
+ this._t3 = t3;
30
+ this._t4 = t4;
31
+ }
32
+ }
33
+ exports.default = SelectResponseThreeJoins;
@@ -0,0 +1,17 @@
1
+ import AbstractTable from '../../../tables/abstractTable';
2
+ import { FullOrPartial, PartialFor } from '../../../tables/inferTypes';
3
+ export default class SelectResponseTwoJoins<T1 extends AbstractTable<T1>, T2 extends AbstractTable<T2>, T3 extends AbstractTable<T3>, TPartial1 extends PartialFor<T1>, TPartial2 extends PartialFor<T2>, TPartial3 extends PartialFor<T3>> {
4
+ private _t1;
5
+ private _t2;
6
+ private _t3;
7
+ constructor(t1: Array<FullOrPartial<T1, TPartial1>>, t2: Array<FullOrPartial<T2, TPartial2>>, t3: Array<FullOrPartial<T3, TPartial3>>);
8
+ map: <M>(imac: (t1: FullOrPartial<T1, TPartial1>, t2: FullOrPartial<T2, TPartial2>, t3: FullOrPartial<T3, TPartial3>) => M) => M[];
9
+ foreach: (imac: (t1: FullOrPartial<T1, TPartial1>, t2: FullOrPartial<T2, TPartial2>, t3: FullOrPartial<T3, TPartial3>) => void) => void;
10
+ group: <TOne, TMany>({ one, many, }: {
11
+ one: (t1: FullOrPartial<T1, TPartial1>, t2: FullOrPartial<T2, TPartial2>, t3: FullOrPartial<T3, TPartial3>) => TOne;
12
+ many: (t1: FullOrPartial<T1, TPartial1>, t2: FullOrPartial<T2, TPartial2>, t3: FullOrPartial<T3, TPartial3>) => TMany;
13
+ }) => {
14
+ one: TOne;
15
+ many: TMany[];
16
+ };
17
+ }
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ class SelectResponseTwoJoins {
4
+ constructor(t1, t2, t3) {
5
+ this.map = (imac) => {
6
+ const objects = new Array();
7
+ for (let i = 0; i < this._t1.length; i += 1) {
8
+ objects.push(imac(this._t1[i], this._t2[i], this._t3[i]));
9
+ }
10
+ return objects;
11
+ };
12
+ this.foreach = (imac) => {
13
+ for (let i = 0; i < this._t1.length; i += 1) {
14
+ imac(this._t1[i], this._t2[i], this._t3[i]);
15
+ }
16
+ };
17
+ this.group = ({ one, many, }) => {
18
+ const objects = new Array();
19
+ for (let i = 0; i < this._t1.length; i += 1) {
20
+ objects.push(many(this._t1[i], this._t2[i], this._t3[i]));
21
+ }
22
+ return {
23
+ one: one(this._t1[0], this._t2[0], this._t3[0]),
24
+ many: objects,
25
+ };
26
+ };
27
+ this._t1 = t1;
28
+ this._t2 = t2;
29
+ this._t3 = t3;
30
+ }
31
+ }
32
+ exports.default = SelectResponseTwoJoins;
@@ -0,0 +1,16 @@
1
+ import AbstractTable from '../../../tables/abstractTable';
2
+ import { FullOrPartial, PartialFor } from '../../../tables/inferTypes';
3
+ export default class SelectResponseJoin<TTable1 extends AbstractTable<TTable1>, TTable2 extends AbstractTable<TTable2>, TPartial1 extends PartialFor<TTable1>, TPartial2 extends PartialFor<TTable2>> {
4
+ private _t1;
5
+ private _t2;
6
+ constructor(t1: Array<FullOrPartial<TTable1, TPartial1>>, t2: Array<FullOrPartial<TTable2, TPartial2>>);
7
+ map: <M>(imac: (t1: FullOrPartial<TTable1, TPartial1>, t2: FullOrPartial<TTable2, TPartial2>) => M) => M[];
8
+ foreach: (imac: (t1: FullOrPartial<TTable1, TPartial1>, t2: FullOrPartial<TTable2, TPartial2>) => void) => void;
9
+ group: <TOne, TMany>({ one, many, }: {
10
+ one: (t1: FullOrPartial<TTable1, TPartial1>, t2: FullOrPartial<TTable2, TPartial2>) => TOne;
11
+ many: (t1: FullOrPartial<TTable1, TPartial1>, t2: FullOrPartial<TTable2, TPartial2>) => TMany;
12
+ }) => {
13
+ one: TOne;
14
+ many: TMany[];
15
+ };
16
+ }
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ class SelectResponseJoin {
4
+ constructor(t1, t2) {
5
+ this.map = (imac) => {
6
+ const objects = new Array();
7
+ for (let i = 0; i < this._t1.length; i += 1) {
8
+ objects.push(imac(this._t1[i], this._t2[i]));
9
+ }
10
+ return objects;
11
+ };
12
+ this.foreach = (imac) => {
13
+ for (let i = 0; i < this._t1.length; i += 1) {
14
+ imac(this._t1[i], this._t2[i]);
15
+ }
16
+ };
17
+ this.group = ({ one, many, }) => {
18
+ const objects = new Array();
19
+ for (let i = 0; i < this._t1.length; i += 1) {
20
+ objects.push(many(this._t1[i], this._t2[i]));
21
+ }
22
+ return {
23
+ one: one(this._t1[0], this._t2[0]),
24
+ many: objects,
25
+ };
26
+ };
27
+ this._t1 = t1;
28
+ this._t2 = t2;
29
+ }
30
+ }
31
+ exports.default = SelectResponseJoin;
@@ -0,0 +1,5 @@
1
+ import ColumnType from '../../columns/types/columnType';
2
+ import AbstractTable from '../../tables/abstractTable';
3
+ import JoinWith from './joinWith';
4
+ declare const to: <TTable extends AbstractTable<TTable>>(table: AbstractTable<TTable>) => JoinWith<ColumnType<{}>, TTable>;
5
+ export default to;
@@ -0,0 +1,9 @@
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 joinWith_1 = __importDefault(require("./joinWith"));
7
+ const to = (table) => new joinWith_1.default(table.tableName(), table.mapServiceToDb());
8
+ // eslint-disable-next-line import/prefer-default-export
9
+ exports.default = to;
File without changes
@@ -0,0 +1 @@
1
+ "use strict";