@aerokit/sdk 12.44.0

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 (399) hide show
  1. package/LICENSE +277 -0
  2. package/README.md +170 -0
  3. package/dist/cjs/bpm/deployer.js +57 -0
  4. package/dist/cjs/bpm/index.js +35 -0
  5. package/dist/cjs/bpm/process.js +636 -0
  6. package/dist/cjs/bpm/tasks.js +973 -0
  7. package/dist/cjs/bpm/values.js +82 -0
  8. package/dist/cjs/cache/cache.js +64 -0
  9. package/dist/cjs/cache/index.js +26 -0
  10. package/dist/cjs/cms/cmis.js +689 -0
  11. package/dist/cjs/cms/index.js +26 -0
  12. package/dist/cjs/component/decorators.js +126 -0
  13. package/dist/cjs/component/index.js +36 -0
  14. package/dist/cjs/core/configurations.js +110 -0
  15. package/dist/cjs/core/context.js +47 -0
  16. package/dist/cjs/core/env.js +45 -0
  17. package/dist/cjs/core/globals.js +54 -0
  18. package/dist/cjs/core/index.js +35 -0
  19. package/dist/cjs/db/dao.js +795 -0
  20. package/dist/cjs/db/database.js +904 -0
  21. package/dist/cjs/db/decorators.js +167 -0
  22. package/dist/cjs/db/index.js +72 -0
  23. package/dist/cjs/db/insert.js +51 -0
  24. package/dist/cjs/db/orm.js +245 -0
  25. package/dist/cjs/db/ormstatements.js +243 -0
  26. package/dist/cjs/db/procedure.js +112 -0
  27. package/dist/cjs/db/query.js +57 -0
  28. package/dist/cjs/db/repository.js +148 -0
  29. package/dist/cjs/db/sequence.js +59 -0
  30. package/dist/cjs/db/sql.js +516 -0
  31. package/dist/cjs/db/store.js +172 -0
  32. package/dist/cjs/db/translator.js +100 -0
  33. package/dist/cjs/db/update.js +43 -0
  34. package/dist/cjs/etcd/client.js +174 -0
  35. package/dist/cjs/etcd/index.js +26 -0
  36. package/dist/cjs/extensions/decorators.js +40 -0
  37. package/dist/cjs/extensions/extensions.js +108 -0
  38. package/dist/cjs/extensions/index.js +39 -0
  39. package/dist/cjs/git/client.js +277 -0
  40. package/dist/cjs/git/index.js +26 -0
  41. package/dist/cjs/http/client-async.js +224 -0
  42. package/dist/cjs/http/client.js +145 -0
  43. package/dist/cjs/http/decorators.js +76 -0
  44. package/dist/cjs/http/errors/ForbiddenError.js +41 -0
  45. package/dist/cjs/http/errors/ValidationError.js +41 -0
  46. package/dist/cjs/http/errors.js +26 -0
  47. package/dist/cjs/http/index.js +59 -0
  48. package/dist/cjs/http/request.js +281 -0
  49. package/dist/cjs/http/response.js +452 -0
  50. package/dist/cjs/http/rs/resource-common.js +32 -0
  51. package/dist/cjs/http/rs/resource-http-controller.js +306 -0
  52. package/dist/cjs/http/rs/resource-mappings.js +130 -0
  53. package/dist/cjs/http/rs/resource-method.js +218 -0
  54. package/dist/cjs/http/rs/resource.js +232 -0
  55. package/dist/cjs/http/rs.js +31 -0
  56. package/dist/cjs/http/session.js +124 -0
  57. package/dist/cjs/http/upload.js +144 -0
  58. package/dist/cjs/http/utils.js +106 -0
  59. package/dist/cjs/index.js +1 -0
  60. package/dist/cjs/indexing/index.js +29 -0
  61. package/dist/cjs/indexing/searcher.js +70 -0
  62. package/dist/cjs/indexing/writer.js +45 -0
  63. package/dist/cjs/integrations/index.js +26 -0
  64. package/dist/cjs/integrations/integrations.js +55 -0
  65. package/dist/cjs/io/bytes.js +101 -0
  66. package/dist/cjs/io/files.js +344 -0
  67. package/dist/cjs/io/image.js +43 -0
  68. package/dist/cjs/io/index.js +38 -0
  69. package/dist/cjs/io/streams.js +243 -0
  70. package/dist/cjs/io/zip.js +251 -0
  71. package/dist/cjs/job/decorators.js +40 -0
  72. package/dist/cjs/job/index.js +39 -0
  73. package/dist/cjs/job/scheduler.js +347 -0
  74. package/dist/cjs/junit/index.js +18 -0
  75. package/dist/cjs/junit/junit.js +67 -0
  76. package/dist/cjs/kafka/consumer.js +70 -0
  77. package/dist/cjs/kafka/index.js +29 -0
  78. package/dist/cjs/kafka/producer.js +70 -0
  79. package/dist/cjs/log/index.js +26 -0
  80. package/dist/cjs/log/logging.js +174 -0
  81. package/dist/cjs/mail/client.js +153 -0
  82. package/dist/cjs/mail/index.js +26 -0
  83. package/dist/cjs/messaging/consumer.js +83 -0
  84. package/dist/cjs/messaging/decorators.js +40 -0
  85. package/dist/cjs/messaging/index.js +42 -0
  86. package/dist/cjs/messaging/producer.js +81 -0
  87. package/dist/cjs/mongodb/client.js +627 -0
  88. package/dist/cjs/mongodb/dao.js +390 -0
  89. package/dist/cjs/mongodb/index.js +36 -0
  90. package/dist/cjs/net/decorators.js +40 -0
  91. package/dist/cjs/net/index.js +42 -0
  92. package/dist/cjs/net/soap.js +228 -0
  93. package/dist/cjs/net/websockets.js +151 -0
  94. package/dist/cjs/net/wrappers/onClose.js +2 -0
  95. package/dist/cjs/net/wrappers/onError.js +2 -0
  96. package/dist/cjs/net/wrappers/onMessage.js +2 -0
  97. package/dist/cjs/net/wrappers/onOpen.js +2 -0
  98. package/dist/cjs/pdf/index.js +26 -0
  99. package/dist/cjs/pdf/pdf.js +160 -0
  100. package/dist/cjs/platform/command.js +47 -0
  101. package/dist/cjs/platform/engines.js +70 -0
  102. package/dist/cjs/platform/index.js +47 -0
  103. package/dist/cjs/platform/lifecycle.js +49 -0
  104. package/dist/cjs/platform/os.js +51 -0
  105. package/dist/cjs/platform/problems.js +127 -0
  106. package/dist/cjs/platform/registry.js +319 -0
  107. package/dist/cjs/platform/repository.js +498 -0
  108. package/dist/cjs/platform/workspace.js +574 -0
  109. package/dist/cjs/qldb/index.js +26 -0
  110. package/dist/cjs/qldb/qldb.js +24 -0
  111. package/dist/cjs/rabbitmq/consumer.js +50 -0
  112. package/dist/cjs/rabbitmq/index.js +29 -0
  113. package/dist/cjs/rabbitmq/producer.js +38 -0
  114. package/dist/cjs/redis/client.js +190 -0
  115. package/dist/cjs/redis/index.js +26 -0
  116. package/dist/cjs/security/decorators.js +48 -0
  117. package/dist/cjs/security/index.js +40 -0
  118. package/dist/cjs/security/oauth.js +75 -0
  119. package/dist/cjs/security/user.js +88 -0
  120. package/dist/cjs/template/engines.js +139 -0
  121. package/dist/cjs/template/index.js +26 -0
  122. package/dist/cjs/utils/alphanumeric.js +107 -0
  123. package/dist/cjs/utils/base64.js +104 -0
  124. package/dist/cjs/utils/converter.js +78 -0
  125. package/dist/cjs/utils/digest.js +167 -0
  126. package/dist/cjs/utils/escape.js +160 -0
  127. package/dist/cjs/utils/hex.js +104 -0
  128. package/dist/cjs/utils/index.js +68 -0
  129. package/dist/cjs/utils/jsonpath.js +489 -0
  130. package/dist/cjs/utils/qrcode.js +41 -0
  131. package/dist/cjs/utils/url.js +82 -0
  132. package/dist/cjs/utils/utf8.js +61 -0
  133. package/dist/cjs/utils/uuid.js +48 -0
  134. package/dist/cjs/utils/xml.js +57 -0
  135. package/dist/dts/bpm/deployer.d.ts +29 -0
  136. package/dist/dts/bpm/index.d.ts +8 -0
  137. package/dist/dts/bpm/process.d.ts +433 -0
  138. package/dist/dts/bpm/tasks.d.ts +2022 -0
  139. package/dist/dts/bpm/values.d.ts +38 -0
  140. package/dist/dts/cache/cache.d.ts +30 -0
  141. package/dist/dts/cache/index.d.ts +2 -0
  142. package/dist/dts/cms/cmis.d.ts +413 -0
  143. package/dist/dts/cms/index.d.ts +2 -0
  144. package/dist/dts/component/decorators.d.ts +52 -0
  145. package/dist/dts/component/index.d.ts +2 -0
  146. package/dist/dts/core/configurations.d.ts +65 -0
  147. package/dist/dts/core/context.d.ts +19 -0
  148. package/dist/dts/core/env.d.ts +23 -0
  149. package/dist/dts/core/globals.d.ts +30 -0
  150. package/dist/dts/core/index.d.ts +8 -0
  151. package/dist/dts/db/dao.d.ts +8 -0
  152. package/dist/dts/db/database.d.ts +507 -0
  153. package/dist/dts/db/decorators.d.ts +89 -0
  154. package/dist/dts/db/index.d.ts +25 -0
  155. package/dist/dts/db/insert.d.ts +32 -0
  156. package/dist/dts/db/orm.d.ts +44 -0
  157. package/dist/dts/db/ormstatements.d.ts +4 -0
  158. package/dist/dts/db/procedure.d.ts +25 -0
  159. package/dist/dts/db/query.d.ts +48 -0
  160. package/dist/dts/db/repository.d.ts +64 -0
  161. package/dist/dts/db/sequence.d.ts +34 -0
  162. package/dist/dts/db/sql.d.ts +267 -0
  163. package/dist/dts/db/store.d.ts +138 -0
  164. package/dist/dts/db/translator.d.ts +26 -0
  165. package/dist/dts/db/update.d.ts +21 -0
  166. package/dist/dts/etcd/client.d.ts +92 -0
  167. package/dist/dts/etcd/index.d.ts +2 -0
  168. package/dist/dts/extensions/decorators.d.ts +11 -0
  169. package/dist/dts/extensions/extensions.d.ts +41 -0
  170. package/dist/dts/extensions/index.d.ts +4 -0
  171. package/dist/dts/git/client.d.ts +478 -0
  172. package/dist/dts/git/index.d.ts +2 -0
  173. package/dist/dts/http/client-async.d.ts +158 -0
  174. package/dist/dts/http/client.d.ts +180 -0
  175. package/dist/dts/http/decorators.d.ts +11 -0
  176. package/dist/dts/http/errors/ForbiddenError.d.ts +20 -0
  177. package/dist/dts/http/errors/ValidationError.d.ts +20 -0
  178. package/dist/dts/http/errors.d.ts +2 -0
  179. package/dist/dts/http/index.d.ts +16 -0
  180. package/dist/dts/http/request.d.ts +158 -0
  181. package/dist/dts/http/response.d.ts +281 -0
  182. package/dist/dts/http/rs/resource-common.d.ts +11 -0
  183. package/dist/dts/http/rs/resource-http-controller.d.ts +43 -0
  184. package/dist/dts/http/rs/resource-mappings.d.ts +70 -0
  185. package/dist/dts/http/rs/resource-method.d.ts +206 -0
  186. package/dist/dts/http/rs/resource.d.ts +126 -0
  187. package/dist/dts/http/rs.d.ts +4 -0
  188. package/dist/dts/http/session.d.ts +81 -0
  189. package/dist/dts/http/upload.d.ts +100 -0
  190. package/dist/dts/http/utils.d.ts +54 -0
  191. package/dist/dts/index.d.ts +0 -0
  192. package/dist/dts/indexing/index.d.ts +4 -0
  193. package/dist/dts/indexing/searcher.d.ts +47 -0
  194. package/dist/dts/indexing/writer.d.ts +22 -0
  195. package/dist/dts/integrations/index.d.ts +2 -0
  196. package/dist/dts/integrations/integrations.d.ts +118 -0
  197. package/dist/dts/io/bytes.d.ts +56 -0
  198. package/dist/dts/io/files.d.ts +261 -0
  199. package/dist/dts/io/image.d.ts +22 -0
  200. package/dist/dts/io/index.d.ts +10 -0
  201. package/dist/dts/io/streams.d.ts +172 -0
  202. package/dist/dts/io/zip.d.ts +178 -0
  203. package/dist/dts/job/decorators.d.ts +11 -0
  204. package/dist/dts/job/index.d.ts +4 -0
  205. package/dist/dts/job/scheduler.d.ts +250 -0
  206. package/dist/dts/junit/index.d.ts +1 -0
  207. package/dist/dts/junit/junit.d.ts +50 -0
  208. package/dist/dts/kafka/consumer.d.ts +48 -0
  209. package/dist/dts/kafka/index.d.ts +4 -0
  210. package/dist/dts/kafka/producer.d.ts +50 -0
  211. package/dist/dts/log/index.d.ts +2 -0
  212. package/dist/dts/log/logging.d.ts +102 -0
  213. package/dist/dts/mail/client.d.ts +90 -0
  214. package/dist/dts/mail/index.d.ts +2 -0
  215. package/dist/dts/messaging/consumer.d.ts +61 -0
  216. package/dist/dts/messaging/decorators.d.ts +11 -0
  217. package/dist/dts/messaging/index.d.ts +6 -0
  218. package/dist/dts/messaging/producer.d.ts +59 -0
  219. package/dist/dts/mongodb/client.d.ts +367 -0
  220. package/dist/dts/mongodb/dao.d.ts +24 -0
  221. package/dist/dts/mongodb/index.d.ts +2 -0
  222. package/dist/dts/net/decorators.d.ts +11 -0
  223. package/dist/dts/net/index.d.ts +6 -0
  224. package/dist/dts/net/soap.d.ts +115 -0
  225. package/dist/dts/net/websockets.d.ts +100 -0
  226. package/dist/dts/net/wrappers/onClose.d.ts +0 -0
  227. package/dist/dts/net/wrappers/onError.d.ts +0 -0
  228. package/dist/dts/net/wrappers/onMessage.d.ts +0 -0
  229. package/dist/dts/net/wrappers/onOpen.d.ts +0 -0
  230. package/dist/dts/pdf/index.d.ts +2 -0
  231. package/dist/dts/pdf/pdf.d.ts +72 -0
  232. package/dist/dts/platform/command.d.ts +41 -0
  233. package/dist/dts/platform/engines.d.ts +35 -0
  234. package/dist/dts/platform/index.d.ts +16 -0
  235. package/dist/dts/platform/lifecycle.d.ts +22 -0
  236. package/dist/dts/platform/os.d.ts +23 -0
  237. package/dist/dts/platform/problems.d.ts +114 -0
  238. package/dist/dts/platform/registry.d.ts +227 -0
  239. package/dist/dts/platform/repository.d.ts +354 -0
  240. package/dist/dts/platform/workspace.d.ts +421 -0
  241. package/dist/dts/qldb/index.d.ts +2 -0
  242. package/dist/dts/qldb/qldb.d.ts +1 -0
  243. package/dist/dts/rabbitmq/consumer.d.ts +25 -0
  244. package/dist/dts/rabbitmq/index.d.ts +4 -0
  245. package/dist/dts/rabbitmq/producer.d.ts +15 -0
  246. package/dist/dts/redis/client.d.ts +134 -0
  247. package/dist/dts/redis/index.d.ts +2 -0
  248. package/dist/dts/security/decorators.d.ts +4 -0
  249. package/dist/dts/security/index.d.ts +5 -0
  250. package/dist/dts/security/oauth.d.ts +39 -0
  251. package/dist/dts/security/user.d.ts +51 -0
  252. package/dist/dts/template/engines.d.ts +98 -0
  253. package/dist/dts/template/index.d.ts +2 -0
  254. package/dist/dts/utils/alphanumeric.d.ts +39 -0
  255. package/dist/dts/utils/base64.d.ts +48 -0
  256. package/dist/dts/utils/converter.d.ts +44 -0
  257. package/dist/dts/utils/digest.d.ts +50 -0
  258. package/dist/dts/utils/escape.d.ts +110 -0
  259. package/dist/dts/utils/hex.d.ts +48 -0
  260. package/dist/dts/utils/index.d.ts +23 -0
  261. package/dist/dts/utils/jsonpath.d.ts +22 -0
  262. package/dist/dts/utils/qrcode.d.ts +16 -0
  263. package/dist/dts/utils/url.d.ts +50 -0
  264. package/dist/dts/utils/utf8.d.ts +33 -0
  265. package/dist/dts/utils/uuid.d.ts +21 -0
  266. package/dist/dts/utils/xml.d.ts +22 -0
  267. package/dist/esm/bpm/deployer.mjs +38 -0
  268. package/dist/esm/bpm/index.mjs +15 -0
  269. package/dist/esm/bpm/process.mjs +617 -0
  270. package/dist/esm/bpm/tasks.mjs +954 -0
  271. package/dist/esm/bpm/values.mjs +63 -0
  272. package/dist/esm/cache/cache.mjs +45 -0
  273. package/dist/esm/cache/index.mjs +6 -0
  274. package/dist/esm/cms/cmis.mjs +660 -0
  275. package/dist/esm/cms/index.mjs +6 -0
  276. package/dist/esm/component/decorators.mjs +107 -0
  277. package/dist/esm/component/index.mjs +6 -0
  278. package/dist/esm/core/configurations.mjs +91 -0
  279. package/dist/esm/core/context.mjs +28 -0
  280. package/dist/esm/core/env.mjs +26 -0
  281. package/dist/esm/core/globals.mjs +35 -0
  282. package/dist/esm/core/index.mjs +15 -0
  283. package/dist/esm/db/dao.mjs +775 -0
  284. package/dist/esm/db/database.mjs +885 -0
  285. package/dist/esm/db/decorators.mjs +148 -0
  286. package/dist/esm/db/index.mjs +42 -0
  287. package/dist/esm/db/insert.mjs +32 -0
  288. package/dist/esm/db/orm.mjs +225 -0
  289. package/dist/esm/db/ormstatements.mjs +223 -0
  290. package/dist/esm/db/procedure.mjs +93 -0
  291. package/dist/esm/db/query.mjs +38 -0
  292. package/dist/esm/db/repository.mjs +129 -0
  293. package/dist/esm/db/sequence.mjs +40 -0
  294. package/dist/esm/db/sql.mjs +497 -0
  295. package/dist/esm/db/store.mjs +153 -0
  296. package/dist/esm/db/translator.mjs +81 -0
  297. package/dist/esm/db/update.mjs +24 -0
  298. package/dist/esm/etcd/client.mjs +155 -0
  299. package/dist/esm/etcd/index.mjs +6 -0
  300. package/dist/esm/extensions/decorators.mjs +21 -0
  301. package/dist/esm/extensions/extensions.mjs +89 -0
  302. package/dist/esm/extensions/index.mjs +9 -0
  303. package/dist/esm/git/client.mjs +258 -0
  304. package/dist/esm/git/index.mjs +6 -0
  305. package/dist/esm/http/client-async.mjs +205 -0
  306. package/dist/esm/http/client.mjs +126 -0
  307. package/dist/esm/http/decorators.mjs +47 -0
  308. package/dist/esm/http/errors/ForbiddenError.mjs +22 -0
  309. package/dist/esm/http/errors/ValidationError.mjs +22 -0
  310. package/dist/esm/http/errors.mjs +7 -0
  311. package/dist/esm/http/index.mjs +29 -0
  312. package/dist/esm/http/request.mjs +262 -0
  313. package/dist/esm/http/response.mjs +433 -0
  314. package/dist/esm/http/rs/resource-common.mjs +13 -0
  315. package/dist/esm/http/rs/resource-http-controller.mjs +287 -0
  316. package/dist/esm/http/rs/resource-mappings.mjs +111 -0
  317. package/dist/esm/http/rs/resource-method.mjs +199 -0
  318. package/dist/esm/http/rs/resource.mjs +213 -0
  319. package/dist/esm/http/rs.mjs +12 -0
  320. package/dist/esm/http/session.mjs +105 -0
  321. package/dist/esm/http/upload.mjs +125 -0
  322. package/dist/esm/http/utils.mjs +87 -0
  323. package/dist/esm/index.mjs +1 -0
  324. package/dist/esm/indexing/index.mjs +9 -0
  325. package/dist/esm/indexing/searcher.mjs +51 -0
  326. package/dist/esm/indexing/writer.mjs +26 -0
  327. package/dist/esm/integrations/index.mjs +6 -0
  328. package/dist/esm/integrations/integrations.mjs +36 -0
  329. package/dist/esm/io/bytes.mjs +82 -0
  330. package/dist/esm/io/files.mjs +325 -0
  331. package/dist/esm/io/image.mjs +24 -0
  332. package/dist/esm/io/index.mjs +18 -0
  333. package/dist/esm/io/streams.mjs +224 -0
  334. package/dist/esm/io/zip.mjs +232 -0
  335. package/dist/esm/job/decorators.mjs +21 -0
  336. package/dist/esm/job/index.mjs +9 -0
  337. package/dist/esm/job/scheduler.mjs +328 -0
  338. package/dist/esm/junit/index.mjs +2 -0
  339. package/dist/esm/junit/junit.mjs +48 -0
  340. package/dist/esm/kafka/consumer.mjs +51 -0
  341. package/dist/esm/kafka/index.mjs +9 -0
  342. package/dist/esm/kafka/producer.mjs +51 -0
  343. package/dist/esm/log/index.mjs +6 -0
  344. package/dist/esm/log/logging.mjs +155 -0
  345. package/dist/esm/mail/client.mjs +134 -0
  346. package/dist/esm/mail/index.mjs +6 -0
  347. package/dist/esm/messaging/consumer.mjs +64 -0
  348. package/dist/esm/messaging/decorators.mjs +21 -0
  349. package/dist/esm/messaging/index.mjs +12 -0
  350. package/dist/esm/messaging/producer.mjs +62 -0
  351. package/dist/esm/mongodb/client.mjs +608 -0
  352. package/dist/esm/mongodb/dao.mjs +360 -0
  353. package/dist/esm/mongodb/index.mjs +7 -0
  354. package/dist/esm/net/decorators.mjs +21 -0
  355. package/dist/esm/net/index.mjs +12 -0
  356. package/dist/esm/net/soap.mjs +209 -0
  357. package/dist/esm/net/websockets.mjs +132 -0
  358. package/dist/esm/net/wrappers/onClose.mjs +2 -0
  359. package/dist/esm/net/wrappers/onError.mjs +2 -0
  360. package/dist/esm/net/wrappers/onMessage.mjs +2 -0
  361. package/dist/esm/net/wrappers/onOpen.mjs +2 -0
  362. package/dist/esm/pdf/index.mjs +6 -0
  363. package/dist/esm/pdf/pdf.mjs +141 -0
  364. package/dist/esm/platform/command.mjs +28 -0
  365. package/dist/esm/platform/engines.mjs +51 -0
  366. package/dist/esm/platform/index.mjs +27 -0
  367. package/dist/esm/platform/lifecycle.mjs +30 -0
  368. package/dist/esm/platform/os.mjs +32 -0
  369. package/dist/esm/platform/problems.mjs +108 -0
  370. package/dist/esm/platform/registry.mjs +300 -0
  371. package/dist/esm/platform/repository.mjs +479 -0
  372. package/dist/esm/platform/workspace.mjs +555 -0
  373. package/dist/esm/qldb/index.mjs +6 -0
  374. package/dist/esm/qldb/qldb.mjs +5 -0
  375. package/dist/esm/rabbitmq/consumer.mjs +31 -0
  376. package/dist/esm/rabbitmq/index.mjs +9 -0
  377. package/dist/esm/rabbitmq/producer.mjs +19 -0
  378. package/dist/esm/redis/client.mjs +171 -0
  379. package/dist/esm/redis/index.mjs +6 -0
  380. package/dist/esm/security/decorators.mjs +29 -0
  381. package/dist/esm/security/index.mjs +10 -0
  382. package/dist/esm/security/oauth.mjs +56 -0
  383. package/dist/esm/security/user.mjs +69 -0
  384. package/dist/esm/template/engines.mjs +120 -0
  385. package/dist/esm/template/index.mjs +6 -0
  386. package/dist/esm/utils/alphanumeric.mjs +88 -0
  387. package/dist/esm/utils/base64.mjs +85 -0
  388. package/dist/esm/utils/converter.mjs +59 -0
  389. package/dist/esm/utils/digest.mjs +148 -0
  390. package/dist/esm/utils/escape.mjs +141 -0
  391. package/dist/esm/utils/hex.mjs +85 -0
  392. package/dist/esm/utils/index.mjs +38 -0
  393. package/dist/esm/utils/jsonpath.mjs +470 -0
  394. package/dist/esm/utils/qrcode.mjs +22 -0
  395. package/dist/esm/utils/url.mjs +63 -0
  396. package/dist/esm/utils/utf8.mjs +42 -0
  397. package/dist/esm/utils/uuid.mjs +29 -0
  398. package/dist/esm/utils/xml.mjs +38 -0
  399. package/package.json +58 -0
@@ -0,0 +1,885 @@
1
+ import { Bytes } from "@aerokit/sdk/io/bytes";
2
+ const DatabaseFacade = Java.type("org.eclipse.dirigible.components.api.db.DatabaseFacade");
3
+ const DatabaseResultSetHelper = Java.type("org.eclipse.dirigible.components.data.management.helpers.DatabaseResultSetHelper");
4
+ const JSqlDate = Java.type("java.sql.Date");
5
+ const JSqlTimestamp = Java.type("java.sql.Timestamp");
6
+ const JSqlTime = Java.type("java.sql.Time");
7
+ const StringWriter = Java.type("java.io.StringWriter");
8
+ const WriterOutputStream = Java.type("org.apache.commons.io.output.WriterOutputStream");
9
+ const StandardCharsets = Java.type("java.nio.charset.StandardCharsets");
10
+ const SQLTypes = Object.freeze({
11
+ "BOOLEAN": 16,
12
+ "DATE": 91,
13
+ "TIME": 92,
14
+ "TIMESTAMP": 93,
15
+ "DOUBLE": 8,
16
+ "FLOAT": 6,
17
+ "REAL": 7,
18
+ "TINYINT": -6,
19
+ "SMALLINT": 5,
20
+ "INTEGER": 4,
21
+ "BIGINT": -5,
22
+ "VARCHAR": 12,
23
+ "CHAR": 1,
24
+ "CLOB": 2005,
25
+ "BLOB": 2004,
26
+ "VARBINARY": -3,
27
+ "DECIMAL": 3,
28
+ "ARRAY": 2003,
29
+ "NVARCHAR": -9,
30
+ "NCLOB": 2011,
31
+ "BIT": -7
32
+ });
33
+ var DatabaseSystem = /* @__PURE__ */ ((DatabaseSystem2) => {
34
+ DatabaseSystem2[DatabaseSystem2["UNKNOWN"] = 0] = "UNKNOWN";
35
+ DatabaseSystem2[DatabaseSystem2["DERBY"] = 1] = "DERBY";
36
+ DatabaseSystem2[DatabaseSystem2["POSTGRESQL"] = 2] = "POSTGRESQL";
37
+ DatabaseSystem2[DatabaseSystem2["H2"] = 3] = "H2";
38
+ DatabaseSystem2[DatabaseSystem2["MARIADB"] = 4] = "MARIADB";
39
+ DatabaseSystem2[DatabaseSystem2["HANA"] = 5] = "HANA";
40
+ DatabaseSystem2[DatabaseSystem2["SNOWFLAKE"] = 6] = "SNOWFLAKE";
41
+ DatabaseSystem2[DatabaseSystem2["MYSQL"] = 7] = "MYSQL";
42
+ DatabaseSystem2[DatabaseSystem2["MONGODB"] = 8] = "MONGODB";
43
+ DatabaseSystem2[DatabaseSystem2["SYBASE"] = 9] = "SYBASE";
44
+ return DatabaseSystem2;
45
+ })(DatabaseSystem || {});
46
+ function isHanaDatabase(connection) {
47
+ let isHanaDatabase2 = false;
48
+ let metadata = connection.getMetaData();
49
+ if (metadata !== null && metadata !== void 0) {
50
+ isHanaDatabase2 = metadata.getDatabaseProductName() === "HDB";
51
+ }
52
+ return isHanaDatabase2;
53
+ }
54
+ function readClobValue(value) {
55
+ return value ? value.getSubString(1, value.length()) : value;
56
+ }
57
+ function createClobValue(native, value) {
58
+ try {
59
+ let connection = native.getConnection();
60
+ if (connection === null || connection === void 0) {
61
+ throw new Error("Can't create new 'Clob' value as the connection is null");
62
+ }
63
+ let clob = null;
64
+ if (isHanaDatabase(connection)) {
65
+ let ps = null;
66
+ try {
67
+ ps = connection.prepareStatement("SELECT TO_CLOB (?) FROM DUMMY;");
68
+ ps.setString(1, value);
69
+ let rs = ps.executeQuery();
70
+ if (rs.next()) {
71
+ clob = rs.getClob(1);
72
+ }
73
+ } finally {
74
+ if (ps !== null && ps !== void 0) {
75
+ ps.close();
76
+ }
77
+ }
78
+ } else {
79
+ clob = connection.createClob();
80
+ clob.setString(1, value);
81
+ }
82
+ return clob;
83
+ } catch (e) {
84
+ throw new Error(`Error occured during creation of 'Clob' value: ${e.message}`);
85
+ }
86
+ }
87
+ function readNClobValue(value) {
88
+ return value ? value.getSubString(1, value.length()) : value;
89
+ }
90
+ function createNClobValue(native, value) {
91
+ try {
92
+ let connection = native.getConnection();
93
+ if (connection === null || connection === void 0) {
94
+ throw new Error("Can't create new 'NClob' value as the connection is null");
95
+ }
96
+ let nclob = null;
97
+ if (isHanaDatabase(connection)) {
98
+ let ps = null;
99
+ try {
100
+ ps = connection.prepareStatement("SELECT TO_NCLOB (?) FROM DUMMY;");
101
+ ps.setString(1, value);
102
+ let rs = ps.executeQuery();
103
+ if (rs.next()) {
104
+ nclob = rs.getNClob(1);
105
+ }
106
+ } finally {
107
+ if (ps !== null && ps !== void 0) {
108
+ ps.close();
109
+ }
110
+ }
111
+ } else {
112
+ nclob = connection.createNClob();
113
+ nclob.setString(1, value);
114
+ }
115
+ return nclob;
116
+ } catch (e) {
117
+ throw new Error(`Error occured during creation of 'NClob' value: ${e.message}`);
118
+ }
119
+ }
120
+ function createBlobValue(native, value) {
121
+ try {
122
+ let connection = native.getConnection();
123
+ if (connection === null || connection === void 0) {
124
+ throw new Error("Can't create new 'Blob' value as the connection is null");
125
+ }
126
+ let blob = null;
127
+ if (isHanaDatabase(connection)) {
128
+ let ps = null;
129
+ try {
130
+ ps = connection.prepareStatement("SELECT TO_BLOB (?) FROM DUMMY;");
131
+ ps.setBytes(1, value);
132
+ let rs = ps.executeQuery();
133
+ if (rs.next()) {
134
+ blob = rs.getBlob(1);
135
+ }
136
+ } finally {
137
+ if (ps !== null && ps !== void 0) {
138
+ ps.close();
139
+ }
140
+ }
141
+ } else {
142
+ blob = connection.createBlob();
143
+ blob.setBytes(1, value);
144
+ }
145
+ return blob;
146
+ } catch (e) {
147
+ throw new Error(`Error occured during creation of 'Clob' value: ${e.message}`);
148
+ }
149
+ }
150
+ function getDateValue(value) {
151
+ if (typeof value === "string") {
152
+ return new Date(value);
153
+ }
154
+ return value;
155
+ }
156
+ class PreparedStatement {
157
+ constructor(native) {
158
+ this.native = native;
159
+ }
160
+ close() {
161
+ this.native.close();
162
+ }
163
+ getResultSet() {
164
+ return new ResultSet(this.native.getResultSet());
165
+ }
166
+ execute() {
167
+ return this.native.execute();
168
+ }
169
+ executeQuery() {
170
+ return new ResultSet(this.native.executeQuery());
171
+ }
172
+ executeUpdate() {
173
+ return this.native.executeUpdate();
174
+ }
175
+ setNull(index, sqlType) {
176
+ this.native.setNull(index, sqlType);
177
+ }
178
+ setBinaryStream(parameterIndex, inputStream, length) {
179
+ if (length) {
180
+ this.native.setBinaryStream(parameterIndex, inputStream, length);
181
+ } else {
182
+ this.native.setBinaryStream(parameterIndex, inputStream);
183
+ }
184
+ }
185
+ setBoolean(index, value) {
186
+ if (value !== null && value !== void 0) {
187
+ this.native.setBoolean(index, value);
188
+ } else {
189
+ this.setNull(index, SQLTypes.BOOLEAN);
190
+ }
191
+ }
192
+ setByte(index, value) {
193
+ if (value !== null && value !== void 0) {
194
+ this.native.setByte(index, value);
195
+ } else {
196
+ this.setNull(index, SQLTypes.TINYINT);
197
+ }
198
+ }
199
+ setBlob(index, value) {
200
+ if (value !== null && value !== void 0) {
201
+ let blob = createBlobValue(this.native, value);
202
+ this.native.setBlob(index, blob);
203
+ } else {
204
+ this.setNull(index, SQLTypes.BLOB);
205
+ }
206
+ }
207
+ setClob(index, value) {
208
+ if (value !== null && value !== void 0) {
209
+ let clob = createClobValue(this.native, value);
210
+ this.native.setClob(index, clob);
211
+ } else {
212
+ this.setNull(index, SQLTypes.CLOB);
213
+ }
214
+ }
215
+ setNClob(index, value) {
216
+ if (value !== null && value !== void 0) {
217
+ let nclob = createNClobValue(this.native, value);
218
+ this.native.setNClob(index, nclob);
219
+ } else {
220
+ this.setNull(index, SQLTypes.NCLOB);
221
+ }
222
+ }
223
+ setBytesNative(index, value) {
224
+ if (value !== null && value !== void 0) {
225
+ this.native.setBytes(index, value);
226
+ } else {
227
+ this.setNull(index, SQLTypes.VARBINARY);
228
+ }
229
+ }
230
+ setBytes(index, value) {
231
+ if (value !== null && value !== void 0) {
232
+ var data = Bytes.toJavaBytes(value);
233
+ this.native.setBytes(index, data);
234
+ } else {
235
+ this.setNull(index, SQLTypes.VARBINARY);
236
+ }
237
+ }
238
+ setDate(index, value) {
239
+ if (value !== null && value !== void 0) {
240
+ const date = getDateValue(value);
241
+ this.native.setDate(index, new JSqlDate(date.getTime()));
242
+ } else {
243
+ this.setNull(index, SQLTypes.DATE);
244
+ }
245
+ }
246
+ setDouble(index, value) {
247
+ if (value !== null && value !== void 0) {
248
+ this.native.setDouble(index, value);
249
+ } else {
250
+ this.setNull(index, SQLTypes.DOUBLE);
251
+ }
252
+ }
253
+ setFloat(index, value) {
254
+ if (value !== null && value !== void 0) {
255
+ this.native.setFloat(index, value);
256
+ } else {
257
+ this.setNull(index, SQLTypes.FLOAT);
258
+ }
259
+ }
260
+ setInt(index, value) {
261
+ if (value !== null && value !== void 0) {
262
+ this.native.setInt(index, value);
263
+ } else {
264
+ this.setNull(index, SQLTypes.INTEGER);
265
+ }
266
+ }
267
+ setLong(index, value) {
268
+ if (value !== null && value !== void 0) {
269
+ this.native.setLong(index, value);
270
+ } else {
271
+ this.setNull(index, SQLTypes.BIGINT);
272
+ }
273
+ }
274
+ setShort(index, value) {
275
+ if (value !== null && value !== void 0) {
276
+ this.native.setShort(index, value);
277
+ } else {
278
+ this.setNull(index, SQLTypes.SMALLINT);
279
+ }
280
+ }
281
+ setString(index, value) {
282
+ if (value !== null && value !== void 0) {
283
+ this.native.setString(index, value);
284
+ } else {
285
+ this.setNull(index, SQLTypes.VARCHAR);
286
+ }
287
+ }
288
+ setTime(index, value) {
289
+ if (value !== null && value !== void 0) {
290
+ const date = getDateValue(value);
291
+ this.native.setTime(index, new JSqlTime(date.getTime()));
292
+ } else {
293
+ this.setNull(index, SQLTypes.TIME);
294
+ }
295
+ }
296
+ setTimestamp(index, value) {
297
+ if (value !== null && value !== void 0) {
298
+ const date = getDateValue(value);
299
+ this.native.setTimestamp(index, new JSqlTimestamp(date.getTime()));
300
+ } else {
301
+ this.setNull(index, SQLTypes.TIMESTAMP);
302
+ }
303
+ }
304
+ setBigDecimal(index, value) {
305
+ if (value !== null && value !== void 0) {
306
+ this.native.setBigDecimal(index, value);
307
+ } else {
308
+ this.setNull(index, SQLTypes.DECIMAL);
309
+ }
310
+ }
311
+ setNString(index, value) {
312
+ if (value !== null && value !== void 0) {
313
+ this.native.setNString(index, value);
314
+ } else {
315
+ this.setNull(index, SQLTypes.NVARCHAR);
316
+ }
317
+ }
318
+ addBatch() {
319
+ this.native.addBatch();
320
+ }
321
+ executeBatch() {
322
+ return this.native.executeBatch();
323
+ }
324
+ getMetaData() {
325
+ return this.native.getMetaData();
326
+ }
327
+ getMoreResults() {
328
+ return this.native.getMoreResults();
329
+ }
330
+ getParameterMetaData() {
331
+ return this.native.getParameterMetaData();
332
+ }
333
+ getSQLWarning() {
334
+ return this.native.getWarnings();
335
+ }
336
+ isClosed() {
337
+ return this.native.isClosed();
338
+ }
339
+ }
340
+ class CallableStatement {
341
+ constructor(native) {
342
+ this.native = native;
343
+ }
344
+ getResultSet() {
345
+ return new ResultSet(this.native.getResultSet());
346
+ }
347
+ executeQuery() {
348
+ return new ResultSet(this.native.executeQuery());
349
+ }
350
+ executeUpdate() {
351
+ return this.native.executeUpdate();
352
+ }
353
+ registerOutParameter(parameterIndex, sqlType) {
354
+ this.native.registerOutParameter(parameterIndex, sqlType);
355
+ }
356
+ registerOutParameterByScale(parameterIndex, sqlType, scale) {
357
+ this.native.registerOutParameter(parameterIndex, sqlType, scale);
358
+ }
359
+ registerOutParameterByTypeName(parameterIndex, sqlType, typeName) {
360
+ this.native.registerOutParameter(parameterIndex, sqlType, typeName);
361
+ }
362
+ wasNull() {
363
+ return this.native.wasNull();
364
+ }
365
+ getString(parameterIndex) {
366
+ return this.native.getString(parameterIndex);
367
+ }
368
+ getBoolean(parameterIndex) {
369
+ return this.native.getBoolean(parameterIndex);
370
+ }
371
+ getByte(parameterIndex) {
372
+ return this.native.getByte(parameterIndex);
373
+ }
374
+ getShort(parameterIndex) {
375
+ return this.native.getShort(parameterIndex);
376
+ }
377
+ getInt(parameterIndex) {
378
+ return this.native.getInt(parameterIndex);
379
+ }
380
+ getLong(parameterIndex) {
381
+ return this.native.getLong(parameterIndex);
382
+ }
383
+ getFloat(parameterIndex) {
384
+ return this.native.getFloat(parameterIndex);
385
+ }
386
+ getDouble(parameterIndex) {
387
+ return this.native.getDouble(parameterIndex);
388
+ }
389
+ getDate(parameterIndex) {
390
+ const dateInstance = this.native.getDate(parameterIndex);
391
+ return dateInstance !== null && dateInstance !== void 0 ? new Date(dateInstance.getTime()) : dateInstance;
392
+ }
393
+ getTime(parameterIndex) {
394
+ const dateInstance = this.native.getTime(parameterIndex);
395
+ return dateInstance !== null && dateInstance !== void 0 ? new Date(dateInstance.getTime()) : dateInstance;
396
+ }
397
+ getTimestamp(parameterIndex) {
398
+ const dateInstance = this.native.getTimestamp(parameterIndex);
399
+ return dateInstance !== null && dateInstance !== void 0 ? new Date(dateInstance.getTime()) : dateInstance;
400
+ }
401
+ getObject(parameterIndex) {
402
+ return this.native.getObject(parameterIndex);
403
+ }
404
+ getBigDecimal(parameterIndex) {
405
+ return this.native.getBigDecimal(parameterIndex);
406
+ }
407
+ getRef(parameterIndex) {
408
+ return this.native.getRef(parameterIndex);
409
+ }
410
+ getBytes(parameterIndex) {
411
+ const data = this.native.getBytes(parameterIndex);
412
+ return Bytes.toJavaScriptBytes(data);
413
+ }
414
+ getBytesNative(parameterIndex) {
415
+ return this.native.getBytes(parameterIndex);
416
+ }
417
+ getBlob(parameterIndex) {
418
+ const data = DatabaseFacade.readBlobValue(this.native, parameterIndex);
419
+ return Bytes.toJavaScriptBytes(data);
420
+ }
421
+ getBlobNative(parameterIndex) {
422
+ return DatabaseFacade.readBlobValue(this.native, parameterIndex);
423
+ }
424
+ getClob(parameterIndex) {
425
+ return readClobValue(this.native.getClob(parameterIndex));
426
+ }
427
+ getNClob(parameterIndex) {
428
+ return readNClobValue(this.native.getNClob(parameterIndex));
429
+ }
430
+ getNString(parameterIndex) {
431
+ return this.native.getNString(parameterIndex);
432
+ }
433
+ getArray(parameterIndex) {
434
+ return this.native.getArray(parameterIndex);
435
+ }
436
+ getURL(parameterIndex) {
437
+ return this.native.getURL(parameterIndex);
438
+ }
439
+ getRowId(parameterIndex) {
440
+ return this.native.getRowId(parameterIndex);
441
+ }
442
+ getSQLXML(parameterIndex) {
443
+ return this.native.getSQLXML(parameterIndex);
444
+ }
445
+ setURL(parameterIndex, value) {
446
+ this.native.setURL(parameterIndex, value);
447
+ }
448
+ setNull(parameterIndex, sqlTypeStr, typeName) {
449
+ const sqlType = Number.isInteger(sqlTypeStr) ? sqlTypeStr : SQLTypes[sqlTypeStr];
450
+ if (typeName !== void 0 && typeName !== null) {
451
+ this.native.setNull(parameterIndex, sqlType, typeName);
452
+ } else {
453
+ this.native.setNull(parameterIndex, sqlType);
454
+ }
455
+ }
456
+ setBoolean(parameterIndex, value) {
457
+ if (value !== null && value !== void 0) {
458
+ this.native.setBoolean(parameterIndex, value);
459
+ } else {
460
+ this.setNull(parameterIndex, SQLTypes.BOOLEAN);
461
+ }
462
+ }
463
+ setByte(parameterIndex, value) {
464
+ if (value !== null && value !== void 0) {
465
+ this.native.setByte(parameterIndex, value);
466
+ } else {
467
+ this.setNull(parameterIndex, SQLTypes.BIT);
468
+ }
469
+ }
470
+ setShort(parameterIndex, value) {
471
+ if (value !== null && value !== void 0) {
472
+ this.native.setShort(parameterIndex, value);
473
+ } else {
474
+ this.setNull(parameterIndex, SQLTypes.SMALLINT);
475
+ }
476
+ }
477
+ setInt(parameterIndex, value) {
478
+ if (value !== null && value !== void 0) {
479
+ this.native.setInt(parameterIndex, value);
480
+ } else {
481
+ this.setNull(parameterIndex, SQLTypes.INTEGER);
482
+ }
483
+ }
484
+ setLong(parameterIndex, value) {
485
+ if (value !== null && value !== void 0) {
486
+ this.native.setLong(parameterIndex, value);
487
+ } else {
488
+ this.setNull(parameterIndex, SQLTypes.BIGINT);
489
+ }
490
+ }
491
+ setFloat(parameterIndex, value) {
492
+ if (value !== null && value !== void 0) {
493
+ this.native.setFloat(parameterIndex, value);
494
+ } else {
495
+ this.setNull(parameterIndex, SQLTypes.FLOAT);
496
+ }
497
+ }
498
+ setDouble(parameterIndex, value) {
499
+ if (value !== null && value !== void 0) {
500
+ this.native.setDouble(parameterIndex, value);
501
+ } else {
502
+ this.setNull(parameterIndex, SQLTypes.DOUBLE);
503
+ }
504
+ }
505
+ setBigDecimal(parameterIndex, value) {
506
+ if (value !== null && value !== void 0) {
507
+ this.native.setBigDecimal(parameterIndex, value);
508
+ } else {
509
+ this.setNull(parameterIndex, SQLTypes.DECIMAL);
510
+ }
511
+ }
512
+ setString(parameterIndex, value) {
513
+ if (value !== null && value !== void 0) {
514
+ this.native.setString(parameterIndex, value);
515
+ } else {
516
+ this.setNull(parameterIndex, SQLTypes.VARCHAR);
517
+ }
518
+ }
519
+ setBytes(parameterIndex, value) {
520
+ if (value !== null && value !== void 0) {
521
+ this.native.setBytes(parameterIndex, value);
522
+ } else {
523
+ this.setNull(parameterIndex, SQLTypes.ARRAY);
524
+ }
525
+ }
526
+ setDate(parameterIndex, value) {
527
+ if (value !== null && value !== void 0) {
528
+ const date = getDateValue(value);
529
+ this.native.setDate(parameterIndex, new JSqlDate(date.getTime()));
530
+ } else {
531
+ this.setNull(parameterIndex, SQLTypes.DATE);
532
+ }
533
+ }
534
+ setTime(parameterIndex, value) {
535
+ if (value !== null && value !== void 0) {
536
+ const date = getDateValue(value);
537
+ this.native.setTime(parameterIndex, new JSqlTime(date.getTime()));
538
+ } else {
539
+ this.setNull(parameterIndex, SQLTypes.TIME);
540
+ }
541
+ }
542
+ setTimestamp(parameterIndex, value) {
543
+ if (value !== null && value !== void 0) {
544
+ let date = getDateValue(value);
545
+ this.native.setTimestamp(parameterIndex, new JSqlTimestamp(date.getTime()));
546
+ } else {
547
+ this.setNull(parameterIndex, SQLTypes.TIMESTAMP);
548
+ }
549
+ }
550
+ setAsciiStream(parameterIndex, inputStream, length) {
551
+ if (length) {
552
+ this.native.setAsciiStream(parameterIndex, inputStream, length);
553
+ } else {
554
+ this.native.setAsciiStream(parameterIndex, inputStream);
555
+ }
556
+ }
557
+ setBinaryStream(parameterIndex, inputStream, length) {
558
+ if (length) {
559
+ this.native.setBinaryStream(parameterIndex, inputStream, length);
560
+ } else {
561
+ this.native.setBinaryStream(parameterIndex, inputStream);
562
+ }
563
+ }
564
+ setObject(parameterIndex, value, targetSqlType, scale) {
565
+ if (scale !== void 0 && scale !== null && targetSqlType !== void 0 && targetSqlType !== null) {
566
+ this.native.setObject(parameterIndex, value, targetSqlType, scale);
567
+ } else if (targetSqlType !== void 0 && targetSqlType !== null) {
568
+ this.native.setObject(parameterIndex, value, targetSqlType);
569
+ } else {
570
+ this.native.setObject(parameterIndex, value);
571
+ }
572
+ }
573
+ setRowId(parameterIndex, value) {
574
+ this.native.setRowId(parameterIndex, value);
575
+ }
576
+ setNString(parameterIndex, value) {
577
+ if (value !== null && value !== void 0) {
578
+ this.native.setNString(parameterIndex, value);
579
+ } else {
580
+ this.setNull(parameterIndex, SQLTypes.NVARCHAR);
581
+ }
582
+ }
583
+ setSQLXML(parameterIndex, value) {
584
+ if (value !== null && value !== void 0) {
585
+ this.native.setSQLXML(parameterIndex, value);
586
+ } else {
587
+ throw new Error("Nullable SQLXML type not supported.");
588
+ }
589
+ }
590
+ setBlob(parameterIndex, value) {
591
+ if (value !== null && value !== void 0) {
592
+ const blob = createBlobValue(this.native, value);
593
+ this.native.setBlob(parameterIndex, blob);
594
+ } else {
595
+ this.setNull(parameterIndex, SQLTypes.BLOB);
596
+ }
597
+ }
598
+ setClob(parameterIndex, value) {
599
+ if (value !== null && value !== void 0) {
600
+ const clob = createClobValue(this.native, value);
601
+ this.native.setClob(parameterIndex, clob);
602
+ } else {
603
+ this.setNull(parameterIndex, SQLTypes.CLOB);
604
+ }
605
+ }
606
+ setNClob(parameterIndex, value) {
607
+ if (value !== null && value !== void 0) {
608
+ const nclob = createNClobValue(this.native, value);
609
+ this.native.setNClob(parameterIndex, nclob);
610
+ } else {
611
+ this.setNull(parameterIndex, SQLTypes.NCLOB);
612
+ }
613
+ }
614
+ execute() {
615
+ return this.native.execute();
616
+ }
617
+ getMoreResults() {
618
+ return this.native.getMoreResults();
619
+ }
620
+ getParameterMetaData() {
621
+ return this.native.getParameterMetaData();
622
+ }
623
+ isClosed() {
624
+ return this.native.isClosed();
625
+ }
626
+ close() {
627
+ this.native.close();
628
+ }
629
+ }
630
+ class ResultSet {
631
+ constructor(native) {
632
+ this.native = native;
633
+ }
634
+ /**
635
+ * Converts the ResultSet into a JSON array of objects.
636
+ * @param limited Whether to use limited JSON conversion (optimized).
637
+ * @param stringify Whether to return the JSON as a string or a parsed array.
638
+ * @returns A JavaScript array of objects representing the result set, or a string if stringify is true.
639
+ */
640
+ toJson(limited = false, stringify = false) {
641
+ const sw = new StringWriter();
642
+ const output = WriterOutputStream.builder().setWriter(sw).setCharset(StandardCharsets.UTF_8).get();
643
+ DatabaseResultSetHelper.toJson(this.native, limited, stringify, output);
644
+ const jsonString = sw.toString();
645
+ return stringify ? jsonString : JSON.parse(jsonString);
646
+ }
647
+ close() {
648
+ this.native.close();
649
+ }
650
+ getBigDecimal(identifier) {
651
+ return this.native.getBigDecimal(identifier);
652
+ }
653
+ getBoolean(identifier) {
654
+ return this.native.getBoolean(identifier);
655
+ }
656
+ getByte(identifier) {
657
+ return this.native.getByte(identifier);
658
+ }
659
+ getBytes(identifier) {
660
+ const data = this.native.getBytes(identifier);
661
+ return Bytes.toJavaScriptBytes(data);
662
+ }
663
+ getBytesNative(identifier) {
664
+ return this.native.getBytes(identifier);
665
+ }
666
+ getBlob(identifier) {
667
+ const data = DatabaseFacade.readBlobValue(this.native, identifier);
668
+ return Bytes.toJavaScriptBytes(data);
669
+ }
670
+ getBlobNative(identifier) {
671
+ return DatabaseFacade.readBlobValue(this.native, identifier);
672
+ }
673
+ getClob(identifier) {
674
+ return readClobValue(this.native.getClob(identifier));
675
+ }
676
+ getNClob(identifier) {
677
+ return readNClobValue(this.native.getNClob(identifier));
678
+ }
679
+ getDate(identifier) {
680
+ const dateInstance = this.native.getDate(identifier);
681
+ return dateInstance !== null && dateInstance !== void 0 ? new Date(dateInstance.getTime()) : void 0;
682
+ }
683
+ getDouble(identifier) {
684
+ return this.native.getDouble(identifier);
685
+ }
686
+ getFloat(identifier) {
687
+ return this.native.getFloat(identifier);
688
+ }
689
+ getInt(identifier) {
690
+ return this.native.getInt(identifier);
691
+ }
692
+ getLong(identifier) {
693
+ return this.native.getLong(identifier);
694
+ }
695
+ getShort(identifier) {
696
+ return this.native.getShort(identifier);
697
+ }
698
+ getString(identifier) {
699
+ return this.native.getString(identifier);
700
+ }
701
+ getTime(identifier) {
702
+ const dateInstance = this.native.getTime(identifier);
703
+ return dateInstance !== null && dateInstance !== void 0 ? new Date(dateInstance.getTime()) : void 0;
704
+ }
705
+ getTimestamp(identifier) {
706
+ const dateInstance = this.native.getTimestamp(identifier);
707
+ return dateInstance !== null && dateInstance !== void 0 ? new Date(dateInstance.getTime()) : void 0;
708
+ }
709
+ isAfterLast() {
710
+ return this.native.isAfterLast();
711
+ }
712
+ isBeforeFirst() {
713
+ return this.native.isBeforeFirst();
714
+ }
715
+ isClosed() {
716
+ return this.native.isClosed();
717
+ }
718
+ isFirst() {
719
+ return this.native.isFirst();
720
+ }
721
+ isLast() {
722
+ return this.native.isLast();
723
+ }
724
+ next() {
725
+ return this.native.next();
726
+ }
727
+ getMetaData() {
728
+ return this.native.getMetaData();
729
+ }
730
+ getNString(columnIndex) {
731
+ return this.native.getNString(columnIndex);
732
+ }
733
+ }
734
+ class Connection {
735
+ constructor(datasourceName) {
736
+ this.native = DatabaseFacade.getConnection(datasourceName);
737
+ }
738
+ /**
739
+ * Checks if the connection is for a specific database system.
740
+ */
741
+ isOfType(databaseSystem) {
742
+ return this.getDatabaseSystem() === databaseSystem;
743
+ }
744
+ /**
745
+ * Returns the type of the underlying database system as a {@link DatabaseSystem} enum.
746
+ */
747
+ getDatabaseSystem() {
748
+ const dbSystem = this.native.getDatabaseSystem().name();
749
+ switch (dbSystem) {
750
+ case "DERBY":
751
+ return 1 /* DERBY */;
752
+ case "POSTGRESQL":
753
+ return 2 /* POSTGRESQL */;
754
+ case "H2":
755
+ return 3 /* H2 */;
756
+ case "MARIADB":
757
+ return 4 /* MARIADB */;
758
+ case "HANA":
759
+ return 5 /* HANA */;
760
+ case "SNOWFLAKE":
761
+ return 6 /* SNOWFLAKE */;
762
+ case "MYSQL":
763
+ return 7 /* MYSQL */;
764
+ case "MONGODB":
765
+ return 8 /* MONGODB */;
766
+ case "SYBASE":
767
+ return 9 /* SYBASE */;
768
+ case "UNKNOWN":
769
+ return 0 /* UNKNOWN */;
770
+ default:
771
+ throw new Error(`Missing mapping for database system type ${dbSystem}`);
772
+ }
773
+ }
774
+ /**
775
+ * Creates a new {@link PreparedStatement} object for sending parameterized SQL statements to the database.
776
+ */
777
+ prepareStatement(sql) {
778
+ return new PreparedStatement(this.native.prepareStatement(sql));
779
+ }
780
+ /**
781
+ * Creates a {@link CallableStatement} object for calling database stored procedures or functions.
782
+ */
783
+ prepareCall(sql) {
784
+ return new CallableStatement(this.native.prepareCall(sql));
785
+ }
786
+ close() {
787
+ if (!this.isClosed()) {
788
+ this.native.close();
789
+ }
790
+ }
791
+ commit() {
792
+ this.native.commit();
793
+ }
794
+ getAutoCommit() {
795
+ return this.native.getAutoCommit();
796
+ }
797
+ getCatalog() {
798
+ return this.native.getCatalog();
799
+ }
800
+ getSchema() {
801
+ return this.native.getSchema();
802
+ }
803
+ getTransactionIsolation() {
804
+ return this.native.getTransactionIsolation();
805
+ }
806
+ isClosed() {
807
+ return this.native.isClosed();
808
+ }
809
+ isReadOnly() {
810
+ return this.native.isReadOnly();
811
+ }
812
+ isValid() {
813
+ return this.native.isValid();
814
+ }
815
+ rollback() {
816
+ this.native.rollback();
817
+ }
818
+ setAutoCommit(autoCommit) {
819
+ this.native.setAutoCommit(autoCommit);
820
+ }
821
+ setCatalog(catalog) {
822
+ this.native.setCatalog(catalog);
823
+ }
824
+ setReadOnly(readOnly) {
825
+ this.native.setReadOnly(readOnly);
826
+ }
827
+ setSchema(schema) {
828
+ this.native.setSchema(schema);
829
+ }
830
+ setTransactionIsolation(transactionIsolation) {
831
+ this.native.setTransactionIsolation(transactionIsolation);
832
+ }
833
+ getMetaData() {
834
+ return this.native.getMetaData();
835
+ }
836
+ }
837
+ class Database {
838
+ /**
839
+ * Returns a list of available data source names.
840
+ */
841
+ static getDataSources() {
842
+ const datasources = DatabaseFacade.getDataSources();
843
+ return datasources ? JSON.parse(datasources) : [];
844
+ }
845
+ /**
846
+ * Returns database metadata for the specified data source.
847
+ */
848
+ static getMetadata(datasourceName) {
849
+ const metadata = DatabaseFacade.getMetadata(datasourceName);
850
+ return metadata ? JSON.parse(metadata) : void 0;
851
+ }
852
+ /**
853
+ * Returns the product name of the underlying database system.
854
+ */
855
+ static getProductName(datasourceName) {
856
+ return DatabaseFacade.getProductName(datasourceName);
857
+ }
858
+ /**
859
+ * Gets a new database connection object.
860
+ */
861
+ static getConnection(datasourceName) {
862
+ return new Connection(datasourceName);
863
+ }
864
+ }
865
+ if (typeof module !== "undefined") {
866
+ module.exports = {
867
+ Database,
868
+ Connection,
869
+ PreparedStatement,
870
+ CallableStatement,
871
+ ResultSet,
872
+ DatabaseSystem,
873
+ SQLTypes
874
+ };
875
+ }
876
+ export {
877
+ CallableStatement,
878
+ Connection,
879
+ Database,
880
+ DatabaseSystem,
881
+ PreparedStatement,
882
+ ResultSet,
883
+ SQLTypes
884
+ };
885
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/database.ts"],
  "sourcesContent": ["/**\n * API Database\n *\n */\nimport { Bytes } from \"@aerokit/sdk/io/bytes\";\nimport { InputStream } from \"@aerokit/sdk/io/streams\";\n\nconst DatabaseFacade = Java.type(\"org.eclipse.dirigible.components.api.db.DatabaseFacade\");\nconst DatabaseResultSetHelper = Java.type(\"org.eclipse.dirigible.components.data.management.helpers.DatabaseResultSetHelper\");\nconst JSqlDate = Java.type(\"java.sql.Date\");\nconst JSqlTimestamp = Java.type(\"java.sql.Timestamp\");\nconst JSqlTime = Java.type(\"java.sql.Time\");\nconst StringWriter = Java.type(\"java.io.StringWriter\");\nconst WriterOutputStream = Java.type(\"org.apache.commons.io.output.WriterOutputStream\");\nconst StandardCharsets = Java.type(\"java.nio.charset.StandardCharsets\");\n\n/**\n * Mapping of SQL type names to their java.sql.Types integer constants.\n */\nexport const SQLTypes = Object.freeze({\n\t\"BOOLEAN\": 16,\n\t\"DATE\": 91,\n\t\"TIME\": 92,\n\t\"TIMESTAMP\": 93,\n\t\"DOUBLE\": 8,\n\t\"FLOAT\": 6,\n\t\"REAL\": 7,\n\t\"TINYINT\": -6,\n\t\"SMALLINT\": 5,\n\t\"INTEGER\": 4,\n\t\"BIGINT\": -5,\n\t\"VARCHAR\": 12,\n\t\"CHAR\": 1,\n\t\"CLOB\": 2005,\n\t\"BLOB\": 2004,\n\t\"VARBINARY\": -3,\n\t\"DECIMAL\": 3,\n\t\"ARRAY\": 2003,\n\t\"NVARCHAR\": -9,\n\t\"NCLOB\": 2011,\n\t\"BIT\": -7\n});\n\nexport enum DatabaseSystem {\n\tUNKNOWN, DERBY, POSTGRESQL, H2, MARIADB, HANA, SNOWFLAKE, MYSQL, MONGODB, SYBASE\n}\n\n// --- Metadata Interfaces ---\n\nexport interface TableMetadata {\n\t/** The name. */\n\treadonly name: string;\n\t/** The type. */\n\treadonly type: string;\n\t/** The remarks. */\n\treadonly remarks: string;\n\t/** The columns. */\n\treadonly columns: ColumnMetadata[];\n\t/** The indices. */\n\treadonly indices: IndexMetadata[];\n\t/** The indices. */\n\treadonly foreignKeys: ForeignKeyMetadata[];\n\t/** The kind. */\n\treadonly kind: string;\n}\n\nexport interface ColumnMetadata {\n\t/** The name. */\n\treadonly name: string;\n\t/** The type. */\n\treadonly type: string;\n\t/** The size. */\n\treadonly size: number;\n\t/** The nullable. */\n\treadonly nullable: boolean;\n\t/** The key. */\n\treadonly key: boolean;\n\t/** The kind. */\n\treadonly kind: string;\n\t/** The scale. */\n\treadonly scale: number;\n}\n\nexport interface IndexMetadata {\n\t/** The name. */\n\treadonly name: string;\n\t/** The type. */\n\treadonly type: string;\n\t/** The column. */\n\treadonly column: string;\n\t/** The non unique. */\n\treadonly nonUnique: boolean;\n\t/** The qualifier. */\n\treadonly qualifier: string;\n\t/** The ordinal position. */\n\treadonly ordinalPosition: string;\n\t/** The sort order. */\n\treadonly sortOrder: string;\n\t/** The cardinality. */\n\treadonly cardinality: number;\n\t/** The pages. */\n\treadonly pages: number;\n\t/** The filter condition. */\n\treadonly filterCondition: string;\n\t/** The kind. */\n\treadonly kind: string;\n}\n\nexport interface ForeignKeyMetadata {\n\t/** The name. */\n\treadonly name: string;\n\t/** The kind. */\n\treadonly kind: string;\n}\n\nexport interface SchemaMetadata {\n\t/** The name. */\n\treadonly name: string;\n\t/** The kind. */\n\treadonly kind: string;\n\t/** The tables. */\n\treadonly tables: TableMetadata[];\n\t/** The views. */\n\treadonly views: TableMetadata[];\n\t/** The procedures. */\n\treadonly procedures: ProcedureMetadata[];\n\t/** The functions. */\n\treadonly functions: FunctionMetadata[];\n\t/** The functions. */\n\treadonly sequences: SequenceMetadata[];\n}\n\nexport interface ProcedureMetadata {\n\t/** The name. */\n\treadonly name: string;\n\t/** The type. */\n\treadonly type: string;\n\t/** The remarks. */\n\treadonly remarks: string;\n\t/** The columns. */\n\treadonly columns: ParameterColumnMetadata[];\n\t/** The kind. */\n\treadonly kind: string;\n}\n\nexport interface FunctionMetadata {\n\t/** The name. */\n\treadonly name: string;\n\t/** The type. */\n\treadonly type: string;\n\t/** The remarks. */\n\treadonly remarks: string;\n\t/** The columns. */\n\treadonly columns: ParameterColumnMetadata[];\n\t/** The kind. */\n\treadonly kind: string;\n}\n\nexport interface ParameterColumnMetadata {\n\t/** The name. */\n\treadonly name: string;\n\t/** The kind. */\n\treadonly kind: number;\n\t/** The type. */\n\treadonly type: string;\n\t/** The precision. */\n\treadonly precision: number;\n\t/** The length. */\n\treadonly length: number;\n\t/** The scale. */\n\treadonly scale: number;\n\t/** The radix. */\n\treadonly radix: number;\n\t/** The nullable. */\n\treadonly nullable: boolean;\n\t/** The remarks. */\n\treadonly remarks: string;\n}\n\nexport interface SequenceMetadata {\n\t/** The name. */\n\treadonly name: string;\n\t/** The kind. */\n\treadonly kind: string;\n}\n\nexport interface DatabaseMetadata {\n\treadonly allProceduresAreCallable: boolean;\n\treadonly allTablesAreSelectable: boolean;\n\treadonly url: string;\n\treadonly userName: string;\n\treadonly isReadOnly: boolean;\n\treadonly nullsAreSortedHigh: boolean;\n\treadonly nullsAreSortedLow: boolean;\n\treadonly nullsAreSortedAtStart: boolean;\n\treadonly nullsAreSortedAtEnd: boolean;\n\treadonly databaseProductName: string;\n\treadonly databaseProductVersion: string;\n\treadonly driverName: string;\n\treadonly driverVersion: string;\n\treadonly driverMajorVersion: number;\n\treadonly driverMinorVersion: number;\n\treadonly usesLocalFiles: boolean;\n\treadonly usesLocalFilePerTable: boolean;\n\treadonly supportsMixedCaseIdentifiers: boolean;\n\treadonly storesUpperCaseIdentifiers: boolean;\n\treadonly storesLowerCaseIdentifiers: boolean;\n\treadonly storesMixedCaseIdentifiers: boolean;\n\treadonly supportsMixedCaseQuotedIdentifiers: boolean;\n\treadonly storesUpperCaseQuotedIdentifiers: boolean;\n\treadonly storesLowerCaseQuotedIdentifiers: boolean;\n\treadonly storesMixedCaseQuotedIdentifiers: boolean;\n\treadonly identifierQuoteString: string;\n\treadonly sqlKeywords: string;\n\treadonly numericFunctions: string;\n\treadonly stringFunctions: string;\n\treadonly systemFunctions: string;\n\treadonly timeDateFunctions: string;\n\treadonly searchStringEscape: string;\n\treadonly extraNameCharacters: string;\n\treadonly supportsAlterTableWithAddColumn: boolean;\n\treadonly supportsAlterTableWithDropColumn: boolean;\n\treadonly supportsColumnAliasing: boolean;\n\treadonly nullPlusNonNullIsNull: boolean;\n\treadonly supportsConvert: boolean;\n\treadonly supportsTableCorrelationNames: boolean;\n\treadonly supportsDifferentTableCorrelationNames: boolean;\n\treadonly supportsExpressionsInOrderBy: boolean;\n\treadonly supportsOrderByUnrelated: boolean;\n\treadonly supportsGroupBy: boolean;\n\treadonly supportsGroupByUnrelated: boolean;\n\treadonly supportsGroupByBeyondSelect: boolean;\n\treadonly supportsLikeEscapeClause: boolean;\n\treadonly supportsMultipleResultSets: boolean;\n\treadonly supportsMultipleTransactions: boolean;\n\treadonly supportsNonNullableColumns: boolean;\n\treadonly supportsMinimumSQLGrammar: boolean;\n\treadonly supportsCoreSQLGrammar: boolean;\n\treadonly supportsExtendedSQLGrammar: boolean;\n\treadonly supportsANSI92EntryLevelSQL: boolean;\n\treadonly supportsANSI92IntermediateSQL: boolean;\n\treadonly supportsANSI92FullSQL: boolean;\n\treadonly supportsIntegrityEnhancementFacility: boolean;\n\treadonly supportsOuterJoins: boolean;\n\treadonly supportsFullOuterJoins: boolean;\n\treadonly supportsLimitedOuterJoins: boolean;\n\treadonly schemaTerm: string;\n\treadonly procedureTerm: string;\n\treadonly catalogTerm: string;\n\treadonly isCatalogAtStart: boolean;\n\treadonly catalogSeparator: string;\n\treadonly supportsSchemasInDataManipulation: boolean;\n\treadonly supportsSchemasInProcedureCalls: boolean;\n\treadonly supportsSchemasInTableDefinitions: boolean;\n\treadonly supportsSchemasInIndexDefinitions: boolean;\n\treadonly supportsSchemasInPrivilegeDefinitions: boolean;\n\treadonly supportsCatalogsInDataManipulation: boolean;\n\treadonly supportsCatalogsInProcedureCalls: boolean;\n\treadonly supportsCatalogsInTableDefinitions: boolean;\n\treadonly supportsCatalogsInIndexDefinitions: boolean;\n\treadonly supportsCatalogsInPrivilegeDefinitions: boolean;\n\treadonly supportsPositionedDelete: boolean;\n\treadonly supportsPositionedUpdate: boolean;\n\treadonly supportsSelectForUpdate: boolean;\n\treadonly supportsStoredProcedures: boolean;\n\treadonly supportsSubqueriesInComparisons: boolean;\n\treadonly supportsSubqueriesInExists: boolean;\n\treadonly supportsSubqueriesInIns: boolean;\n\treadonly supportsSubqueriesInQuantifieds: boolean;\n\treadonly supportsCorrelatedSubqueries: boolean;\n\treadonly supportsUnion: boolean;\n\treadonly supportsUnionAll: boolean;\n\treadonly supportsOpenCursorsAcrossCommit: boolean;\n\treadonly supportsOpenCursorsAcrossRollback: boolean;\n\treadonly supportsOpenStatementsAcrossCommit: boolean;\n\treadonly supportsOpenStatementsAcrossRollback: boolean;\n\treadonly maxBinaryLiteralLength: number;\n\treadonly maxCharLiteralLength: number;\n\treadonly maxColumnNameLength: number;\n\treadonly maxColumnsInGroupBy: number;\n\treadonly maxColumnsInIndex: number;\n\treadonly maxColumnsInOrderBy: number;\n\treadonly maxColumnsInSelect: number;\n\treadonly maxColumnsInTable: number;\n\treadonly maxConnections: number;\n\treadonly maxCursorNameLength: number;\n\treadonly maxIndexLength: number;\n\treadonly maxSchemaNameLength: number;\n\treadonly maxProcedureNameLength: number;\n\treadonly maxCatalogNameLength: number;\n\treadonly maxRowSize: number;\n\treadonly maxRowSizeIncludeBlobs: boolean;\n\treadonly maxStatementLength: number;\n\treadonly maxStatements: number;\n\treadonly maxTableNameLength: number;\n\treadonly maxTablesInSelect: number;\n\treadonly maxUserNameLength: number;\n\treadonly defaultTransactionIsolation: number;\n\treadonly supportsTransactions: boolean;\n\treadonly supportsDataDefinitionAndDataManipulationTransactions: boolean;\n\treadonly supportsDataManipulationTransactionsOnly: boolean;\n\treadonly dataDefinitionCausesTransactionCommit: boolean;\n\treadonly dataDefinitionIgnoredInTransactions: boolean;\n\treadonly supportsBatchUpdates: boolean;\n\treadonly supportsSavepoints: boolean;\n\treadonly supportsNamedParameters: boolean;\n\treadonly supportsMultipleOpenResults: boolean;\n\treadonly supportsGetGeneratedKeys: boolean;\n\treadonly resultSetHoldability: number;\n\treadonly databaseMajorVersion: number;\n\treadonly databaseMinorVersion: number;\n\treadonly jdbcMajorVersion: number;\n\treadonly jdbcMinorVersion: number;\n\treadonly sqlStateType: number;\n\treadonly locatorsUpdateCopy: boolean;\n\treadonly supportsStatementPooling: boolean;\n\treadonly supportsStoredFunctionsUsingCallSyntax: boolean;\n\treadonly autoCommitFailureClosesAllResultSets: boolean;\n\treadonly generatedKeyAlwaysReturned: boolean;\n\treadonly maxLogicalLobSize: number;\n\treadonly supportsRefCursors: boolean;\n\treadonly schemas: SchemaMetadata[];\n\treadonly kind: string;\n}\n\n// --- Helper Functions ---\n\nfunction isHanaDatabase(connection: any): boolean {\n\tlet isHanaDatabase = false;\n\tlet metadata = connection.getMetaData();\n\tif (metadata !== null && metadata !== undefined) {\n\t\tisHanaDatabase = metadata.getDatabaseProductName() === \"HDB\";\n\t}\n\treturn isHanaDatabase;\n}\n\nfunction readClobValue(value: any): string | any {\n\treturn value ? value.getSubString(1, value.length()) : value;\n}\n\nfunction createClobValue(native: any, value: any): any {\n\ttry {\n\t\tlet connection = native.getConnection(); // intentionally not closed\n\t\tif (connection === null || connection === undefined) {\n\t\t\tthrow new Error(\"Can't create new 'Clob' value as the connection is null\");\n\t\t}\n\t\tlet clob = null;\n\t\tif (isHanaDatabase(connection)) {\n\t\t\tlet ps = null;\n\t\t\ttry {\n\t\t\t\tps = connection.prepareStatement(\"SELECT TO_CLOB (?) FROM DUMMY;\");\n\t\t\t\tps.setString(1, value);\n\t\t\t\tlet rs = ps.executeQuery();\n\t\t\t\tif (rs.next()) {\n\t\t\t\t\tclob = rs.getClob(1);\n\t\t\t\t}\n\t\t\t} finally {\n\t\t\t\tif (ps !== null && ps !== undefined) {\n\t\t\t\t\tps.close();\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tclob = connection.createClob();\n\t\t\tclob.setString(1, value);\n\t\t}\n\t\treturn clob;\n\t} catch (e: any) {\n\t\tthrow new Error(`Error occured during creation of 'Clob' value: ${e.message}`);\n\t}\n}\n\nfunction readNClobValue(value: any): string | any {\n\treturn value ? value.getSubString(1, value.length()) : value;\n}\n\nfunction createNClobValue(native: any, value: any): any {\n\ttry {\n\t\tlet connection = native.getConnection(); // intentionally not closed\n\t\tif (connection === null || connection === undefined) {\n\t\t\tthrow new Error(\"Can't create new 'NClob' value as the connection is null\");\n\t\t}\n\t\tlet nclob = null;\n\t\tif (isHanaDatabase(connection)) {\n\t\t\tlet ps = null;\n\t\t\ttry {\n\t\t\t\tps = connection.prepareStatement(\"SELECT TO_NCLOB (?) FROM DUMMY;\");\n\t\t\t\tps.setString(1, value);\n\t\t\t\tlet rs = ps.executeQuery();\n\t\t\t\tif (rs.next()) {\n\t\t\t\t\tnclob = rs.getNClob(1);\n\t\t\t\t}\n\t\t\t} finally {\n\t\t\t\tif (ps !== null && ps !== undefined) {\n\t\t\t\t\tps.close();\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tnclob = connection.createNClob();\n\t\t\tnclob.setString(1, value);\n\t\t}\n\t\treturn nclob;\n\t} catch (e: any) {\n\t\tthrow new Error(`Error occured during creation of 'NClob' value: ${e.message}`);\n\t}\n}\n\nfunction createBlobValue(native: any, value: any): any {\n\ttry {\n\t\tlet connection = native.getConnection(); // intentionally not closed\n\t\tif (connection === null || connection === undefined) {\n\t\t\tthrow new Error(\"Can't create new 'Blob' value as the connection is null\");\n\t\t}\n\t\tlet blob = null;\n\t\tif (isHanaDatabase(connection)) {\n\t\t\tlet ps = null;\n\t\t\ttry {\n\t\t\t\tps = connection.prepareStatement(\"SELECT TO_BLOB (?) FROM DUMMY;\");\n\t\t\t\tps.setBytes(1, value);\n\t\t\t\tlet rs = ps.executeQuery();\n\t\t\t\tif (rs.next()) {\n\t\t\t\t\tblob = rs.getBlob(1);\n\t\t\t\t}\n\t\t\t} finally {\n\t\t\t\tif (ps !== null && ps !== undefined) {\n\t\t\t\t\tps.close();\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tblob = connection.createBlob();\n\t\t\tblob.setBytes(1, value);\n\t\t}\n\t\treturn blob;\n\t} catch (e: any) {\n\t\tthrow new Error(`Error occured during creation of 'Clob' value: ${e.message}`);\n\t}\n}\n\nfunction getDateValue(value: string | Date): Date {\n\tif (typeof value === \"string\") {\n\t\treturn new Date(value);\n\t}\n\treturn value;\n}\n\n// --- Statement Classes ---\n\n/**\n * Statement object\n */\nexport class PreparedStatement {\n\n\tprivate readonly native: any;\n\n\tconstructor(native: any) {\n\t\tthis.native = native;\n\t}\n\n\tpublic close(): void {\n\t\tthis.native.close();\n\t}\n\n\tpublic getResultSet(): ResultSet {\n\t\treturn new ResultSet(this.native.getResultSet());\n\t}\n\n\tpublic execute(): boolean {\n\t\treturn this.native.execute();\n\t}\n\n\tpublic executeQuery(): ResultSet {\n\t\treturn new ResultSet(this.native.executeQuery());\n\t}\n\n\tpublic executeUpdate(): number {\n\t\treturn this.native.executeUpdate();\n\t}\n\n\tpublic setNull(index: number, sqlType: number): void {\n\t\tthis.native.setNull(index, sqlType);\n\t}\n\n\tpublic setBinaryStream(parameterIndex: number, inputStream: InputStream, length?: number): void {\n\t\tif (length) {\n\t\t\tthis.native.setBinaryStream(parameterIndex, inputStream, length);\n\t\t} else {\n\t\t\tthis.native.setBinaryStream(parameterIndex, inputStream);\n\t\t}\n\t}\n\n\tpublic setBoolean(index: number, value?: boolean): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setBoolean(index, value);\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.BOOLEAN);\n\t\t}\n\t}\n\n\tpublic setByte(index: number, value?: any /*: Byte*/): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setByte(index, value);\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.TINYINT);\n\t\t}\n\t}\n\n\tpublic setBlob(index: number, value?: any /**: Blob*/): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tlet blob = createBlobValue(this.native, value);\n\t\t\tthis.native.setBlob(index, blob);\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.BLOB);\n\t\t}\n\t}\n\n\tpublic setClob(index: number, value?: any /*: Clob*/): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tlet clob = createClobValue(this.native, value);\n\t\t\tthis.native.setClob(index, clob);\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.CLOB);\n\t\t}\n\t}\n\n\tpublic setNClob(index: number, value?: any /*: NClob*/): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tlet nclob = createNClobValue(this.native, value);\n\t\t\tthis.native.setNClob(index, nclob);\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.NCLOB);\n\t\t}\n\t}\n\n\tpublic setBytesNative(index: number, value?: any[] /*byte[]*/): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setBytes(index, value);\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.VARBINARY);\n\t\t}\n\t}\n\n\tpublic setBytes(index: number, value?: any[] /*byte[]*/): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tvar data = Bytes.toJavaBytes(value);\n\t\t\tthis.native.setBytes(index, data);\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.VARBINARY);\n\t\t}\n\t}\n\n\tpublic setDate(index: number, value?: string | Date): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tconst date = getDateValue(value);\n\t\t\tthis.native.setDate(index, new JSqlDate(date.getTime()));\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.DATE);\n\t\t}\n\t}\n\n\tpublic setDouble(index: number, value?: number): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setDouble(index, value);\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.DOUBLE);\n\t\t}\n\t}\n\n\tpublic setFloat(index: number, value?: number): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setFloat(index, value);\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.FLOAT);\n\t\t}\n\t}\n\n\tpublic setInt(index: number, value?: number): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setInt(index, value);\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.INTEGER);\n\t\t}\n\t}\n\n\tpublic setLong(index: number, value?: number): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setLong(index, value);\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.BIGINT);\n\t\t}\n\t}\n\n\tpublic setShort(index: number, value?: number): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setShort(index, value);\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.SMALLINT);\n\t\t}\n\t}\n\n\tpublic setString(index: number, value?: string): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setString(index, value);\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.VARCHAR);\n\t\t}\n\t}\n\n\tpublic setTime(index: number, value?: string | Date): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tconst date = getDateValue(value);\n\t\t\tthis.native.setTime(index, new JSqlTime(date.getTime()));\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.TIME);\n\t\t}\n\t}\n\n\tpublic setTimestamp(index: number, value?: string | Date): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tconst date = getDateValue(value);\n\t\t\tthis.native.setTimestamp(index, new JSqlTimestamp(date.getTime()));\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.TIMESTAMP);\n\t\t}\n\t}\n\n\tpublic setBigDecimal(index: number, value?: number /*: BigDecimal*/): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setBigDecimal(index, value);\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.DECIMAL);\n\t\t}\n\t}\n\n\tpublic setNString(index: number, value?: string): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setNString(index, value);\n\t\t} else {\n\t\t\tthis.setNull(index, SQLTypes.NVARCHAR);\n\t\t}\n\t}\n\n\tpublic addBatch(): void {\n\t\tthis.native.addBatch();\n\t}\n\n\tpublic executeBatch(): number[] {\n\t\treturn this.native.executeBatch();\n\t}\n\n\tpublic getMetaData(): any {\n\t\treturn this.native.getMetaData();\n\t}\n\n\tpublic getMoreResults(): boolean {\n\t\treturn this.native.getMoreResults();\n\t}\n\n\tpublic getParameterMetaData(): any {\n\t\treturn this.native.getParameterMetaData();\n\t}\n\n\tpublic getSQLWarning(): any {\n\t\treturn this.native.getWarnings();\n\t}\n\n\tpublic isClosed(): boolean {\n\t\treturn this.native.isClosed();\n\t}\n}\n\nexport class CallableStatement {\n\tprivate readonly native: any;\n\n\tconstructor(native: any) {\n\t\tthis.native = native;\n\t}\n\n\tpublic getResultSet(): ResultSet {\n\t\treturn new ResultSet(this.native.getResultSet());\n\t}\n\n\tpublic executeQuery(): ResultSet {\n\t\treturn new ResultSet(this.native.executeQuery());\n\t}\n\n\tpublic executeUpdate(): number {\n\t\treturn this.native.executeUpdate();\n\t}\n\n\tpublic registerOutParameter(parameterIndex: number, sqlType: keyof typeof SQLTypes | number): void {\n\t\tthis.native.registerOutParameter(parameterIndex, sqlType);\n\t}\n\n\tpublic registerOutParameterByScale(parameterIndex: number, sqlType: keyof typeof SQLTypes | number, scale: number): void {\n\t\tthis.native.registerOutParameter(parameterIndex, sqlType, scale);\n\t}\n\n\tpublic registerOutParameterByTypeName(parameterIndex: number, sqlType: keyof typeof SQLTypes | number, typeName: string): void {\n\t\tthis.native.registerOutParameter(parameterIndex, sqlType, typeName);\n\t}\n\n\tpublic wasNull(): boolean {\n\t\treturn this.native.wasNull();\n\t}\n\n\tpublic getString(parameterIndex: number): string {\n\t\treturn this.native.getString(parameterIndex);\n\t}\n\n\tpublic getBoolean(parameterIndex: number): boolean {\n\t\treturn this.native.getBoolean(parameterIndex);\n\t}\n\n\tpublic getByte(parameterIndex: number): any /*: byte*/ {\n\t\treturn this.native.getByte(parameterIndex);\n\t}\n\n\tpublic getShort(parameterIndex: number): number {\n\t\treturn this.native.getShort(parameterIndex);\n\t}\n\n\tpublic getInt(parameterIndex: number): number {\n\t\treturn this.native.getInt(parameterIndex);\n\t}\n\n\tpublic getLong(parameterIndex: number): number {\n\t\treturn this.native.getLong(parameterIndex);\n\t}\n\n\tpublic getFloat(parameterIndex: number): number {\n\t\treturn this.native.getFloat(parameterIndex);\n\t}\n\n\tpublic getDouble(parameterIndex: number): number {\n\t\treturn this.native.getDouble(parameterIndex);\n\t}\n\n\tpublic getDate(parameterIndex: number): Date {\n\t\tconst dateInstance = this.native.getDate(parameterIndex);\n\t\treturn dateInstance !== null && dateInstance !== undefined ? new Date(dateInstance.getTime()) : dateInstance;\n\t}\n\n\tpublic getTime(parameterIndex: number): Date {\n\t\tconst dateInstance = this.native.getTime(parameterIndex);\n\t\treturn dateInstance !== null && dateInstance !== undefined ? new Date(dateInstance.getTime()) : dateInstance;\n\t}\n\n\tpublic getTimestamp(parameterIndex: number): Date {\n\t\tconst dateInstance = this.native.getTimestamp(parameterIndex);\n\t\treturn dateInstance !== null && dateInstance !== undefined ? new Date(dateInstance.getTime()) : dateInstance;\n\t}\n\n\tpublic getObject(parameterIndex: number): any {\n\t\treturn this.native.getObject(parameterIndex);\n\t}\n\n\tpublic getBigDecimal(parameterIndex: number): number /*: sql.BigDecimal*/ {\n\t\treturn this.native.getBigDecimal(parameterIndex);\n\t}\n\n\tpublic getRef(parameterIndex: number): any /*: sql.Ref*/ {\n\t\treturn this.native.getRef(parameterIndex);\n\t}\n\n\tpublic getBytes(parameterIndex: number): any[] /*: byte[]*/ {\n\t\tconst data = this.native.getBytes(parameterIndex);\n\t\treturn Bytes.toJavaScriptBytes(data);\n\t}\n\n\tpublic getBytesNative(parameterIndex: number): any[] /*: byte[]*/ {\n\t\treturn this.native.getBytes(parameterIndex);\n\t}\n\n\tpublic getBlob(parameterIndex: number): any /*: sql.Blob*/ {\n\t\tconst data = DatabaseFacade.readBlobValue(this.native, parameterIndex);\n\t\treturn Bytes.toJavaScriptBytes(data);\n\t}\n\n\tpublic getBlobNative(parameterIndex: number): any /*: sql.Blob*/ {\n\t\treturn DatabaseFacade.readBlobValue(this.native, parameterIndex);\n\t}\n\n\tpublic getClob(parameterIndex: number): any /*: sql.Clob*/ {\n\t\treturn readClobValue(this.native.getClob(parameterIndex));\n\t}\n\n\tpublic getNClob(parameterIndex: string | number): any /*: sql.NClob*/ {\n\t\treturn readNClobValue(this.native.getNClob(parameterIndex));\n\t}\n\n\tpublic getNString(parameterIndex: string | number): string {\n\t\treturn this.native.getNString(parameterIndex);\n\t}\n\n\tpublic getArray(parameterIndex: string | number): any[] /*: sql.Array*/ {\n\t\treturn this.native.getArray(parameterIndex);\n\t}\n\n\tpublic getURL(parameterIndex: string | number): any {\n\t\treturn this.native.getURL(parameterIndex);\n\t}\n\n\tpublic getRowId(parameterIndex: string | number): any /*: sql.RowId*/ {\n\t\treturn this.native.getRowId(parameterIndex);\n\t}\n\n\tpublic getSQLXML(parameterIndex: string | number): any /*: sql.SQLXML*/ {\n\t\treturn this.native.getSQLXML(parameterIndex);\n\t}\n\n\tpublic setURL(parameterIndex: number, value: any): void {\n\t\tthis.native.setURL(parameterIndex, value);\n\t}\n\n\tpublic setNull(parameterIndex: number, sqlTypeStr: keyof typeof SQLTypes | number, typeName?: string): void {\n\t\tconst sqlType: number = Number.isInteger(sqlTypeStr as number) ? sqlTypeStr as number : SQLTypes[sqlTypeStr as keyof typeof SQLTypes];\n\t\tif (typeName !== undefined && typeName !== null) {\n\t\t\tthis.native.setNull(parameterIndex, sqlType, typeName);\n\t\t} else {\n\t\t\tthis.native.setNull(parameterIndex, sqlType);\n\t\t}\n\t}\n\n\tpublic setBoolean(parameterIndex: number, value?: boolean): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setBoolean(parameterIndex, value);\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.BOOLEAN);\n\t\t}\n\t}\n\n\tpublic setByte(parameterIndex: number, value?: any /*: byte*/): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setByte(parameterIndex, value);\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.BIT);\n\t\t}\n\t}\n\n\tpublic setShort(parameterIndex: number, value?: number): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setShort(parameterIndex, value);\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.SMALLINT);\n\t\t}\n\t}\n\n\tpublic setInt(parameterIndex: number, value?: number): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setInt(parameterIndex, value);\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.INTEGER);\n\t\t}\n\t}\n\n\tpublic setLong(parameterIndex: number, value?: number): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setLong(parameterIndex, value);\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.BIGINT);\n\t\t}\n\t}\n\n\tpublic setFloat(parameterIndex: number, value?: number): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setFloat(parameterIndex, value);\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.FLOAT);\n\t\t}\n\t}\n\n\tpublic setDouble(parameterIndex: number, value?: number): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setDouble(parameterIndex, value);\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.DOUBLE);\n\t\t}\n\t}\n\n\tpublic setBigDecimal(parameterIndex: number, value?: number /*: BigDecimal*/): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setBigDecimal(parameterIndex, value);\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.DECIMAL);\n\t\t}\n\t}\n\n\tpublic setString(parameterIndex: number, value?: string): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setString(parameterIndex, value);\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.VARCHAR);\n\t\t}\n\t}\n\n\tpublic setBytes(parameterIndex: number, value?: any[] /*byte[]*/): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setBytes(parameterIndex, value);\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.ARRAY);\n\t\t}\n\t}\n\n\tpublic setDate(parameterIndex: number, value?: string | Date): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tconst date = getDateValue(value);\n\t\t\tthis.native.setDate(parameterIndex, new JSqlDate(date.getTime()));\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.DATE);\n\t\t}\n\t}\n\n\tpublic setTime(parameterIndex: number, value?: string | Date): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tconst date = getDateValue(value);\n\t\t\tthis.native.setTime(parameterIndex, new JSqlTime(date.getTime()));\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.TIME);\n\t\t}\n\t}\n\n\tpublic setTimestamp(parameterIndex: number, value?: string | Date): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tlet date = getDateValue(value);\n\t\t\tthis.native.setTimestamp(parameterIndex, new JSqlTimestamp(date.getTime()));\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.TIMESTAMP);\n\t\t}\n\t}\n\n\tpublic setAsciiStream(parameterIndex: number, inputStream: InputStream, length?: number): void {\n\t\tif (length) {\n\t\t\tthis.native.setAsciiStream(parameterIndex, inputStream, length);\n\t\t} else {\n\t\t\tthis.native.setAsciiStream(parameterIndex, inputStream);\n\t\t}\n\t}\n\n\tpublic setBinaryStream(parameterIndex: number, inputStream: InputStream, length?: number): void {\n\t\tif (length) {\n\t\t\tthis.native.setBinaryStream(parameterIndex, inputStream, length);\n\t\t} else {\n\t\t\tthis.native.setBinaryStream(parameterIndex, inputStream);\n\t\t}\n\t}\n\n\tpublic setObject(parameterIndex: number, value: any, targetSqlType?: number, scale?: number): void {\n\t\tif (scale !== undefined && scale !== null && targetSqlType !== undefined && targetSqlType !== null) {\n\t\t\tthis.native.setObject(parameterIndex, value, targetSqlType, scale);\n\t\t} else if (targetSqlType !== undefined && targetSqlType !== null) {\n\t\t\tthis.native.setObject(parameterIndex, value, targetSqlType);\n\t\t} else {\n\t\t\tthis.native.setObject(parameterIndex, value);\n\t\t}\n\t}\n\n\tpublic setRowId(parameterIndex: number, value: number /*: RowId*/): void {\n\t\tthis.native.setRowId(parameterIndex, value);\n\t}\n\n\tpublic setNString(parameterIndex: number, value: string): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setNString(parameterIndex, value);\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.NVARCHAR);\n\t\t}\n\t}\n\n\tpublic setSQLXML(parameterIndex: number, value: any /*: SQLXML*/): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tthis.native.setSQLXML(parameterIndex, value);\n\t\t} else {\n\t\t\tthrow new Error(\"Nullable SQLXML type not supported.\");\n\t\t}\n\t}\n\n\tpublic setBlob(parameterIndex: number, value: any /*Blob */): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tconst blob = createBlobValue(this.native, value);\n\t\t\tthis.native.setBlob(parameterIndex, blob);\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.BLOB);\n\t\t}\n\t}\n\n\tpublic setClob(parameterIndex: number, value: any /*: Clob*/): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tconst clob = createClobValue(this.native, value);\n\t\t\tthis.native.setClob(parameterIndex, clob);\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.CLOB);\n\t\t}\n\t}\n\n\tpublic setNClob(parameterIndex: number, value: any /*: NClob*/): void {\n\t\tif (value !== null && value !== undefined) {\n\t\t\tconst nclob = createNClobValue(this.native, value);\n\t\t\tthis.native.setNClob(parameterIndex, nclob);\n\t\t} else {\n\t\t\tthis.setNull(parameterIndex, SQLTypes.NCLOB);\n\t\t}\n\t}\n\n\tpublic execute(): boolean {\n\t\treturn this.native.execute();\n\t}\n\n\tpublic getMoreResults(): boolean {\n\t\treturn this.native.getMoreResults();\n\t}\n\n\tpublic getParameterMetaData(): any /*: ParameterMetaData*/ {\n\t\treturn this.native.getParameterMetaData();\n\t}\n\n\tpublic isClosed(): boolean {\n\t\treturn this.native.isClosed();\n\t}\n\n\tpublic close(): void {\n\t\tthis.native.close();\n\t}\n}\n\n/**\n * ResultSet object\n */\nexport class ResultSet {\n\n\tprivate readonly native: any;\n\n\tconstructor(native: any) {\n\t\tthis.native = native;\n\t}\n\n\t/**\n\t * Converts the ResultSet into a JSON array of objects.\n\t * @param limited Whether to use limited JSON conversion (optimized).\n\t * @param stringify Whether to return the JSON as a string or a parsed array.\n\t * @returns A JavaScript array of objects representing the result set, or a string if stringify is true.\n\t */\n\tpublic toJson(limited = false, stringify = false): any[] {\n\t\tconst sw = new StringWriter();\n\t\tconst output = WriterOutputStream\n\t\t\t.builder()\n\t\t\t.setWriter(sw)\n\t\t\t.setCharset(StandardCharsets.UTF_8)\n\t\t\t.get();\n\t\tDatabaseResultSetHelper.toJson(this.native, limited, stringify, output);\n\t\tconst jsonString = sw.toString();\n\t\treturn stringify ? jsonString : JSON.parse(jsonString);\n\t}\n\n\tpublic close(): void {\n\t\tthis.native.close();\n\t}\n\n\tpublic getBigDecimal(identifier: number | string): any /*: BigDecimal*/  {\n\t\treturn this.native.getBigDecimal(identifier);\n\t}\n\n\tpublic getBoolean(identifier: number | string): boolean {\n\t\treturn this.native.getBoolean(identifier);\n\t}\n\n\tpublic getByte(identifier: number | string): any /*: byte*/ {\n\t\treturn this.native.getByte(identifier);\n\t}\n\n\tpublic getBytes(identifier: number | string): any[] /*: byte[]*/ {\n\t\tconst data = this.native.getBytes(identifier);\n\t\treturn Bytes.toJavaScriptBytes(data);\n\t};\n\n\tpublic getBytesNative(identifier: number | string): any[] /*: byte[]*/ {\n\t\treturn this.native.getBytes(identifier);\n\t};\n\n\tpublic getBlob(identifier: number | string): any /*: sql.Blob*/ {\n\t\tconst data = DatabaseFacade.readBlobValue(this.native, identifier);\n\t\treturn Bytes.toJavaScriptBytes(data);\n\t}\n\n\tpublic getBlobNative(identifier: number | string): any /*: sql.Blob*/ {\n\t\treturn DatabaseFacade.readBlobValue(this.native, identifier);\n\t}\n\n\tpublic getClob(identifier: number | string): any /*: sql.Clob*/ {\n\t\treturn readClobValue(this.native.getClob(identifier));\n\t}\n\n\tpublic getNClob(identifier: number | string): any /*: sql.NClob*/ {\n\t\treturn readNClobValue(this.native.getNClob(identifier));\n\t}\n\n\tpublic getDate(identifier: number | string): Date | undefined {\n\t\tconst dateInstance = this.native.getDate(identifier);\n\t\treturn dateInstance !== null && dateInstance !== undefined ? new Date(dateInstance.getTime()) : undefined;\n\t}\n\n\tpublic getDouble(identifier: number | string): number {\n\t\treturn this.native.getDouble(identifier);\n\t}\n\n\tpublic getFloat(identifier: number | string): number {\n\t\treturn this.native.getFloat(identifier);\n\t}\n\n\tpublic getInt(identifier: number | string): number {\n\t\treturn this.native.getInt(identifier);\n\t}\n\n\tpublic getLong(identifier: number | string): number {\n\t\treturn this.native.getLong(identifier);\n\t}\n\n\tpublic getShort(identifier: number | string): number {\n\t\treturn this.native.getShort(identifier);\n\t}\n\n\tpublic getString(identifier: number | string): string {\n\t\treturn this.native.getString(identifier);\n\t}\n\n\tpublic getTime(identifier: number | string): Date | undefined {\n\t\tconst dateInstance = this.native.getTime(identifier);\n\t\treturn dateInstance !== null && dateInstance !== undefined ? new Date(dateInstance.getTime()) : undefined;\n\t}\n\n\tpublic getTimestamp(identifier: number | string): Date | undefined {\n\t\tconst dateInstance = this.native.getTimestamp(identifier);\n\t\treturn dateInstance !== null && dateInstance !== undefined ? new Date(dateInstance.getTime()) : undefined;\n\t}\n\n\tpublic isAfterLast(): boolean {\n\t\treturn this.native.isAfterLast();\n\t}\n\n\tpublic isBeforeFirst(): boolean {\n\t\treturn this.native.isBeforeFirst();\n\t}\n\n\tpublic isClosed(): boolean {\n\t\treturn this.native.isClosed();\n\t}\n\n\tpublic isFirst(): boolean {\n\t\treturn this.native.isFirst();\n\t}\n\n\tpublic isLast(): boolean {\n\t\treturn this.native.isLast();\n\t}\n\n\tpublic next(): boolean {\n\t\treturn this.native.next();\n\t}\n\n\tpublic getMetaData(): any /*: ResultSetMetaData*/ {\n\t\treturn this.native.getMetaData();\n\t}\n\n\tpublic getNString(columnIndex: number): string {\n\t\treturn this.native.getNString(columnIndex);\n\t}\n}\n\n// --- Connection Class ---\n\n/**\n * Connection object wrapper around a native Java `Connection`.\n */\nexport class Connection {\n\n\tpublic readonly native: any;\n\n\tconstructor(datasourceName?: string) {\n\t\tthis.native = DatabaseFacade.getConnection(datasourceName);\n\t}\n\n\t/**\n\t * Checks if the connection is for a specific database system.\n\t */\n\tpublic isOfType(databaseSystem: DatabaseSystem): boolean {\n\t\treturn this.getDatabaseSystem() === databaseSystem;\n\t}\n\n\t/**\n\t * Returns the type of the underlying database system as a {@link DatabaseSystem} enum.\n\t */\n\tpublic getDatabaseSystem(): DatabaseSystem {\n\t\tconst dbSystem: string = this.native.getDatabaseSystem().name();\n\t\tswitch (dbSystem) {\n\t\t\tcase \"DERBY\":\n\t\t\t\treturn DatabaseSystem.DERBY;\n\t\t\tcase \"POSTGRESQL\":\n\t\t\t\treturn DatabaseSystem.POSTGRESQL;\n\t\t\tcase \"H2\":\n\t\t\t\treturn DatabaseSystem.H2;\n\t\t\tcase \"MARIADB\":\n\t\t\t\treturn DatabaseSystem.MARIADB;\n\t\t\tcase \"HANA\":\n\t\t\t\treturn DatabaseSystem.HANA;\n\t\t\tcase \"SNOWFLAKE\":\n\t\t\t\treturn DatabaseSystem.SNOWFLAKE;\n\t\t\tcase \"MYSQL\":\n\t\t\t\treturn DatabaseSystem.MYSQL;\n\t\t\tcase \"MONGODB\":\n\t\t\t\treturn DatabaseSystem.MONGODB;\n\t\t\tcase \"SYBASE\":\n\t\t\t\treturn DatabaseSystem.SYBASE;\n\t\t\tcase \"UNKNOWN\":\n\t\t\t\treturn DatabaseSystem.UNKNOWN;\n\t\t\tdefault:\n\t\t\t\tthrow new Error(`Missing mapping for database system type ${dbSystem}`);\n\t\t}\n\t}\n\n\t/**\n\t * Creates a new {@link PreparedStatement} object for sending parameterized SQL statements to the database.\n\t */\n\tpublic prepareStatement(sql: string): PreparedStatement {\n\t\treturn new PreparedStatement(this.native.prepareStatement(sql));\n\t}\n\n\t/**\n\t * Creates a {@link CallableStatement} object for calling database stored procedures or functions.\n\t */\n\tpublic prepareCall(sql: string): CallableStatement {\n\t\treturn new CallableStatement(this.native.prepareCall(sql));\n\t}\n\n\tpublic close(): void {\n\t\tif (!this.isClosed()) {\n\t\t\tthis.native.close();\n\t\t}\n\t}\n\n\tpublic commit(): void {\n\t\tthis.native.commit();\n\t}\n\n\tpublic getAutoCommit(): boolean {\n\t\treturn this.native.getAutoCommit();\n\t}\n\n\tpublic getCatalog(): string {\n\t\treturn this.native.getCatalog();\n\t}\n\n\tpublic getSchema(): string {\n\t\treturn this.native.getSchema();\n\t}\n\n\tpublic getTransactionIsolation(): number {\n\t\treturn this.native.getTransactionIsolation();\n\t}\n\n\tpublic isClosed(): boolean {\n\t\treturn this.native.isClosed();\n\t}\n\n\tpublic isReadOnly(): boolean {\n\t\treturn this.native.isReadOnly();\n\t}\n\n\tpublic isValid(): boolean {\n\t\treturn this.native.isValid();\n\t}\n\n\tpublic rollback(): void {\n\t\tthis.native.rollback();\n\t}\n\n\tpublic setAutoCommit(autoCommit: boolean): void {\n\t\tthis.native.setAutoCommit(autoCommit);\n\t}\n\n\tpublic setCatalog(catalog: string): void {\n\t\tthis.native.setCatalog(catalog);\n\t}\n\n\tpublic setReadOnly(readOnly: boolean): void {\n\t\tthis.native.setReadOnly(readOnly);\n\t}\n\n\tpublic setSchema(schema: string): void {\n\t\tthis.native.setSchema(schema);\n\t}\n\n\tpublic setTransactionIsolation(transactionIsolation: number): void {\n\t\tthis.native.setTransactionIsolation(transactionIsolation);\n\t}\n\n\tpublic getMetaData(): any /*: DatabaseMetaData*/ {\n\t\treturn this.native.getMetaData();\n\t}\n}\n\n// --- Database Class ---\n\nexport class Database {\n\n\t/**\n\t * Returns a list of available data source names.\n\t */\n\tpublic static getDataSources(): string[] {\n\t\tconst datasources = DatabaseFacade.getDataSources();\n\t\treturn datasources ? JSON.parse(datasources) : [];\n\t}\n\n\t/**\n\t * Returns database metadata for the specified data source.\n\t */\n\tpublic static getMetadata(datasourceName?: string): DatabaseMetadata | undefined {\n\t\tconst metadata = DatabaseFacade.getMetadata(datasourceName);\n\t\treturn metadata ? JSON.parse(metadata) : undefined;\n\t}\n\n\t/**\n\t * Returns the product name of the underlying database system.\n\t */\n\tpublic static getProductName(datasourceName?: string): string {\n\t\treturn DatabaseFacade.getProductName(datasourceName);\n\t}\n\n\t/**\n\t * Gets a new database connection object.\n\t */\n\tpublic static getConnection(datasourceName?: string): Connection {\n\t\treturn new Connection(datasourceName);\n\t}\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = {\n\t\tDatabase,\n\t\tConnection,\n\t\tPreparedStatement,\n\t\tCallableStatement,\n\t\tResultSet,\n\t\tDatabaseSystem,\n\t\tSQLTypes\n\t};\n}\n"],
  "mappings": "AAIA,SAAS,aAAa;AAGtB,MAAM,iBAAiB,KAAK,KAAK,wDAAwD;AACzF,MAAM,0BAA0B,KAAK,KAAK,kFAAkF;AAC5H,MAAM,WAAW,KAAK,KAAK,eAAe;AAC1C,MAAM,gBAAgB,KAAK,KAAK,oBAAoB;AACpD,MAAM,WAAW,KAAK,KAAK,eAAe;AAC1C,MAAM,eAAe,KAAK,KAAK,sBAAsB;AACrD,MAAM,qBAAqB,KAAK,KAAK,iDAAiD;AACtF,MAAM,mBAAmB,KAAK,KAAK,mCAAmC;AAK/D,MAAM,WAAW,OAAO,OAAO;AAAA,EACrC,WAAW;AAAA,EACX,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,aAAa;AAAA,EACb,UAAU;AAAA,EACV,SAAS;AAAA,EACT,QAAQ;AAAA,EACR,WAAW;AAAA,EACX,YAAY;AAAA,EACZ,WAAW;AAAA,EACX,UAAU;AAAA,EACV,WAAW;AAAA,EACX,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,aAAa;AAAA,EACb,WAAW;AAAA,EACX,SAAS;AAAA,EACT,YAAY;AAAA,EACZ,SAAS;AAAA,EACT,OAAO;AACR,CAAC;AAEM,IAAK,iBAAL,kBAAKA,oBAAL;AACN,EAAAA,gCAAA;AAAS,EAAAA,gCAAA;AAAO,EAAAA,gCAAA;AAAY,EAAAA,gCAAA;AAAI,EAAAA,gCAAA;AAAS,EAAAA,gCAAA;AAAM,EAAAA,gCAAA;AAAW,EAAAA,gCAAA;AAAO,EAAAA,gCAAA;AAAS,EAAAA,gCAAA;AAD/D,SAAAA;AAAA,GAAA;AA4RZ,SAAS,eAAe,YAA0B;AACjD,MAAIC,kBAAiB;AACrB,MAAI,WAAW,WAAW,YAAY;AACtC,MAAI,aAAa,QAAQ,aAAa,QAAW;AAChD,IAAAA,kBAAiB,SAAS,uBAAuB,MAAM;AAAA,EACxD;AACA,SAAOA;AACR;AAEA,SAAS,cAAc,OAA0B;AAChD,SAAO,QAAQ,MAAM,aAAa,GAAG,MAAM,OAAO,CAAC,IAAI;AACxD;AAEA,SAAS,gBAAgB,QAAa,OAAiB;AACtD,MAAI;AACH,QAAI,aAAa,OAAO,cAAc;AACtC,QAAI,eAAe,QAAQ,eAAe,QAAW;AACpD,YAAM,IAAI,MAAM,yDAAyD;AAAA,IAC1E;AACA,QAAI,OAAO;AACX,QAAI,eAAe,UAAU,GAAG;AAC/B,UAAI,KAAK;AACT,UAAI;AACH,aAAK,WAAW,iBAAiB,gCAAgC;AACjE,WAAG,UAAU,GAAG,KAAK;AACrB,YAAI,KAAK,GAAG,aAAa;AACzB,YAAI,GAAG,KAAK,GAAG;AACd,iBAAO,GAAG,QAAQ,CAAC;AAAA,QACpB;AAAA,MACD,UAAE;AACD,YAAI,OAAO,QAAQ,OAAO,QAAW;AACpC,aAAG,MAAM;AAAA,QACV;AAAA,MACD;AAAA,IACD,OAAO;AACN,aAAO,WAAW,WAAW;AAC7B,WAAK,UAAU,GAAG,KAAK;AAAA,IACxB;AACA,WAAO;AAAA,EACR,SAAS,GAAQ;AAChB,UAAM,IAAI,MAAM,kDAAkD,EAAE,OAAO,EAAE;AAAA,EAC9E;AACD;AAEA,SAAS,eAAe,OAA0B;AACjD,SAAO,QAAQ,MAAM,aAAa,GAAG,MAAM,OAAO,CAAC,IAAI;AACxD;AAEA,SAAS,iBAAiB,QAAa,OAAiB;AACvD,MAAI;AACH,QAAI,aAAa,OAAO,cAAc;AACtC,QAAI,eAAe,QAAQ,eAAe,QAAW;AACpD,YAAM,IAAI,MAAM,0DAA0D;AAAA,IAC3E;AACA,QAAI,QAAQ;AACZ,QAAI,eAAe,UAAU,GAAG;AAC/B,UAAI,KAAK;AACT,UAAI;AACH,aAAK,WAAW,iBAAiB,iCAAiC;AAClE,WAAG,UAAU,GAAG,KAAK;AACrB,YAAI,KAAK,GAAG,aAAa;AACzB,YAAI,GAAG,KAAK,GAAG;AACd,kBAAQ,GAAG,SAAS,CAAC;AAAA,QACtB;AAAA,MACD,UAAE;AACD,YAAI,OAAO,QAAQ,OAAO,QAAW;AACpC,aAAG,MAAM;AAAA,QACV;AAAA,MACD;AAAA,IACD,OAAO;AACN,cAAQ,WAAW,YAAY;AAC/B,YAAM,UAAU,GAAG,KAAK;AAAA,IACzB;AACA,WAAO;AAAA,EACR,SAAS,GAAQ;AAChB,UAAM,IAAI,MAAM,mDAAmD,EAAE,OAAO,EAAE;AAAA,EAC/E;AACD;AAEA,SAAS,gBAAgB,QAAa,OAAiB;AACtD,MAAI;AACH,QAAI,aAAa,OAAO,cAAc;AACtC,QAAI,eAAe,QAAQ,eAAe,QAAW;AACpD,YAAM,IAAI,MAAM,yDAAyD;AAAA,IAC1E;AACA,QAAI,OAAO;AACX,QAAI,eAAe,UAAU,GAAG;AAC/B,UAAI,KAAK;AACT,UAAI;AACH,aAAK,WAAW,iBAAiB,gCAAgC;AACjE,WAAG,SAAS,GAAG,KAAK;AACpB,YAAI,KAAK,GAAG,aAAa;AACzB,YAAI,GAAG,KAAK,GAAG;AACd,iBAAO,GAAG,QAAQ,CAAC;AAAA,QACpB;AAAA,MACD,UAAE;AACD,YAAI,OAAO,QAAQ,OAAO,QAAW;AACpC,aAAG,MAAM;AAAA,QACV;AAAA,MACD;AAAA,IACD,OAAO;AACN,aAAO,WAAW,WAAW;AAC7B,WAAK,SAAS,GAAG,KAAK;AAAA,IACvB;AACA,WAAO;AAAA,EACR,SAAS,GAAQ;AAChB,UAAM,IAAI,MAAM,kDAAkD,EAAE,OAAO,EAAE;AAAA,EAC9E;AACD;AAEA,SAAS,aAAa,OAA4B;AACjD,MAAI,OAAO,UAAU,UAAU;AAC9B,WAAO,IAAI,KAAK,KAAK;AAAA,EACtB;AACA,SAAO;AACR;AAOO,MAAM,kBAAkB;AAAA,EAI9B,YAAY,QAAa;AACxB,SAAK,SAAS;AAAA,EACf;AAAA,EAEO,QAAc;AACpB,SAAK,OAAO,MAAM;AAAA,EACnB;AAAA,EAEO,eAA0B;AAChC,WAAO,IAAI,UAAU,KAAK,OAAO,aAAa,CAAC;AAAA,EAChD;AAAA,EAEO,UAAmB;AACzB,WAAO,KAAK,OAAO,QAAQ;AAAA,EAC5B;AAAA,EAEO,eAA0B;AAChC,WAAO,IAAI,UAAU,KAAK,OAAO,aAAa,CAAC;AAAA,EAChD;AAAA,EAEO,gBAAwB;AAC9B,WAAO,KAAK,OAAO,cAAc;AAAA,EAClC;AAAA,EAEO,QAAQ,OAAe,SAAuB;AACpD,SAAK,OAAO,QAAQ,OAAO,OAAO;AAAA,EACnC;AAAA,EAEO,gBAAgB,gBAAwB,aAA0B,QAAuB;AAC/F,QAAI,QAAQ;AACX,WAAK,OAAO,gBAAgB,gBAAgB,aAAa,MAAM;AAAA,IAChE,OAAO;AACN,WAAK,OAAO,gBAAgB,gBAAgB,WAAW;AAAA,IACxD;AAAA,EACD;AAAA,EAEO,WAAW,OAAe,OAAuB;AACvD,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,WAAW,OAAO,KAAK;AAAA,IACpC,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,OAAO;AAAA,IACrC;AAAA,EACD;AAAA,EAEO,QAAQ,OAAe,OAA8B;AAC3D,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,QAAQ,OAAO,KAAK;AAAA,IACjC,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,OAAO;AAAA,IACrC;AAAA,EACD;AAAA,EAEO,QAAQ,OAAe,OAA+B;AAC5D,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,UAAI,OAAO,gBAAgB,KAAK,QAAQ,KAAK;AAC7C,WAAK,OAAO,QAAQ,OAAO,IAAI;AAAA,IAChC,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,IAAI;AAAA,IAClC;AAAA,EACD;AAAA,EAEO,QAAQ,OAAe,OAA8B;AAC3D,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,UAAI,OAAO,gBAAgB,KAAK,QAAQ,KAAK;AAC7C,WAAK,OAAO,QAAQ,OAAO,IAAI;AAAA,IAChC,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,IAAI;AAAA,IAClC;AAAA,EACD;AAAA,EAEO,SAAS,OAAe,OAA+B;AAC7D,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,UAAI,QAAQ,iBAAiB,KAAK,QAAQ,KAAK;AAC/C,WAAK,OAAO,SAAS,OAAO,KAAK;AAAA,IAClC,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,KAAK;AAAA,IACnC;AAAA,EACD;AAAA,EAEO,eAAe,OAAe,OAAgC;AACpE,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,SAAS,OAAO,KAAK;AAAA,IAClC,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,SAAS;AAAA,IACvC;AAAA,EACD;AAAA,EAEO,SAAS,OAAe,OAAgC;AAC9D,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,UAAI,OAAO,MAAM,YAAY,KAAK;AAClC,WAAK,OAAO,SAAS,OAAO,IAAI;AAAA,IACjC,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,SAAS;AAAA,IACvC;AAAA,EACD;AAAA,EAEO,QAAQ,OAAe,OAA6B;AAC1D,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,YAAM,OAAO,aAAa,KAAK;AAC/B,WAAK,OAAO,QAAQ,OAAO,IAAI,SAAS,KAAK,QAAQ,CAAC,CAAC;AAAA,IACxD,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,IAAI;AAAA,IAClC;AAAA,EACD;AAAA,EAEO,UAAU,OAAe,OAAsB;AACrD,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,UAAU,OAAO,KAAK;AAAA,IACnC,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,MAAM;AAAA,IACpC;AAAA,EACD;AAAA,EAEO,SAAS,OAAe,OAAsB;AACpD,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,SAAS,OAAO,KAAK;AAAA,IAClC,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,KAAK;AAAA,IACnC;AAAA,EACD;AAAA,EAEO,OAAO,OAAe,OAAsB;AAClD,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,OAAO,OAAO,KAAK;AAAA,IAChC,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,OAAO;AAAA,IACrC;AAAA,EACD;AAAA,EAEO,QAAQ,OAAe,OAAsB;AACnD,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,QAAQ,OAAO,KAAK;AAAA,IACjC,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,MAAM;AAAA,IACpC;AAAA,EACD;AAAA,EAEO,SAAS,OAAe,OAAsB;AACpD,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,SAAS,OAAO,KAAK;AAAA,IAClC,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,QAAQ;AAAA,IACtC;AAAA,EACD;AAAA,EAEO,UAAU,OAAe,OAAsB;AACrD,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,UAAU,OAAO,KAAK;AAAA,IACnC,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,OAAO;AAAA,IACrC;AAAA,EACD;AAAA,EAEO,QAAQ,OAAe,OAA6B;AAC1D,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,YAAM,OAAO,aAAa,KAAK;AAC/B,WAAK,OAAO,QAAQ,OAAO,IAAI,SAAS,KAAK,QAAQ,CAAC,CAAC;AAAA,IACxD,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,IAAI;AAAA,IAClC;AAAA,EACD;AAAA,EAEO,aAAa,OAAe,OAA6B;AAC/D,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,YAAM,OAAO,aAAa,KAAK;AAC/B,WAAK,OAAO,aAAa,OAAO,IAAI,cAAc,KAAK,QAAQ,CAAC,CAAC;AAAA,IAClE,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,SAAS;AAAA,IACvC;AAAA,EACD;AAAA,EAEO,cAAc,OAAe,OAAuC;AAC1E,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,cAAc,OAAO,KAAK;AAAA,IACvC,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,OAAO;AAAA,IACrC;AAAA,EACD;AAAA,EAEO,WAAW,OAAe,OAAsB;AACtD,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,WAAW,OAAO,KAAK;AAAA,IACpC,OAAO;AACN,WAAK,QAAQ,OAAO,SAAS,QAAQ;AAAA,IACtC;AAAA,EACD;AAAA,EAEO,WAAiB;AACvB,SAAK,OAAO,SAAS;AAAA,EACtB;AAAA,EAEO,eAAyB;AAC/B,WAAO,KAAK,OAAO,aAAa;AAAA,EACjC;AAAA,EAEO,cAAmB;AACzB,WAAO,KAAK,OAAO,YAAY;AAAA,EAChC;AAAA,EAEO,iBAA0B;AAChC,WAAO,KAAK,OAAO,eAAe;AAAA,EACnC;AAAA,EAEO,uBAA4B;AAClC,WAAO,KAAK,OAAO,qBAAqB;AAAA,EACzC;AAAA,EAEO,gBAAqB;AAC3B,WAAO,KAAK,OAAO,YAAY;AAAA,EAChC;AAAA,EAEO,WAAoB;AAC1B,WAAO,KAAK,OAAO,SAAS;AAAA,EAC7B;AACD;AAEO,MAAM,kBAAkB;AAAA,EAG9B,YAAY,QAAa;AACxB,SAAK,SAAS;AAAA,EACf;AAAA,EAEO,eAA0B;AAChC,WAAO,IAAI,UAAU,KAAK,OAAO,aAAa,CAAC;AAAA,EAChD;AAAA,EAEO,eAA0B;AAChC,WAAO,IAAI,UAAU,KAAK,OAAO,aAAa,CAAC;AAAA,EAChD;AAAA,EAEO,gBAAwB;AAC9B,WAAO,KAAK,OAAO,cAAc;AAAA,EAClC;AAAA,EAEO,qBAAqB,gBAAwB,SAA+C;AAClG,SAAK,OAAO,qBAAqB,gBAAgB,OAAO;AAAA,EACzD;AAAA,EAEO,4BAA4B,gBAAwB,SAAyC,OAAqB;AACxH,SAAK,OAAO,qBAAqB,gBAAgB,SAAS,KAAK;AAAA,EAChE;AAAA,EAEO,+BAA+B,gBAAwB,SAAyC,UAAwB;AAC9H,SAAK,OAAO,qBAAqB,gBAAgB,SAAS,QAAQ;AAAA,EACnE;AAAA,EAEO,UAAmB;AACzB,WAAO,KAAK,OAAO,QAAQ;AAAA,EAC5B;AAAA,EAEO,UAAU,gBAAgC;AAChD,WAAO,KAAK,OAAO,UAAU,cAAc;AAAA,EAC5C;AAAA,EAEO,WAAW,gBAAiC;AAClD,WAAO,KAAK,OAAO,WAAW,cAAc;AAAA,EAC7C;AAAA,EAEO,QAAQ,gBAAwC;AACtD,WAAO,KAAK,OAAO,QAAQ,cAAc;AAAA,EAC1C;AAAA,EAEO,SAAS,gBAAgC;AAC/C,WAAO,KAAK,OAAO,SAAS,cAAc;AAAA,EAC3C;AAAA,EAEO,OAAO,gBAAgC;AAC7C,WAAO,KAAK,OAAO,OAAO,cAAc;AAAA,EACzC;AAAA,EAEO,QAAQ,gBAAgC;AAC9C,WAAO,KAAK,OAAO,QAAQ,cAAc;AAAA,EAC1C;AAAA,EAEO,SAAS,gBAAgC;AAC/C,WAAO,KAAK,OAAO,SAAS,cAAc;AAAA,EAC3C;AAAA,EAEO,UAAU,gBAAgC;AAChD,WAAO,KAAK,OAAO,UAAU,cAAc;AAAA,EAC5C;AAAA,EAEO,QAAQ,gBAA8B;AAC5C,UAAM,eAAe,KAAK,OAAO,QAAQ,cAAc;AACvD,WAAO,iBAAiB,QAAQ,iBAAiB,SAAY,IAAI,KAAK,aAAa,QAAQ,CAAC,IAAI;AAAA,EACjG;AAAA,EAEO,QAAQ,gBAA8B;AAC5C,UAAM,eAAe,KAAK,OAAO,QAAQ,cAAc;AACvD,WAAO,iBAAiB,QAAQ,iBAAiB,SAAY,IAAI,KAAK,aAAa,QAAQ,CAAC,IAAI;AAAA,EACjG;AAAA,EAEO,aAAa,gBAA8B;AACjD,UAAM,eAAe,KAAK,OAAO,aAAa,cAAc;AAC5D,WAAO,iBAAiB,QAAQ,iBAAiB,SAAY,IAAI,KAAK,aAAa,QAAQ,CAAC,IAAI;AAAA,EACjG;AAAA,EAEO,UAAU,gBAA6B;AAC7C,WAAO,KAAK,OAAO,UAAU,cAAc;AAAA,EAC5C;AAAA,EAEO,cAAc,gBAAqD;AACzE,WAAO,KAAK,OAAO,cAAc,cAAc;AAAA,EAChD;AAAA,EAEO,OAAO,gBAA2C;AACxD,WAAO,KAAK,OAAO,OAAO,cAAc;AAAA,EACzC;AAAA,EAEO,SAAS,gBAA4C;AAC3D,UAAM,OAAO,KAAK,OAAO,SAAS,cAAc;AAChD,WAAO,MAAM,kBAAkB,IAAI;AAAA,EACpC;AAAA,EAEO,eAAe,gBAA4C;AACjE,WAAO,KAAK,OAAO,SAAS,cAAc;AAAA,EAC3C;AAAA,EAEO,QAAQ,gBAA4C;AAC1D,UAAM,OAAO,eAAe,cAAc,KAAK,QAAQ,cAAc;AACrE,WAAO,MAAM,kBAAkB,IAAI;AAAA,EACpC;AAAA,EAEO,cAAc,gBAA4C;AAChE,WAAO,eAAe,cAAc,KAAK,QAAQ,cAAc;AAAA,EAChE;AAAA,EAEO,QAAQ,gBAA4C;AAC1D,WAAO,cAAc,KAAK,OAAO,QAAQ,cAAc,CAAC;AAAA,EACzD;AAAA,EAEO,SAAS,gBAAsD;AACrE,WAAO,eAAe,KAAK,OAAO,SAAS,cAAc,CAAC;AAAA,EAC3D;AAAA,EAEO,WAAW,gBAAyC;AAC1D,WAAO,KAAK,OAAO,WAAW,cAAc;AAAA,EAC7C;AAAA,EAEO,SAAS,gBAAwD;AACvE,WAAO,KAAK,OAAO,SAAS,cAAc;AAAA,EAC3C;AAAA,EAEO,OAAO,gBAAsC;AACnD,WAAO,KAAK,OAAO,OAAO,cAAc;AAAA,EACzC;AAAA,EAEO,SAAS,gBAAsD;AACrE,WAAO,KAAK,OAAO,SAAS,cAAc;AAAA,EAC3C;AAAA,EAEO,UAAU,gBAAuD;AACvE,WAAO,KAAK,OAAO,UAAU,cAAc;AAAA,EAC5C;AAAA,EAEO,OAAO,gBAAwB,OAAkB;AACvD,SAAK,OAAO,OAAO,gBAAgB,KAAK;AAAA,EACzC;AAAA,EAEO,QAAQ,gBAAwB,YAA4C,UAAyB;AAC3G,UAAM,UAAkB,OAAO,UAAU,UAAoB,IAAI,aAAuB,SAAS,UAAmC;AACpI,QAAI,aAAa,UAAa,aAAa,MAAM;AAChD,WAAK,OAAO,QAAQ,gBAAgB,SAAS,QAAQ;AAAA,IACtD,OAAO;AACN,WAAK,OAAO,QAAQ,gBAAgB,OAAO;AAAA,IAC5C;AAAA,EACD;AAAA,EAEO,WAAW,gBAAwB,OAAuB;AAChE,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,WAAW,gBAAgB,KAAK;AAAA,IAC7C,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,OAAO;AAAA,IAC9C;AAAA,EACD;AAAA,EAEO,QAAQ,gBAAwB,OAA8B;AACpE,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,QAAQ,gBAAgB,KAAK;AAAA,IAC1C,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,GAAG;AAAA,IAC1C;AAAA,EACD;AAAA,EAEO,SAAS,gBAAwB,OAAsB;AAC7D,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,SAAS,gBAAgB,KAAK;AAAA,IAC3C,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,QAAQ;AAAA,IAC/C;AAAA,EACD;AAAA,EAEO,OAAO,gBAAwB,OAAsB;AAC3D,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,OAAO,gBAAgB,KAAK;AAAA,IACzC,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,OAAO;AAAA,IAC9C;AAAA,EACD;AAAA,EAEO,QAAQ,gBAAwB,OAAsB;AAC5D,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,QAAQ,gBAAgB,KAAK;AAAA,IAC1C,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,MAAM;AAAA,IAC7C;AAAA,EACD;AAAA,EAEO,SAAS,gBAAwB,OAAsB;AAC7D,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,SAAS,gBAAgB,KAAK;AAAA,IAC3C,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,KAAK;AAAA,IAC5C;AAAA,EACD;AAAA,EAEO,UAAU,gBAAwB,OAAsB;AAC9D,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,UAAU,gBAAgB,KAAK;AAAA,IAC5C,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,MAAM;AAAA,IAC7C;AAAA,EACD;AAAA,EAEO,cAAc,gBAAwB,OAAuC;AACnF,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,cAAc,gBAAgB,KAAK;AAAA,IAChD,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,OAAO;AAAA,IAC9C;AAAA,EACD;AAAA,EAEO,UAAU,gBAAwB,OAAsB;AAC9D,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,UAAU,gBAAgB,KAAK;AAAA,IAC5C,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,OAAO;AAAA,IAC9C;AAAA,EACD;AAAA,EAEO,SAAS,gBAAwB,OAAgC;AACvE,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,SAAS,gBAAgB,KAAK;AAAA,IAC3C,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,KAAK;AAAA,IAC5C;AAAA,EACD;AAAA,EAEO,QAAQ,gBAAwB,OAA6B;AACnE,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,YAAM,OAAO,aAAa,KAAK;AAC/B,WAAK,OAAO,QAAQ,gBAAgB,IAAI,SAAS,KAAK,QAAQ,CAAC,CAAC;AAAA,IACjE,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,IAAI;AAAA,IAC3C;AAAA,EACD;AAAA,EAEO,QAAQ,gBAAwB,OAA6B;AACnE,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,YAAM,OAAO,aAAa,KAAK;AAC/B,WAAK,OAAO,QAAQ,gBAAgB,IAAI,SAAS,KAAK,QAAQ,CAAC,CAAC;AAAA,IACjE,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,IAAI;AAAA,IAC3C;AAAA,EACD;AAAA,EAEO,aAAa,gBAAwB,OAA6B;AACxE,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,UAAI,OAAO,aAAa,KAAK;AAC7B,WAAK,OAAO,aAAa,gBAAgB,IAAI,cAAc,KAAK,QAAQ,CAAC,CAAC;AAAA,IAC3E,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,SAAS;AAAA,IAChD;AAAA,EACD;AAAA,EAEO,eAAe,gBAAwB,aAA0B,QAAuB;AAC9F,QAAI,QAAQ;AACX,WAAK,OAAO,eAAe,gBAAgB,aAAa,MAAM;AAAA,IAC/D,OAAO;AACN,WAAK,OAAO,eAAe,gBAAgB,WAAW;AAAA,IACvD;AAAA,EACD;AAAA,EAEO,gBAAgB,gBAAwB,aAA0B,QAAuB;AAC/F,QAAI,QAAQ;AACX,WAAK,OAAO,gBAAgB,gBAAgB,aAAa,MAAM;AAAA,IAChE,OAAO;AACN,WAAK,OAAO,gBAAgB,gBAAgB,WAAW;AAAA,IACxD;AAAA,EACD;AAAA,EAEO,UAAU,gBAAwB,OAAY,eAAwB,OAAsB;AAClG,QAAI,UAAU,UAAa,UAAU,QAAQ,kBAAkB,UAAa,kBAAkB,MAAM;AACnG,WAAK,OAAO,UAAU,gBAAgB,OAAO,eAAe,KAAK;AAAA,IAClE,WAAW,kBAAkB,UAAa,kBAAkB,MAAM;AACjE,WAAK,OAAO,UAAU,gBAAgB,OAAO,aAAa;AAAA,IAC3D,OAAO;AACN,WAAK,OAAO,UAAU,gBAAgB,KAAK;AAAA,IAC5C;AAAA,EACD;AAAA,EAEO,SAAS,gBAAwB,OAAiC;AACxE,SAAK,OAAO,SAAS,gBAAgB,KAAK;AAAA,EAC3C;AAAA,EAEO,WAAW,gBAAwB,OAAqB;AAC9D,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,WAAW,gBAAgB,KAAK;AAAA,IAC7C,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,QAAQ;AAAA,IAC/C;AAAA,EACD;AAAA,EAEO,UAAU,gBAAwB,OAA+B;AACvE,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,WAAK,OAAO,UAAU,gBAAgB,KAAK;AAAA,IAC5C,OAAO;AACN,YAAM,IAAI,MAAM,qCAAqC;AAAA,IACtD;AAAA,EACD;AAAA,EAEO,QAAQ,gBAAwB,OAA4B;AAClE,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,YAAM,OAAO,gBAAgB,KAAK,QAAQ,KAAK;AAC/C,WAAK,OAAO,QAAQ,gBAAgB,IAAI;AAAA,IACzC,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,IAAI;AAAA,IAC3C;AAAA,EACD;AAAA,EAEO,QAAQ,gBAAwB,OAA6B;AACnE,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,YAAM,OAAO,gBAAgB,KAAK,QAAQ,KAAK;AAC/C,WAAK,OAAO,QAAQ,gBAAgB,IAAI;AAAA,IACzC,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,IAAI;AAAA,IAC3C;AAAA,EACD;AAAA,EAEO,SAAS,gBAAwB,OAA8B;AACrE,QAAI,UAAU,QAAQ,UAAU,QAAW;AAC1C,YAAM,QAAQ,iBAAiB,KAAK,QAAQ,KAAK;AACjD,WAAK,OAAO,SAAS,gBAAgB,KAAK;AAAA,IAC3C,OAAO;AACN,WAAK,QAAQ,gBAAgB,SAAS,KAAK;AAAA,IAC5C;AAAA,EACD;AAAA,EAEO,UAAmB;AACzB,WAAO,KAAK,OAAO,QAAQ;AAAA,EAC5B;AAAA,EAEO,iBAA0B;AAChC,WAAO,KAAK,OAAO,eAAe;AAAA,EACnC;AAAA,EAEO,uBAAoD;AAC1D,WAAO,KAAK,OAAO,qBAAqB;AAAA,EACzC;AAAA,EAEO,WAAoB;AAC1B,WAAO,KAAK,OAAO,SAAS;AAAA,EAC7B;AAAA,EAEO,QAAc;AACpB,SAAK,OAAO,MAAM;AAAA,EACnB;AACD;AAKO,MAAM,UAAU;AAAA,EAItB,YAAY,QAAa;AACxB,SAAK,SAAS;AAAA,EACf;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,OAAO,UAAU,OAAO,YAAY,OAAc;AACxD,UAAM,KAAK,IAAI,aAAa;AAC5B,UAAM,SAAS,mBACb,QAAQ,EACR,UAAU,EAAE,EACZ,WAAW,iBAAiB,KAAK,EACjC,IAAI;AACN,4BAAwB,OAAO,KAAK,QAAQ,SAAS,WAAW,MAAM;AACtE,UAAM,aAAa,GAAG,SAAS;AAC/B,WAAO,YAAY,aAAa,KAAK,MAAM,UAAU;AAAA,EACtD;AAAA,EAEO,QAAc;AACpB,SAAK,OAAO,MAAM;AAAA,EACnB;AAAA,EAEO,cAAc,YAAoD;AACxE,WAAO,KAAK,OAAO,cAAc,UAAU;AAAA,EAC5C;AAAA,EAEO,WAAW,YAAsC;AACvD,WAAO,KAAK,OAAO,WAAW,UAAU;AAAA,EACzC;AAAA,EAEO,QAAQ,YAA6C;AAC3D,WAAO,KAAK,OAAO,QAAQ,UAAU;AAAA,EACtC;AAAA,EAEO,SAAS,YAAiD;AAChE,UAAM,OAAO,KAAK,OAAO,SAAS,UAAU;AAC5C,WAAO,MAAM,kBAAkB,IAAI;AAAA,EACpC;AAAA,EAEO,eAAe,YAAiD;AACtE,WAAO,KAAK,OAAO,SAAS,UAAU;AAAA,EACvC;AAAA,EAEO,QAAQ,YAAiD;AAC/D,UAAM,OAAO,eAAe,cAAc,KAAK,QAAQ,UAAU;AACjE,WAAO,MAAM,kBAAkB,IAAI;AAAA,EACpC;AAAA,EAEO,cAAc,YAAiD;AACrE,WAAO,eAAe,cAAc,KAAK,QAAQ,UAAU;AAAA,EAC5D;AAAA,EAEO,QAAQ,YAAiD;AAC/D,WAAO,cAAc,KAAK,OAAO,QAAQ,UAAU,CAAC;AAAA,EACrD;AAAA,EAEO,SAAS,YAAkD;AACjE,WAAO,eAAe,KAAK,OAAO,SAAS,UAAU,CAAC;AAAA,EACvD;AAAA,EAEO,QAAQ,YAA+C;AAC7D,UAAM,eAAe,KAAK,OAAO,QAAQ,UAAU;AACnD,WAAO,iBAAiB,QAAQ,iBAAiB,SAAY,IAAI,KAAK,aAAa,QAAQ,CAAC,IAAI;AAAA,EACjG;AAAA,EAEO,UAAU,YAAqC;AACrD,WAAO,KAAK,OAAO,UAAU,UAAU;AAAA,EACxC;AAAA,EAEO,SAAS,YAAqC;AACpD,WAAO,KAAK,OAAO,SAAS,UAAU;AAAA,EACvC;AAAA,EAEO,OAAO,YAAqC;AAClD,WAAO,KAAK,OAAO,OAAO,UAAU;AAAA,EACrC;AAAA,EAEO,QAAQ,YAAqC;AACnD,WAAO,KAAK,OAAO,QAAQ,UAAU;AAAA,EACtC;AAAA,EAEO,SAAS,YAAqC;AACpD,WAAO,KAAK,OAAO,SAAS,UAAU;AAAA,EACvC;AAAA,EAEO,UAAU,YAAqC;AACrD,WAAO,KAAK,OAAO,UAAU,UAAU;AAAA,EACxC;AAAA,EAEO,QAAQ,YAA+C;AAC7D,UAAM,eAAe,KAAK,OAAO,QAAQ,UAAU;AACnD,WAAO,iBAAiB,QAAQ,iBAAiB,SAAY,IAAI,KAAK,aAAa,QAAQ,CAAC,IAAI;AAAA,EACjG;AAAA,EAEO,aAAa,YAA+C;AAClE,UAAM,eAAe,KAAK,OAAO,aAAa,UAAU;AACxD,WAAO,iBAAiB,QAAQ,iBAAiB,SAAY,IAAI,KAAK,aAAa,QAAQ,CAAC,IAAI;AAAA,EACjG;AAAA,EAEO,cAAuB;AAC7B,WAAO,KAAK,OAAO,YAAY;AAAA,EAChC;AAAA,EAEO,gBAAyB;AAC/B,WAAO,KAAK,OAAO,cAAc;AAAA,EAClC;AAAA,EAEO,WAAoB;AAC1B,WAAO,KAAK,OAAO,SAAS;AAAA,EAC7B;AAAA,EAEO,UAAmB;AACzB,WAAO,KAAK,OAAO,QAAQ;AAAA,EAC5B;AAAA,EAEO,SAAkB;AACxB,WAAO,KAAK,OAAO,OAAO;AAAA,EAC3B;AAAA,EAEO,OAAgB;AACtB,WAAO,KAAK,OAAO,KAAK;AAAA,EACzB;AAAA,EAEO,cAA2C;AACjD,WAAO,KAAK,OAAO,YAAY;AAAA,EAChC;AAAA,EAEO,WAAW,aAA6B;AAC9C,WAAO,KAAK,OAAO,WAAW,WAAW;AAAA,EAC1C;AACD;AAOO,MAAM,WAAW;AAAA,EAIvB,YAAY,gBAAyB;AACpC,SAAK,SAAS,eAAe,cAAc,cAAc;AAAA,EAC1D;AAAA;AAAA;AAAA;AAAA,EAKO,SAAS,gBAAyC;AACxD,WAAO,KAAK,kBAAkB,MAAM;AAAA,EACrC;AAAA;AAAA;AAAA;AAAA,EAKO,oBAAoC;AAC1C,UAAM,WAAmB,KAAK,OAAO,kBAAkB,EAAE,KAAK;AAC9D,YAAQ,UAAU;AAAA,MACjB,KAAK;AACJ,eAAO;AAAA,MACR,KAAK;AACJ,eAAO;AAAA,MACR,KAAK;AACJ,eAAO;AAAA,MACR,KAAK;AACJ,eAAO;AAAA,MACR,KAAK;AACJ,eAAO;AAAA,MACR,KAAK;AACJ,eAAO;AAAA,MACR,KAAK;AACJ,eAAO;AAAA,MACR,KAAK;AACJ,eAAO;AAAA,MACR,KAAK;AACJ,eAAO;AAAA,MACR,KAAK;AACJ,eAAO;AAAA,MACR;AACC,cAAM,IAAI,MAAM,4CAA4C,QAAQ,EAAE;AAAA,IACxE;AAAA,EACD;AAAA;AAAA;AAAA;AAAA,EAKO,iBAAiB,KAAgC;AACvD,WAAO,IAAI,kBAAkB,KAAK,OAAO,iBAAiB,GAAG,CAAC;AAAA,EAC/D;AAAA;AAAA;AAAA;AAAA,EAKO,YAAY,KAAgC;AAClD,WAAO,IAAI,kBAAkB,KAAK,OAAO,YAAY,GAAG,CAAC;AAAA,EAC1D;AAAA,EAEO,QAAc;AACpB,QAAI,CAAC,KAAK,SAAS,GAAG;AACrB,WAAK,OAAO,MAAM;AAAA,IACnB;AAAA,EACD;AAAA,EAEO,SAAe;AACrB,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA,EAEO,gBAAyB;AAC/B,WAAO,KAAK,OAAO,cAAc;AAAA,EAClC;AAAA,EAEO,aAAqB;AAC3B,WAAO,KAAK,OAAO,WAAW;AAAA,EAC/B;AAAA,EAEO,YAAoB;AAC1B,WAAO,KAAK,OAAO,UAAU;AAAA,EAC9B;AAAA,EAEO,0BAAkC;AACxC,WAAO,KAAK,OAAO,wBAAwB;AAAA,EAC5C;AAAA,EAEO,WAAoB;AAC1B,WAAO,KAAK,OAAO,SAAS;AAAA,EAC7B;AAAA,EAEO,aAAsB;AAC5B,WAAO,KAAK,OAAO,WAAW;AAAA,EAC/B;AAAA,EAEO,UAAmB;AACzB,WAAO,KAAK,OAAO,QAAQ;AAAA,EAC5B;AAAA,EAEO,WAAiB;AACvB,SAAK,OAAO,SAAS;AAAA,EACtB;AAAA,EAEO,cAAc,YAA2B;AAC/C,SAAK,OAAO,cAAc,UAAU;AAAA,EACrC;AAAA,EAEO,WAAW,SAAuB;AACxC,SAAK,OAAO,WAAW,OAAO;AAAA,EAC/B;AAAA,EAEO,YAAY,UAAyB;AAC3C,SAAK,OAAO,YAAY,QAAQ;AAAA,EACjC;AAAA,EAEO,UAAU,QAAsB;AACtC,SAAK,OAAO,UAAU,MAAM;AAAA,EAC7B;AAAA,EAEO,wBAAwB,sBAAoC;AAClE,SAAK,OAAO,wBAAwB,oBAAoB;AAAA,EACzD;AAAA,EAEO,cAA0C;AAChD,WAAO,KAAK,OAAO,YAAY;AAAA,EAChC;AACD;AAIO,MAAM,SAAS;AAAA;AAAA;AAAA;AAAA,EAKrB,OAAc,iBAA2B;AACxC,UAAM,cAAc,eAAe,eAAe;AAClD,WAAO,cAAc,KAAK,MAAM,WAAW,IAAI,CAAC;AAAA,EACjD;AAAA;AAAA;AAAA;AAAA,EAKA,OAAc,YAAY,gBAAuD;AAChF,UAAM,WAAW,eAAe,YAAY,cAAc;AAC1D,WAAO,WAAW,KAAK,MAAM,QAAQ,IAAI;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA,EAKA,OAAc,eAAe,gBAAiC;AAC7D,WAAO,eAAe,eAAe,cAAc;AAAA,EACpD;AAAA;AAAA;AAAA;AAAA,EAKA,OAAc,cAAc,gBAAqC;AAChE,WAAO,IAAI,WAAW,cAAc;AAAA,EACrC;AACD;AAGA,IAAI,OAAO,WAAW,aAAa;AAElC,SAAO,UAAU;AAAA,IAChB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACD;AACD;",
  "names": ["DatabaseSystem", "isHanaDatabase"]
}
