af-db-ts 2.0.19 → 2.0.73

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 (307) hide show
  1. package/dist/cjs/__tests__/db/ms/@gen-types/test-table_schema.js +3 -0
  2. package/dist/cjs/__tests__/db/ms/@gen-types/test-table_schema.js.map +1 -0
  3. package/dist/cjs/__tests__/db/ms/ddl/column-schema-for-test-table-schema-ms.json +216 -0
  4. package/dist/cjs/__tests__/db/ms/ms-get-sql.spec.js +190 -0
  5. package/dist/cjs/__tests__/db/ms/ms-get-sql.spec.js.map +1 -0
  6. package/dist/cjs/__tests__/db/ms/ms-prepare-sql-value.spec.js +584 -0
  7. package/dist/cjs/__tests__/db/ms/ms-prepare-sql-value.spec.js.map +1 -0
  8. package/dist/cjs/__tests__/db/ms/ms-table-schema.spec.js +107 -0
  9. package/dist/cjs/__tests__/db/ms/ms-table-schema.spec.js.map +1 -0
  10. package/dist/cjs/__tests__/db/pg/@gen-types/test-hard_case.js +3 -0
  11. package/dist/cjs/__tests__/db/pg/@gen-types/test-hard_case.js.map +1 -0
  12. package/dist/cjs/__tests__/db/pg/@gen-types/test-only_one_serial.js +3 -0
  13. package/dist/cjs/__tests__/db/pg/@gen-types/test-only_one_serial.js.map +1 -0
  14. package/dist/cjs/__tests__/db/pg/@gen-types/test-only_one_uniq.js +3 -0
  15. package/dist/cjs/__tests__/db/pg/@gen-types/test-only_one_uniq.js.map +1 -0
  16. package/dist/cjs/__tests__/db/pg/@gen-types/test-serial_and_uniq.js +3 -0
  17. package/dist/cjs/__tests__/db/pg/@gen-types/test-serial_and_uniq.js.map +1 -0
  18. package/dist/cjs/__tests__/db/pg/@gen-types/test-table_schema.js +3 -0
  19. package/dist/cjs/__tests__/db/pg/@gen-types/test-table_schema.js.map +1 -0
  20. package/dist/cjs/__tests__/db/pg/ddl/column-schema-for-test-table-schema-pg.json +170 -0
  21. package/dist/cjs/__tests__/db/pg/gen-table-interfaces-4-test-pg.js +36 -0
  22. package/dist/cjs/__tests__/db/pg/gen-table-interfaces-4-test-pg.js.map +1 -0
  23. package/dist/cjs/__tests__/db/pg/pg-get-sql.spec.js +261 -0
  24. package/dist/cjs/__tests__/db/pg/pg-get-sql.spec.js.map +1 -0
  25. package/dist/cjs/__tests__/db/pg/pg-insert.spec.js +294 -0
  26. package/dist/cjs/__tests__/db/pg/pg-insert.spec.js.map +1 -0
  27. package/dist/cjs/__tests__/db/pg/pg-prepare-sql-value.spec.js +575 -0
  28. package/dist/cjs/__tests__/db/pg/pg-prepare-sql-value.spec.js.map +1 -0
  29. package/dist/cjs/__tests__/db/pg/pg-table-schema.spec.js +117 -0
  30. package/dist/cjs/__tests__/db/pg/pg-table-schema.spec.js.map +1 -0
  31. package/dist/cjs/src/@types/i-data-types-ms.js +3 -0
  32. package/dist/cjs/src/@types/i-data-types-ms.js.map +1 -0
  33. package/dist/cjs/src/@types/i-data-types-pg.js +7 -0
  34. package/dist/cjs/src/@types/i-data-types-pg.js.map +1 -0
  35. package/dist/cjs/src/@types/i-pg.js +0 -21
  36. package/dist/cjs/src/@types/i-pg.js.map +1 -1
  37. package/dist/cjs/src/common.js +6 -5
  38. package/dist/cjs/src/common.js.map +1 -1
  39. package/dist/cjs/src/index.js +75 -54
  40. package/dist/cjs/src/index.js.map +1 -1
  41. package/dist/cjs/src/ms/gen-table-interfaces-ms.js +64 -0
  42. package/dist/cjs/src/ms/gen-table-interfaces-ms.js.map +1 -0
  43. package/dist/cjs/src/ms/get-sql/insert.js +37 -0
  44. package/dist/cjs/src/ms/get-sql/insert.js.map +1 -0
  45. package/dist/cjs/src/ms/get-sql/merge.js +93 -0
  46. package/dist/cjs/src/ms/get-sql/merge.js.map +1 -0
  47. package/dist/cjs/src/ms/get-sql/update.js +32 -0
  48. package/dist/cjs/src/ms/get-sql/update.js.map +1 -0
  49. package/dist/cjs/src/{mssql → ms}/pool-ms.js +6 -23
  50. package/dist/cjs/src/ms/pool-ms.js.map +1 -0
  51. package/dist/cjs/src/ms/prepare-value.js +178 -0
  52. package/dist/cjs/src/ms/prepare-value.js.map +1 -0
  53. package/dist/cjs/src/{mssql → ms}/query-ms.js +1 -1
  54. package/dist/cjs/src/ms/query-ms.js.map +1 -0
  55. package/dist/cjs/src/ms/table-schema-ms.js +241 -0
  56. package/dist/cjs/src/ms/table-schema-ms.js.map +1 -0
  57. package/dist/cjs/src/ms/utils-ms.js +92 -0
  58. package/dist/cjs/src/ms/utils-ms.js.map +1 -0
  59. package/dist/cjs/src/ms/wrap-transaction-ms.js +32 -0
  60. package/dist/cjs/src/ms/wrap-transaction-ms.js.map +1 -0
  61. package/dist/cjs/src/pg/gen-table-interfaces-pg.js +83 -0
  62. package/dist/cjs/src/pg/gen-table-interfaces-pg.js.map +1 -0
  63. package/dist/cjs/src/pg/get-sql/insert.js +38 -0
  64. package/dist/cjs/src/pg/get-sql/insert.js.map +1 -0
  65. package/dist/cjs/src/pg/get-sql/merge.js +60 -0
  66. package/dist/cjs/src/pg/get-sql/merge.js.map +1 -0
  67. package/dist/cjs/src/pg/get-sql/update.js +32 -0
  68. package/dist/cjs/src/pg/get-sql/update.js.map +1 -0
  69. package/dist/cjs/src/pg/{insert.js → insert-pg.js} +10 -10
  70. package/dist/cjs/src/pg/insert-pg.js.map +1 -0
  71. package/dist/cjs/src/pg/is-table-or-view-exists.js +1 -2
  72. package/dist/cjs/src/pg/is-table-or-view-exists.js.map +1 -1
  73. package/dist/cjs/src/pg/{pg-pool.js → pool-pg.js} +6 -7
  74. package/dist/cjs/src/pg/pool-pg.js.map +1 -0
  75. package/dist/cjs/src/pg/prepare-value.js +116 -69
  76. package/dist/cjs/src/pg/prepare-value.js.map +1 -1
  77. package/dist/cjs/src/pg/query-pg.js +2 -2
  78. package/dist/cjs/src/pg/query-pg.js.map +1 -1
  79. package/dist/cjs/src/pg/table-schema-pg.js +183 -0
  80. package/dist/cjs/src/pg/table-schema-pg.js.map +1 -0
  81. package/dist/cjs/src/pg/utils-pg.js +99 -0
  82. package/dist/cjs/src/pg/utils-pg.js.map +1 -0
  83. package/dist/cjs/src/utils/utils-array.js +152 -0
  84. package/dist/cjs/src/utils/utils-array.js.map +1 -0
  85. package/dist/cjs/src/utils/utils-dt.js +121 -0
  86. package/dist/cjs/src/utils/utils-dt.js.map +1 -0
  87. package/dist/cjs/src/utils/utils-num.js +127 -0
  88. package/dist/cjs/src/utils/utils-num.js.map +1 -0
  89. package/dist/cjs/src/utils/utils.js +66 -0
  90. package/dist/cjs/src/utils/utils.js.map +1 -0
  91. package/dist/esm/src/@types/i-data-types-ms.js +2 -0
  92. package/dist/esm/src/@types/i-data-types-ms.js.map +1 -0
  93. package/dist/esm/src/@types/i-data-types-pg.js +6 -0
  94. package/dist/esm/src/@types/i-data-types-pg.js.map +1 -0
  95. package/dist/esm/src/@types/i-pg.js +1 -20
  96. package/dist/esm/src/@types/i-pg.js.map +1 -1
  97. package/dist/esm/src/common.js +3 -2
  98. package/dist/esm/src/common.js.map +1 -1
  99. package/dist/esm/src/index.js +24 -15
  100. package/dist/esm/src/index.js.map +1 -1
  101. package/dist/esm/src/ms/gen-table-interfaces-ms.js +36 -0
  102. package/dist/esm/src/ms/gen-table-interfaces-ms.js.map +1 -0
  103. package/dist/esm/src/ms/get-sql/insert.js +33 -0
  104. package/dist/esm/src/ms/get-sql/insert.js.map +1 -0
  105. package/dist/esm/src/ms/get-sql/merge.js +89 -0
  106. package/dist/esm/src/ms/get-sql/merge.js.map +1 -0
  107. package/dist/esm/src/ms/get-sql/update.js +28 -0
  108. package/dist/esm/src/ms/get-sql/update.js.map +1 -0
  109. package/dist/esm/src/{mssql → ms}/pool-ms.js +5 -20
  110. package/dist/esm/src/ms/pool-ms.js.map +1 -0
  111. package/dist/esm/src/ms/prepare-value.js +149 -0
  112. package/dist/esm/src/ms/prepare-value.js.map +1 -0
  113. package/dist/esm/src/{mssql → ms}/query-ms.js +1 -1
  114. package/dist/esm/src/ms/query-ms.js.map +1 -0
  115. package/dist/esm/src/ms/table-schema-ms.js +213 -0
  116. package/dist/esm/src/ms/table-schema-ms.js.map +1 -0
  117. package/dist/esm/src/ms/utils-ms.js +65 -0
  118. package/dist/esm/src/ms/utils-ms.js.map +1 -0
  119. package/dist/esm/src/ms/wrap-transaction-ms.js +28 -0
  120. package/dist/esm/src/ms/wrap-transaction-ms.js.map +1 -0
  121. package/dist/esm/src/pg/gen-table-interfaces-pg.js +55 -0
  122. package/dist/esm/src/pg/gen-table-interfaces-pg.js.map +1 -0
  123. package/dist/esm/src/pg/get-sql/insert.js +34 -0
  124. package/dist/esm/src/pg/get-sql/insert.js.map +1 -0
  125. package/dist/esm/src/pg/get-sql/merge.js +56 -0
  126. package/dist/esm/src/pg/get-sql/merge.js.map +1 -0
  127. package/dist/esm/src/pg/get-sql/update.js +28 -0
  128. package/dist/esm/src/pg/get-sql/update.js.map +1 -0
  129. package/dist/esm/src/pg/{insert.js → insert-pg.js} +10 -10
  130. package/dist/esm/src/pg/insert-pg.js.map +1 -0
  131. package/dist/esm/src/pg/is-table-or-view-exists.js +1 -2
  132. package/dist/esm/src/pg/is-table-or-view-exists.js.map +1 -1
  133. package/dist/esm/src/pg/{pg-pool.js → pool-pg.js} +6 -7
  134. package/dist/esm/src/pg/pool-pg.js.map +1 -0
  135. package/dist/esm/src/pg/prepare-value.js +113 -67
  136. package/dist/esm/src/pg/prepare-value.js.map +1 -1
  137. package/dist/esm/src/pg/query-pg.js +1 -1
  138. package/dist/esm/src/pg/query-pg.js.map +1 -1
  139. package/dist/esm/src/pg/table-schema-pg.js +178 -0
  140. package/dist/esm/src/pg/table-schema-pg.js.map +1 -0
  141. package/dist/esm/src/pg/utils-pg.js +93 -0
  142. package/dist/esm/src/pg/utils-pg.js.map +1 -0
  143. package/dist/esm/src/utils/utils-array.js +125 -0
  144. package/dist/esm/src/utils/utils-array.js.map +1 -0
  145. package/dist/esm/src/utils/utils-dt.js +114 -0
  146. package/dist/esm/src/utils/utils-dt.js.map +1 -0
  147. package/dist/esm/src/utils/utils-num.js +117 -0
  148. package/dist/esm/src/utils/utils-num.js.map +1 -0
  149. package/dist/esm/src/utils/utils.js +58 -0
  150. package/dist/esm/src/utils/utils.js.map +1 -0
  151. package/dist/types/src/@types/i-common.d.ts +35 -3
  152. package/dist/types/src/@types/i-common.d.ts.map +1 -1
  153. package/dist/types/src/@types/i-data-types-ms.d.ts +3 -0
  154. package/dist/types/src/@types/i-data-types-ms.d.ts.map +1 -0
  155. package/dist/types/src/@types/i-data-types-pg.d.ts +35 -0
  156. package/dist/types/src/@types/i-data-types-pg.d.ts.map +1 -0
  157. package/dist/types/src/@types/i-ms.d.ts +26 -126
  158. package/dist/types/src/@types/i-ms.d.ts.map +1 -1
  159. package/dist/types/src/@types/i-pg.d.ts +11 -35
  160. package/dist/types/src/@types/i-pg.d.ts.map +1 -1
  161. package/dist/types/src/common.d.ts +1 -0
  162. package/dist/types/src/common.d.ts.map +1 -1
  163. package/dist/types/src/index.d.ts +28 -16
  164. package/dist/types/src/index.d.ts.map +1 -1
  165. package/dist/types/src/ms/gen-table-interfaces-ms.d.ts +3 -0
  166. package/dist/types/src/ms/gen-table-interfaces-ms.d.ts.map +1 -0
  167. package/dist/types/src/ms/get-sql/insert.d.ts +9 -0
  168. package/dist/types/src/ms/get-sql/insert.d.ts.map +1 -0
  169. package/dist/types/src/ms/get-sql/merge.d.ts +14 -0
  170. package/dist/types/src/ms/get-sql/merge.d.ts.map +1 -0
  171. package/dist/types/src/ms/get-sql/update.d.ts +9 -0
  172. package/dist/types/src/ms/get-sql/update.d.ts.map +1 -0
  173. package/dist/types/src/{mssql → ms}/pool-ms.d.ts +0 -8
  174. package/dist/types/src/ms/pool-ms.d.ts.map +1 -0
  175. package/dist/types/src/ms/prepare-value.d.ts +12 -0
  176. package/dist/types/src/ms/prepare-value.d.ts.map +1 -0
  177. package/dist/types/src/ms/query-ms.d.ts +3 -0
  178. package/dist/types/src/ms/query-ms.d.ts.map +1 -0
  179. package/dist/types/src/ms/table-schema-ms.d.ts +9 -0
  180. package/dist/types/src/ms/table-schema-ms.d.ts.map +1 -0
  181. package/dist/types/src/ms/utils-ms.d.ts +3 -0
  182. package/dist/types/src/ms/utils-ms.d.ts.map +1 -0
  183. package/dist/types/src/ms/wrap-transaction-ms.d.ts +5 -0
  184. package/dist/types/src/ms/wrap-transaction-ms.d.ts.map +1 -0
  185. package/dist/types/src/pg/gen-table-interfaces-pg.d.ts +3 -0
  186. package/dist/types/src/pg/gen-table-interfaces-pg.d.ts.map +1 -0
  187. package/dist/types/src/pg/get-sql/insert.d.ts +9 -0
  188. package/dist/types/src/pg/get-sql/insert.d.ts.map +1 -0
  189. package/dist/types/src/pg/get-sql/merge.d.ts +10 -0
  190. package/dist/types/src/pg/get-sql/merge.d.ts.map +1 -0
  191. package/dist/types/src/pg/get-sql/update.d.ts +9 -0
  192. package/dist/types/src/pg/get-sql/update.d.ts.map +1 -0
  193. package/dist/types/src/pg/{insert.d.ts → insert-pg.d.ts} +3 -3
  194. package/dist/types/src/pg/insert-pg.d.ts.map +1 -0
  195. package/dist/types/src/pg/{pg-pool.d.ts → pool-pg.d.ts} +1 -1
  196. package/dist/types/src/pg/{pg-pool.d.ts.map → pool-pg.d.ts.map} +1 -1
  197. package/dist/types/src/pg/prepare-value.d.ts +3 -1
  198. package/dist/types/src/pg/prepare-value.d.ts.map +1 -1
  199. package/dist/types/src/pg/query-pg.d.ts +3 -2
  200. package/dist/types/src/pg/query-pg.d.ts.map +1 -1
  201. package/dist/types/src/pg/table-schema-pg.d.ts +12 -0
  202. package/dist/types/src/pg/table-schema-pg.d.ts.map +1 -0
  203. package/dist/types/src/pg/utils-pg.d.ts +5 -0
  204. package/dist/types/src/pg/utils-pg.d.ts.map +1 -0
  205. package/dist/types/src/utils/utils-array.d.ts +5 -0
  206. package/dist/types/src/utils/utils-array.d.ts.map +1 -0
  207. package/dist/types/src/utils/utils-dt.d.ts +15 -0
  208. package/dist/types/src/utils/utils-dt.d.ts.map +1 -0
  209. package/dist/types/src/utils/utils-num.d.ts +9 -0
  210. package/dist/types/src/utils/utils-num.d.ts.map +1 -0
  211. package/dist/types/src/utils/utils.d.ts +18 -0
  212. package/dist/types/src/utils/utils.d.ts.map +1 -0
  213. package/package.json +13 -13
  214. package/src/@types/i-common.ts +42 -4
  215. package/src/@types/i-data-types-ms.ts +81 -0
  216. package/src/@types/i-data-types-pg.ts +120 -0
  217. package/src/@types/i-ms.ts +29 -153
  218. package/src/@types/i-pg.ts +11 -36
  219. package/src/common.ts +4 -2
  220. package/src/index.ts +101 -59
  221. package/src/ms/gen-table-interfaces-ms.ts +52 -0
  222. package/src/ms/get-sql/insert.ts +45 -0
  223. package/src/ms/get-sql/merge.ts +118 -0
  224. package/src/ms/get-sql/update.ts +46 -0
  225. package/src/{mssql → ms}/pool-ms.ts +0 -16
  226. package/src/ms/prepare-value.ts +175 -0
  227. package/src/{mssql → ms}/query-ms.ts +2 -2
  228. package/src/ms/table-schema-ms.ts +231 -0
  229. package/src/ms/utils-ms.ts +72 -0
  230. package/src/ms/wrap-transaction-ms.ts +27 -0
  231. package/src/pg/gen-table-interfaces-pg.ts +74 -0
  232. package/src/pg/get-sql/insert.ts +46 -0
  233. package/src/pg/get-sql/merge.ts +70 -0
  234. package/src/pg/get-sql/update.ts +46 -0
  235. package/src/pg/{insert.ts → insert-pg.ts} +9 -9
  236. package/src/pg/prepare-value.ts +129 -67
  237. package/src/pg/query-pg.ts +4 -3
  238. package/src/pg/table-schema-pg.ts +196 -0
  239. package/src/pg/utils-pg.ts +97 -0
  240. package/src/utils/utils-array.ts +133 -0
  241. package/src/utils/utils-dt.ts +123 -0
  242. package/src/utils/utils-num.ts +131 -0
  243. package/src/utils/utils.ts +64 -0
  244. package/dist/cjs/__tests__/02_getValueForSqlMs.spec.js +0 -50
  245. package/dist/cjs/__tests__/02_getValueForSqlMs.spec.js.map +0 -1
  246. package/dist/cjs/src/mssql/get-value-for-sql.js +0 -277
  247. package/dist/cjs/src/mssql/get-value-for-sql.js.map +0 -1
  248. package/dist/cjs/src/mssql/pool-ms.js.map +0 -1
  249. package/dist/cjs/src/mssql/query-ms.js.map +0 -1
  250. package/dist/cjs/src/mssql/sql.js +0 -427
  251. package/dist/cjs/src/mssql/sql.js.map +0 -1
  252. package/dist/cjs/src/mssql/utils.js +0 -36
  253. package/dist/cjs/src/mssql/utils.js.map +0 -1
  254. package/dist/cjs/src/pg/get-merge-sql.js +0 -52
  255. package/dist/cjs/src/pg/get-merge-sql.js.map +0 -1
  256. package/dist/cjs/src/pg/get-update-sql.js +0 -30
  257. package/dist/cjs/src/pg/get-update-sql.js.map +0 -1
  258. package/dist/cjs/src/pg/insert.js.map +0 -1
  259. package/dist/cjs/src/pg/pg-pool.js.map +0 -1
  260. package/dist/cjs/src/pg/table-schema.js +0 -179
  261. package/dist/cjs/src/pg/table-schema.js.map +0 -1
  262. package/dist/cjs/src/utils.js +0 -17
  263. package/dist/cjs/src/utils.js.map +0 -1
  264. package/dist/esm/src/mssql/get-value-for-sql.js +0 -272
  265. package/dist/esm/src/mssql/get-value-for-sql.js.map +0 -1
  266. package/dist/esm/src/mssql/pool-ms.js.map +0 -1
  267. package/dist/esm/src/mssql/query-ms.js.map +0 -1
  268. package/dist/esm/src/mssql/sql.js +0 -390
  269. package/dist/esm/src/mssql/sql.js.map +0 -1
  270. package/dist/esm/src/mssql/utils.js +0 -31
  271. package/dist/esm/src/mssql/utils.js.map +0 -1
  272. package/dist/esm/src/pg/get-merge-sql.js +0 -48
  273. package/dist/esm/src/pg/get-merge-sql.js.map +0 -1
  274. package/dist/esm/src/pg/get-update-sql.js +0 -26
  275. package/dist/esm/src/pg/get-update-sql.js.map +0 -1
  276. package/dist/esm/src/pg/insert.js.map +0 -1
  277. package/dist/esm/src/pg/pg-pool.js.map +0 -1
  278. package/dist/esm/src/pg/table-schema.js +0 -174
  279. package/dist/esm/src/pg/table-schema.js.map +0 -1
  280. package/dist/esm/src/utils.js +0 -14
  281. package/dist/esm/src/utils.js.map +0 -1
  282. package/dist/types/src/mssql/get-value-for-sql.d.ts +0 -11
  283. package/dist/types/src/mssql/get-value-for-sql.d.ts.map +0 -1
  284. package/dist/types/src/mssql/pool-ms.d.ts.map +0 -1
  285. package/dist/types/src/mssql/query-ms.d.ts +0 -3
  286. package/dist/types/src/mssql/query-ms.d.ts.map +0 -1
  287. package/dist/types/src/mssql/sql.d.ts +0 -57
  288. package/dist/types/src/mssql/sql.d.ts.map +0 -1
  289. package/dist/types/src/mssql/utils.d.ts +0 -10
  290. package/dist/types/src/mssql/utils.d.ts.map +0 -1
  291. package/dist/types/src/pg/get-merge-sql.d.ts +0 -9
  292. package/dist/types/src/pg/get-merge-sql.d.ts.map +0 -1
  293. package/dist/types/src/pg/get-update-sql.d.ts +0 -3
  294. package/dist/types/src/pg/get-update-sql.d.ts.map +0 -1
  295. package/dist/types/src/pg/insert.d.ts.map +0 -1
  296. package/dist/types/src/pg/table-schema.d.ts +0 -12
  297. package/dist/types/src/pg/table-schema.d.ts.map +0 -1
  298. package/dist/types/src/utils.d.ts +0 -9
  299. package/dist/types/src/utils.d.ts.map +0 -1
  300. package/src/mssql/get-value-for-sql.ts +0 -325
  301. package/src/mssql/sql.ts +0 -430
  302. package/src/mssql/utils.ts +0 -31
  303. package/src/pg/get-merge-sql.ts +0 -62
  304. package/src/pg/get-update-sql.ts +0 -32
  305. package/src/pg/table-schema.ts +0 -189
  306. package/src/utils.ts +0 -14
  307. /package/src/pg/{pg-pool.ts → pool-pg.ts} +0 -0
@@ -1,85 +1,132 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.prepareSqlValuePg = exports.prepareSqlStringPg = void 0;
4
- // noinspection SqlResolve
5
- const luxon_1 = require("luxon");
6
- const i_pg_1 = require("../@types/i-pg");
7
- const NULL = 'null';
8
- const utc$ = (millis) => luxon_1.DateTime.fromMillis(millis == null ? Date.now() : millis).setZone('UTC');
9
- const prepareSqlStringPg = (s) => {
10
- s = String(s);
11
- if (/['\\]|\${2,}/.test(s)) {
12
- return `$s$${s}$s$`;
3
+ exports.prepareSqlValuePg = exports.prepareSqlStringPg = exports.quoteStringPg = void 0;
4
+ const af_tools_ts_1 = require("af-tools-ts");
5
+ const common_1 = require("../common");
6
+ const utils_dt_1 = require("../utils/utils-dt");
7
+ const utils_num_1 = require("../utils/utils-num");
8
+ const utils_1 = require("../utils/utils");
9
+ const utils_array_1 = require("../utils/utils-array");
10
+ const quoteStringPg = (value) => {
11
+ if (value == null) {
12
+ return common_1.NULL;
13
13
  }
14
- return `'${s}'`;
14
+ return /['\\]|\${2,}/.test(value) ? `$s$${value}$s$` : `'${value}'`;
15
+ };
16
+ exports.quoteStringPg = quoteStringPg;
17
+ const prepareSqlStringPg = (value, fieldDef) => {
18
+ if (value == null) {
19
+ return common_1.NULL;
20
+ }
21
+ let v = String(value);
22
+ const { length = 0, noQuotes } = fieldDef;
23
+ if (length > 0 && v.length > length) {
24
+ v = v.substring(0, length);
25
+ }
26
+ if (noQuotes) {
27
+ return v;
28
+ }
29
+ return (0, exports.quoteStringPg)(v);
15
30
  };
16
31
  exports.prepareSqlStringPg = prepareSqlStringPg;
32
+ const prepareDateTimeOffset = (value, fieldDef) => (0, utils_dt_1.getDatetimeWithPrecisionAndOffset)({ value, fieldDef, defaultDtPrecision: 6 });
33
+ const prepareTimeOffset = (value, fieldDefOriginal) => {
34
+ const fieldDef = { ...fieldDefOriginal, noQuotes: true };
35
+ fieldDef.dateTimeOptions = fieldDef.dateTimeOptions || {};
36
+ const { includeOffset = fieldDef.dataType === 'timetz' } = fieldDef.dateTimeOptions;
37
+ fieldDef.dateTimeOptions.includeOffset = includeOffset;
38
+ const dts = (0, utils_dt_1.getDatetimeWithPrecisionAndOffset)({ value, fieldDef, defaultDtPrecision: 6, stripTrailingZeros: true });
39
+ return dts === common_1.NULL ? common_1.NULL : `'${dts.substring(11, dts.length)}'::${fieldDef.dataType}`;
40
+ };
41
+ const prepareJsonPg = (value, dataType) => {
42
+ const v = (0, utils_1.prepareJSON)(value);
43
+ if (v === common_1.NULL) {
44
+ return common_1.NULL;
45
+ }
46
+ return `${(0, exports.quoteStringPg)(v)}::${dataType}`;
47
+ };
17
48
  const prepareSqlValuePg = (arg) => {
18
49
  const { value, fieldDef } = arg;
19
- if (value == null && fieldDef.isNullable) {
20
- return NULL;
50
+ if (value == null) {
51
+ return common_1.NULL;
21
52
  }
22
- switch (fieldDef.dataType) {
23
- case i_pg_1.EDataTypePg.boolean: {
24
- return value ? 'true' : 'false';
25
- }
26
- case i_pg_1.EDataTypePg.bigint: {
27
- return `'${value}'`;
53
+ const fieldDefWithNoQuotes = { ...fieldDef, noQuotes: true };
54
+ let v = value;
55
+ const { noQuotes, dataType } = fieldDef;
56
+ switch (dataType) {
57
+ case 'bit':
58
+ return (0, af_tools_ts_1.getBool)(value) ? '1' : '0';
59
+ case 'bool':
60
+ case 'boolean':
61
+ return (0, af_tools_ts_1.getBool)(value) ? 'true' : 'false';
62
+ case 'smallint':
63
+ case 'int2':
64
+ return (0, utils_num_1.prepareIntNumber)(value, -32768, 32767);
65
+ case 'int':
66
+ case 'integer':
67
+ case 'int4':
68
+ return (0, utils_num_1.prepareIntNumber)(value, -2147483648, 2147483647);
69
+ case 'bigint':
70
+ case 'int8':
71
+ return (0, utils_num_1.prepareBigIntNumber)(value);
72
+ case 'numeric':
73
+ case 'decimal':
74
+ return (0, utils_num_1.prepareNumeric)(value, fieldDef.precision, fieldDef.scale);
75
+ case 'real':
76
+ case 'float4':
77
+ case 'money':
78
+ case 'double precision':
79
+ case 'float8':
80
+ return (0, utils_num_1.prepareFloatNumber)(value);
81
+ case 'json':
82
+ case 'jsonb':
83
+ return prepareJsonPg(value, dataType);
84
+ case 'uuid':
85
+ return (0, utils_1.prepareUUID)(v, true, fieldDef.noQuotes);
86
+ case 'string':
87
+ case 'text':
88
+ case 'character':
89
+ case 'char':
90
+ case 'varchar':
91
+ case 'character varying':
92
+ return (0, exports.prepareSqlStringPg)(value, fieldDef);
93
+ case 'timestamp':
94
+ case 'timestamp without time zone': {
95
+ // '2023-09-05T02:23:54.105+03:00'::timestamp
96
+ // '2023-09-05T02:23:54.105'::timestamp
97
+ const { includeOffset = false } = fieldDef.dateTimeOptions || {}; // По умолчанию для timestamp includeOffset = false
98
+ const str = prepareDateTimeOffset(value, { ...fieldDef, noQuotes: true, dateTimeOptions: { ...(fieldDef.dateTimeOptions || {}), includeOffset } });
99
+ return str === common_1.NULL ? common_1.NULL : `'${str}'::timestamp`;
28
100
  }
29
- case i_pg_1.EDataTypePg.numeric:
30
- case i_pg_1.EDataTypePg.real: {
31
- const v = Number(value);
32
- return Number.isNaN(v) ? NULL : v;
101
+ case 'timestamptz':
102
+ case 'timestamp with time zone': {
103
+ // '2023-09-05T02:23:54.105'::timestamptz
104
+ // '2023-09-05T02:23:54.105+03:00'::timestamptz
105
+ const str = prepareDateTimeOffset(value, fieldDefWithNoQuotes);
106
+ return str === common_1.NULL ? common_1.NULL : `'${str}'::timestamptz`;
33
107
  }
34
- case i_pg_1.EDataTypePg.integer:
35
- case i_pg_1.EDataTypePg.smallint: {
36
- const v = Number(value);
37
- return Number.isNaN(v) ? NULL : Math.floor(v);
38
- }
39
- case i_pg_1.EDataTypePg.text:
40
- case i_pg_1.EDataTypePg.character:
41
- case i_pg_1.EDataTypePg.varchar:
42
- case i_pg_1.EDataTypePg.uuid: {
43
- return (0, exports.prepareSqlStringPg)(value);
44
- }
45
- case i_pg_1.EDataTypePg.json:
46
- case i_pg_1.EDataTypePg.jsonb: {
47
- return (0, exports.prepareSqlStringPg)(JSON.stringify(value));
48
- }
49
- case i_pg_1.EDataTypePg.date:
50
- case i_pg_1.EDataTypePg.timestamp:
51
- case i_pg_1.EDataTypePg.timestamptz: {
52
- let v = value;
53
- if (value instanceof Date) {
54
- v = +value;
55
- }
56
- else if (value instanceof luxon_1.DateTime) {
57
- v = value.toMillis();
108
+ case 'date':
109
+ // '2023-09-05'::date
110
+ return (0, utils_dt_1.dateTimeValue)(value, fieldDefWithNoQuotes, (dt) => `'${dt.toISODate()}'::date`);
111
+ case 'timetz': // '02:22:17.368+03:00'::time
112
+ case 'time with time zone':
113
+ case 'time': // '02:22:17.368'::time
114
+ case 'time without time zone':
115
+ return prepareTimeOffset(value, fieldDef);
116
+ case 'bytea':
117
+ v = (0, utils_1.binToHexString)(value);
118
+ return v ? (0, utils_1.q)(v, noQuotes) : common_1.NULL;
119
+ case 'ARRAY': {
120
+ v = (0, utils_array_1.arrayToJsonList)(value, fieldDef.arrayType);
121
+ if (v === common_1.NULL) {
122
+ return common_1.NULL;
58
123
  }
59
- else if (typeof value === 'string') {
60
- v = luxon_1.DateTime.fromISO(value).toMillis();
61
- }
62
- switch (fieldDef.dataType) {
63
- case i_pg_1.EDataTypePg.date: {
64
- return `'${typeof v === 'number' ? utc$(v).toISODate() : v}'::date`;
65
- }
66
- case i_pg_1.EDataTypePg.timestamp:
67
- case i_pg_1.EDataTypePg.timestamptz: {
68
- return `'${typeof v === 'number' ? utc$(v).toISO() : v}'::timestamptz`;
69
- }
70
- default:
71
- return `'${v}'`;
72
- }
73
- }
74
- case i_pg_1.EDataTypePg.USER_DEFINED:
75
- return (0, exports.prepareSqlStringPg)(value);
76
- case i_pg_1.EDataTypePg.ARRAY: {
77
- let v = JSON.stringify(value);
78
- v = v.replace(/^\[(.*?)]$/, '{$1}');
79
- return (0, exports.prepareSqlStringPg)(v);
124
+ v = `{${v}}`;
125
+ return fieldDef.noQuotes ? v : (0, exports.quoteStringPg)(v);
80
126
  }
127
+ // 'USER_DEFINED'
81
128
  default:
82
- return (0, exports.prepareSqlStringPg)(value);
129
+ return (0, exports.prepareSqlStringPg)(value, fieldDef);
83
130
  }
84
131
  };
85
132
  exports.prepareSqlValuePg = prepareSqlValuePg;
@@ -1 +1 @@
1
- {"version":3,"file":"prepare-value.js","sourceRoot":"","sources":["../../../../src/pg/prepare-value.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"prepare-value.js","sourceRoot":"","sources":["../../../../src/pg/prepare-value.ts"],"names":[],"mappings":"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"}
@@ -1,10 +1,10 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.queryPg = void 0;
4
- const pg_pool_1 = require("./pg-pool");
4
+ const pool_pg_1 = require("./pool-pg");
5
5
  const common_1 = require("../common");
6
6
  const queryPg = async (connectionId, sqlText, sqlValues, throwError, prefix) => {
7
- const pool = await (0, pg_pool_1.getPoolPg)(connectionId);
7
+ const pool = await (0, pool_pg_1.getPoolPg)(connectionId);
8
8
  let res;
9
9
  try {
10
10
  if (Array.isArray(sqlValues)) {
@@ -1 +1 @@
1
- {"version":3,"file":"query-pg.js","sourceRoot":"","sources":["../../../../src/pg/query-pg.ts"],"names":[],"mappings":";;;AACA,uCAAsC;AACtC,sCAAwC;AAGjC,MAAM,OAAO,GAAG,KAAK,EAC1B,YAAoB,EACpB,OAAe,EACf,SAAiB,EACjB,UAAoB,EACpB,MAAe,EAEqB,EAAE;IACtC,MAAM,IAAI,GAAY,MAAM,IAAA,mBAAS,EAAC,YAAY,CAAC,CAAC;IACpD,IAAI,GAAgB,CAAC;IACrB,IAAI;QACF,IAAI,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YAC5B,GAAG,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;SAC5C;aAAM;YACL,GAAG,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;SACjC;QACD,OAAO,GAAG,CAAC;KACZ;IAAC,OAAO,GAAG,EAAE;QACZ,IAAA,oBAAW,EAAC,GAAG,EAAE,CAAC,UAAU,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;KAChD;AACH,CAAC,CAAC;AApBW,QAAA,OAAO,WAoBlB"}
1
+ {"version":3,"file":"query-pg.js","sourceRoot":"","sources":["../../../../src/pg/query-pg.ts"],"names":[],"mappings":";;;AACA,uCAAsC;AACtC,sCAAwC;AAIjC,MAAM,OAAO,GAAG,KAAK,EAC1B,YAAoB,EACpB,OAAe,EACf,SAAiB,EACjB,UAAoB,EACpB,MAAe,EAEqB,EAAE;IACtC,MAAM,IAAI,GAAY,MAAM,IAAA,mBAAS,EAAC,YAAY,CAAC,CAAC;IACpD,IAAI,GAAgB,CAAC;IACrB,IAAI,CAAC;QACH,IAAI,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;YAC7B,GAAG,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAC7C,CAAC;aAAM,CAAC;YACN,GAAG,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAClC,CAAC;QACD,OAAO,GAAG,CAAC;IACb,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,IAAA,oBAAW,EAAC,GAAG,EAAE,CAAC,UAAU,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;IACjD,CAAC;AACH,CAAC,CAAC;AApBW,QAAA,OAAO,WAoBlB"}
@@ -0,0 +1,183 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getFieldsAndValuesPg = exports.getTableSchemaPg = void 0;
4
+ // noinspection SqlResolve
5
+ const query_pg_1 = require("./query-pg");
6
+ const logger_error_1 = require("../logger-error");
7
+ const common_1 = require("../common");
8
+ const utils_1 = require("../utils/utils");
9
+ const utils_pg_1 = require("./utils-pg");
10
+ // commonSchemaAndTable: <schema>.<table> : Staff.nnPersones-personGuid
11
+ // schemaAndTablePg: "<schema>"."<table>" : "Staff"."nnPersones-personGuid"
12
+ const tableSchemaHash = {};
13
+ const getColumnsSchemaPg_ = async (connectionId, commonSchemaAndTable) => {
14
+ const [schema, table] = utils_1.schemaTable.to.common(commonSchemaAndTable).split('.');
15
+ const sql = `SELECT column_name,
16
+ column_default,
17
+ is_nullable,
18
+ data_type,
19
+ character_maximum_length,
20
+ numeric_precision,
21
+ numeric_precision_radix,
22
+ numeric_scale,
23
+ datetime_precision,
24
+ udt_name,
25
+ is_generated
26
+ FROM information_schema.columns
27
+ WHERE table_name = '${table}'
28
+ AND table_schema = '${schema}';`;
29
+ const result = await (0, query_pg_1.queryPg)(connectionId, sql);
30
+ const fields = result?.rows || [];
31
+ const columnsSchema = {};
32
+ fields.forEach((fieldDef) => {
33
+ const columnDefault = fieldDef.column_default != null ? fieldDef.column_default : undefined;
34
+ const name = fieldDef.column_name;
35
+ const dataType = (0, utils_pg_1.getNormalizedTypePg)(fieldDef.data_type);
36
+ const fieldSchema = {
37
+ name,
38
+ isNullable: /yes/i.test(fieldDef.is_nullable || ''),
39
+ columnDefault: fieldDef.column_default,
40
+ hasDefault: columnDefault != null,
41
+ dataType,
42
+ length: fieldDef.character_maximum_length,
43
+ precision: fieldDef.numeric_precision,
44
+ scale: fieldDef.numeric_scale,
45
+ radix: fieldDef.numeric_precision_radix,
46
+ dtPrecision: fieldDef.datetime_precision,
47
+ arrayType: dataType === 'ARRAY' ? (0, utils_pg_1.getTypeByUdtNamePg)(fieldDef.udt_name) : undefined,
48
+ readOnly: fieldDef.is_generated === 'ALWAYS', // boolean;
49
+ };
50
+ Object.entries(fieldSchema).forEach(([prop, value]) => {
51
+ if (value == null) {
52
+ delete fieldSchema[prop];
53
+ }
54
+ });
55
+ columnsSchema[name] = fieldSchema;
56
+ });
57
+ return columnsSchema;
58
+ };
59
+ const getPrimaryKey = async (connectionId, commonSchemaAndTable) => {
60
+ const schemaTablePg = utils_1.schemaTable.to.pg(commonSchemaAndTable);
61
+ const sql = `
62
+ SELECT a.attname as f
63
+ FROM pg_index i
64
+ JOIN pg_attribute a
65
+ ON a.attrelid = i.indrelid AND a.attnum = ANY (i.indkey)
66
+ WHERE i.indrelid = '${schemaTablePg}'::regclass
67
+ AND i.indisprimary;`;
68
+ const result = await (0, query_pg_1.queryPg)(connectionId, sql);
69
+ return (result?.rows || []).map(({ f }) => f);
70
+ };
71
+ const getUniqueConstraints = async (connectionId, commonSchemaAndTable) => {
72
+ const schemaTablePg = utils_1.schemaTable.to.pg(commonSchemaAndTable);
73
+ const [schema, table] = utils_1.schemaTable.to.common(commonSchemaAndTable).split('.');
74
+ const sql = `
75
+ SELECT UI.cn as cn, UI.cols as cols, CASE WHEN UC.cn IS NULL THEN 'UX' ELSE 'UC' END AS typ
76
+ FROM (SELECT c.relname as cn, array_to_json(array_agg(a.attname ORDER BY a.attname)) AS cols
77
+ FROM pg_index i
78
+ JOIN pg_attribute a ON a.attrelid = i.indrelid AND a.attnum = ANY (i.indkey)
79
+ JOIN pg_class AS c ON c.oid = i.indexrelid
80
+ WHERE i.indrelid = '${schemaTablePg}'::regclass
81
+ AND i.indisunique
82
+ AND NOT i.indisprimary
83
+ GROUP BY c.relname) AS UI
84
+ LEFT OUTER JOIN (SELECT ccu.constraint_name AS cn
85
+ FROM information_schema.table_constraints tc
86
+ JOIN information_schema.constraint_column_usage AS ccu USING (constraint_schema, constraint_name)
87
+ JOIN information_schema.columns AS c ON c.table_schema = tc.constraint_schema
88
+ AND tc.table_name = c.table_name AND ccu.column_name = c.column_name
89
+ WHERE tc.table_schema = '${schema}'
90
+ AND tc.table_name = '${table}'
91
+ AND tc.constraint_type = 'UNIQUE'
92
+ GROUP BY ccu.constraint_name) AS UC ON UC.cn = UI.cn
93
+ ORDER BY CASE WHEN UC.cn IS NULL THEN 2 ELSE 1 END
94
+ `;
95
+ const result = await (0, query_pg_1.queryPg)(connectionId, sql);
96
+ const uc = {};
97
+ result?.rows?.forEach(({ cn, cols }) => {
98
+ uc[cn] = cols;
99
+ });
100
+ return uc;
101
+ };
102
+ const getSerials = async (connectionId, commonSchemaAndTable) => {
103
+ const fqName = utils_1.schemaTable.to.common(commonSchemaAndTable);
104
+ const sql = `
105
+ WITH fq_objects AS (SELECT c.oid,
106
+ n.nspname || '.' || c.relname AS fqname,
107
+ c.relkind,
108
+ c.relname AS relation
109
+ FROM pg_class c
110
+ JOIN pg_namespace n ON n.oid = c.relnamespace),
111
+ sequences AS (SELECT oid, fqname FROM fq_objects WHERE relkind = 'S'),
112
+ tables AS (SELECT oid, fqname FROM fq_objects WHERE relkind = 'r')
113
+ SELECT t.fqname AS tbl, array_to_json(array_agg(a.attname ORDER BY a.attname)) AS cols
114
+ FROM pg_depend d
115
+ JOIN sequences s ON s.oid = d.objid
116
+ JOIN tables t ON t.oid = d.refobjid
117
+ JOIN pg_attribute a ON a.attrelid = d.refobjid and a.attnum = d.refobjsubid
118
+ WHERE d.deptype = 'a'
119
+ AND t.fqname = '${fqName}'
120
+ GROUP BY t.fqname
121
+ `;
122
+ const result = await (0, query_pg_1.queryPg)(connectionId, sql);
123
+ return result?.rows?.[0]?.cols || [];
124
+ };
125
+ const getTableSchemaPg = async (connectionId, commonSchemaAndTable) => {
126
+ let tableSchema = tableSchemaHash[commonSchemaAndTable];
127
+ if (tableSchema) {
128
+ return tableSchema;
129
+ }
130
+ try {
131
+ const columnsSchema = await getColumnsSchemaPg_(connectionId, commonSchemaAndTable);
132
+ const pk = await getPrimaryKey(connectionId, commonSchemaAndTable);
133
+ const uc = await getUniqueConstraints(connectionId, commonSchemaAndTable);
134
+ const serialsFields = await getSerials(connectionId, commonSchemaAndTable);
135
+ const defaults = {};
136
+ Object.values(columnsSchema).forEach((fieldDef) => {
137
+ const { name: f = '', columnDefault, hasDefault } = fieldDef;
138
+ if (hasDefault && !serialsFields.includes(f)) {
139
+ defaults[f] = `${columnDefault}`;
140
+ }
141
+ });
142
+ const fieldsArray = Object.keys(columnsSchema);
143
+ const readOnlyFields = Object.values(columnsSchema).filter((s) => s.readOnly).map((s) => s.name);
144
+ const fieldsWoSerialsAndRO = fieldsArray.filter((f) => !serialsFields.includes(f) && !readOnlyFields.includes(f));
145
+ tableSchema = {
146
+ columnsSchema, pk, uc, defaults, serialsFields, fieldsArray, fieldsWoSerialsAndRO, readOnlyFields,
147
+ };
148
+ tableSchemaHash[commonSchemaAndTable] = tableSchema;
149
+ }
150
+ catch (err) {
151
+ logger_error_1.logger.error(`Failed to get schema for table ${commonSchemaAndTable}`);
152
+ logger_error_1.logger.error(err);
153
+ await (0, common_1.graceExit)();
154
+ }
155
+ return tableSchema;
156
+ };
157
+ exports.getTableSchemaPg = getTableSchemaPg;
158
+ const getFieldsAndValuesPg = (record, columnsSchema) => {
159
+ const recordNormalized = {};
160
+ Object.entries(record).forEach(([f, v]) => {
161
+ const { dataType } = columnsSchema[f] || {};
162
+ if (!dataType) {
163
+ return;
164
+ }
165
+ if ((dataType === 'jsonb' || dataType === 'json') && Array.isArray(v)) {
166
+ recordNormalized[f] = JSON.stringify(v);
167
+ }
168
+ else {
169
+ recordNormalized[f] = v;
170
+ }
171
+ });
172
+ const fields = Object.keys(recordNormalized);
173
+ const fieldsList = fields.join(', ');
174
+ const values = Object.values(recordNormalized);
175
+ const positionsList = fields.map((__, i) => `$${++i}`).join(', ');
176
+ const setFields = fields.map((f, i) => `${f} = $${++i}`).join(', ');
177
+ const upsertFields = fields.map((f) => `${f} = EXCLUDED.${f}`).join(',\n');
178
+ return {
179
+ fields, fieldsList, values, positionsList, setFields, upsertFields,
180
+ };
181
+ };
182
+ exports.getFieldsAndValuesPg = getFieldsAndValuesPg;
183
+ //# sourceMappingURL=table-schema-pg.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"table-schema-pg.js","sourceRoot":"","sources":["../../../../src/pg/table-schema-pg.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,99 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getNormalizedTypePg = exports.getTypeByUdtNamePg = exports.getJsTypeByTypePg = void 0;
4
+ const getJsTypeByTypePg = (dataType, arrayType) => {
5
+ switch (dataType) {
6
+ case 'boolean':
7
+ return 'boolean';
8
+ case 'bigint':
9
+ return 'string | number';
10
+ case 'integer':
11
+ case 'numeric':
12
+ case 'real':
13
+ case 'smallint':
14
+ return 'number';
15
+ case 'text':
16
+ case 'character':
17
+ case 'varchar':
18
+ case 'uuid':
19
+ return 'string';
20
+ case 'json':
21
+ case 'jsonb':
22
+ return 'any';
23
+ case 'date':
24
+ case 'timestamptz':
25
+ case 'timestamp':
26
+ return 'string | Date | number';
27
+ case 'USER_DEFINED':
28
+ return 'string';
29
+ case 'ARRAY': {
30
+ const jsType = (0, exports.getJsTypeByTypePg)(arrayType);
31
+ return `${jsType}[]`;
32
+ }
33
+ default:
34
+ return 'string';
35
+ }
36
+ };
37
+ exports.getJsTypeByTypePg = getJsTypeByTypePg;
38
+ const udtNames2TypeMap = {
39
+ _bit: 'bit',
40
+ _bool: 'bool',
41
+ _box: 'box',
42
+ _bytea: 'bytea',
43
+ _char: 'char',
44
+ _circle: 'circle',
45
+ _date: 'date',
46
+ _float4: 'real',
47
+ _float8: 'double precision',
48
+ _inet: 'inet',
49
+ _int2: 'smallint',
50
+ _int4: 'int',
51
+ _int8: 'bigint',
52
+ _interval: 'interval',
53
+ _lseg: 'lseg',
54
+ _macaddr: 'macaddr',
55
+ _money: 'money',
56
+ _numeric: 'numeric',
57
+ _path: 'path',
58
+ _point: 'point',
59
+ _polygon: 'polygon',
60
+ _text: 'text',
61
+ _time: 'time',
62
+ _timestamp: 'timestamp',
63
+ _timestamptz: 'timestamptz',
64
+ _timetz: 'timetz',
65
+ _uuid: 'uuid',
66
+ _varchar: 'varchar',
67
+ _xml: 'xml',
68
+ // _oid: 'oid',
69
+ // _abstime: 'abstime',
70
+ // _name: 'name',
71
+ };
72
+ const getTypeByUdtNamePg = (udtName) => {
73
+ const dataType = udtNames2TypeMap[udtName];
74
+ return dataType || 'varchar';
75
+ };
76
+ exports.getTypeByUdtNamePg = getTypeByUdtNamePg;
77
+ const typeNormalizationMap = {
78
+ bool: 'boolean',
79
+ int2: 'smallint',
80
+ integer: 'int',
81
+ int4: 'int',
82
+ int8: 'bigint',
83
+ serial2: 'smallserial',
84
+ serial4: 'serial',
85
+ serial8: 'bigserial',
86
+ decimal: 'numeric',
87
+ float4: 'real',
88
+ float8: 'double precision',
89
+ character: 'char',
90
+ 'character varying': 'varchar',
91
+ 'timestamp with time zone': 'timestamptz',
92
+ 'timestamp without time zone': 'timestamp',
93
+ 'time without time zone': 'time',
94
+ 'time with time zone': 'timetz',
95
+ 'bit varying': 'varbit',
96
+ };
97
+ const getNormalizedTypePg = (pgDataType) => typeNormalizationMap[pgDataType] || pgDataType;
98
+ exports.getNormalizedTypePg = getNormalizedTypePg;
99
+ //# sourceMappingURL=utils-pg.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils-pg.js","sourceRoot":"","sources":["../../../../src/pg/utils-pg.ts"],"names":[],"mappings":"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"}