@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,627 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: true });
8
+ };
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
+ }
15
+ return to;
16
+ };
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+ var client_exports = {};
19
+ __export(client_exports, {
20
+ Client: () => Client,
21
+ DB: () => DB,
22
+ DBCollection: () => DBCollection,
23
+ DBCursor: () => DBCursor,
24
+ DBObject: () => DBObject,
25
+ createBasicDBObject: () => createBasicDBObject
26
+ });
27
+ module.exports = __toCommonJS(client_exports);
28
+ var import_uuid = require("@aerokit/sdk/utils/uuid");
29
+ const MongoDBFacade = Java.type("org.eclipse.dirigible.components.api.mongodb.MongoDBFacade");
30
+ const TimeUnit = Java.type("java.util.concurrent.TimeUnit");
31
+ class DBObject {
32
+ /**
33
+ * Constructs a new DBObject instance.
34
+ * @param native The native MongoDB object (e.g., com.mongodb.DBObject)
35
+ */
36
+ constructor(native) {
37
+ this.native = native;
38
+ }
39
+ /**
40
+ * Appends a key-value pair to the DBObject.
41
+ * @param key The field name.
42
+ * @param value The value to append.
43
+ * @returns The current DBObject instance for chaining.
44
+ */
45
+ append(key, value) {
46
+ this.native.append(key, value);
47
+ return this;
48
+ }
49
+ /**
50
+ * Converts the DBObject to a standard JavaScript object representation (JSON).
51
+ * @returns A plain JavaScript object.
52
+ */
53
+ toJson() {
54
+ return this.native.toJson();
55
+ }
56
+ /**
57
+ * Marks the object as a partial object (used internally by MongoDB driver).
58
+ */
59
+ markAsPartialObject() {
60
+ this.native.markAsPartialObject();
61
+ }
62
+ /**
63
+ * Checks if the object is a partial object.
64
+ * @returns True if partial, false otherwise.
65
+ */
66
+ isPartialObject() {
67
+ return this.native.isPartialObject();
68
+ }
69
+ /**
70
+ * Checks if the DBObject contains a field with the specified key.
71
+ * @param key The field name.
72
+ * @returns True if the field exists, false otherwise.
73
+ */
74
+ containsField(key) {
75
+ return this.native.containsField(key);
76
+ }
77
+ /**
78
+ * Gets the value associated with the given key.
79
+ * @param key The field name.
80
+ * @returns The field value.
81
+ */
82
+ get(key) {
83
+ return this.native.get(key);
84
+ }
85
+ /**
86
+ * Puts a key-value pair into the DBObject.
87
+ * @param key The field name.
88
+ * @param value The value to put.
89
+ * @returns The previous value associated with the key, or null.
90
+ */
91
+ put(key, value) {
92
+ return this.native.put(key, value);
93
+ }
94
+ /**
95
+ * Removes a field from the DBObject.
96
+ * @param key The field name to remove.
97
+ * @returns The removed field value.
98
+ */
99
+ removeField(key) {
100
+ return this.native.removeField(key);
101
+ }
102
+ }
103
+ function extract(dbObject) {
104
+ if (!dbObject.native) {
105
+ return {};
106
+ }
107
+ var extracted = JSON.parse(dbObject.native.toJson());
108
+ for (var propertyName in extracted) {
109
+ dbObject[propertyName] = extracted[propertyName];
110
+ }
111
+ return extracted;
112
+ }
113
+ function implicit(object) {
114
+ if (!object) {
115
+ return void 0;
116
+ }
117
+ if (object.native) {
118
+ return object;
119
+ }
120
+ var dbObject = createBasicDBObject();
121
+ for (var propertyName in object) {
122
+ dbObject.append(propertyName, object[propertyName]);
123
+ }
124
+ return dbObject;
125
+ }
126
+ function createBasicDBObject() {
127
+ const dbObject = new DBObject(MongoDBFacade.createBasicDBObject());
128
+ extract(dbObject);
129
+ return dbObject;
130
+ }
131
+ class Client {
132
+ /**
133
+ * Constructs a new MongoDB Client instance.
134
+ * @param uri The MongoDB connection URI.
135
+ * @param user The username for authentication.
136
+ * @param password The password for authentication.
137
+ */
138
+ constructor(uri, user, password) {
139
+ this.native = MongoDBFacade.getClient(uri, user, password);
140
+ }
141
+ /**
142
+ * Retrieves a database instance.
143
+ * @param name Optional name of the database. If not provided, the default database name is used.
144
+ * @returns A DB instance.
145
+ */
146
+ getDB(name) {
147
+ let native = null;
148
+ if (name) {
149
+ native = this.native.getDB(name);
150
+ } else {
151
+ const defaultDB = MongoDBFacade.getDefaultDatabaseName();
152
+ native = this.native.getDB(defaultDB);
153
+ }
154
+ return new DB(native);
155
+ }
156
+ }
157
+ class DB {
158
+ /**
159
+ * Constructs a new DB instance.
160
+ * @param native The native MongoDB DB object.
161
+ */
162
+ constructor(native) {
163
+ this.native = native;
164
+ }
165
+ /**
166
+ * Retrieves a collection instance from the database.
167
+ * @param name The name of the collection.
168
+ * @returns A DBCollection instance.
169
+ */
170
+ getCollection(name) {
171
+ const native = this.native.getCollection(name);
172
+ return new DBCollection(native);
173
+ }
174
+ }
175
+ class DBCollection {
176
+ /**
177
+ * Constructs a new DBCollection instance.
178
+ * @param native The native MongoDB DBCollection object.
179
+ */
180
+ constructor(native) {
181
+ this.native = native;
182
+ }
183
+ /**
184
+ * Inserts a document into the collection.
185
+ * @param dbObject The document to insert (can be a plain JS object or DBObject).
186
+ */
187
+ insert(dbObject) {
188
+ const dbo = implicit(dbObject);
189
+ if (dbo) {
190
+ this.native.insert(dbo.native);
191
+ }
192
+ }
193
+ /**
194
+ * Finds documents matching the query.
195
+ * @param query The query specification (can be a plain JS object or DBObject).
196
+ * @param projection The fields to include or exclude (can be a plain JS object or DBObject).
197
+ * @returns A DBCursor for iterating over results.
198
+ */
199
+ find(query, projection) {
200
+ const q = implicit(query);
201
+ const p = implicit(projection);
202
+ var native = null;
203
+ if (q) {
204
+ if (p) {
205
+ native = this.native.find(q.native, p.native);
206
+ } else {
207
+ native = this.native.find(q.native);
208
+ }
209
+ } else {
210
+ native = this.native.find();
211
+ }
212
+ return new DBCursor(native);
213
+ }
214
+ /**
215
+ * Finds a single document matching the query.
216
+ * @param query The query specification.
217
+ * @param projection The fields to include or exclude.
218
+ * @param sort The sorting specification.
219
+ * @returns The found document as a DBObject.
220
+ */
221
+ findOne(query, projection, sort) {
222
+ const q = implicit(query);
223
+ const p = implicit(projection);
224
+ const s = implicit(sort);
225
+ var dbObject = createBasicDBObject();
226
+ var native = null;
227
+ if (q) {
228
+ if (p) {
229
+ if (s) {
230
+ native = this.native.findOne(q.native, p.native, s.native);
231
+ } else {
232
+ native = this.native.findOne(q.native, p.native);
233
+ }
234
+ } else {
235
+ native = this.native.findOne(q.native);
236
+ }
237
+ } else {
238
+ native = this.native.findOne();
239
+ }
240
+ dbObject.native = native;
241
+ extract(dbObject);
242
+ return dbObject;
243
+ }
244
+ /**
245
+ * Finds a single document by its string ID.
246
+ * @param id The string ID of the document.
247
+ * @param projection The fields to include or exclude.
248
+ * @returns The found document as a DBObject.
249
+ */
250
+ findOneById(id, projection) {
251
+ const p = implicit(projection);
252
+ const dbObject = createBasicDBObject();
253
+ let native = null;
254
+ if (p) {
255
+ native = this.native.findOne(id, p.native);
256
+ } else {
257
+ native = this.native.findOne(id);
258
+ }
259
+ dbObject.native = native;
260
+ extract(dbObject);
261
+ return dbObject;
262
+ }
263
+ /**
264
+ * Counts the number of documents in the collection, optionally filtered by a query.
265
+ * @param query Optional query to filter the count.
266
+ * @returns The number of documents.
267
+ */
268
+ count(query) {
269
+ const q = implicit(query);
270
+ if (q) {
271
+ return this.native.count(q.native);
272
+ }
273
+ return this.native.count();
274
+ }
275
+ /**
276
+ * Gets the count of documents (alias for count).
277
+ * @param query Optional query to filter the count.
278
+ * @returns The number of documents.
279
+ */
280
+ getCount(query) {
281
+ const q = implicit(query);
282
+ if (q) {
283
+ return this.native.getCount(q.native);
284
+ }
285
+ return this.native.getCount();
286
+ }
287
+ /**
288
+ * Creates an index on the collection.
289
+ * @param keys The index key specification.
290
+ * @param options Optional index options.
291
+ */
292
+ createIndex(keys, options) {
293
+ const k = implicit(keys);
294
+ const o = implicit(options);
295
+ if (k) {
296
+ if (o) {
297
+ this.native.createIndex(k.native, o.native);
298
+ } else {
299
+ this.native.createIndex(k.native);
300
+ }
301
+ } else {
302
+ throw new Error("At least Keys parameter must be provided");
303
+ }
304
+ }
305
+ /**
306
+ * Creates an index on a single field by name.
307
+ * @param name The name of the field to index.
308
+ */
309
+ createIndexForField(name) {
310
+ if (name) {
311
+ this.native.createIndex(name);
312
+ } else {
313
+ throw new Error("The filed name must be provided");
314
+ }
315
+ }
316
+ /**
317
+ * Retrieves the distinct values for a specified field across a collection.
318
+ * NOTE: The signature in the original code seems slightly off compared to typical MongoDB drivers.
319
+ * This implementation follows the original structure using `keys.native` if `keys` is provided.
320
+ * @param name The field name.
321
+ * @param query Optional query to filter results.
322
+ * @param keys Optional keys to use for distinct (replaces 'name' if provided and query exists).
323
+ */
324
+ distinct(name, query, keys) {
325
+ const q = implicit(query);
326
+ const k = implicit(keys);
327
+ if (name) {
328
+ if (q) {
329
+ this.native.distinct(k ? k.native : name, q.native);
330
+ } else {
331
+ this.native.distinct(name);
332
+ }
333
+ } else {
334
+ throw new Error("At least the filed name parameter must be provided");
335
+ }
336
+ }
337
+ /**
338
+ * Drops a specified index.
339
+ * @param index The name of the index or the DBObject representing the index keys.
340
+ */
341
+ dropIndex(index) {
342
+ if (typeof index === "string") {
343
+ this.native.dropIndex(index);
344
+ } else {
345
+ const dbo = implicit(index);
346
+ if (dbo) {
347
+ this.native.dropIndex(dbo.native);
348
+ }
349
+ }
350
+ }
351
+ /**
352
+ * Drops a specified index by name.
353
+ * @param name The name of the index.
354
+ */
355
+ dropIndexByName(name) {
356
+ this.native.dropIndex(name);
357
+ }
358
+ /**
359
+ * Drops all indexes on the collection.
360
+ */
361
+ dropIndexes() {
362
+ this.native.dropIndexes();
363
+ }
364
+ /**
365
+ * Removes documents from the collection matching the query.
366
+ * @param query The deletion query specification.
367
+ */
368
+ remove(query) {
369
+ const q = implicit(query);
370
+ if (q) {
371
+ this.native.remove(q.native);
372
+ }
373
+ }
374
+ /**
375
+ * Renames the collection.
376
+ * @param newName The new name for the collection.
377
+ */
378
+ rename(newName) {
379
+ this.native.rename(newName);
380
+ }
381
+ /**
382
+ * Saves a document to the collection. If the document has an `_id`, it performs an update;
383
+ * otherwise, it performs an insert.
384
+ * @param dbObject The document to save.
385
+ */
386
+ save(dbObject) {
387
+ const dbo = implicit(dbObject);
388
+ if (dbo) {
389
+ this.native.save(dbo.native);
390
+ }
391
+ }
392
+ /**
393
+ * Updates documents in the collection matching the query.
394
+ * @param query The update query specification.
395
+ * @param update The update operation specification (e.g., {$set: {...}}).
396
+ * @param upsert If true, creates a new document if no documents match the query.
397
+ * @param multi If true, updates all documents matching the query; otherwise, only one.
398
+ */
399
+ update(query, update, upsert, multi) {
400
+ const q = implicit(query);
401
+ const u = implicit(update);
402
+ if (q) {
403
+ if (u) {
404
+ if (upsert) {
405
+ if (multi) {
406
+ this.native.update(q.native, u.native, upsert, multi);
407
+ } else {
408
+ this.native.update(q.native, u.native, upsert);
409
+ }
410
+ } else {
411
+ this.native.update(q.native, u.native);
412
+ }
413
+ } else {
414
+ throw new Error("The update parameter must be provided");
415
+ }
416
+ } else {
417
+ throw new Error("The query parameter must be provided");
418
+ }
419
+ }
420
+ /**
421
+ * Updates multiple documents in the collection matching the query.
422
+ * (Equivalent to calling `update` with `multi=true` and `upsert=true` implicitly).
423
+ * @param query The update query specification.
424
+ * @param update The update operation specification.
425
+ */
426
+ updateMulti(query, update) {
427
+ const q = implicit(query);
428
+ const u = implicit(update);
429
+ if (q) {
430
+ if (u) {
431
+ this.native.update(q.native, u.native, true, true);
432
+ } else {
433
+ throw new Error("The update parameter must be provided");
434
+ }
435
+ } else {
436
+ throw new Error("The query parameter must be provided");
437
+ }
438
+ }
439
+ /**
440
+ * Calculates the next sequential ID based on the largest existing `_id` in the collection.
441
+ * Assumes `_id` is a numeric field.
442
+ * @returns The next available sequential ID (starting at 1 if collection is empty).
443
+ */
444
+ getNextId() {
445
+ var cursor = this.find({}, { "_id": 1 }).sort({ "_id": -1 }).limit(1);
446
+ if (!cursor.hasNext()) {
447
+ return 1;
448
+ } else {
449
+ return cursor.next()["_id"] + 1;
450
+ }
451
+ }
452
+ /**
453
+ * Generates a new random UUID (Universally Unique Identifier).
454
+ * @returns A string representing the UUID.
455
+ */
456
+ generateUUID() {
457
+ return import_uuid.UUID.random();
458
+ }
459
+ }
460
+ class DBCursor {
461
+ /**
462
+ * Constructs a new DBCursor instance.
463
+ * @param native The native MongoDB DBCursor object.
464
+ */
465
+ constructor(native) {
466
+ this.native = native;
467
+ }
468
+ /**
469
+ * Returns the single result from the cursor.
470
+ * @returns A DBObject representing the document.
471
+ */
472
+ one() {
473
+ const dbObject = new DBObject(this.native.one());
474
+ extract(dbObject);
475
+ return dbObject;
476
+ }
477
+ /**
478
+ * Sets the batch size for the cursor.
479
+ * @param numberOfElements The batch size.
480
+ * @returns The DBCursor instance for chaining.
481
+ */
482
+ batchSize(numberOfElements) {
483
+ this.native.batchSize(numberOfElements);
484
+ return this;
485
+ }
486
+ /**
487
+ * Gets the current batch size.
488
+ * @returns The batch size.
489
+ */
490
+ getBatchSize() {
491
+ return this.native.getBatchSize();
492
+ }
493
+ /**
494
+ * Gets the collection associated with this cursor.
495
+ * @returns The DBCollection instance.
496
+ */
497
+ getCollection() {
498
+ return new DBCollection(this.native.getCollection());
499
+ }
500
+ /**
501
+ * Gets the cursor ID.
502
+ * @returns The cursor ID string.
503
+ */
504
+ getCursorId() {
505
+ return this.native.getCursorId();
506
+ }
507
+ /**
508
+ * Gets the projection object (fields wanted) used in the query.
509
+ * @returns The projection DBObject.
510
+ */
511
+ getKeysWanted() {
512
+ const dbObject = new DBObject(this.native.getKeysWanted());
513
+ extract(dbObject);
514
+ return dbObject;
515
+ }
516
+ /**
517
+ * Gets the limit set on the cursor.
518
+ * @returns The limit number.
519
+ */
520
+ getLimit() {
521
+ return this.native.getLimit();
522
+ }
523
+ /**
524
+ * Closes the cursor.
525
+ */
526
+ close() {
527
+ this.native.close();
528
+ }
529
+ /**
530
+ * Checks if there is a next document in the cursor.
531
+ * @returns True if there is a next document, false otherwise.
532
+ */
533
+ hasNext() {
534
+ return this.native.hasNext();
535
+ }
536
+ /**
537
+ * Retrieves the next document in the cursor.
538
+ * @returns The next document as a DBObject.
539
+ */
540
+ next() {
541
+ const dbObject = new DBObject(this.native.next());
542
+ extract(dbObject);
543
+ return dbObject;
544
+ }
545
+ /**
546
+ * Gets the query object used to create this cursor.
547
+ * @returns The query DBObject.
548
+ */
549
+ getQuery() {
550
+ const dbObject = new DBObject(this.native.getQuery());
551
+ extract(dbObject);
552
+ return dbObject;
553
+ }
554
+ /**
555
+ * Gets the number of documents matched by the query.
556
+ * @returns The total number of documents.
557
+ */
558
+ length() {
559
+ return this.native.length();
560
+ }
561
+ /**
562
+ * Specifies the order in which the query returns the results.
563
+ * @param orderBy The sorting specification (e.g., {field: 1} for ascending).
564
+ * @returns The DBCursor instance for chaining.
565
+ */
566
+ sort(orderBy) {
567
+ const dbo = implicit(orderBy);
568
+ if (!dbo) {
569
+ throw new Error("The orderBy parameter must be provided");
570
+ }
571
+ this.native.sort(dbo.native);
572
+ return this;
573
+ }
574
+ /**
575
+ * Limits the number of results to be returned.
576
+ * @param limit The maximum number of documents to return.
577
+ * @returns The DBCursor instance for chaining.
578
+ */
579
+ limit(limit) {
580
+ this.native.limit(limit);
581
+ return this;
582
+ }
583
+ /**
584
+ * Specifies the exclusive upper bound for a specific index.
585
+ * @param min The minimum value.
586
+ * @returns The DBCursor instance for chaining.
587
+ */
588
+ min(min) {
589
+ this.native.min(min);
590
+ return this;
591
+ }
592
+ /**
593
+ * Specifies the exclusive upper bound for a specific index.
594
+ * @param max The maximum value.
595
+ * @returns The DBCursor instance for chaining.
596
+ */
597
+ max(max) {
598
+ this.native.max(max);
599
+ return this;
600
+ }
601
+ /**
602
+ * Sets a timeout for the server to execute the query.
603
+ * @param maxTime The maximum time in milliseconds.
604
+ * @returns The DBCursor instance for chaining.
605
+ */
606
+ maxTime(maxTime) {
607
+ this.native.maxTime(maxTime, TimeUnit.MILLISECONDS);
608
+ return this;
609
+ }
610
+ /**
611
+ * Gets the size of the result set.
612
+ * @returns The size number.
613
+ */
614
+ size() {
615
+ return this.native.size();
616
+ }
617
+ /**
618
+ * Skips the specified number of documents.
619
+ * @param numberOfElements The number of documents to skip.
620
+ * @returns The DBCursor instance for chaining.
621
+ */
622
+ skip(numberOfElements) {
623
+ this.native.skip(numberOfElements);
624
+ return this;
625
+ }
626
+ }
627
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/mongodb/client.ts"],
  "sourcesContent": ["const MongoDBFacade = Java.type(\"org.eclipse.dirigible.components.api.mongodb.MongoDBFacade\");\nconst TimeUnit = Java.type(\"java.util.concurrent.TimeUnit\");\nimport { UUID } from \"@aerokit/sdk/utils/uuid\";\n\n/**\n * Define a common type for input to functions that accept either a plain JavaScript object\n * (which will be implicitly converted to DBObject) or an existing DBObject wrapper instance.\n */\ntype DBInput = { [key: string]: any } | DBObject | undefined | null;\n\n/**\n * DBObject object represents a BSON document used for queries, insertions, and updates.\n * It wraps the underlying native Java object.\n */\nexport class DBObject {\n\n    /**\n     * The underlying native Java object representing the BSON document.\n     * @private\n     */\n    public native: any;\n\n    /**\n     * Constructs a new DBObject instance.\n     * @param native The native MongoDB object (e.g., com.mongodb.DBObject)\n     */\n    constructor(native: any) {\n        this.native = native;\n    }\n\n    /**\n     * Appends a key-value pair to the DBObject.\n     * @param key The field name.\n     * @param value The value to append.\n     * @returns The current DBObject instance for chaining.\n     */\n    public append(key: string, value: any): DBObject {\n        this.native.append(key, value);\n        return this;\n    }\n\n    /**\n     * Converts the DBObject to a standard JavaScript object representation (JSON).\n     * @returns A plain JavaScript object.\n     */\n    public toJson(): { [key: string]: any } {\n        return this.native.toJson();\n    }\n\n    /**\n     * Marks the object as a partial object (used internally by MongoDB driver).\n     */\n    public markAsPartialObject(): void {\n        this.native.markAsPartialObject();\n    }\n\n    /**\n     * Checks if the object is a partial object.\n     * @returns True if partial, false otherwise.\n     */\n    public isPartialObject(): boolean {\n        return this.native.isPartialObject();\n    }\n\n    /**\n     * Checks if the DBObject contains a field with the specified key.\n     * @param key The field name.\n     * @returns True if the field exists, false otherwise.\n     */\n    public containsField(key: string): boolean {\n        return this.native.containsField(key);\n    }\n\n    /**\n     * Gets the value associated with the given key.\n     * @param key The field name.\n     * @returns The field value.\n     */\n    public get(key: string): any {\n        return this.native.get(key);\n    }\n\n    /**\n     * Puts a key-value pair into the DBObject.\n     * @param key The field name.\n     * @param value The value to put.\n     * @returns The previous value associated with the key, or null.\n     */\n    public put(key: string, value: any): any {\n        return this.native.put(key, value);\n    }\n\n    /**\n     * Removes a field from the DBObject.\n     * @param key The field name to remove.\n     * @returns The removed field value.\n     */\n    public removeField(key: string): any {\n        return this.native.removeField(key);\n    }\n\n}\n\n/**\n * Copies the properties from the native MongoDB object's JSON representation\n * onto the public properties of the DBObject wrapper instance.\n * This allows direct access like `dbObject.fieldName`.\n * @param dbObject The DBObject wrapper instance.\n * @returns The extracted properties object.\n */\nfunction extract(dbObject: DBObject): { [key: string]: any } {\n    if (!dbObject.native) {\n        return {};\n    }\n    // Parse the native object's JSON representation\n    var extracted = JSON.parse(dbObject.native.toJson());\n    // Copy all properties to the wrapper instance\n    for (var propertyName in extracted) {\n        dbObject[propertyName] = extracted[propertyName];\n    }\n    return extracted;\n}\n\n/**\n * Helper function to implicitly convert a plain JS object to a DBObject,\n * or return the existing DBObject instance.\n * @param object Input object which can be a plain object, DBObject, or undefined/null.\n * @returns DBObject or undefined.\n */\nfunction implicit(object: DBInput): DBObject | undefined {\n    if (!object) {\n        return undefined; // Explicitly return undefined if input is falsy\n    }\n    // Check if it already has the native property (assumes it's a DBObject or similar wrapper)\n    if ((object as any).native) {\n        return object as DBObject;\n    }\n\n    // Convert plain object to DBObject\n    var dbObject = createBasicDBObject();\n\n    for (var propertyName in object) {\n        dbObject.append(propertyName, object[propertyName]);\n    }\n    return dbObject;\n}\n\n/**\n * Creates a new, empty DBObject instance.\n * @returns A new DBObject.\n */\nexport function createBasicDBObject(): DBObject {\n    const dbObject = new DBObject(MongoDBFacade.createBasicDBObject());\n    extract(dbObject);\n    return dbObject;\n}\n\n/**\n * Client object wrapper for connecting to MongoDB.\n */\nexport class Client {\n\n    /**\n     * The underlying native MongoDB client object.\n     * @private\n     */\n    private readonly native: any;\n\n    /**\n     * Constructs a new MongoDB Client instance.\n     * @param uri The MongoDB connection URI.\n     * @param user The username for authentication.\n     * @param password The password for authentication.\n     */\n    constructor(uri: string, user: string, password: string) {\n        this.native = MongoDBFacade.getClient(uri, user, password)\n    }\n\n    /**\n     * Retrieves a database instance.\n     * @param name Optional name of the database. If not provided, the default database name is used.\n     * @returns A DB instance.\n     */\n    public getDB(name?: string): DB {\n        let native = null;\n        if (name) {\n            native = this.native.getDB(name);\n        } else {\n            const defaultDB = MongoDBFacade.getDefaultDatabaseName();\n            native = this.native.getDB(defaultDB);\n        }\n\n        return new DB(native);\n    }\n}\n\n/**\n * DB object wrapper for a MongoDB database.\n */\nexport class DB {\n\n    /**\n     * The underlying native MongoDB DB object.\n     * @private\n     */\n    private readonly native: any;\n\n    /**\n     * Constructs a new DB instance.\n     * @param native The native MongoDB DB object.\n     */\n    constructor(native: any) {\n        this.native = native;\n    }\n\n    /**\n     * Retrieves a collection instance from the database.\n     * @param name The name of the collection.\n     * @returns A DBCollection instance.\n     */\n    public getCollection(name: string): DBCollection {\n        const native = this.native.getCollection(name);\n        return new DBCollection(native);\n    }\n}\n\n/**\n * DBCollection object wrapper for a MongoDB collection.\n */\nexport class DBCollection {\n\n    /**\n     * The underlying native MongoDB DBCollection object.\n     * @private\n     */\n    private readonly native: any;\n\n    /**\n     * Constructs a new DBCollection instance.\n     * @param native The native MongoDB DBCollection object.\n     */\n    constructor(native: any) {\n        this.native = native;\n    }\n\n    /**\n     * Inserts a document into the collection.\n     * @param dbObject The document to insert (can be a plain JS object or DBObject).\n     */\n    public insert(dbObject: DBInput): void {\n        const dbo = implicit(dbObject);\n        if (dbo) {\n            this.native.insert(dbo.native);\n        }\n    }\n\n    /**\n     * Finds documents matching the query.\n     * @param query The query specification (can be a plain JS object or DBObject).\n     * @param projection The fields to include or exclude (can be a plain JS object or DBObject).\n     * @returns A DBCursor for iterating over results.\n     */\n    public find(query?: DBInput, projection?: DBInput): DBCursor {\n        const q = implicit(query);\n        const p = implicit(projection);\n\n        var native = null;\n        if (q) {\n            if (p) {\n                native = this.native.find(q.native, p.native);\n            } else {\n                native = this.native.find(q.native);\n            }\n        } else {\n            native = this.native.find();\n        }\n\n        return new DBCursor(native);\n    }\n\n    /**\n     * Finds a single document matching the query.\n     * @param query The query specification.\n     * @param projection The fields to include or exclude.\n     * @param sort The sorting specification.\n     * @returns The found document as a DBObject.\n     */\n    public findOne(query: DBInput, projection: DBInput, sort: DBInput): DBObject {\n        const q = implicit(query);\n        const p = implicit(projection);\n        const s = implicit(sort);\n\n        var dbObject = createBasicDBObject();\n        var native = null;\n        if (q) {\n            if (p) {\n                if (s) {\n                    native = this.native.findOne(q.native, p.native, s.native);\n                } else {\n                    native = this.native.findOne(q.native, p.native);\n                }\n            } else {\n                native = this.native.findOne(q.native);\n            }\n        } else {\n            native = this.native.findOne();\n        }\n        dbObject.native = native;\n        extract(dbObject);\n        return dbObject;\n    }\n\n    /**\n     * Finds a single document by its string ID.\n     * @param id The string ID of the document.\n     * @param projection The fields to include or exclude.\n     * @returns The found document as a DBObject.\n     */\n    public findOneById(id: string, projection?: DBInput): DBObject {\n        const p = implicit(projection);\n        const dbObject = createBasicDBObject();\n        let native = null;\n        if (p) {\n            native = this.native.findOne(id, p.native);\n        } else {\n            native = this.native.findOne(id);\n        }\n        dbObject.native = native;\n        extract(dbObject);\n        return dbObject;\n    }\n\n    /**\n     * Counts the number of documents in the collection, optionally filtered by a query.\n     * @param query Optional query to filter the count.\n     * @returns The number of documents.\n     */\n    public count(query?: DBInput): number {\n        const q = implicit(query);\n        if (q) {\n            return this.native.count(q.native);\n        }\n        return this.native.count();\n    }\n\n    /**\n     * Gets the count of documents (alias for count).\n     * @param query Optional query to filter the count.\n     * @returns The number of documents.\n     */\n    public getCount(query: DBInput): number {\n        const q = implicit(query);\n        if (q) {\n            return this.native.getCount(q.native);\n        }\n        return this.native.getCount();\n    }\n\n    /**\n     * Creates an index on the collection.\n     * @param keys The index key specification.\n     * @param options Optional index options.\n     */\n    public createIndex(keys: DBInput, options: DBInput): void {\n        const k = implicit(keys);\n        const o = implicit(options);\n        if (k) {\n            if (o) {\n                this.native.createIndex(k.native, o.native);\n            } else {\n                this.native.createIndex(k.native);\n            }\n        } else {\n            throw new Error(\"At least Keys parameter must be provided\");\n        }\n    }\n\n    /**\n     * Creates an index on a single field by name.\n     * @param name The name of the field to index.\n     */\n    public createIndexForField(name: string): void {\n        if (name) {\n            this.native.createIndex(name);\n        } else {\n            throw new Error(\"The filed name must be provided\");\n        }\n    }\n\n    /**\n     * Retrieves the distinct values for a specified field across a collection.\n     * NOTE: The signature in the original code seems slightly off compared to typical MongoDB drivers.\n     * This implementation follows the original structure using `keys.native` if `keys` is provided.\n     * @param name The field name.\n     * @param query Optional query to filter results.\n     * @param keys Optional keys to use for distinct (replaces 'name' if provided and query exists).\n     */\n    public distinct(name: string, query: DBInput, keys: DBInput): void {\n        const q = implicit(query);\n        const k = implicit(keys);\n        if (name) {\n            if (q) {\n                // If query is provided, use keys for the field name if k is present, otherwise use 'name'\n                this.native.distinct(k ? k.native : name, q.native);\n            } else {\n                this.native.distinct(name);\n            }\n        } else {\n            throw new Error(\"At least the filed name parameter must be provided\");\n        }\n    }\n\n    /**\n     * Drops a specified index.\n     * @param index The name of the index or the DBObject representing the index keys.\n     */\n    public dropIndex(index: string | DBInput): void {\n        if (typeof index === 'string') {\n            this.native.dropIndex(index);\n        } else {\n            const dbo = implicit(index);\n            if (dbo) {\n                this.native.dropIndex(dbo.native);\n            }\n        }\n    }\n\n    /**\n     * Drops a specified index by name.\n     * @param name The name of the index.\n     */\n    public dropIndexByName(name: string): void {\n        this.native.dropIndex(name);\n    }\n\n    /**\n     * Drops all indexes on the collection.\n     */\n    public dropIndexes(): void {\n        this.native.dropIndexes();\n    }\n\n    /**\n     * Removes documents from the collection matching the query.\n     * @param query The deletion query specification.\n     */\n    public remove(query: DBInput): void {\n        const q = implicit(query);\n        if (q) {\n            this.native.remove(q.native);\n        }\n    }\n\n    /**\n     * Renames the collection.\n     * @param newName The new name for the collection.\n     */\n    public rename(newName: string): void {\n        this.native.rename(newName);\n    }\n\n    /**\n     * Saves a document to the collection. If the document has an `_id`, it performs an update;\n     * otherwise, it performs an insert.\n     * @param dbObject The document to save.\n     */\n    public save(dbObject: DBInput): void {\n        const dbo = implicit(dbObject);\n        if (dbo) {\n            this.native.save(dbo.native);\n        }\n    }\n\n    /**\n     * Updates documents in the collection matching the query.\n     * @param query The update query specification.\n     * @param update The update operation specification (e.g., {$set: {...}}).\n     * @param upsert If true, creates a new document if no documents match the query.\n     * @param multi If true, updates all documents matching the query; otherwise, only one.\n     */\n    public update(query: DBInput, update: DBInput, upsert?: boolean, multi?: boolean): void {\n        const q = implicit(query);\n        const u = implicit(update);\n        if (q) {\n            if (u) {\n                if (upsert) {\n                    if (multi) {\n                        this.native.update(q.native, u.native, upsert, multi);\n                    } else {\n                        this.native.update(q.native, u.native, upsert);\n                    }\n                } else {\n                    this.native.update(q.native, u.native);\n                }\n            } else {\n                throw new Error(\"The update parameter must be provided\");\n            }\n        } else {\n            throw new Error(\"The query parameter must be provided\");\n        }\n    }\n\n    /**\n     * Updates multiple documents in the collection matching the query.\n     * (Equivalent to calling `update` with `multi=true` and `upsert=true` implicitly).\n     * @param query The update query specification.\n     * @param update The update operation specification.\n     */\n    public updateMulti(query: DBInput, update: DBInput): void {\n        const q = implicit(query);\n        const u = implicit(update);\n        if (q) {\n            if (u) {\n                this.native.update(q.native, u.native, true, true); // Assuming updateMulti means upsert=true and multi=true\n            } else {\n                throw new Error(\"The update parameter must be provided\");\n            }\n        } else {\n            throw new Error(\"The query parameter must be provided\");\n        }\n    };\n\n    /**\n     * Calculates the next sequential ID based on the largest existing `_id` in the collection.\n     * Assumes `_id` is a numeric field.\n     * @returns The next available sequential ID (starting at 1 if collection is empty).\n     */\n    public getNextId(): number {\n        var cursor = this.find({}, { \"_id\": 1 }).sort({ \"_id\": -1 }).limit(1);\n        if (!cursor.hasNext()) {\n            return 1;\n        } else {\n            return cursor.next()[\"_id\"] + 1;\n        }\n    }\n\n    /**\n     * Generates a new random UUID (Universally Unique Identifier).\n     * @returns A string representing the UUID.\n     */\n    public generateUUID(): string {\n        return UUID.random();\n    }\n\n}\n\n/**\n * DBCursor object wrapper for iterating over results of a MongoDB query.\n */\nexport class DBCursor {\n\n    /**\n     * The underlying native MongoDB DBCursor object.\n     * @private\n     */\n    private readonly native: any;\n\n    /**\n     * Constructs a new DBCursor instance.\n     * @param native The native MongoDB DBCursor object.\n     */\n    constructor(native: any) {\n        this.native = native;\n    }\n\n    /**\n     * Returns the single result from the cursor.\n     * @returns A DBObject representing the document.\n     */\n    public one(): DBObject {\n        const dbObject = new DBObject(this.native.one());\n        extract(dbObject);\n        return dbObject;\n    }\n\n    /**\n     * Sets the batch size for the cursor.\n     * @param numberOfElements The batch size.\n     * @returns The DBCursor instance for chaining.\n     */\n    public batchSize(numberOfElements: number): DBCursor {\n        this.native.batchSize(numberOfElements);\n        return this;\n    }\n\n    /**\n     * Gets the current batch size.\n     * @returns The batch size.\n     */\n    public getBatchSize(): number {\n        return this.native.getBatchSize();\n    }\n\n    /**\n     * Gets the collection associated with this cursor.\n     * @returns The DBCollection instance.\n     */\n    public getCollection(): DBCollection {\n        return new DBCollection(this.native.getCollection());\n    }\n\n    /**\n     * Gets the cursor ID.\n     * @returns The cursor ID string.\n     */\n    public getCursorId(): string {\n        return this.native.getCursorId();\n    }\n\n    /**\n     * Gets the projection object (fields wanted) used in the query.\n     * @returns The projection DBObject.\n     */\n    public getKeysWanted(): DBObject {\n        const dbObject = new DBObject(this.native.getKeysWanted());\n        extract(dbObject);\n        return dbObject;\n    }\n\n    /**\n     * Gets the limit set on the cursor.\n     * @returns The limit number.\n     */\n    public getLimit(): number {\n        return this.native.getLimit();\n    }\n\n    /**\n     * Closes the cursor.\n     */\n    public close(): void {\n        this.native.close();\n    }\n\n    /**\n     * Checks if there is a next document in the cursor.\n     * @returns True if there is a next document, false otherwise.\n     */\n    public hasNext(): boolean {\n        return this.native.hasNext();\n    }\n\n    /**\n     * Retrieves the next document in the cursor.\n     * @returns The next document as a DBObject.\n     */\n    public next(): DBObject {\n        const dbObject = new DBObject(this.native.next());\n        extract(dbObject);\n        return dbObject;\n    }\n\n    /**\n     * Gets the query object used to create this cursor.\n     * @returns The query DBObject.\n     */\n    public getQuery(): DBObject {\n        const dbObject = new DBObject(this.native.getQuery());\n        extract(dbObject);\n        return dbObject;\n    }\n\n    /**\n     * Gets the number of documents matched by the query.\n     * @returns The total number of documents.\n     */\n    public length(): number {\n        return this.native.length();\n    }\n\n    /**\n     * Specifies the order in which the query returns the results.\n     * @param orderBy The sorting specification (e.g., {field: 1} for ascending).\n     * @returns The DBCursor instance for chaining.\n     */\n    public sort(orderBy: DBInput): DBCursor {\n        const dbo = implicit(orderBy);\n        if (!dbo) {\n            throw new Error(\"The orderBy parameter must be provided\");\n        }\n        this.native.sort(dbo.native);\n        return this;\n    }\n\n    /**\n     * Limits the number of results to be returned.\n     * @param limit The maximum number of documents to return.\n     * @returns The DBCursor instance for chaining.\n     */\n    public limit(limit: number): DBCursor {\n        this.native.limit(limit);\n        return this;\n    }\n\n    /**\n     * Specifies the exclusive upper bound for a specific index.\n     * @param min The minimum value.\n     * @returns The DBCursor instance for chaining.\n     */\n    public min(min: number): DBCursor {\n        this.native.min(min);\n        return this;\n    }\n\n    /**\n     * Specifies the exclusive upper bound for a specific index.\n     * @param max The maximum value.\n     * @returns The DBCursor instance for chaining.\n     */\n    public max(max: number): DBCursor {\n        this.native.max(max);\n        return this;\n    }\n\n    /**\n     * Sets a timeout for the server to execute the query.\n     * @param maxTime The maximum time in milliseconds.\n     * @returns The DBCursor instance for chaining.\n     */\n    public maxTime(maxTime: number): DBCursor {\n        this.native.maxTime(maxTime, TimeUnit.MILLISECONDS);\n        return this;\n    }\n\n    /**\n     * Gets the size of the result set.\n     * @returns The size number.\n     */\n    public size(): number {\n        return this.native.size();\n    }\n\n    /**\n     * Skips the specified number of documents.\n     * @param numberOfElements The number of documents to skip.\n     * @returns The DBCursor instance for chaining.\n     */\n    public skip(numberOfElements: number): DBCursor {\n        this.native.skip(numberOfElements);\n        return this;\n    }\n\n}\n"],
  "mappings": "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",
  "names": []
}
