taon-type-sql 18.0.9

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 (325) hide show
  1. package/assets/shared/shared_folder_info.txt +7 -0
  2. package/browser/README.md +24 -0
  3. package/browser/esm2022/lib/builder/column/basic-column.mjs +13 -0
  4. package/browser/esm2022/lib/builder/column/boolean-column.mjs +14 -0
  5. package/browser/esm2022/lib/builder/column/comparable-column.mjs +41 -0
  6. package/browser/esm2022/lib/builder/column/date-column.mjs +14 -0
  7. package/browser/esm2022/lib/builder/column/number-column.mjs +19 -0
  8. package/browser/esm2022/lib/builder/column/query-column.mjs +21 -0
  9. package/browser/esm2022/lib/builder/column/string-column.mjs +36 -0
  10. package/browser/esm2022/lib/builder/column/value-column.mjs +30 -0
  11. package/browser/esm2022/lib/builder/condition/query-column-condition.mjs +19 -0
  12. package/browser/esm2022/lib/builder/condition/query-condition-chain.mjs +28 -0
  13. package/browser/esm2022/lib/builder/condition/query-condition.mjs +6 -0
  14. package/browser/esm2022/lib/builder/condition/query-join-condition.mjs +19 -0
  15. package/browser/esm2022/lib/builder/helpers/generics-helper.mjs +5 -0
  16. package/browser/esm2022/lib/builder/helpers/internal-types.mjs +4 -0
  17. package/browser/esm2022/lib/builder/join/joined-tables-chain.mjs +14 -0
  18. package/browser/esm2022/lib/builder/join/joined-tables.mjs +22 -0
  19. package/browser/esm2022/lib/builder/other/query-ordering.mjs +17 -0
  20. package/browser/esm2022/lib/builder/query/select-query.mjs +48 -0
  21. package/browser/esm2022/lib/builder/query/table-condition-query.mjs +25 -0
  22. package/browser/esm2022/lib/builder/query/table-query.mjs +54 -0
  23. package/browser/esm2022/lib/builder/query-source.mjs +20 -0
  24. package/browser/esm2022/lib/builder/query-table.mjs +24 -0
  25. package/browser/esm2022/lib/client/mysql.mjs +10 -0
  26. package/browser/esm2022/lib/client/query-processor.mjs +45 -0
  27. package/browser/esm2022/lib/converter/param-converter.mjs +27 -0
  28. package/browser/esm2022/lib/converter/parameterized-converter.mjs +17 -0
  29. package/browser/esm2022/lib/converter/query-converter.mjs +282 -0
  30. package/browser/esm2022/lib/converter/result-converter.mjs +88 -0
  31. package/browser/esm2022/lib/converter/sql-converter.mjs +8 -0
  32. package/browser/esm2022/lib/converter/type-converter.mjs +39 -0
  33. package/browser/esm2022/lib/converter/types.mjs +4 -0
  34. package/browser/esm2022/lib/index.mjs +23 -0
  35. package/browser/esm2022/public-api.mjs +2 -0
  36. package/browser/esm2022/taon-type-sql.mjs +5 -0
  37. package/browser/fesm2022/taon-type-sql.mjs +877 -0
  38. package/browser/fesm2022/taon-type-sql.mjs.map +1 -0
  39. package/browser/index.d.ts +6 -0
  40. package/browser/lib/builder/column/basic-column.d.ts +9 -0
  41. package/browser/lib/builder/column/boolean-column.d.ts +10 -0
  42. package/browser/lib/builder/column/comparable-column.d.ts +19 -0
  43. package/browser/lib/builder/column/date-column.d.ts +10 -0
  44. package/browser/lib/builder/column/number-column.d.ts +11 -0
  45. package/browser/lib/builder/column/query-column.d.ts +19 -0
  46. package/browser/lib/builder/column/string-column.d.ts +18 -0
  47. package/browser/lib/builder/column/value-column.d.ts +16 -0
  48. package/browser/lib/builder/condition/query-column-condition.d.ts +14 -0
  49. package/browser/lib/builder/condition/query-condition-chain.d.ts +18 -0
  50. package/browser/lib/builder/condition/query-condition.d.ts +8 -0
  51. package/browser/lib/builder/condition/query-join-condition.d.ts +13 -0
  52. package/browser/lib/builder/helpers/generics-helper.d.ts +3 -0
  53. package/browser/lib/builder/helpers/internal-types.d.ts +16 -0
  54. package/browser/lib/builder/join/joined-tables-chain.d.ts +12 -0
  55. package/browser/lib/builder/join/joined-tables.d.ts +13 -0
  56. package/browser/lib/builder/other/query-ordering.d.ts +11 -0
  57. package/browser/lib/builder/query/select-query.d.ts +30 -0
  58. package/browser/lib/builder/query/table-condition-query.d.ts +17 -0
  59. package/browser/lib/builder/query/table-query.d.ts +24 -0
  60. package/browser/lib/builder/query-source.d.ts +15 -0
  61. package/browser/lib/builder/query-table.d.ts +16 -0
  62. package/browser/lib/client/mysql.d.ts +6 -0
  63. package/browser/lib/client/query-processor.d.ts +11 -0
  64. package/browser/lib/converter/param-converter.d.ts +3 -0
  65. package/browser/lib/converter/parameterized-converter.d.ts +6 -0
  66. package/browser/lib/converter/query-converter.d.ts +3 -0
  67. package/browser/lib/converter/result-converter.d.ts +3 -0
  68. package/browser/lib/converter/sql-converter.d.ts +3 -0
  69. package/browser/lib/converter/type-converter.d.ts +5 -0
  70. package/browser/lib/converter/types.d.ts +6 -0
  71. package/browser/lib/index.d.ts +26 -0
  72. package/browser/package.json +25 -0
  73. package/browser/public-api.d.ts +2 -0
  74. package/client/README.md +24 -0
  75. package/client/esm2022/lib/builder/column/basic-column.mjs +13 -0
  76. package/client/esm2022/lib/builder/column/boolean-column.mjs +14 -0
  77. package/client/esm2022/lib/builder/column/comparable-column.mjs +41 -0
  78. package/client/esm2022/lib/builder/column/date-column.mjs +14 -0
  79. package/client/esm2022/lib/builder/column/number-column.mjs +19 -0
  80. package/client/esm2022/lib/builder/column/query-column.mjs +21 -0
  81. package/client/esm2022/lib/builder/column/string-column.mjs +36 -0
  82. package/client/esm2022/lib/builder/column/value-column.mjs +30 -0
  83. package/client/esm2022/lib/builder/condition/query-column-condition.mjs +19 -0
  84. package/client/esm2022/lib/builder/condition/query-condition-chain.mjs +28 -0
  85. package/client/esm2022/lib/builder/condition/query-condition.mjs +6 -0
  86. package/client/esm2022/lib/builder/condition/query-join-condition.mjs +19 -0
  87. package/client/esm2022/lib/builder/helpers/generics-helper.mjs +5 -0
  88. package/client/esm2022/lib/builder/helpers/internal-types.mjs +4 -0
  89. package/client/esm2022/lib/builder/join/joined-tables-chain.mjs +14 -0
  90. package/client/esm2022/lib/builder/join/joined-tables.mjs +22 -0
  91. package/client/esm2022/lib/builder/other/query-ordering.mjs +17 -0
  92. package/client/esm2022/lib/builder/query/select-query.mjs +48 -0
  93. package/client/esm2022/lib/builder/query/table-condition-query.mjs +25 -0
  94. package/client/esm2022/lib/builder/query/table-query.mjs +54 -0
  95. package/client/esm2022/lib/builder/query-source.mjs +20 -0
  96. package/client/esm2022/lib/builder/query-table.mjs +24 -0
  97. package/client/esm2022/lib/client/mysql.mjs +10 -0
  98. package/client/esm2022/lib/client/query-processor.mjs +45 -0
  99. package/client/esm2022/lib/converter/param-converter.mjs +27 -0
  100. package/client/esm2022/lib/converter/parameterized-converter.mjs +17 -0
  101. package/client/esm2022/lib/converter/query-converter.mjs +282 -0
  102. package/client/esm2022/lib/converter/result-converter.mjs +88 -0
  103. package/client/esm2022/lib/converter/sql-converter.mjs +8 -0
  104. package/client/esm2022/lib/converter/type-converter.mjs +39 -0
  105. package/client/esm2022/lib/converter/types.mjs +4 -0
  106. package/client/esm2022/lib/index.mjs +23 -0
  107. package/client/esm2022/public-api.mjs +2 -0
  108. package/client/esm2022/taon-type-sql.mjs +5 -0
  109. package/client/fesm2022/taon-type-sql.mjs +877 -0
  110. package/client/fesm2022/taon-type-sql.mjs.map +1 -0
  111. package/client/index.d.ts +6 -0
  112. package/client/lib/builder/column/basic-column.d.ts +9 -0
  113. package/client/lib/builder/column/boolean-column.d.ts +10 -0
  114. package/client/lib/builder/column/comparable-column.d.ts +19 -0
  115. package/client/lib/builder/column/date-column.d.ts +10 -0
  116. package/client/lib/builder/column/number-column.d.ts +11 -0
  117. package/client/lib/builder/column/query-column.d.ts +19 -0
  118. package/client/lib/builder/column/string-column.d.ts +18 -0
  119. package/client/lib/builder/column/value-column.d.ts +16 -0
  120. package/client/lib/builder/condition/query-column-condition.d.ts +14 -0
  121. package/client/lib/builder/condition/query-condition-chain.d.ts +18 -0
  122. package/client/lib/builder/condition/query-condition.d.ts +8 -0
  123. package/client/lib/builder/condition/query-join-condition.d.ts +13 -0
  124. package/client/lib/builder/helpers/generics-helper.d.ts +3 -0
  125. package/client/lib/builder/helpers/internal-types.d.ts +16 -0
  126. package/client/lib/builder/join/joined-tables-chain.d.ts +12 -0
  127. package/client/lib/builder/join/joined-tables.d.ts +13 -0
  128. package/client/lib/builder/other/query-ordering.d.ts +11 -0
  129. package/client/lib/builder/query/select-query.d.ts +30 -0
  130. package/client/lib/builder/query/table-condition-query.d.ts +17 -0
  131. package/client/lib/builder/query/table-query.d.ts +24 -0
  132. package/client/lib/builder/query-source.d.ts +15 -0
  133. package/client/lib/builder/query-table.d.ts +16 -0
  134. package/client/lib/client/mysql.d.ts +6 -0
  135. package/client/lib/client/query-processor.d.ts +11 -0
  136. package/client/lib/converter/param-converter.d.ts +3 -0
  137. package/client/lib/converter/parameterized-converter.d.ts +6 -0
  138. package/client/lib/converter/query-converter.d.ts +3 -0
  139. package/client/lib/converter/result-converter.d.ts +3 -0
  140. package/client/lib/converter/sql-converter.d.ts +3 -0
  141. package/client/lib/converter/type-converter.d.ts +5 -0
  142. package/client/lib/converter/types.d.ts +6 -0
  143. package/client/lib/index.d.ts +26 -0
  144. package/client/public-api.d.ts +2 -0
  145. package/index.d.ts +1 -0
  146. package/index.js +7 -0
  147. package/index.js.map +1 -0
  148. package/lib/build-info._auto-generated_.d.ts +1 -0
  149. package/lib/build-info._auto-generated_.js +5 -0
  150. package/lib/build-info._auto-generated_.js.map +1 -0
  151. package/lib/builder/column/basic-column.d.ts +8 -0
  152. package/lib/builder/column/basic-column.js +19 -0
  153. package/lib/builder/column/basic-column.js.map +1 -0
  154. package/lib/builder/column/boolean-column.d.ts +9 -0
  155. package/lib/builder/column/boolean-column.js +20 -0
  156. package/lib/builder/column/boolean-column.js.map +1 -0
  157. package/lib/builder/column/comparable-column.d.ts +18 -0
  158. package/lib/builder/column/comparable-column.js +46 -0
  159. package/lib/builder/column/comparable-column.js.map +1 -0
  160. package/lib/builder/column/date-column.d.ts +9 -0
  161. package/lib/builder/column/date-column.js +20 -0
  162. package/lib/builder/column/date-column.js.map +1 -0
  163. package/lib/builder/column/number-column.d.ts +10 -0
  164. package/lib/builder/column/number-column.js +25 -0
  165. package/lib/builder/column/number-column.js.map +1 -0
  166. package/lib/builder/column/query-column.d.ts +18 -0
  167. package/lib/builder/column/query-column.js +23 -0
  168. package/lib/builder/column/query-column.js.map +1 -0
  169. package/lib/builder/column/string-column.d.ts +17 -0
  170. package/lib/builder/column/string-column.js +42 -0
  171. package/lib/builder/column/string-column.js.map +1 -0
  172. package/lib/builder/column/value-column.d.ts +15 -0
  173. package/lib/builder/column/value-column.js +34 -0
  174. package/lib/builder/column/value-column.js.map +1 -0
  175. package/lib/builder/condition/query-column-condition.d.ts +13 -0
  176. package/lib/builder/condition/query-column-condition.js +28 -0
  177. package/lib/builder/condition/query-column-condition.js.map +1 -0
  178. package/lib/builder/condition/query-condition-chain.d.ts +17 -0
  179. package/lib/builder/condition/query-condition-chain.js +34 -0
  180. package/lib/builder/condition/query-condition-chain.js.map +1 -0
  181. package/lib/builder/condition/query-condition.d.ts +7 -0
  182. package/lib/builder/condition/query-condition.js +10 -0
  183. package/lib/builder/condition/query-condition.js.map +1 -0
  184. package/lib/builder/condition/query-join-condition.d.ts +12 -0
  185. package/lib/builder/condition/query-join-condition.js +24 -0
  186. package/lib/builder/condition/query-join-condition.js.map +1 -0
  187. package/lib/builder/helpers/generics-helper.d.ts +2 -0
  188. package/lib/builder/helpers/generics-helper.js +10 -0
  189. package/lib/builder/helpers/generics-helper.js.map +1 -0
  190. package/lib/builder/helpers/internal-types.d.ts +15 -0
  191. package/lib/builder/helpers/internal-types.js +4 -0
  192. package/lib/builder/helpers/internal-types.js.map +1 -0
  193. package/lib/builder/join/joined-tables-chain.d.ts +11 -0
  194. package/lib/builder/join/joined-tables-chain.js +16 -0
  195. package/lib/builder/join/joined-tables-chain.js.map +1 -0
  196. package/lib/builder/join/joined-tables.d.ts +12 -0
  197. package/lib/builder/join/joined-tables.js +24 -0
  198. package/lib/builder/join/joined-tables.js.map +1 -0
  199. package/lib/builder/other/query-ordering.d.ts +10 -0
  200. package/lib/builder/other/query-ordering.js +19 -0
  201. package/lib/builder/other/query-ordering.js.map +1 -0
  202. package/lib/builder/query/select-query.d.ts +29 -0
  203. package/lib/builder/query/select-query.js +70 -0
  204. package/lib/builder/query/select-query.js.map +1 -0
  205. package/lib/builder/query/table-condition-query.d.ts +16 -0
  206. package/lib/builder/query/table-condition-query.js +27 -0
  207. package/lib/builder/query/table-condition-query.js.map +1 -0
  208. package/lib/builder/query/table-query.d.ts +23 -0
  209. package/lib/builder/query/table-query.js +63 -0
  210. package/lib/builder/query/table-query.js.map +1 -0
  211. package/lib/builder/query-source.d.ts +14 -0
  212. package/lib/builder/query-source.js +22 -0
  213. package/lib/builder/query-source.js.map +1 -0
  214. package/lib/builder/query-table.d.ts +15 -0
  215. package/lib/builder/query-table.js +26 -0
  216. package/lib/builder/query-table.js.map +1 -0
  217. package/lib/client/mysql.d.ts +5 -0
  218. package/lib/client/mysql.js +15 -0
  219. package/lib/client/mysql.js.map +1 -0
  220. package/lib/client/pg.d.ts +5 -0
  221. package/lib/client/pg.js +15 -0
  222. package/lib/client/pg.js.map +1 -0
  223. package/lib/client/query-processor.d.ts +10 -0
  224. package/lib/client/query-processor.js +75 -0
  225. package/lib/client/query-processor.js.map +1 -0
  226. package/lib/converter/param-converter.d.ts +2 -0
  227. package/lib/converter/param-converter.js +31 -0
  228. package/lib/converter/param-converter.js.map +1 -0
  229. package/lib/converter/parameterized-converter.d.ts +5 -0
  230. package/lib/converter/parameterized-converter.js +18 -0
  231. package/lib/converter/parameterized-converter.js.map +1 -0
  232. package/lib/converter/query-converter.d.ts +2 -0
  233. package/lib/converter/query-converter.js +286 -0
  234. package/lib/converter/query-converter.js.map +1 -0
  235. package/lib/converter/result-converter.d.ts +2 -0
  236. package/lib/converter/result-converter.js +89 -0
  237. package/lib/converter/result-converter.js.map +1 -0
  238. package/lib/converter/sql-converter.d.ts +2 -0
  239. package/lib/converter/sql-converter.js +9 -0
  240. package/lib/converter/sql-converter.js.map +1 -0
  241. package/lib/converter/type-converter.d.ts +4 -0
  242. package/lib/converter/type-converter.js +43 -0
  243. package/lib/converter/type-converter.js.map +1 -0
  244. package/lib/converter/types.d.ts +5 -0
  245. package/lib/converter/types.js +3 -0
  246. package/lib/converter/types.js.map +1 -0
  247. package/lib/index.d.ts +25 -0
  248. package/lib/index.js +48 -0
  249. package/lib/index.js.map +1 -0
  250. package/package.json +38 -0
  251. package/src.d.ts +6 -0
  252. package/taon.jsonc +23 -0
  253. package/tmp-environment.json +359 -0
  254. package/websql/README.md +24 -0
  255. package/websql/esm2022/lib/builder/column/basic-column.mjs +13 -0
  256. package/websql/esm2022/lib/builder/column/boolean-column.mjs +14 -0
  257. package/websql/esm2022/lib/builder/column/comparable-column.mjs +41 -0
  258. package/websql/esm2022/lib/builder/column/date-column.mjs +14 -0
  259. package/websql/esm2022/lib/builder/column/number-column.mjs +19 -0
  260. package/websql/esm2022/lib/builder/column/query-column.mjs +21 -0
  261. package/websql/esm2022/lib/builder/column/string-column.mjs +36 -0
  262. package/websql/esm2022/lib/builder/column/value-column.mjs +30 -0
  263. package/websql/esm2022/lib/builder/condition/query-column-condition.mjs +19 -0
  264. package/websql/esm2022/lib/builder/condition/query-condition-chain.mjs +28 -0
  265. package/websql/esm2022/lib/builder/condition/query-condition.mjs +6 -0
  266. package/websql/esm2022/lib/builder/condition/query-join-condition.mjs +19 -0
  267. package/websql/esm2022/lib/builder/helpers/generics-helper.mjs +5 -0
  268. package/websql/esm2022/lib/builder/helpers/internal-types.mjs +4 -0
  269. package/websql/esm2022/lib/builder/join/joined-tables-chain.mjs +14 -0
  270. package/websql/esm2022/lib/builder/join/joined-tables.mjs +22 -0
  271. package/websql/esm2022/lib/builder/other/query-ordering.mjs +17 -0
  272. package/websql/esm2022/lib/builder/query/select-query.mjs +48 -0
  273. package/websql/esm2022/lib/builder/query/table-condition-query.mjs +25 -0
  274. package/websql/esm2022/lib/builder/query/table-query.mjs +54 -0
  275. package/websql/esm2022/lib/builder/query-source.mjs +20 -0
  276. package/websql/esm2022/lib/builder/query-table.mjs +24 -0
  277. package/websql/esm2022/lib/client/mysql.mjs +10 -0
  278. package/websql/esm2022/lib/client/query-processor.mjs +45 -0
  279. package/websql/esm2022/lib/converter/param-converter.mjs +27 -0
  280. package/websql/esm2022/lib/converter/parameterized-converter.mjs +17 -0
  281. package/websql/esm2022/lib/converter/query-converter.mjs +282 -0
  282. package/websql/esm2022/lib/converter/result-converter.mjs +88 -0
  283. package/websql/esm2022/lib/converter/sql-converter.mjs +8 -0
  284. package/websql/esm2022/lib/converter/type-converter.mjs +39 -0
  285. package/websql/esm2022/lib/converter/types.mjs +4 -0
  286. package/websql/esm2022/lib/index.mjs +23 -0
  287. package/websql/esm2022/public-api.mjs +2 -0
  288. package/websql/esm2022/taon-type-sql.mjs +5 -0
  289. package/websql/fesm2022/taon-type-sql.mjs +877 -0
  290. package/websql/fesm2022/taon-type-sql.mjs.map +1 -0
  291. package/websql/index.d.ts +6 -0
  292. package/websql/lib/builder/column/basic-column.d.ts +9 -0
  293. package/websql/lib/builder/column/boolean-column.d.ts +10 -0
  294. package/websql/lib/builder/column/comparable-column.d.ts +19 -0
  295. package/websql/lib/builder/column/date-column.d.ts +10 -0
  296. package/websql/lib/builder/column/number-column.d.ts +11 -0
  297. package/websql/lib/builder/column/query-column.d.ts +19 -0
  298. package/websql/lib/builder/column/string-column.d.ts +18 -0
  299. package/websql/lib/builder/column/value-column.d.ts +16 -0
  300. package/websql/lib/builder/condition/query-column-condition.d.ts +14 -0
  301. package/websql/lib/builder/condition/query-condition-chain.d.ts +18 -0
  302. package/websql/lib/builder/condition/query-condition.d.ts +8 -0
  303. package/websql/lib/builder/condition/query-join-condition.d.ts +13 -0
  304. package/websql/lib/builder/helpers/generics-helper.d.ts +3 -0
  305. package/websql/lib/builder/helpers/internal-types.d.ts +16 -0
  306. package/websql/lib/builder/join/joined-tables-chain.d.ts +12 -0
  307. package/websql/lib/builder/join/joined-tables.d.ts +13 -0
  308. package/websql/lib/builder/other/query-ordering.d.ts +11 -0
  309. package/websql/lib/builder/query/select-query.d.ts +30 -0
  310. package/websql/lib/builder/query/table-condition-query.d.ts +17 -0
  311. package/websql/lib/builder/query/table-query.d.ts +24 -0
  312. package/websql/lib/builder/query-source.d.ts +15 -0
  313. package/websql/lib/builder/query-table.d.ts +16 -0
  314. package/websql/lib/client/mysql.d.ts +6 -0
  315. package/websql/lib/client/query-processor.d.ts +11 -0
  316. package/websql/lib/converter/param-converter.d.ts +3 -0
  317. package/websql/lib/converter/parameterized-converter.d.ts +6 -0
  318. package/websql/lib/converter/query-converter.d.ts +3 -0
  319. package/websql/lib/converter/result-converter.d.ts +3 -0
  320. package/websql/lib/converter/sql-converter.d.ts +3 -0
  321. package/websql/lib/converter/type-converter.d.ts +5 -0
  322. package/websql/lib/converter/types.d.ts +6 -0
  323. package/websql/lib/index.d.ts +26 -0
  324. package/websql/package.json +25 -0
  325. package/websql/public-api.d.ts +2 -0
@@ -0,0 +1,75 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createQueryProcessor = createQueryProcessor;
4
+ var ng2_logger_1 = require("ng2-logger");
5
+ var parameterized_converter_1 = require("../converter/parameterized-converter");
6
+ var sql_converter_1 = require("../converter/sql-converter");
7
+ var log = ng2_logger_1.Log.create('query processor');
8
+ var DEFAULT_OPTIONS = {
9
+ lineBreaks: false,
10
+ parameterized: true,
11
+ logging: true,
12
+ identifierQuote: '"'
13
+ };
14
+ function mySqlTypeCast(field, next) {
15
+ if (field.type == 'TINY' && field.length == 1) { // Boolean
16
+ var value = field.string();
17
+ if (value == '1')
18
+ return true;
19
+ if (value == '0')
20
+ return false;
21
+ return null;
22
+ }
23
+ else if (field.type == 'JSON') {
24
+ var value = field.string();
25
+ return value == null ? null : JSON.parse(value);
26
+ }
27
+ return next();
28
+ }
29
+ function createQueryProcessor(client, _options, engine) {
30
+ if (_options === void 0) { _options = {}; }
31
+ if (engine === void 0) { engine = 'pg'; }
32
+ var options = Object.assign({}, DEFAULT_OPTIONS, _options);
33
+ var queryOptions = {
34
+ lineBreak: options.lineBreaks ? '\n' : ' ',
35
+ nameEscape: _options.identifierQuote || (engine === 'mysql' ? '`' : '"')
36
+ };
37
+ // function processSql(query: any, sql: string, params: any[] | undefined, callback: any): Promise<any> {
38
+ // if (options.logging) log.i(sql);
39
+ // if (options.logger) options.logger(sql, params);
40
+ // return new Promise((resolve, reject) => {
41
+ // callback(sql, params, (err: any, result: any) => {
42
+ // if (err) reject(err);
43
+ // else resolve(convertResult(query, result, engine));
44
+ // });
45
+ // });
46
+ // }
47
+ // function executeSql(sql: string, params: any[] | undefined, cb: any) {
48
+ // if (engine === 'pg') {
49
+ // client.query(sql, params || cb, params ? cb : undefined);
50
+ // } else if (engine === 'mysql') {
51
+ // client.query({
52
+ // sql,
53
+ // values: params,
54
+ // typeCast: mySqlTypeCast
55
+ // }, cb);
56
+ // } else throw new Error('Unknown DB engine: ' + engine);
57
+ // }
58
+ return function (query) {
59
+ if (options.parameterized) {
60
+ var _a = (0, parameterized_converter_1.convertQueryToParameterizedSQL)(query, queryOptions, engine), sql = _a.sql, params = _a.params;
61
+ // if (Helpers.isWebSQL || Helpers.isNode) {
62
+ return client.query(sql, params);
63
+ // }
64
+ // return processSql(query, sql, params, (sql: string, params: any[], cb: any) => executeSql(sql, params, cb));
65
+ }
66
+ else {
67
+ var sql = (0, sql_converter_1.convertQueryToSQL)(query, queryOptions, engine);
68
+ // if (Helpers.isWebSQL || Helpers.isNode) {
69
+ return client.query(sql, undefined);
70
+ // }
71
+ // return processSql(query, sql, undefined, (sql: string, params: undefined, cb: any) => executeSql(sql, undefined, cb));
72
+ }
73
+ };
74
+ }
75
+ //# sourceMappingURL=query-processor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"query-processor.js","sourceRoot":"","sources":[""],"names":[],"mappings":";;AAwCA,oDAgDC;AAxFD,yCAAwC;AACxC,gFAAsF;AACtF,4DAA+D;AAM/D,IAAM,GAAG,GAAG,gBAAG,CAAC,MAAM,CAAC,iBAAiB,CAEvC,CAAA;AAUD,IAAM,eAAe,GAA0B;IAC7C,UAAU,EAAE,KAAK;IACjB,aAAa,EAAE,IAAI;IACnB,OAAO,EAAE,IAAI;IACb,eAAe,EAAE,GAAG;CACrB,CAAC;AAEF,SAAS,aAAa,CAAC,KAAU,EAAE,IAAS;IAC1C,IAAI,KAAK,CAAC,IAAI,IAAI,MAAM,IAAI,KAAK,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC,CAAC,UAAU;QACzD,IAAI,KAAK,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC;QAC3B,IAAI,KAAK,IAAI,GAAG;YAAE,OAAO,IAAI,CAAC;QAC9B,IAAI,KAAK,IAAI,GAAG;YAAE,OAAO,KAAK,CAAC;QAC/B,OAAO,IAAI,CAAC;IACd,CAAC;SAAM,IAAI,KAAK,CAAC,IAAI,IAAI,MAAM,EAAE,CAAC;QAChC,IAAI,KAAK,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC;QAC3B,OAAO,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IAClD,CAAC;IACD,OAAO,IAAI,EAAE,CAAC;AAChB,CAAC;AAED,SAAgB,oBAAoB,CAAC,MAAW,EAAE,QAAoC,EAAE,MAA0B;IAAhE,yBAAA,EAAA,aAAoC;IAAE,uBAAA,EAAA,aAA0B;IAEhH,IAAI,OAAO,GAA0B,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,eAAe,EAAE,QAAQ,CAAC,CAAC;IAElF,IAAI,YAAY,GAAqB;QACnC,SAAS,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG;QAC1C,UAAU,EAAE,QAAQ,CAAC,eAAe,IAAI,CAAC,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;KACzE,CAAC;IAEF,yGAAyG;IACzG,qCAAqC;IACrC,qDAAqD;IAErD,8CAA8C;IAC9C,yDAAyD;IACzD,8BAA8B;IAC9B,4DAA4D;IAC5D,UAAU;IACV,QAAQ;IACR,IAAI;IAEJ,yEAAyE;IACzE,2BAA2B;IAC3B,gEAAgE;IAChE,qCAAqC;IACrC,qBAAqB;IACrB,aAAa;IACb,wBAAwB;IACxB,gCAAgC;IAChC,cAAc;IACd,4DAA4D;IAC5D,IAAI;IAEJ,OAAO,UAAC,KAAU;QAChB,IAAI,OAAO,CAAC,aAAa,EAAE,CAAC;YACtB,IAAA,KAAkB,IAAA,wDAA8B,EAAC,KAAK,EAAE,YAAY,EAAE,MAAM,CAAC,EAA3E,GAAG,SAAA,EAAE,MAAM,YAAgE,CAAC;YAClF,4CAA4C;YAC5C,OAAO,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;YACjC,IAAI;YACJ,+GAA+G;QACjH,CAAC;aAAM,CAAC;YACN,IAAI,GAAG,GAAG,IAAA,iCAAiB,EAAC,KAAK,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;YACzD,4CAA4C;YAC5C,OAAO,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;YACpC,IAAI;YACJ,yHAAyH;QAC3H,CAAC;IACH,CAAC,CAAC;AACJ,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function convertSubstitutionParam(param: any): string;
2
+ export declare function convertEscapedParam(param: any): any;
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.convertSubstitutionParam = convertSubstitutionParam;
4
+ exports.convertEscapedParam = convertEscapedParam;
5
+ function convertSubstitutionParam(param) {
6
+ if (param == null)
7
+ return 'NULL';
8
+ if (typeof param === 'string' || param instanceof String) {
9
+ return "'".concat(String(param), "'");
10
+ }
11
+ else if (typeof param === 'boolean' || param instanceof Boolean) {
12
+ return String(param).toUpperCase();
13
+ }
14
+ else if (param instanceof Date) {
15
+ return "'".concat(param.toISOString(), "'");
16
+ }
17
+ else if (typeof param === 'number' || param instanceof Number) {
18
+ return String(param);
19
+ }
20
+ return "'".concat(JSON.stringify(param), "'");
21
+ }
22
+ // node mysql doesn't have an typeCast equivalent solution for the other direction
23
+ // node-postgres: https://github.com/brianc/node-postgres/issues/442
24
+ function convertEscapedParam(param) {
25
+ if (typeof param === 'object' && !(param == null || param instanceof String || param instanceof Number ||
26
+ param instanceof Boolean || param instanceof Date)) {
27
+ return JSON.stringify(param);
28
+ }
29
+ return param;
30
+ }
31
+ //# sourceMappingURL=param-converter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"param-converter.js","sourceRoot":"","sources":[""],"names":[],"mappings":";;AACA,4DAYC;AAID,kDAMC;AAtBD,SAAgB,wBAAwB,CAAC,KAAU;IAC/C,IAAI,KAAK,IAAI,IAAI;QAAE,OAAO,MAAM,CAAC;IACjC,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,YAAY,MAAM,EAAE,CAAC;QACvD,OAAO,WAAI,MAAM,CAAC,KAAK,CAAC,MAAG,CAAC;IAChC,CAAC;SAAM,IAAI,OAAO,KAAK,KAAK,SAAS,IAAI,KAAK,YAAY,OAAO,EAAE,CAAC;QAChE,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC;IACvC,CAAC;SAAM,IAAI,KAAK,YAAY,IAAI,EAAE,CAAC;QAC/B,OAAO,WAAI,KAAK,CAAC,WAAW,EAAE,MAAG,CAAC;IACtC,CAAC;SAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,YAAY,MAAM,EAAE,CAAC;QAC9D,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IACD,OAAO,WAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAG,CAAC;AACxC,CAAC;AAED,kFAAkF;AAClF,oEAAoE;AACpE,SAAgB,mBAAmB,CAAC,KAAU;IAC1C,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,CAAC,CAAC,KAAK,IAAI,IAAI,IAAI,KAAK,YAAY,MAAM,IAAI,KAAK,YAAY,MAAM;QAClG,KAAK,YAAY,OAAO,IAAI,KAAK,YAAY,IAAI,CAAC,EAAE,CAAC;QACrD,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IACD,OAAO,KAAK,CAAC;AACjB,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { QueryEngine, ConverterOptions } from "./types";
2
+ export declare function convertQueryToParameterizedSQL(query: any, options: ConverterOptions, engine: QueryEngine): {
3
+ sql: string;
4
+ params: any[];
5
+ };
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.convertQueryToParameterizedSQL = convertQueryToParameterizedSQL;
4
+ var query_converter_1 = require("./query-converter");
5
+ var param_converter_1 = require("./param-converter");
6
+ var pgParamConverter = function (index) { return '$' + index; };
7
+ var mySqlParamConverter = function (index) { return '?'; };
8
+ function convertSingleParam(param, params, paramConverter) {
9
+ params.push((0, param_converter_1.convertEscapedParam)(param));
10
+ return paramConverter(params.length);
11
+ }
12
+ function convertQueryToParameterizedSQL(query, options, engine) {
13
+ var params = [];
14
+ var paramConverter = engine === 'mysql' ? mySqlParamConverter : pgParamConverter;
15
+ var sql = (0, query_converter_1.createQueryConverter)(function (param) { return convertSingleParam(param, params, paramConverter); }, options, engine)(query);
16
+ return { sql: sql, params: params };
17
+ }
18
+ //# sourceMappingURL=parameterized-converter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parameterized-converter.js","sourceRoot":"","sources":[""],"names":[],"mappings":";;AAYA,wEAOC;AAnBD,qDAAuD;AACvD,qDAAsD;AAGtD,IAAI,gBAAgB,GAAG,UAAC,KAAa,IAAK,OAAA,GAAG,GAAG,KAAK,EAAX,CAAW,CAAC;AACtD,IAAI,mBAAmB,GAAG,UAAC,KAAa,IAAK,OAAA,GAAG,EAAH,CAAG,CAAC;AAEjD,SAAS,kBAAkB,CAAC,KAAU,EAAE,MAAa,EAAE,cAAsC;IACzF,MAAM,CAAC,IAAI,CAAC,IAAA,qCAAmB,EAAC,KAAK,CAAC,CAAC,CAAC;IACxC,OAAO,cAAc,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;AACzC,CAAC;AAED,SAAgB,8BAA8B,CAAC,KAAU,EAAE,OAAyB,EAAE,MAAmB;IACrG,IAAI,MAAM,GAAU,EAAE,CAAC;IAEvB,IAAI,cAAc,GAAG,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,gBAAgB,CAAC;IACjF,IAAI,GAAG,GAAG,IAAA,sCAAoB,EAAC,UAAC,KAAU,IAAK,OAAA,kBAAkB,CAAC,KAAK,EAAE,MAAM,EAAE,cAAc,CAAC,EAAjD,CAAiD,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC;IAE1H,OAAO,EAAE,GAAG,KAAA,EAAE,MAAM,QAAA,EAAE,CAAC;AAC3B,CAAC"}
@@ -0,0 +1,2 @@
1
+ import { QueryEngine, ConverterOptions } from "./types";
2
+ export declare function createQueryConverter(paramConverter: (param: any) => string, options: ConverterOptions, engine: QueryEngine): (query: any) => string;
@@ -0,0 +1,286 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createQueryConverter = createQueryConverter;
4
+ var type_converter_1 = require("./type-converter");
5
+ function createQueryConverter(paramConverter, options, engine) {
6
+ return convertQuery;
7
+ function convertQuery(query) {
8
+ if (query._action === 'select')
9
+ return convertSelectQuery(query);
10
+ if (query._action === 'delete')
11
+ return convertDeleteQuery(query);
12
+ if (query._action === 'update')
13
+ return convertUpdateQuery(query);
14
+ if (query._action === 'insert')
15
+ return convertInsertQuery(query);
16
+ throw new Error('Unknown query type:' + query._action);
17
+ }
18
+ function convertDeleteQuery(query) {
19
+ var s = 'DELETE FROM ' + convertTable(query._table);
20
+ s += convertConditions(query._conditions);
21
+ return s;
22
+ }
23
+ function convertUpdateQuery(query) {
24
+ var s = 'UPDATE ' + convertTable(query._table) + ' SET ';
25
+ s += convertUpdateSetters(query._table, query._entity);
26
+ s += convertConditions(query._conditions);
27
+ return s;
28
+ }
29
+ function convertUpdateSetters(table, entity) {
30
+ return Object.keys(entity).sort().map(function (key) {
31
+ var value = entity[key];
32
+ var column = table[key];
33
+ return convertColumnName(column) + ' = ' + convertParam(column, value);
34
+ }).join(', ');
35
+ }
36
+ function convertInsertQuery(query) {
37
+ var items = Array.isArray(query._entity) ? query._entity : [query._entity];
38
+ var keySet = items.reduce(function (set, item) {
39
+ Object.keys(item).forEach(function (key) { return set.add(key); });
40
+ return set;
41
+ }, new Set());
42
+ var keys = Array.from(keySet).sort();
43
+ var s = 'INSERT INTO ' + convertTable(query._table) + ' ';
44
+ s += '(' + keys.map(function (key) { return convertColumnName(query._table[key]); }).join(', ') + ')';
45
+ s += options.lineBreak + 'VALUES ';
46
+ s += items.map(function (item) { return convertInsertItem(query._table, item, keys); })
47
+ .map(function (row) { return '(' + row + ')'; }).join(', ');
48
+ s += getPgInsertReturningIfNeeded(query);
49
+ return s;
50
+ }
51
+ function getPgInsertReturningIfNeeded(query) {
52
+ if (engine === 'pg' && query._action === 'insert' && !Array.isArray(query._entity) &&
53
+ query._table.$id && query._table.$id._table && query._table.$id._name) {
54
+ return ' RETURNING ' + convertColumnName(query._table.$id);
55
+ }
56
+ return '';
57
+ }
58
+ function convertInsertItem(table, entity, keys) {
59
+ return keys.map(function (key) {
60
+ var value = entity[key];
61
+ var column = table[key];
62
+ return convertParam(column, value);
63
+ }).join(', ');
64
+ }
65
+ function convertSelectQuery(query) {
66
+ var s = 'SELECT ';
67
+ if (query._distinct) {
68
+ s += 'DISTINCT ';
69
+ }
70
+ if (query._columns == null || query._columns.length === 0) {
71
+ s += '*';
72
+ }
73
+ else {
74
+ s += query._columns.map(function (column) { return convertColumn(column); }).join(', ');
75
+ }
76
+ s += options.lineBreak + 'FROM ';
77
+ if (query._tables) {
78
+ s += query._tables.map(function (table) { return table._parent ? convertJoin(table) : convertTable(table); }).join(', ');
79
+ }
80
+ else {
81
+ s += convertTable(query._table);
82
+ }
83
+ s += convertConditions(query._conditions);
84
+ if (query._groupBy && query._groupBy.length > 0) {
85
+ s += options.lineBreak + 'GROUP BY ';
86
+ s += query._groupBy.map(function (column) { return convertColumn(column); }).join(', ');
87
+ }
88
+ s += convertConditions(query._having, 'HAVING');
89
+ if (query._orderings && query._orderings.length > 0) {
90
+ s += options.lineBreak + 'ORDER BY ';
91
+ s += query._orderings.map(function (ordering) { return convertOrdering(ordering); }).join(', ');
92
+ }
93
+ if (query._limit != null) {
94
+ s += options.lineBreak + 'LIMIT ' + (0, type_converter_1.number)(query._limit);
95
+ }
96
+ if (query._offset != null) {
97
+ s += options.lineBreak + 'OFFSET ' + (0, type_converter_1.number)(query._offset);
98
+ }
99
+ return s;
100
+ }
101
+ function convertConditions(conditions, keyword) {
102
+ if (keyword === void 0) { keyword = 'WHERE'; }
103
+ var s = '';
104
+ if (conditions && conditions.length > 0) {
105
+ s += options.lineBreak + keyword + ' ';
106
+ preprocessConditions(conditions);
107
+ s += conditions.map(function (condition) { return convertCondition(condition, true); }).join(' AND ');
108
+ }
109
+ return s;
110
+ }
111
+ function convertJoin(joinChain) {
112
+ var items = [];
113
+ while (joinChain) {
114
+ items.push(joinChain);
115
+ joinChain = joinChain._parent;
116
+ }
117
+ var root = items[items.length - 1];
118
+ var s = convertTable(root);
119
+ for (var i = items.length - 2; i >= 0; i -= 2) {
120
+ var table = items[i]._table;
121
+ var modifier = items[i]._modifier;
122
+ var condition = items[i - 1]._condition;
123
+ var param = convertColumn(condition._otherColumn);
124
+ s += ' ' + modifier.toUpperCase() + ' JOIN ' + convertTable(table) + ' ON ' +
125
+ convertColumnCondition(condition, param);
126
+ }
127
+ return s;
128
+ }
129
+ function convertOrdering(ordering) {
130
+ if (ordering._column) {
131
+ var s = convertColumn(ordering._column);
132
+ if (ordering._nullsPosition != null) { // "NULLS FIRST" only exists in PG, this is the general solution
133
+ s += ' IS NULL ' + (ordering._nullsPosition === 'FIRST' ? 'DESC' : 'ASC') + ', ' + s;
134
+ }
135
+ if (ordering._direction === 'ASC')
136
+ s += ' ASC';
137
+ if (ordering._direction === 'DESC')
138
+ s += ' DESC';
139
+ return s;
140
+ }
141
+ else {
142
+ return convertColumn(ordering);
143
+ }
144
+ }
145
+ function convertTable(table) {
146
+ return options.nameEscape + table._$name + options.nameEscape;
147
+ }
148
+ function convertColumn(column) {
149
+ var s = '';
150
+ if (!(column._name === '*' && column._modifiers.length > 0 && column._modifiers[0].name === 'count')) {
151
+ s += convertTable(column._table) + '.';
152
+ }
153
+ s += convertColumnName(column);
154
+ return convertColumnModifiers(s, column);
155
+ }
156
+ function convertColumnModifiers(s, column) {
157
+ if (column._modifiers) {
158
+ column._modifiers.forEach(function (modifier) {
159
+ var name = modifier.name;
160
+ if (name === 'lower')
161
+ s = 'LOWER(' + s + ')';
162
+ else if (name === 'upper')
163
+ s = 'UPPER(' + s + ')';
164
+ else if (name === 'count')
165
+ s = 'COUNT(' + s + ')';
166
+ else if (name === 'sum')
167
+ s = 'SUM(' + s + ')';
168
+ else if (name === 'avg')
169
+ s = 'AVG(' + s + ')';
170
+ else if (name === 'min')
171
+ s = 'MIN(' + s + ')';
172
+ else if (name === 'max')
173
+ s = 'MAX(' + s + ')';
174
+ else if (name === 'as')
175
+ s = s + ' AS ' + options.nameEscape + modifier.params + options.nameEscape;
176
+ });
177
+ }
178
+ return s + '';
179
+ }
180
+ function convertColumnName(column) {
181
+ if (column._name === '*')
182
+ return column._name;
183
+ var name = typeof column._name === 'string' ? column._name : column._name.name;
184
+ return options.nameEscape + name + options.nameEscape;
185
+ }
186
+ function preprocessConditions(conditions) {
187
+ conditions.forEach(function (condition) {
188
+ if (conditions.length > 1 && condition._sibling) {
189
+ condition._parenthesis = true;
190
+ }
191
+ preprocessParams(condition);
192
+ });
193
+ }
194
+ // this is only needed, so that the $1, $2... numbering is not reversed
195
+ function preprocessParams(condition) {
196
+ if (condition._sibling) {
197
+ preprocessParams(condition._sibling);
198
+ }
199
+ if (!condition._sibling && !condition._child) {
200
+ condition.__param = getConditionParam(condition);
201
+ }
202
+ if (condition._child) {
203
+ preprocessParams(condition._child);
204
+ }
205
+ }
206
+ function convertCondition(condition, root) {
207
+ if (root === void 0) { root = false; }
208
+ if (!condition._sibling && !condition._child) {
209
+ return convertColumnCondition(condition, condition.__param);
210
+ }
211
+ var s = '';
212
+ if (condition._child) {
213
+ s += convertCondition(condition._child);
214
+ }
215
+ if (condition._sibling) {
216
+ s = convertCondition(condition._sibling, root) + ' ' + condition._chainType.toUpperCase() + ' ' + s;
217
+ }
218
+ if (condition._parenthesis || ((!root || condition._negation) && condition._child)) {
219
+ s = '( ' + s + ' )';
220
+ }
221
+ if (condition._negation) {
222
+ s = 'NOT ' + s;
223
+ }
224
+ return s;
225
+ }
226
+ function convertColumnCondition(condition, param) {
227
+ var s = convertColumn(condition._column);
228
+ s += getConditionString(condition, param);
229
+ return s;
230
+ }
231
+ function getConditionString(condition, param) {
232
+ switch (condition._type) {
233
+ case 'eq': return ' = ' + param;
234
+ case 'ne': return ' <> ' + param;
235
+ case 'lt': return ' < ' + param;
236
+ case 'gt': return ' > ' + param;
237
+ case 'lte': return ' <= ' + param;
238
+ case 'gte': return ' >= ' + param;
239
+ case 'is-null': return ' IS NULL';
240
+ case 'is-not-null': return ' IS NOT NULL';
241
+ case 'like': return ' LIKE ' + param;
242
+ case 'not-like': return ' NOT LIKE ' + param;
243
+ case 'in': return ' IN (' + param + ')';
244
+ case 'not-in': return ' NOT IN (' + param + ')';
245
+ case 'between': return ' BETWEEN ' + param;
246
+ case 'not-between': return ' NOT BETWEEN ' + param;
247
+ default: return '';
248
+ }
249
+ }
250
+ function getConditionParam(condition) {
251
+ var param = '';
252
+ if (condition._otherColumn) {
253
+ param = convertColumn(condition._otherColumn);
254
+ }
255
+ else {
256
+ var _convertParam_1 = function (param) { return convertParam(condition._column, param); };
257
+ if (condition._type === 'in' || condition._type === 'not-in') {
258
+ param = condition._values.map(function (value) { return _convertParam_1(value); }).join(', ');
259
+ }
260
+ else if (condition._type === 'between' || condition._type === 'not-between') {
261
+ param = _convertParam_1(condition._values[0]) + ' AND ' + _convertParam_1(condition._values[1]);
262
+ }
263
+ else if (condition._type !== 'is-null' && condition._type !== 'is-not-null') {
264
+ param = _convertParam_1(condition._values[0]);
265
+ }
266
+ }
267
+ return param;
268
+ }
269
+ function convertParam(column, param) {
270
+ if (param == null)
271
+ return 'NULL';
272
+ return paramConverter(getTypedParam(column._type, param));
273
+ }
274
+ function getTypedParam(type, param) {
275
+ if (type === 'number')
276
+ return (0, type_converter_1.number)(param);
277
+ else if (type === 'boolean')
278
+ return (0, type_converter_1.boolean)(param);
279
+ else if (type === 'date')
280
+ return (0, type_converter_1.date)(param);
281
+ else if (type === 'string')
282
+ return (0, type_converter_1.string)(param);
283
+ return param;
284
+ }
285
+ }
286
+ //# sourceMappingURL=query-converter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"query-converter.js","sourceRoot":"","sources":[""],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { QueryEngine } from "./types";
2
+ export declare function convertResult(query: any, result: any, engine: QueryEngine): any;
@@ -0,0 +1,89 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.convertResult = convertResult;
4
+ function convertResult(query, result, engine) {
5
+ var rows = engine === 'pg' ? result.rows : result;
6
+ var rowCount = engine === 'pg' ? result.rowCount : result.affectedRows || result.changedRows;
7
+ if (query._action === 'select')
8
+ return convertSelectResult(query, rows);
9
+ if (query._action === 'delete')
10
+ return rowCount;
11
+ if (query._action === 'update')
12
+ return rowCount;
13
+ if (query._action === 'insert')
14
+ return convertInsertResult(result, engine);
15
+ throw new Error('Unknown query type:' + query._action);
16
+ }
17
+ function convertInsertResult(result, engine) {
18
+ if (engine === 'mysql')
19
+ return result.insertId > 0 ? result.insertId : undefined; // mysql returns 0 for tables that have a non-autoincrement ID
20
+ if (engine === 'pg' && result.rows && result.rows.length === 1) {
21
+ var columnName = Object.keys(result.rows[0])[0];
22
+ return result.rows[0][columnName];
23
+ }
24
+ }
25
+ function convertSelectResult(query, rows) {
26
+ if (query._columns && query._columns.length === 1 &&
27
+ !(query._columns[0]._name === '*' && query._columns[0]._modifiers.length === 0)) {
28
+ if (rows.length == 0)
29
+ return [];
30
+ var columnName_1 = Object.keys(rows[0])[0]; // easier than reverse engineering from the column modifiers
31
+ var values = rows.map(function (row) { return row[columnName_1]; });
32
+ if (query._columns[0]._name === '*' && query._columns[0]._modifiers.some(function (m) { return m.name === 'count'; })) {
33
+ return values.map(function (value) { return Number(value); }); // string to number conversion for PG count values
34
+ }
35
+ return values;
36
+ }
37
+ else {
38
+ convertAliasFields(query, rows);
39
+ return rows;
40
+ }
41
+ }
42
+ function convertAliasFields(query, rows) {
43
+ var aliasByName = getColumnAliasesByName(query);
44
+ if (Object.keys(aliasByName).length === 0)
45
+ return;
46
+ rows.forEach(function (row) {
47
+ Object.keys(row).forEach(function (name) {
48
+ if (aliasByName[name]) {
49
+ row[aliasByName[name]] = row[name];
50
+ delete row[name];
51
+ }
52
+ });
53
+ });
54
+ }
55
+ function getColumnAliasesByName(query) {
56
+ var aliasByName = {};
57
+ if (query._columns && query._columns.length > 0) {
58
+ query._columns.forEach(function (column) {
59
+ if (column._name && column._name.alias && column._modifiers.length === 0) {
60
+ aliasByName[column._name.name] = column._name.alias;
61
+ }
62
+ else if (column._name === '*' && column._modifiers.length === 0) {
63
+ getAliasColumnsOfTable(column._table).forEach(function (column) {
64
+ aliasByName[column._name.name] = column._name.alias;
65
+ });
66
+ }
67
+ });
68
+ }
69
+ else {
70
+ var tables = query._table ? [query._table] : query._tables;
71
+ tables.forEach(function (table) {
72
+ getAliasColumnsOfTable(table).forEach(function (column) {
73
+ aliasByName[column._name.name] = column._name.alias;
74
+ });
75
+ var joinTable = table._parent;
76
+ while (joinTable) {
77
+ getAliasColumnsOfTable(joinTable).forEach(function (column) {
78
+ aliasByName[column._name.name] = column._name.alias;
79
+ });
80
+ joinTable = joinTable._parent;
81
+ }
82
+ });
83
+ }
84
+ return aliasByName;
85
+ }
86
+ function getAliasColumnsOfTable(table) {
87
+ return Object.keys(table).map(function (key) { return table[key]; }).filter(function (column) { return column && column._name && column._name.alias; });
88
+ }
89
+ //# sourceMappingURL=result-converter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"result-converter.js","sourceRoot":"","sources":[""],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { QueryEngine, ConverterOptions } from "./types";
2
+ export declare function convertQueryToSQL(query: any, options: ConverterOptions, engine: QueryEngine): string;
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.convertQueryToSQL = convertQueryToSQL;
4
+ var query_converter_1 = require("./query-converter");
5
+ var param_converter_1 = require("./param-converter");
6
+ function convertQueryToSQL(query, options, engine) {
7
+ return (0, query_converter_1.createQueryConverter)(function (param) { return (0, param_converter_1.convertSubstitutionParam)(param); }, options, engine)(query);
8
+ }
9
+ //# sourceMappingURL=sql-converter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sql-converter.js","sourceRoot":"","sources":[""],"names":[],"mappings":";;AAIA,8CAEC;AAND,qDAAuD;AACvD,qDAA2D;AAG3D,SAAgB,iBAAiB,CAAC,KAAU,EAAE,OAAyB,EAAE,MAAmB;IACxF,OAAO,IAAA,sCAAoB,EAAC,UAAC,KAAU,IAAK,OAAA,IAAA,0CAAwB,EAAC,KAAK,CAAC,EAA/B,CAA+B,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC;AACzG,CAAC"}
@@ -0,0 +1,4 @@
1
+ export declare function number(param: any): number;
2
+ export declare function boolean(param: any): boolean;
3
+ export declare function date(param: any): Date;
4
+ export declare function string(param: any): string;
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.number = number;
4
+ exports.boolean = boolean;
5
+ exports.date = date;
6
+ exports.string = string;
7
+ function number(param) {
8
+ var result = Number(param);
9
+ if (Number.isNaN(result))
10
+ throw new Error('Invalid number parameter in SQL query: ' + param);
11
+ return result;
12
+ }
13
+ function boolean(param) {
14
+ if (typeof param === 'boolean')
15
+ return param;
16
+ if (param instanceof Boolean)
17
+ return param.valueOf();
18
+ if (param === 'true')
19
+ return true;
20
+ if (param === 'false')
21
+ return false;
22
+ throw new Error('Invalid boolean parameter in SQL query: ' + param);
23
+ }
24
+ function date(param) {
25
+ if (param instanceof Date)
26
+ return param; // @ts-ignore
27
+ if (typeof param === 'number' || param instanceof Number)
28
+ return new Date(param);
29
+ if (typeof param === 'string' || param instanceof String) {
30
+ if (Number.isNaN(Date.parse(String(param))))
31
+ throw new Error('Invalid date parameter in SQL query: ' + param); // @ts-ignore
32
+ return new Date(param);
33
+ }
34
+ throw new Error('Invalid date parameter in SQL query: ' + param);
35
+ }
36
+ function string(param) {
37
+ if (typeof param === 'string')
38
+ return param;
39
+ if (param instanceof String)
40
+ return param.valueOf();
41
+ throw new Error('Invalid string parameter in SQL query: ' + param);
42
+ }
43
+ //# sourceMappingURL=type-converter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"type-converter.js","sourceRoot":"","sources":[""],"names":[],"mappings":";;AACA,wBAIC;AAED,0BAMC;AAED,oBAQC;AAED,wBAIC;AA5BD,SAAgB,MAAM,CAAC,KAAU;IAC/B,IAAI,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAC3B,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC;QAAE,MAAM,IAAI,KAAK,CAAC,yCAAyC,GAAG,KAAK,CAAC,CAAC;IAC7F,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,SAAgB,OAAO,CAAC,KAAU;IAChC,IAAI,OAAO,KAAK,KAAK,SAAS;QAAE,OAAO,KAAK,CAAC;IAC7C,IAAI,KAAK,YAAY,OAAO;QAAE,OAAO,KAAK,CAAC,OAAO,EAAE,CAAC;IACrD,IAAI,KAAK,KAAK,MAAM;QAAE,OAAO,IAAI,CAAC;IAClC,IAAI,KAAK,KAAK,OAAO;QAAE,OAAO,KAAK,CAAC;IACpC,MAAM,IAAI,KAAK,CAAC,0CAA0C,GAAG,KAAK,CAAC,CAAC;AACtE,CAAC;AAED,SAAgB,IAAI,CAAC,KAAU;IAC7B,IAAI,KAAK,YAAY,IAAI;QAAE,OAAO,KAAK,CAAC,CAAC,aAAa;IACtD,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,YAAY,MAAM;QAAE,OAAO,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC;IACjF,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,YAAY,MAAM,EAAE,CAAC;QACzD,IAAI,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,uCAAuC,GAAG,KAAK,CAAC,CAAC,CAAC,aAAa;QAC5H,OAAO,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IACD,MAAM,IAAI,KAAK,CAAC,uCAAuC,GAAG,KAAK,CAAC,CAAC;AACnE,CAAC;AAED,SAAgB,MAAM,CAAC,KAAU;IAC/B,IAAI,OAAO,KAAK,KAAK,QAAQ;QAAE,OAAO,KAAK,CAAC;IAC5C,IAAI,KAAK,YAAY,MAAM;QAAE,OAAO,KAAK,CAAC,OAAO,EAAE,CAAC;IACpD,MAAM,IAAI,KAAK,CAAC,yCAAyC,GAAG,KAAK,CAAC,CAAC;AACrE,CAAC"}