mongo.do 0.1.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 (707) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +454 -0
  3. package/dist/agentfs/adapters/anthropic.d.ts +176 -0
  4. package/dist/agentfs/adapters/anthropic.d.ts.map +1 -0
  5. package/dist/agentfs/adapters/anthropic.js +629 -0
  6. package/dist/agentfs/adapters/anthropic.js.map +1 -0
  7. package/dist/agentfs/adapters/index.d.ts +21 -0
  8. package/dist/agentfs/adapters/index.d.ts.map +1 -0
  9. package/dist/agentfs/adapters/index.js +23 -0
  10. package/dist/agentfs/adapters/index.js.map +1 -0
  11. package/dist/agentfs/adapters/vercel.d.ts +260 -0
  12. package/dist/agentfs/adapters/vercel.d.ts.map +1 -0
  13. package/dist/agentfs/adapters/vercel.js +288 -0
  14. package/dist/agentfs/adapters/vercel.js.map +1 -0
  15. package/dist/agentfs/glob.d.ts +116 -0
  16. package/dist/agentfs/glob.d.ts.map +1 -0
  17. package/dist/agentfs/glob.js +270 -0
  18. package/dist/agentfs/glob.js.map +1 -0
  19. package/dist/agentfs/grep.d.ts +83 -0
  20. package/dist/agentfs/grep.d.ts.map +1 -0
  21. package/dist/agentfs/grep.js +193 -0
  22. package/dist/agentfs/grep.js.map +1 -0
  23. package/dist/agentfs/index.d.ts +22 -0
  24. package/dist/agentfs/index.d.ts.map +1 -0
  25. package/dist/agentfs/index.js +18 -0
  26. package/dist/agentfs/index.js.map +1 -0
  27. package/dist/agentfs/kv-store.d.ts +128 -0
  28. package/dist/agentfs/kv-store.d.ts.map +1 -0
  29. package/dist/agentfs/kv-store.js +227 -0
  30. package/dist/agentfs/kv-store.js.map +1 -0
  31. package/dist/agentfs/mondo-agent.d.ts +255 -0
  32. package/dist/agentfs/mondo-agent.d.ts.map +1 -0
  33. package/dist/agentfs/mondo-agent.js +879 -0
  34. package/dist/agentfs/mondo-agent.js.map +1 -0
  35. package/dist/agentfs/toolcalls.d.ts +130 -0
  36. package/dist/agentfs/toolcalls.d.ts.map +1 -0
  37. package/dist/agentfs/toolcalls.js +178 -0
  38. package/dist/agentfs/toolcalls.js.map +1 -0
  39. package/dist/agentfs/types.d.ts +171 -0
  40. package/dist/agentfs/types.d.ts.map +1 -0
  41. package/dist/agentfs/types.js +7 -0
  42. package/dist/agentfs/types.js.map +1 -0
  43. package/dist/agentfs/vfs.d.ts +249 -0
  44. package/dist/agentfs/vfs.d.ts.map +1 -0
  45. package/dist/agentfs/vfs.js +469 -0
  46. package/dist/agentfs/vfs.js.map +1 -0
  47. package/dist/cli/index.d.ts +15 -0
  48. package/dist/cli/index.d.ts.map +1 -0
  49. package/dist/cli/index.js +219 -0
  50. package/dist/cli/index.js.map +1 -0
  51. package/dist/cli/mcp.d.ts +119 -0
  52. package/dist/cli/mcp.d.ts.map +1 -0
  53. package/dist/cli/mcp.js +418 -0
  54. package/dist/cli/mcp.js.map +1 -0
  55. package/dist/cli/server.d.ts +179 -0
  56. package/dist/cli/server.d.ts.map +1 -0
  57. package/dist/cli/server.js +441 -0
  58. package/dist/cli/server.js.map +1 -0
  59. package/dist/client/Collection.d.ts +199 -0
  60. package/dist/client/Collection.d.ts.map +1 -0
  61. package/dist/client/Collection.js +256 -0
  62. package/dist/client/Collection.js.map +1 -0
  63. package/dist/client/Database.d.ts +68 -0
  64. package/dist/client/Database.d.ts.map +1 -0
  65. package/dist/client/Database.js +105 -0
  66. package/dist/client/Database.js.map +1 -0
  67. package/dist/client/MongoClient.d.ts +165 -0
  68. package/dist/client/MongoClient.d.ts.map +1 -0
  69. package/dist/client/MongoClient.js +307 -0
  70. package/dist/client/MongoClient.js.map +1 -0
  71. package/dist/client/aggregation-cursor.d.ts +210 -0
  72. package/dist/client/aggregation-cursor.d.ts.map +1 -0
  73. package/dist/client/aggregation-cursor.js +509 -0
  74. package/dist/client/aggregation-cursor.js.map +1 -0
  75. package/dist/client/bulk-write.d.ts +216 -0
  76. package/dist/client/bulk-write.d.ts.map +1 -0
  77. package/dist/client/bulk-write.js +63 -0
  78. package/dist/client/bulk-write.js.map +1 -0
  79. package/dist/client/change-stream.d.ts +245 -0
  80. package/dist/client/change-stream.d.ts.map +1 -0
  81. package/dist/client/change-stream.js +429 -0
  82. package/dist/client/change-stream.js.map +1 -0
  83. package/dist/client/cursor.d.ts +85 -0
  84. package/dist/client/cursor.d.ts.map +1 -0
  85. package/dist/client/cursor.js +156 -0
  86. package/dist/client/cursor.js.map +1 -0
  87. package/dist/client/http-cursor.d.ts +233 -0
  88. package/dist/client/http-cursor.d.ts.map +1 -0
  89. package/dist/client/http-cursor.js +496 -0
  90. package/dist/client/http-cursor.js.map +1 -0
  91. package/dist/client/index.d.ts +18 -0
  92. package/dist/client/index.d.ts.map +1 -0
  93. package/dist/client/index.js +24 -0
  94. package/dist/client/index.js.map +1 -0
  95. package/dist/client/mongo-client.d.ts +60 -0
  96. package/dist/client/mongo-client.d.ts.map +1 -0
  97. package/dist/client/mongo-client.js +190 -0
  98. package/dist/client/mongo-client.js.map +1 -0
  99. package/dist/client/mongo-collection.d.ts +359 -0
  100. package/dist/client/mongo-collection.d.ts.map +1 -0
  101. package/dist/client/mongo-collection.js +1641 -0
  102. package/dist/client/mongo-collection.js.map +1 -0
  103. package/dist/client/mongo-cursor.d.ts +257 -0
  104. package/dist/client/mongo-cursor.d.ts.map +1 -0
  105. package/dist/client/mongo-cursor.js +621 -0
  106. package/dist/client/mongo-cursor.js.map +1 -0
  107. package/dist/client/mongo-database.d.ts +88 -0
  108. package/dist/client/mongo-database.d.ts.map +1 -0
  109. package/dist/client/mongo-database.js +139 -0
  110. package/dist/client/mongo-database.js.map +1 -0
  111. package/dist/client/session.d.ts +210 -0
  112. package/dist/client/session.d.ts.map +1 -0
  113. package/dist/client/session.js +326 -0
  114. package/dist/client/session.js.map +1 -0
  115. package/dist/durable-object/index-manager.d.ts +173 -0
  116. package/dist/durable-object/index-manager.d.ts.map +1 -0
  117. package/dist/durable-object/index-manager.js +764 -0
  118. package/dist/durable-object/index-manager.js.map +1 -0
  119. package/dist/durable-object/index.d.ts +12 -0
  120. package/dist/durable-object/index.d.ts.map +1 -0
  121. package/dist/durable-object/index.js +8 -0
  122. package/dist/durable-object/index.js.map +1 -0
  123. package/dist/durable-object/mcp-handler.d.ts +52 -0
  124. package/dist/durable-object/mcp-handler.d.ts.map +1 -0
  125. package/dist/durable-object/mcp-handler.js +186 -0
  126. package/dist/durable-object/mcp-handler.js.map +1 -0
  127. package/dist/durable-object/migrations.d.ts +40 -0
  128. package/dist/durable-object/migrations.d.ts.map +1 -0
  129. package/dist/durable-object/migrations.js +121 -0
  130. package/dist/durable-object/migrations.js.map +1 -0
  131. package/dist/durable-object/mondo-database.d.ts +148 -0
  132. package/dist/durable-object/mondo-database.d.ts.map +1 -0
  133. package/dist/durable-object/mondo-database.js +621 -0
  134. package/dist/durable-object/mondo-database.js.map +1 -0
  135. package/dist/durable-object/schema.d.ts +192 -0
  136. package/dist/durable-object/schema.d.ts.map +1 -0
  137. package/dist/durable-object/schema.js +186 -0
  138. package/dist/durable-object/schema.js.map +1 -0
  139. package/dist/embedding/document-serializer.d.ts +118 -0
  140. package/dist/embedding/document-serializer.d.ts.map +1 -0
  141. package/dist/embedding/document-serializer.js +339 -0
  142. package/dist/embedding/document-serializer.js.map +1 -0
  143. package/dist/embedding/embedding-manager.d.ts +136 -0
  144. package/dist/embedding/embedding-manager.d.ts.map +1 -0
  145. package/dist/embedding/embedding-manager.js +176 -0
  146. package/dist/embedding/embedding-manager.js.map +1 -0
  147. package/dist/embedding/index.d.ts +9 -0
  148. package/dist/embedding/index.d.ts.map +1 -0
  149. package/dist/embedding/index.js +9 -0
  150. package/dist/embedding/index.js.map +1 -0
  151. package/dist/executor/aggregation-executor.d.ts +93 -0
  152. package/dist/executor/aggregation-executor.d.ts.map +1 -0
  153. package/dist/executor/aggregation-executor.js +275 -0
  154. package/dist/executor/aggregation-executor.js.map +1 -0
  155. package/dist/executor/function-executor.d.ts +39 -0
  156. package/dist/executor/function-executor.d.ts.map +1 -0
  157. package/dist/executor/function-executor.js +168 -0
  158. package/dist/executor/function-executor.js.map +1 -0
  159. package/dist/executor/index.d.ts +4 -0
  160. package/dist/executor/index.d.ts.map +1 -0
  161. package/dist/executor/index.js +4 -0
  162. package/dist/executor/index.js.map +1 -0
  163. package/dist/executor/vector-search-executor.d.ts +71 -0
  164. package/dist/executor/vector-search-executor.d.ts.map +1 -0
  165. package/dist/executor/vector-search-executor.js +113 -0
  166. package/dist/executor/vector-search-executor.js.map +1 -0
  167. package/dist/index.d.ts +21 -0
  168. package/dist/index.d.ts.map +1 -0
  169. package/dist/index.js +28 -0
  170. package/dist/index.js.map +1 -0
  171. package/dist/mcp/adapters/anthropic-adapter.d.ts +256 -0
  172. package/dist/mcp/adapters/anthropic-adapter.d.ts.map +1 -0
  173. package/dist/mcp/adapters/anthropic-adapter.js +409 -0
  174. package/dist/mcp/adapters/anthropic-adapter.js.map +1 -0
  175. package/dist/mcp/adapters/base-adapter.d.ts +164 -0
  176. package/dist/mcp/adapters/base-adapter.d.ts.map +1 -0
  177. package/dist/mcp/adapters/base-adapter.js +277 -0
  178. package/dist/mcp/adapters/base-adapter.js.map +1 -0
  179. package/dist/mcp/adapters/errors.d.ts +173 -0
  180. package/dist/mcp/adapters/errors.d.ts.map +1 -0
  181. package/dist/mcp/adapters/errors.js +305 -0
  182. package/dist/mcp/adapters/errors.js.map +1 -0
  183. package/dist/mcp/adapters/index.d.ts +65 -0
  184. package/dist/mcp/adapters/index.d.ts.map +1 -0
  185. package/dist/mcp/adapters/index.js +92 -0
  186. package/dist/mcp/adapters/index.js.map +1 -0
  187. package/dist/mcp/adapters/streaming.d.ts +200 -0
  188. package/dist/mcp/adapters/streaming.d.ts.map +1 -0
  189. package/dist/mcp/adapters/streaming.js +381 -0
  190. package/dist/mcp/adapters/streaming.js.map +1 -0
  191. package/dist/mcp/adapters/vercel-adapter.d.ts +321 -0
  192. package/dist/mcp/adapters/vercel-adapter.d.ts.map +1 -0
  193. package/dist/mcp/adapters/vercel-adapter.js +487 -0
  194. package/dist/mcp/adapters/vercel-adapter.js.map +1 -0
  195. package/dist/mcp/agent.d.ts +192 -0
  196. package/dist/mcp/agent.d.ts.map +1 -0
  197. package/dist/mcp/agent.js +338 -0
  198. package/dist/mcp/agent.js.map +1 -0
  199. package/dist/mcp/cli.d.ts +71 -0
  200. package/dist/mcp/cli.d.ts.map +1 -0
  201. package/dist/mcp/cli.js +218 -0
  202. package/dist/mcp/cli.js.map +1 -0
  203. package/dist/mcp/index.d.ts +15 -0
  204. package/dist/mcp/index.d.ts.map +1 -0
  205. package/dist/mcp/index.js +20 -0
  206. package/dist/mcp/index.js.map +1 -0
  207. package/dist/mcp/sandbox/database-proxy.d.ts +118 -0
  208. package/dist/mcp/sandbox/database-proxy.d.ts.map +1 -0
  209. package/dist/mcp/sandbox/database-proxy.js +154 -0
  210. package/dist/mcp/sandbox/database-proxy.js.map +1 -0
  211. package/dist/mcp/sandbox/index.d.ts +8 -0
  212. package/dist/mcp/sandbox/index.d.ts.map +1 -0
  213. package/dist/mcp/sandbox/index.js +7 -0
  214. package/dist/mcp/sandbox/index.js.map +1 -0
  215. package/dist/mcp/sandbox/miniflare-evaluator.d.ts +72 -0
  216. package/dist/mcp/sandbox/miniflare-evaluator.d.ts.map +1 -0
  217. package/dist/mcp/sandbox/miniflare-evaluator.js +379 -0
  218. package/dist/mcp/sandbox/miniflare-evaluator.js.map +1 -0
  219. package/dist/mcp/sandbox/template.d.ts +48 -0
  220. package/dist/mcp/sandbox/template.d.ts.map +1 -0
  221. package/dist/mcp/sandbox/template.js +147 -0
  222. package/dist/mcp/sandbox/template.js.map +1 -0
  223. package/dist/mcp/sandbox/worker-evaluator.d.ts +160 -0
  224. package/dist/mcp/sandbox/worker-evaluator.d.ts.map +1 -0
  225. package/dist/mcp/sandbox/worker-evaluator.js +217 -0
  226. package/dist/mcp/sandbox/worker-evaluator.js.map +1 -0
  227. package/dist/mcp/server.d.ts +75 -0
  228. package/dist/mcp/server.d.ts.map +1 -0
  229. package/dist/mcp/server.js +278 -0
  230. package/dist/mcp/server.js.map +1 -0
  231. package/dist/mcp/tool-call-auditor.d.ts +188 -0
  232. package/dist/mcp/tool-call-auditor.d.ts.map +1 -0
  233. package/dist/mcp/tool-call-auditor.js +198 -0
  234. package/dist/mcp/tool-call-auditor.js.map +1 -0
  235. package/dist/mcp/tools/do.d.ts +51 -0
  236. package/dist/mcp/tools/do.d.ts.map +1 -0
  237. package/dist/mcp/tools/do.js +113 -0
  238. package/dist/mcp/tools/do.js.map +1 -0
  239. package/dist/mcp/tools/fetch.d.ts +43 -0
  240. package/dist/mcp/tools/fetch.d.ts.map +1 -0
  241. package/dist/mcp/tools/fetch.js +127 -0
  242. package/dist/mcp/tools/fetch.js.map +1 -0
  243. package/dist/mcp/tools/index.d.ts +9 -0
  244. package/dist/mcp/tools/index.d.ts.map +1 -0
  245. package/dist/mcp/tools/index.js +9 -0
  246. package/dist/mcp/tools/index.js.map +1 -0
  247. package/dist/mcp/tools/search.d.ts +60 -0
  248. package/dist/mcp/tools/search.d.ts.map +1 -0
  249. package/dist/mcp/tools/search.js +278 -0
  250. package/dist/mcp/tools/search.js.map +1 -0
  251. package/dist/mcp/transport/http.d.ts +144 -0
  252. package/dist/mcp/transport/http.d.ts.map +1 -0
  253. package/dist/mcp/transport/http.js +545 -0
  254. package/dist/mcp/transport/http.js.map +1 -0
  255. package/dist/mcp/transport/index.d.ts +10 -0
  256. package/dist/mcp/transport/index.d.ts.map +1 -0
  257. package/dist/mcp/transport/index.js +12 -0
  258. package/dist/mcp/transport/index.js.map +1 -0
  259. package/dist/mcp/transport/stdio.d.ts +132 -0
  260. package/dist/mcp/transport/stdio.d.ts.map +1 -0
  261. package/dist/mcp/transport/stdio.js +466 -0
  262. package/dist/mcp/transport/stdio.js.map +1 -0
  263. package/dist/mcp/types.d.ts +476 -0
  264. package/dist/mcp/types.d.ts.map +1 -0
  265. package/dist/mcp/types.js +178 -0
  266. package/dist/mcp/types.js.map +1 -0
  267. package/dist/olap/cdc/cdc-buffer.d.ts +92 -0
  268. package/dist/olap/cdc/cdc-buffer.d.ts.map +1 -0
  269. package/dist/olap/cdc/cdc-buffer.js +146 -0
  270. package/dist/olap/cdc/cdc-buffer.js.map +1 -0
  271. package/dist/olap/cdc/cdc-emitter.d.ts +118 -0
  272. package/dist/olap/cdc/cdc-emitter.d.ts.map +1 -0
  273. package/dist/olap/cdc/cdc-emitter.js +217 -0
  274. package/dist/olap/cdc/cdc-emitter.js.map +1 -0
  275. package/dist/olap/cdc/cdc-schema.d.ts +119 -0
  276. package/dist/olap/cdc/cdc-schema.d.ts.map +1 -0
  277. package/dist/olap/cdc/cdc-schema.js +253 -0
  278. package/dist/olap/cdc/cdc-schema.js.map +1 -0
  279. package/dist/olap/cdc/index.d.ts +10 -0
  280. package/dist/olap/cdc/index.d.ts.map +1 -0
  281. package/dist/olap/cdc/index.js +10 -0
  282. package/dist/olap/cdc/index.js.map +1 -0
  283. package/dist/olap/clickhouse/iceberg.d.ts +164 -0
  284. package/dist/olap/clickhouse/iceberg.d.ts.map +1 -0
  285. package/dist/olap/clickhouse/iceberg.js +138 -0
  286. package/dist/olap/clickhouse/iceberg.js.map +1 -0
  287. package/dist/olap/clickhouse/index.d.ts +14 -0
  288. package/dist/olap/clickhouse/index.d.ts.map +1 -0
  289. package/dist/olap/clickhouse/index.js +14 -0
  290. package/dist/olap/clickhouse/index.js.map +1 -0
  291. package/dist/olap/clickhouse/mapper.d.ts +170 -0
  292. package/dist/olap/clickhouse/mapper.d.ts.map +1 -0
  293. package/dist/olap/clickhouse/mapper.js +654 -0
  294. package/dist/olap/clickhouse/mapper.js.map +1 -0
  295. package/dist/olap/clickhouse/olap-backend.d.ts +181 -0
  296. package/dist/olap/clickhouse/olap-backend.d.ts.map +1 -0
  297. package/dist/olap/clickhouse/olap-backend.js +1083 -0
  298. package/dist/olap/clickhouse/olap-backend.js.map +1 -0
  299. package/dist/olap/clickhouse/query-executor.d.ts +163 -0
  300. package/dist/olap/clickhouse/query-executor.d.ts.map +1 -0
  301. package/dist/olap/clickhouse/query-executor.js +560 -0
  302. package/dist/olap/clickhouse/query-executor.js.map +1 -0
  303. package/dist/olap/clickhouse/query.d.ts +134 -0
  304. package/dist/olap/clickhouse/query.d.ts.map +1 -0
  305. package/dist/olap/clickhouse/query.js +512 -0
  306. package/dist/olap/clickhouse/query.js.map +1 -0
  307. package/dist/olap/stage/index.d.ts +6 -0
  308. package/dist/olap/stage/index.d.ts.map +1 -0
  309. package/dist/olap/stage/index.js +6 -0
  310. package/dist/olap/stage/index.js.map +1 -0
  311. package/dist/olap/stage/parser.d.ts +68 -0
  312. package/dist/olap/stage/parser.d.ts.map +1 -0
  313. package/dist/olap/stage/parser.js +293 -0
  314. package/dist/olap/stage/parser.js.map +1 -0
  315. package/dist/olap/stage/router.d.ts +94 -0
  316. package/dist/olap/stage/router.d.ts.map +1 -0
  317. package/dist/olap/stage/router.js +390 -0
  318. package/dist/olap/stage/router.js.map +1 -0
  319. package/dist/rpc/endpoint.d.ts +52 -0
  320. package/dist/rpc/endpoint.d.ts.map +1 -0
  321. package/dist/rpc/endpoint.js +734 -0
  322. package/dist/rpc/endpoint.js.map +1 -0
  323. package/dist/rpc/index.d.ts +34 -0
  324. package/dist/rpc/index.d.ts.map +1 -0
  325. package/dist/rpc/index.js +45 -0
  326. package/dist/rpc/index.js.map +1 -0
  327. package/dist/rpc/rpc-client.d.ts +275 -0
  328. package/dist/rpc/rpc-client.d.ts.map +1 -0
  329. package/dist/rpc/rpc-client.js +735 -0
  330. package/dist/rpc/rpc-client.js.map +1 -0
  331. package/dist/rpc/rpc-target.d.ts +220 -0
  332. package/dist/rpc/rpc-target.d.ts.map +1 -0
  333. package/dist/rpc/rpc-target.js +500 -0
  334. package/dist/rpc/rpc-target.js.map +1 -0
  335. package/dist/rpc/worker-entrypoint.d.ts +159 -0
  336. package/dist/rpc/worker-entrypoint.d.ts.map +1 -0
  337. package/dist/rpc/worker-entrypoint.js +212 -0
  338. package/dist/rpc/worker-entrypoint.js.map +1 -0
  339. package/dist/server.d.ts +18 -0
  340. package/dist/server.d.ts.map +1 -0
  341. package/dist/server.js +129 -0
  342. package/dist/server.js.map +1 -0
  343. package/dist/studio/components/browser/CollectionItem.d.ts +26 -0
  344. package/dist/studio/components/browser/CollectionItem.d.ts.map +1 -0
  345. package/dist/studio/components/browser/CollectionItem.js +143 -0
  346. package/dist/studio/components/browser/CollectionItem.js.map +1 -0
  347. package/dist/studio/components/browser/CollectionTree.d.ts +45 -0
  348. package/dist/studio/components/browser/CollectionTree.d.ts.map +1 -0
  349. package/dist/studio/components/browser/CollectionTree.js +207 -0
  350. package/dist/studio/components/browser/CollectionTree.js.map +1 -0
  351. package/dist/studio/components/browser/ConnectedDatabaseBrowser.d.ts +51 -0
  352. package/dist/studio/components/browser/ConnectedDatabaseBrowser.d.ts.map +1 -0
  353. package/dist/studio/components/browser/ConnectedDatabaseBrowser.js +185 -0
  354. package/dist/studio/components/browser/ConnectedDatabaseBrowser.js.map +1 -0
  355. package/dist/studio/components/browser/DatabaseBrowser.d.ts +46 -0
  356. package/dist/studio/components/browser/DatabaseBrowser.d.ts.map +1 -0
  357. package/dist/studio/components/browser/DatabaseBrowser.js +304 -0
  358. package/dist/studio/components/browser/DatabaseBrowser.js.map +1 -0
  359. package/dist/studio/components/browser/__tests__/CollectionItem.test.d.ts +5 -0
  360. package/dist/studio/components/browser/__tests__/CollectionItem.test.d.ts.map +1 -0
  361. package/dist/studio/components/browser/__tests__/CollectionItem.test.js +169 -0
  362. package/dist/studio/components/browser/__tests__/CollectionItem.test.js.map +1 -0
  363. package/dist/studio/components/browser/__tests__/CollectionTree.test.d.ts +5 -0
  364. package/dist/studio/components/browser/__tests__/CollectionTree.test.d.ts.map +1 -0
  365. package/dist/studio/components/browser/__tests__/CollectionTree.test.js +203 -0
  366. package/dist/studio/components/browser/__tests__/CollectionTree.test.js.map +1 -0
  367. package/dist/studio/components/browser/__tests__/DatabaseBrowser.e2e.test.d.ts +8 -0
  368. package/dist/studio/components/browser/__tests__/DatabaseBrowser.e2e.test.d.ts.map +1 -0
  369. package/dist/studio/components/browser/__tests__/DatabaseBrowser.e2e.test.js +522 -0
  370. package/dist/studio/components/browser/__tests__/DatabaseBrowser.e2e.test.js.map +1 -0
  371. package/dist/studio/components/browser/__tests__/DatabaseBrowser.test.d.ts +5 -0
  372. package/dist/studio/components/browser/__tests__/DatabaseBrowser.test.d.ts.map +1 -0
  373. package/dist/studio/components/browser/__tests__/DatabaseBrowser.test.js +518 -0
  374. package/dist/studio/components/browser/__tests__/DatabaseBrowser.test.js.map +1 -0
  375. package/dist/studio/components/browser/__tests__/setup.d.ts +5 -0
  376. package/dist/studio/components/browser/__tests__/setup.d.ts.map +1 -0
  377. package/dist/studio/components/browser/__tests__/setup.js +22 -0
  378. package/dist/studio/components/browser/__tests__/setup.js.map +1 -0
  379. package/dist/studio/components/browser/index.d.ts +15 -0
  380. package/dist/studio/components/browser/index.d.ts.map +1 -0
  381. package/dist/studio/components/browser/index.js +10 -0
  382. package/dist/studio/components/browser/index.js.map +1 -0
  383. package/dist/studio/components/browser/types.d.ts +33 -0
  384. package/dist/studio/components/browser/types.d.ts.map +1 -0
  385. package/dist/studio/components/browser/types.js +5 -0
  386. package/dist/studio/components/browser/types.js.map +1 -0
  387. package/dist/studio/components/connection/ConnectionForm.d.ts +59 -0
  388. package/dist/studio/components/connection/ConnectionForm.d.ts.map +1 -0
  389. package/dist/studio/components/connection/ConnectionForm.js +274 -0
  390. package/dist/studio/components/connection/ConnectionForm.js.map +1 -0
  391. package/dist/studio/components/connection/ConnectionList.d.ts +59 -0
  392. package/dist/studio/components/connection/ConnectionList.d.ts.map +1 -0
  393. package/dist/studio/components/connection/ConnectionList.js +286 -0
  394. package/dist/studio/components/connection/ConnectionList.js.map +1 -0
  395. package/dist/studio/components/connection/ConnectionPanel.d.ts +132 -0
  396. package/dist/studio/components/connection/ConnectionPanel.d.ts.map +1 -0
  397. package/dist/studio/components/connection/ConnectionPanel.js +293 -0
  398. package/dist/studio/components/connection/ConnectionPanel.js.map +1 -0
  399. package/dist/studio/components/connection/__tests__/ConnectionPanel.test.d.ts +8 -0
  400. package/dist/studio/components/connection/__tests__/ConnectionPanel.test.d.ts.map +1 -0
  401. package/dist/studio/components/connection/__tests__/ConnectionPanel.test.js +632 -0
  402. package/dist/studio/components/connection/__tests__/ConnectionPanel.test.js.map +1 -0
  403. package/dist/studio/components/connection/__tests__/setup.d.ts +5 -0
  404. package/dist/studio/components/connection/__tests__/setup.d.ts.map +1 -0
  405. package/dist/studio/components/connection/__tests__/setup.js +11 -0
  406. package/dist/studio/components/connection/__tests__/setup.js.map +1 -0
  407. package/dist/studio/components/connection/index.d.ts +10 -0
  408. package/dist/studio/components/connection/index.d.ts.map +1 -0
  409. package/dist/studio/components/connection/index.js +7 -0
  410. package/dist/studio/components/connection/index.js.map +1 -0
  411. package/dist/studio/components/crud/DeleteDocumentDialog.d.ts +91 -0
  412. package/dist/studio/components/crud/DeleteDocumentDialog.d.ts.map +1 -0
  413. package/dist/studio/components/crud/DeleteDocumentDialog.js +273 -0
  414. package/dist/studio/components/crud/DeleteDocumentDialog.js.map +1 -0
  415. package/dist/studio/components/crud/DocumentEditor.d.ts +32 -0
  416. package/dist/studio/components/crud/DocumentEditor.d.ts.map +1 -0
  417. package/dist/studio/components/crud/DocumentEditor.js +546 -0
  418. package/dist/studio/components/crud/DocumentEditor.js.map +1 -0
  419. package/dist/studio/components/crud/InsertDocumentDialog.d.ts +78 -0
  420. package/dist/studio/components/crud/InsertDocumentDialog.d.ts.map +1 -0
  421. package/dist/studio/components/crud/InsertDocumentDialog.js +323 -0
  422. package/dist/studio/components/crud/InsertDocumentDialog.js.map +1 -0
  423. package/dist/studio/components/crud/__tests__/DeleteDocumentDialog.test.d.ts +5 -0
  424. package/dist/studio/components/crud/__tests__/DeleteDocumentDialog.test.d.ts.map +1 -0
  425. package/dist/studio/components/crud/__tests__/DeleteDocumentDialog.test.js +298 -0
  426. package/dist/studio/components/crud/__tests__/DeleteDocumentDialog.test.js.map +1 -0
  427. package/dist/studio/components/crud/__tests__/DocumentEditor.test.d.ts +8 -0
  428. package/dist/studio/components/crud/__tests__/DocumentEditor.test.d.ts.map +1 -0
  429. package/dist/studio/components/crud/__tests__/DocumentEditor.test.js +368 -0
  430. package/dist/studio/components/crud/__tests__/DocumentEditor.test.js.map +1 -0
  431. package/dist/studio/components/crud/__tests__/InsertDocumentDialog.test.d.ts +2 -0
  432. package/dist/studio/components/crud/__tests__/InsertDocumentDialog.test.d.ts.map +1 -0
  433. package/dist/studio/components/crud/__tests__/InsertDocumentDialog.test.js +352 -0
  434. package/dist/studio/components/crud/__tests__/InsertDocumentDialog.test.js.map +1 -0
  435. package/dist/studio/components/crud/__tests__/setup.d.ts +5 -0
  436. package/dist/studio/components/crud/__tests__/setup.d.ts.map +1 -0
  437. package/dist/studio/components/crud/__tests__/setup.js +22 -0
  438. package/dist/studio/components/crud/__tests__/setup.js.map +1 -0
  439. package/dist/studio/components/crud/index.d.ts +12 -0
  440. package/dist/studio/components/crud/index.d.ts.map +1 -0
  441. package/dist/studio/components/crud/index.js +11 -0
  442. package/dist/studio/components/crud/index.js.map +1 -0
  443. package/dist/studio/hooks/useConnection.d.ts +127 -0
  444. package/dist/studio/hooks/useConnection.d.ts.map +1 -0
  445. package/dist/studio/hooks/useConnection.js +414 -0
  446. package/dist/studio/hooks/useConnection.js.map +1 -0
  447. package/dist/studio/hooks/useDatabaseBrowser.d.ts +107 -0
  448. package/dist/studio/hooks/useDatabaseBrowser.d.ts.map +1 -0
  449. package/dist/studio/hooks/useDatabaseBrowser.js +294 -0
  450. package/dist/studio/hooks/useDatabaseBrowser.js.map +1 -0
  451. package/dist/studio/index.d.ts +16 -0
  452. package/dist/studio/index.d.ts.map +1 -0
  453. package/dist/studio/index.js +14 -0
  454. package/dist/studio/index.js.map +1 -0
  455. package/dist/studio/types/connection.d.ts +266 -0
  456. package/dist/studio/types/connection.d.ts.map +1 -0
  457. package/dist/studio/types/connection.js +159 -0
  458. package/dist/studio/types/connection.js.map +1 -0
  459. package/dist/studio/vitest.config.d.ts +3 -0
  460. package/dist/studio/vitest.config.d.ts.map +1 -0
  461. package/dist/studio/vitest.config.js +33 -0
  462. package/dist/studio/vitest.config.js.map +1 -0
  463. package/dist/translator/aggregation-translator.d.ts +51 -0
  464. package/dist/translator/aggregation-translator.d.ts.map +1 -0
  465. package/dist/translator/aggregation-translator.js +324 -0
  466. package/dist/translator/aggregation-translator.js.map +1 -0
  467. package/dist/translator/dialect.d.ts +131 -0
  468. package/dist/translator/dialect.d.ts.map +1 -0
  469. package/dist/translator/dialect.js +276 -0
  470. package/dist/translator/dialect.js.map +1 -0
  471. package/dist/translator/geo-translator.d.ts +91 -0
  472. package/dist/translator/geo-translator.d.ts.map +1 -0
  473. package/dist/translator/geo-translator.js +587 -0
  474. package/dist/translator/geo-translator.js.map +1 -0
  475. package/dist/translator/hybrid-translator.d.ts +70 -0
  476. package/dist/translator/hybrid-translator.d.ts.map +1 -0
  477. package/dist/translator/hybrid-translator.js +193 -0
  478. package/dist/translator/hybrid-translator.js.map +1 -0
  479. package/dist/translator/index.d.ts +13 -0
  480. package/dist/translator/index.d.ts.map +1 -0
  481. package/dist/translator/index.js +11 -0
  482. package/dist/translator/index.js.map +1 -0
  483. package/dist/translator/query-translator.d.ts +211 -0
  484. package/dist/translator/query-translator.d.ts.map +1 -0
  485. package/dist/translator/query-translator.js +1276 -0
  486. package/dist/translator/query-translator.js.map +1 -0
  487. package/dist/translator/search-highlight.d.ts +83 -0
  488. package/dist/translator/search-highlight.d.ts.map +1 -0
  489. package/dist/translator/search-highlight.js +83 -0
  490. package/dist/translator/search-highlight.js.map +1 -0
  491. package/dist/translator/search-translator.d.ts +155 -0
  492. package/dist/translator/search-translator.d.ts.map +1 -0
  493. package/dist/translator/search-translator.js +241 -0
  494. package/dist/translator/search-translator.js.map +1 -0
  495. package/dist/translator/stages/add-fields-stage.d.ts +7 -0
  496. package/dist/translator/stages/add-fields-stage.d.ts.map +1 -0
  497. package/dist/translator/stages/add-fields-stage.js +72 -0
  498. package/dist/translator/stages/add-fields-stage.js.map +1 -0
  499. package/dist/translator/stages/bucket-stage.d.ts +7 -0
  500. package/dist/translator/stages/bucket-stage.d.ts.map +1 -0
  501. package/dist/translator/stages/bucket-stage.js +87 -0
  502. package/dist/translator/stages/bucket-stage.js.map +1 -0
  503. package/dist/translator/stages/count-stage.d.ts +7 -0
  504. package/dist/translator/stages/count-stage.d.ts.map +1 -0
  505. package/dist/translator/stages/count-stage.js +12 -0
  506. package/dist/translator/stages/count-stage.js.map +1 -0
  507. package/dist/translator/stages/expression-translator.d.ts +68 -0
  508. package/dist/translator/stages/expression-translator.d.ts.map +1 -0
  509. package/dist/translator/stages/expression-translator.js +467 -0
  510. package/dist/translator/stages/expression-translator.js.map +1 -0
  511. package/dist/translator/stages/facet-stage.d.ts +13 -0
  512. package/dist/translator/stages/facet-stage.d.ts.map +1 -0
  513. package/dist/translator/stages/facet-stage.js +26 -0
  514. package/dist/translator/stages/facet-stage.js.map +1 -0
  515. package/dist/translator/stages/fusion-stages.d.ts +118 -0
  516. package/dist/translator/stages/fusion-stages.d.ts.map +1 -0
  517. package/dist/translator/stages/fusion-stages.js +201 -0
  518. package/dist/translator/stages/fusion-stages.js.map +1 -0
  519. package/dist/translator/stages/group-stage.d.ts +8 -0
  520. package/dist/translator/stages/group-stage.d.ts.map +1 -0
  521. package/dist/translator/stages/group-stage.js +123 -0
  522. package/dist/translator/stages/group-stage.js.map +1 -0
  523. package/dist/translator/stages/index.d.ts +24 -0
  524. package/dist/translator/stages/index.d.ts.map +1 -0
  525. package/dist/translator/stages/index.js +24 -0
  526. package/dist/translator/stages/index.js.map +1 -0
  527. package/dist/translator/stages/join-optimizer.d.ts +37 -0
  528. package/dist/translator/stages/join-optimizer.d.ts.map +1 -0
  529. package/dist/translator/stages/join-optimizer.js +93 -0
  530. package/dist/translator/stages/join-optimizer.js.map +1 -0
  531. package/dist/translator/stages/limit-stage.d.ts +7 -0
  532. package/dist/translator/stages/limit-stage.d.ts.map +1 -0
  533. package/dist/translator/stages/limit-stage.js +11 -0
  534. package/dist/translator/stages/limit-stage.js.map +1 -0
  535. package/dist/translator/stages/lookup-stage.d.ts +7 -0
  536. package/dist/translator/stages/lookup-stage.d.ts.map +1 -0
  537. package/dist/translator/stages/lookup-stage.js +73 -0
  538. package/dist/translator/stages/lookup-stage.js.map +1 -0
  539. package/dist/translator/stages/match-stage.d.ts +7 -0
  540. package/dist/translator/stages/match-stage.d.ts.map +1 -0
  541. package/dist/translator/stages/match-stage.js +14 -0
  542. package/dist/translator/stages/match-stage.js.map +1 -0
  543. package/dist/translator/stages/optimizer.d.ts +15 -0
  544. package/dist/translator/stages/optimizer.d.ts.map +1 -0
  545. package/dist/translator/stages/optimizer.js +249 -0
  546. package/dist/translator/stages/optimizer.js.map +1 -0
  547. package/dist/translator/stages/parallel-facet.d.ts +47 -0
  548. package/dist/translator/stages/parallel-facet.d.ts.map +1 -0
  549. package/dist/translator/stages/parallel-facet.js +57 -0
  550. package/dist/translator/stages/parallel-facet.js.map +1 -0
  551. package/dist/translator/stages/project-stage.d.ts +8 -0
  552. package/dist/translator/stages/project-stage.d.ts.map +1 -0
  553. package/dist/translator/stages/project-stage.js +145 -0
  554. package/dist/translator/stages/project-stage.js.map +1 -0
  555. package/dist/translator/stages/search-stage.d.ts +60 -0
  556. package/dist/translator/stages/search-stage.d.ts.map +1 -0
  557. package/dist/translator/stages/search-stage.js +89 -0
  558. package/dist/translator/stages/search-stage.js.map +1 -0
  559. package/dist/translator/stages/skip-stage.d.ts +7 -0
  560. package/dist/translator/stages/skip-stage.d.ts.map +1 -0
  561. package/dist/translator/stages/skip-stage.js +11 -0
  562. package/dist/translator/stages/skip-stage.js.map +1 -0
  563. package/dist/translator/stages/sort-stage.d.ts +7 -0
  564. package/dist/translator/stages/sort-stage.d.ts.map +1 -0
  565. package/dist/translator/stages/sort-stage.js +21 -0
  566. package/dist/translator/stages/sort-stage.js.map +1 -0
  567. package/dist/translator/stages/types.d.ts +136 -0
  568. package/dist/translator/stages/types.d.ts.map +1 -0
  569. package/dist/translator/stages/types.js +5 -0
  570. package/dist/translator/stages/types.js.map +1 -0
  571. package/dist/translator/stages/unwind-stage.d.ts +7 -0
  572. package/dist/translator/stages/unwind-stage.d.ts.map +1 -0
  573. package/dist/translator/stages/unwind-stage.js +61 -0
  574. package/dist/translator/stages/unwind-stage.js.map +1 -0
  575. package/dist/translator/stages/vector-search-stage.d.ts +53 -0
  576. package/dist/translator/stages/vector-search-stage.d.ts.map +1 -0
  577. package/dist/translator/stages/vector-search-stage.js +62 -0
  578. package/dist/translator/stages/vector-search-stage.js.map +1 -0
  579. package/dist/translator/update-translator.d.ts +148 -0
  580. package/dist/translator/update-translator.d.ts.map +1 -0
  581. package/dist/translator/update-translator.js +819 -0
  582. package/dist/translator/update-translator.js.map +1 -0
  583. package/dist/translator/vector-translator.d.ts +89 -0
  584. package/dist/translator/vector-translator.d.ts.map +1 -0
  585. package/dist/translator/vector-translator.js +106 -0
  586. package/dist/translator/vector-translator.js.map +1 -0
  587. package/dist/types/env.d.ts +31 -0
  588. package/dist/types/env.d.ts.map +1 -0
  589. package/dist/types/env.js +5 -0
  590. package/dist/types/env.js.map +1 -0
  591. package/dist/types/function.d.ts +65 -0
  592. package/dist/types/function.d.ts.map +1 -0
  593. package/dist/types/function.js +5 -0
  594. package/dist/types/function.js.map +1 -0
  595. package/dist/types/index.d.ts +137 -0
  596. package/dist/types/index.d.ts.map +1 -0
  597. package/dist/types/index.js +13 -0
  598. package/dist/types/index.js.map +1 -0
  599. package/dist/types/mongodb.d.ts +258 -0
  600. package/dist/types/mongodb.d.ts.map +1 -0
  601. package/dist/types/mongodb.js +5 -0
  602. package/dist/types/mongodb.js.map +1 -0
  603. package/dist/types/objectid.d.ts +130 -0
  604. package/dist/types/objectid.d.ts.map +1 -0
  605. package/dist/types/objectid.js +314 -0
  606. package/dist/types/objectid.js.map +1 -0
  607. package/dist/types/rpc.d.ts +313 -0
  608. package/dist/types/rpc.d.ts.map +1 -0
  609. package/dist/types/rpc.js +136 -0
  610. package/dist/types/rpc.js.map +1 -0
  611. package/dist/types/vectorize.d.ts +136 -0
  612. package/dist/types/vectorize.d.ts.map +1 -0
  613. package/dist/types/vectorize.js +8 -0
  614. package/dist/types/vectorize.js.map +1 -0
  615. package/dist/utils/sql-safety.d.ts +64 -0
  616. package/dist/utils/sql-safety.d.ts.map +1 -0
  617. package/dist/utils/sql-safety.js +112 -0
  618. package/dist/utils/sql-safety.js.map +1 -0
  619. package/dist/validation/document-validator.d.ts +195 -0
  620. package/dist/validation/document-validator.d.ts.map +1 -0
  621. package/dist/validation/document-validator.js +529 -0
  622. package/dist/validation/document-validator.js.map +1 -0
  623. package/dist/vectorize/document-serializer.d.ts +119 -0
  624. package/dist/vectorize/document-serializer.d.ts.map +1 -0
  625. package/dist/vectorize/document-serializer.js +320 -0
  626. package/dist/vectorize/document-serializer.js.map +1 -0
  627. package/dist/wire/auth/index.d.ts +5 -0
  628. package/dist/wire/auth/index.d.ts.map +1 -0
  629. package/dist/wire/auth/index.js +5 -0
  630. package/dist/wire/auth/index.js.map +1 -0
  631. package/dist/wire/auth/scram.d.ts +160 -0
  632. package/dist/wire/auth/scram.d.ts.map +1 -0
  633. package/dist/wire/auth/scram.js +425 -0
  634. package/dist/wire/auth/scram.js.map +1 -0
  635. package/dist/wire/backend/interface.d.ts +168 -0
  636. package/dist/wire/backend/interface.d.ts.map +1 -0
  637. package/dist/wire/backend/interface.js +10 -0
  638. package/dist/wire/backend/interface.js.map +1 -0
  639. package/dist/wire/backend/local-sqlite.d.ts +89 -0
  640. package/dist/wire/backend/local-sqlite.d.ts.map +1 -0
  641. package/dist/wire/backend/local-sqlite.js +1002 -0
  642. package/dist/wire/backend/local-sqlite.js.map +1 -0
  643. package/dist/wire/backend/query-router.d.ts +197 -0
  644. package/dist/wire/backend/query-router.d.ts.map +1 -0
  645. package/dist/wire/backend/query-router.js +590 -0
  646. package/dist/wire/backend/query-router.js.map +1 -0
  647. package/dist/wire/backend/validation.d.ts +26 -0
  648. package/dist/wire/backend/validation.d.ts.map +1 -0
  649. package/dist/wire/backend/validation.js +79 -0
  650. package/dist/wire/backend/validation.js.map +1 -0
  651. package/dist/wire/backend/workers-proxy.d.ts +95 -0
  652. package/dist/wire/backend/workers-proxy.d.ts.map +1 -0
  653. package/dist/wire/backend/workers-proxy.js +429 -0
  654. package/dist/wire/backend/workers-proxy.js.map +1 -0
  655. package/dist/wire/commands/admin.d.ts +49 -0
  656. package/dist/wire/commands/admin.d.ts.map +1 -0
  657. package/dist/wire/commands/admin.js +272 -0
  658. package/dist/wire/commands/admin.js.map +1 -0
  659. package/dist/wire/commands/aggregate.d.ts +15 -0
  660. package/dist/wire/commands/aggregate.d.ts.map +1 -0
  661. package/dist/wire/commands/aggregate.js +98 -0
  662. package/dist/wire/commands/aggregate.js.map +1 -0
  663. package/dist/wire/commands/auth.d.ts +58 -0
  664. package/dist/wire/commands/auth.d.ts.map +1 -0
  665. package/dist/wire/commands/auth.js +158 -0
  666. package/dist/wire/commands/auth.js.map +1 -0
  667. package/dist/wire/commands/crud.d.ts +49 -0
  668. package/dist/wire/commands/crud.d.ts.map +1 -0
  669. package/dist/wire/commands/crud.js +336 -0
  670. package/dist/wire/commands/crud.js.map +1 -0
  671. package/dist/wire/commands/hello.d.ts +35 -0
  672. package/dist/wire/commands/hello.d.ts.map +1 -0
  673. package/dist/wire/commands/hello.js +204 -0
  674. package/dist/wire/commands/hello.js.map +1 -0
  675. package/dist/wire/commands/index.d.ts +24 -0
  676. package/dist/wire/commands/index.d.ts.map +1 -0
  677. package/dist/wire/commands/index.js +145 -0
  678. package/dist/wire/commands/index.js.map +1 -0
  679. package/dist/wire/commands/router.d.ts +46 -0
  680. package/dist/wire/commands/router.d.ts.map +1 -0
  681. package/dist/wire/commands/router.js +151 -0
  682. package/dist/wire/commands/router.js.map +1 -0
  683. package/dist/wire/commands/types.d.ts +51 -0
  684. package/dist/wire/commands/types.d.ts.map +1 -0
  685. package/dist/wire/commands/types.js +15 -0
  686. package/dist/wire/commands/types.js.map +1 -0
  687. package/dist/wire/index.d.ts +15 -0
  688. package/dist/wire/index.d.ts.map +1 -0
  689. package/dist/wire/index.js +19 -0
  690. package/dist/wire/index.js.map +1 -0
  691. package/dist/wire/message.d.ts +49 -0
  692. package/dist/wire/message.d.ts.map +1 -0
  693. package/dist/wire/message.js +299 -0
  694. package/dist/wire/message.js.map +1 -0
  695. package/dist/wire/server.d.ts +145 -0
  696. package/dist/wire/server.d.ts.map +1 -0
  697. package/dist/wire/server.js +284 -0
  698. package/dist/wire/server.js.map +1 -0
  699. package/dist/wire/types.d.ts +140 -0
  700. package/dist/wire/types.d.ts.map +1 -0
  701. package/dist/wire/types.js +64 -0
  702. package/dist/wire/types.js.map +1 -0
  703. package/dist/worker.d.ts +17 -0
  704. package/dist/worker.d.ts.map +1 -0
  705. package/dist/worker.js +22 -0
  706. package/dist/worker.js.map +1 -0
  707. package/package.json +82 -0
@@ -0,0 +1,1002 @@
1
+ /**
2
+ * Local SQLite Backend
3
+ *
4
+ * Implements MondoBackend using Bun's native SQLite for local development.
5
+ * Simplified implementation for wire protocol server.
6
+ */
7
+ import { Database } from 'bun:sqlite';
8
+ import { ObjectId } from 'bson';
9
+ import { validateFieldPath, safeJsonPath } from '../../utils/sql-safety.js';
10
+ import { sanitizeDatabaseName, validateCollectionName } from './validation.js';
11
+ // Re-export validation functions for backwards compatibility
12
+ export { sanitizeDatabaseName, validateCollectionName } from './validation.js';
13
+ /** Default batch size for cursor results */
14
+ const DEFAULT_BATCH_SIZE = 101;
15
+ /** Cursor timeout in milliseconds (10 minutes) */
16
+ const CURSOR_TIMEOUT_MS = 10 * 60 * 1000;
17
+ /**
18
+ * Local SQLite Backend
19
+ */
20
+ export class LocalSQLiteBackend {
21
+ databases = new Map();
22
+ cursors = new Map();
23
+ nextCursorId = 1n;
24
+ dataDir;
25
+ constructor(dataDir = '.mongodo') {
26
+ this.dataDir = dataDir;
27
+ // Ensure data directory exists
28
+ const fs = require('fs');
29
+ if (!fs.existsSync(dataDir)) {
30
+ fs.mkdirSync(dataDir, { recursive: true });
31
+ }
32
+ // Start cursor cleanup interval
33
+ setInterval(() => this.cleanupExpiredCursors(), 60000);
34
+ }
35
+ /**
36
+ * Get or create a database connection
37
+ */
38
+ getDatabase(name) {
39
+ // SECURITY: Validate database name to prevent path traversal attacks
40
+ const safeName = sanitizeDatabaseName(name);
41
+ let db = this.databases.get(safeName);
42
+ if (!db) {
43
+ const dbPath = `${this.dataDir}/${safeName}.sqlite`;
44
+ db = new Database(dbPath);
45
+ this.initializeSchema(db);
46
+ this.databases.set(safeName, db);
47
+ }
48
+ return db;
49
+ }
50
+ /**
51
+ * Initialize the database schema
52
+ */
53
+ initializeSchema(db) {
54
+ db.exec(`
55
+ CREATE TABLE IF NOT EXISTS collections (
56
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
57
+ name TEXT NOT NULL UNIQUE,
58
+ options TEXT DEFAULT '{}'
59
+ );
60
+
61
+ CREATE TABLE IF NOT EXISTS documents (
62
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
63
+ collection_id INTEGER NOT NULL,
64
+ _id TEXT NOT NULL,
65
+ data TEXT NOT NULL DEFAULT '{}',
66
+ FOREIGN KEY (collection_id) REFERENCES collections(id) ON DELETE CASCADE,
67
+ UNIQUE(collection_id, _id)
68
+ );
69
+
70
+ CREATE INDEX IF NOT EXISTS idx_documents_id ON documents(_id);
71
+ CREATE INDEX IF NOT EXISTS idx_documents_collection_id ON documents(collection_id, _id);
72
+
73
+ CREATE TABLE IF NOT EXISTS indexes (
74
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
75
+ collection_id INTEGER NOT NULL,
76
+ name TEXT NOT NULL,
77
+ key TEXT NOT NULL,
78
+ options TEXT DEFAULT '{}',
79
+ FOREIGN KEY (collection_id) REFERENCES collections(id) ON DELETE CASCADE,
80
+ UNIQUE(collection_id, name)
81
+ );
82
+ `);
83
+ }
84
+ /**
85
+ * Get collection ID, creating collection if it doesn't exist
86
+ */
87
+ getOrCreateCollectionId(db, name) {
88
+ // SECURITY: Validate collection name
89
+ const safeName = validateCollectionName(name);
90
+ const existing = db.query('SELECT id FROM collections WHERE name = ?').get(safeName);
91
+ if (existing) {
92
+ return existing.id;
93
+ }
94
+ const result = db.query('INSERT INTO collections (name) VALUES (?) RETURNING id').get(safeName);
95
+ return result.id;
96
+ }
97
+ /**
98
+ * Get collection ID or null if not found
99
+ */
100
+ getCollectionId(db, name) {
101
+ // SECURITY: Validate collection name
102
+ const safeName = validateCollectionName(name);
103
+ const result = db.query('SELECT id FROM collections WHERE name = ?').get(safeName);
104
+ return result?.id ?? null;
105
+ }
106
+ // ============ Database Operations ============
107
+ async listDatabases() {
108
+ const fs = require('fs');
109
+ const path = require('path');
110
+ let files = [];
111
+ try {
112
+ files = fs.readdirSync(this.dataDir);
113
+ }
114
+ catch {
115
+ // Directory doesn't exist
116
+ }
117
+ const databases = [];
118
+ for (const file of files) {
119
+ if (file.endsWith('.sqlite')) {
120
+ const name = file.replace('.sqlite', '');
121
+ const filePath = path.join(this.dataDir, file);
122
+ const stats = fs.statSync(filePath);
123
+ databases.push({
124
+ name,
125
+ sizeOnDisk: stats.size,
126
+ empty: stats.size < 1000,
127
+ });
128
+ }
129
+ }
130
+ // Always include admin database
131
+ if (!databases.find((d) => d.name === 'admin')) {
132
+ databases.unshift({ name: 'admin', sizeOnDisk: 0, empty: true });
133
+ }
134
+ return databases;
135
+ }
136
+ async createDatabase(name) {
137
+ this.getDatabase(name);
138
+ }
139
+ async dropDatabase(name) {
140
+ // SECURITY: Validate database name to prevent path traversal attacks
141
+ const safeName = sanitizeDatabaseName(name);
142
+ const db = this.databases.get(safeName);
143
+ if (db) {
144
+ db.close();
145
+ this.databases.delete(safeName);
146
+ }
147
+ const fs = require('fs');
148
+ const dbPath = `${this.dataDir}/${safeName}.sqlite`;
149
+ if (fs.existsSync(dbPath)) {
150
+ fs.unlinkSync(dbPath);
151
+ }
152
+ }
153
+ async databaseExists(name) {
154
+ // SECURITY: Validate database name to prevent path traversal attacks
155
+ const safeName = sanitizeDatabaseName(name);
156
+ const fs = require('fs');
157
+ return fs.existsSync(`${this.dataDir}/${safeName}.sqlite`);
158
+ }
159
+ // ============ Collection Operations ============
160
+ async listCollections(dbName, filter) {
161
+ const db = this.getDatabase(dbName);
162
+ let query = 'SELECT name, options FROM collections';
163
+ const params = [];
164
+ if (filter?.name && typeof filter.name === 'string') {
165
+ query += ' WHERE name = ?';
166
+ params.push(filter.name);
167
+ }
168
+ const rows = db.query(query).all(...params);
169
+ return rows.map((row) => ({
170
+ name: row.name,
171
+ type: 'collection',
172
+ options: JSON.parse(row.options),
173
+ info: { readOnly: false },
174
+ }));
175
+ }
176
+ async createCollection(dbName, name, options) {
177
+ // SECURITY: Validate collection name
178
+ const safeName = validateCollectionName(name);
179
+ const db = this.getDatabase(dbName);
180
+ const optionsJson = JSON.stringify(options || {});
181
+ db.query('INSERT OR IGNORE INTO collections (name, options) VALUES (?, ?)').run(safeName, optionsJson);
182
+ }
183
+ async dropCollection(dbName, name) {
184
+ // SECURITY: Validate collection name
185
+ const safeName = validateCollectionName(name);
186
+ const db = this.getDatabase(dbName);
187
+ db.query('DELETE FROM collections WHERE name = ?').run(safeName);
188
+ }
189
+ async collectionExists(dbName, name) {
190
+ // SECURITY: Validate collection name
191
+ const safeName = validateCollectionName(name);
192
+ const db = this.getDatabase(dbName);
193
+ const result = db.query('SELECT 1 FROM collections WHERE name = ? LIMIT 1').get(safeName);
194
+ return result !== null;
195
+ }
196
+ async collStats(dbName, collection) {
197
+ const db = this.getDatabase(dbName);
198
+ const collectionId = this.getCollectionId(db, collection);
199
+ if (!collectionId) {
200
+ return {
201
+ ns: `${dbName}.${collection}`,
202
+ count: 0,
203
+ size: 0,
204
+ avgObjSize: 0,
205
+ storageSize: 0,
206
+ totalIndexSize: 0,
207
+ nindexes: 1,
208
+ indexSizes: { _id_: 0 },
209
+ };
210
+ }
211
+ const stats = db
212
+ .query(`
213
+ SELECT COUNT(*) as count, COALESCE(SUM(LENGTH(data)), 0) as size
214
+ FROM documents WHERE collection_id = ?
215
+ `)
216
+ .get(collectionId);
217
+ return {
218
+ ns: `${dbName}.${collection}`,
219
+ count: stats.count,
220
+ size: stats.size,
221
+ avgObjSize: stats.count > 0 ? stats.size / stats.count : 0,
222
+ storageSize: stats.size,
223
+ totalIndexSize: stats.count * 50,
224
+ nindexes: 1,
225
+ indexSizes: { _id_: stats.count * 50 },
226
+ };
227
+ }
228
+ async dbStats(dbName) {
229
+ const db = this.getDatabase(dbName);
230
+ const collectionStats = db
231
+ .query('SELECT COUNT(DISTINCT id) as collections FROM collections')
232
+ .get();
233
+ const docStats = db
234
+ .query('SELECT COUNT(*) as objects, COALESCE(SUM(LENGTH(data)), 0) as dataSize FROM documents')
235
+ .get();
236
+ return {
237
+ db: dbName,
238
+ collections: collectionStats.collections,
239
+ views: 0,
240
+ objects: docStats.objects,
241
+ avgObjSize: docStats.objects > 0 ? docStats.dataSize / docStats.objects : 0,
242
+ dataSize: docStats.dataSize,
243
+ storageSize: docStats.dataSize,
244
+ indexes: collectionStats.collections,
245
+ indexSize: docStats.objects * 50,
246
+ };
247
+ }
248
+ // ============ CRUD Operations ============
249
+ async find(dbName, collection, options) {
250
+ const db = this.getDatabase(dbName);
251
+ const collectionId = this.getCollectionId(db, collection);
252
+ if (!collectionId) {
253
+ return { documents: [], cursorId: 0n, hasMore: false };
254
+ }
255
+ let sql = 'SELECT _id, data FROM documents WHERE collection_id = ?';
256
+ const params = [collectionId];
257
+ // Build filter (simplified)
258
+ if (options.filter && Object.keys(options.filter).length > 0) {
259
+ const filterSql = this.buildFilterSql(options.filter, params);
260
+ if (filterSql) {
261
+ sql += ` AND (${filterSql})`;
262
+ }
263
+ }
264
+ // Add sorting
265
+ if (options.sort) {
266
+ const sortClauses = [];
267
+ for (const [field, direction] of Object.entries(options.sort)) {
268
+ const dir = direction === -1 ? 'DESC' : 'ASC';
269
+ if (field === '_id') {
270
+ sortClauses.push(`_id ${dir}`);
271
+ }
272
+ else {
273
+ // Validate field name to prevent SQL injection
274
+ const safePath = safeJsonPath(validateFieldPath(field));
275
+ sortClauses.push(`json_extract(data, '${safePath}') ${dir}`);
276
+ }
277
+ }
278
+ if (sortClauses.length > 0) {
279
+ sql += ` ORDER BY ${sortClauses.join(', ')}`;
280
+ }
281
+ }
282
+ // Add limit and offset
283
+ if (options.limit && options.limit > 0) {
284
+ sql += ` LIMIT ${options.limit}`;
285
+ }
286
+ if (options.skip && options.skip > 0) {
287
+ sql += ` OFFSET ${options.skip}`;
288
+ }
289
+ const rows = db.query(sql).all(...params);
290
+ let documents = rows.map((row) => {
291
+ const doc = JSON.parse(row.data);
292
+ doc._id = this.parseId(row._id);
293
+ return doc;
294
+ });
295
+ // Apply projection
296
+ if (options.projection) {
297
+ documents = documents.map((doc) => this.applyProjection(doc, options.projection));
298
+ }
299
+ const batchSize = options.batchSize || DEFAULT_BATCH_SIZE;
300
+ // Handle cursor for large result sets
301
+ if (documents.length > batchSize) {
302
+ const cursorId = this.nextCursorId++;
303
+ this.cursors.set(cursorId, {
304
+ id: cursorId,
305
+ namespace: `${dbName}.${collection}`,
306
+ documents,
307
+ position: batchSize,
308
+ batchSize,
309
+ createdAt: Date.now(),
310
+ });
311
+ return {
312
+ documents: documents.slice(0, batchSize),
313
+ cursorId,
314
+ hasMore: true,
315
+ };
316
+ }
317
+ return { documents, cursorId: 0n, hasMore: false };
318
+ }
319
+ async insertOne(dbName, collection, doc) {
320
+ return this.insertMany(dbName, collection, [doc]);
321
+ }
322
+ async insertMany(dbName, collection, docs) {
323
+ const db = this.getDatabase(dbName);
324
+ const collectionId = this.getOrCreateCollectionId(db, collection);
325
+ const insertedIds = new Map();
326
+ let insertedCount = 0;
327
+ const stmt = db.prepare('INSERT INTO documents (collection_id, _id, data) VALUES (?, ?, ?)');
328
+ db.transaction(() => {
329
+ for (let i = 0; i < docs.length; i++) {
330
+ const doc = { ...docs[i] };
331
+ if (!doc._id) {
332
+ doc._id = new ObjectId();
333
+ }
334
+ const idStr = this.serializeId(doc._id);
335
+ const dataJson = JSON.stringify(doc);
336
+ stmt.run(collectionId, idStr, dataJson);
337
+ insertedIds.set(i, doc._id);
338
+ insertedCount++;
339
+ }
340
+ })();
341
+ return { acknowledged: true, insertedIds, insertedCount };
342
+ }
343
+ async updateOne(dbName, collection, filter, update, options) {
344
+ const db = this.getDatabase(dbName);
345
+ const collectionId = this.getCollectionId(db, collection);
346
+ if (!collectionId && !options?.upsert) {
347
+ return { acknowledged: true, matchedCount: 0, modifiedCount: 0, upsertedCount: 0 };
348
+ }
349
+ // Find the document
350
+ let sql = 'SELECT id, _id, data FROM documents WHERE collection_id = ?';
351
+ const params = [collectionId || 0];
352
+ const filterSql = this.buildFilterSql(filter, params);
353
+ if (filterSql) {
354
+ sql += ` AND (${filterSql})`;
355
+ }
356
+ sql += ' LIMIT 1';
357
+ const row = db.query(sql).get(...params);
358
+ if (!row) {
359
+ if (options?.upsert) {
360
+ const cid = this.getOrCreateCollectionId(db, collection);
361
+ const newDoc = { ...filter };
362
+ const updatedDoc = this.applyUpdate(newDoc, update);
363
+ if (!updatedDoc._id) {
364
+ updatedDoc._id = new ObjectId();
365
+ }
366
+ const idStr = this.serializeId(updatedDoc._id);
367
+ db.query('INSERT INTO documents (collection_id, _id, data) VALUES (?, ?, ?)').run(cid, idStr, JSON.stringify(updatedDoc));
368
+ return {
369
+ acknowledged: true,
370
+ matchedCount: 0,
371
+ modifiedCount: 0,
372
+ upsertedId: updatedDoc._id,
373
+ upsertedCount: 1,
374
+ };
375
+ }
376
+ return { acknowledged: true, matchedCount: 0, modifiedCount: 0, upsertedCount: 0 };
377
+ }
378
+ const doc = JSON.parse(row.data);
379
+ doc._id = this.parseId(row._id);
380
+ const updatedDoc = this.applyUpdate(doc, update);
381
+ db.query('UPDATE documents SET data = ? WHERE id = ?').run(JSON.stringify(updatedDoc), row.id);
382
+ return { acknowledged: true, matchedCount: 1, modifiedCount: 1, upsertedCount: 0 };
383
+ }
384
+ async updateMany(dbName, collection, filter, update, options) {
385
+ const db = this.getDatabase(dbName);
386
+ const collectionId = this.getCollectionId(db, collection);
387
+ if (!collectionId) {
388
+ if (options?.upsert) {
389
+ const result = await this.updateOne(dbName, collection, filter, update, options);
390
+ return result;
391
+ }
392
+ return { acknowledged: true, matchedCount: 0, modifiedCount: 0, upsertedCount: 0 };
393
+ }
394
+ let sql = 'SELECT id, _id, data FROM documents WHERE collection_id = ?';
395
+ const params = [collectionId];
396
+ const filterSql = this.buildFilterSql(filter, params);
397
+ if (filterSql) {
398
+ sql += ` AND (${filterSql})`;
399
+ }
400
+ const rows = db.query(sql).all(...params);
401
+ if (rows.length === 0 && options?.upsert) {
402
+ const result = await this.updateOne(dbName, collection, filter, update, options);
403
+ return result;
404
+ }
405
+ const stmt = db.prepare('UPDATE documents SET data = ? WHERE id = ?');
406
+ db.transaction(() => {
407
+ for (const row of rows) {
408
+ const doc = JSON.parse(row.data);
409
+ doc._id = this.parseId(row._id);
410
+ const updatedDoc = this.applyUpdate(doc, update);
411
+ stmt.run(JSON.stringify(updatedDoc), row.id);
412
+ }
413
+ })();
414
+ return {
415
+ acknowledged: true,
416
+ matchedCount: rows.length,
417
+ modifiedCount: rows.length,
418
+ upsertedCount: 0,
419
+ };
420
+ }
421
+ async deleteOne(dbName, collection, filter) {
422
+ const db = this.getDatabase(dbName);
423
+ const collectionId = this.getCollectionId(db, collection);
424
+ if (!collectionId) {
425
+ return { acknowledged: true, deletedCount: 0 };
426
+ }
427
+ // Find one document first
428
+ let sql = 'SELECT id FROM documents WHERE collection_id = ?';
429
+ const params = [collectionId];
430
+ const filterSql = this.buildFilterSql(filter, params);
431
+ if (filterSql) {
432
+ sql += ` AND (${filterSql})`;
433
+ }
434
+ sql += ' LIMIT 1';
435
+ const row = db.query(sql).get(...params);
436
+ if (!row) {
437
+ return { acknowledged: true, deletedCount: 0 };
438
+ }
439
+ db.query('DELETE FROM documents WHERE id = ?').run(row.id);
440
+ return { acknowledged: true, deletedCount: 1 };
441
+ }
442
+ async deleteMany(dbName, collection, filter) {
443
+ const db = this.getDatabase(dbName);
444
+ const collectionId = this.getCollectionId(db, collection);
445
+ if (!collectionId) {
446
+ return { acknowledged: true, deletedCount: 0 };
447
+ }
448
+ let sql = 'DELETE FROM documents WHERE collection_id = ?';
449
+ const params = [collectionId];
450
+ const filterSql = this.buildFilterSql(filter, params);
451
+ if (filterSql) {
452
+ sql += ` AND (${filterSql})`;
453
+ }
454
+ const result = db.query(sql).run(...params);
455
+ return { acknowledged: true, deletedCount: result.changes };
456
+ }
457
+ // ============ Count & Distinct ============
458
+ async count(dbName, collection, query) {
459
+ const db = this.getDatabase(dbName);
460
+ const collectionId = this.getCollectionId(db, collection);
461
+ if (!collectionId) {
462
+ return 0;
463
+ }
464
+ let sql = 'SELECT COUNT(*) as count FROM documents WHERE collection_id = ?';
465
+ const params = [collectionId];
466
+ if (query && Object.keys(query).length > 0) {
467
+ const filterSql = this.buildFilterSql(query, params);
468
+ if (filterSql) {
469
+ sql += ` AND (${filterSql})`;
470
+ }
471
+ }
472
+ const result = db.query(sql).get(...params);
473
+ return result.count;
474
+ }
475
+ async distinct(dbName, collection, field, query) {
476
+ const db = this.getDatabase(dbName);
477
+ const collectionId = this.getCollectionId(db, collection);
478
+ if (!collectionId) {
479
+ return [];
480
+ }
481
+ let sql;
482
+ if (field === '_id') {
483
+ sql = 'SELECT DISTINCT _id as value FROM documents WHERE collection_id = ?';
484
+ }
485
+ else {
486
+ // Validate field name to prevent SQL injection
487
+ const safePath = safeJsonPath(validateFieldPath(field));
488
+ sql = `SELECT DISTINCT json_extract(data, '${safePath}') as value FROM documents WHERE collection_id = ?`;
489
+ }
490
+ const params = [collectionId];
491
+ if (query && Object.keys(query).length > 0) {
492
+ const filterSql = this.buildFilterSql(query, params);
493
+ if (filterSql) {
494
+ sql += ` AND (${filterSql})`;
495
+ }
496
+ }
497
+ const rows = db.query(sql).all(...params);
498
+ return rows.map((r) => r.value).filter((v) => v !== null);
499
+ }
500
+ // ============ Aggregation ============
501
+ async aggregate(dbName, collection, pipeline, options) {
502
+ const db = this.getDatabase(dbName);
503
+ const collectionId = this.getCollectionId(db, collection);
504
+ if (!collectionId) {
505
+ return { documents: [], cursorId: 0n, hasMore: false };
506
+ }
507
+ // Get all documents for in-memory processing
508
+ const rows = db
509
+ .query('SELECT _id, data FROM documents WHERE collection_id = ?')
510
+ .all(collectionId);
511
+ let documents = rows.map((row) => {
512
+ const doc = JSON.parse(row.data);
513
+ doc._id = this.parseId(row._id);
514
+ return doc;
515
+ });
516
+ // Apply pipeline stages
517
+ documents = this.applyPipeline(documents, pipeline);
518
+ const batchSize = options?.batchSize || DEFAULT_BATCH_SIZE;
519
+ if (documents.length > batchSize) {
520
+ const cursorId = this.nextCursorId++;
521
+ this.cursors.set(cursorId, {
522
+ id: cursorId,
523
+ namespace: `${dbName}.${collection}`,
524
+ documents,
525
+ position: batchSize,
526
+ batchSize,
527
+ createdAt: Date.now(),
528
+ });
529
+ return {
530
+ documents: documents.slice(0, batchSize),
531
+ cursorId,
532
+ hasMore: true,
533
+ };
534
+ }
535
+ return { documents, cursorId: 0n, hasMore: false };
536
+ }
537
+ // ============ Index Operations ============
538
+ async listIndexes(dbName, collection) {
539
+ const db = this.getDatabase(dbName);
540
+ const collectionId = this.getCollectionId(db, collection);
541
+ const indexes = [{ v: 2, key: { _id: 1 }, name: '_id_' }];
542
+ if (!collectionId) {
543
+ return indexes;
544
+ }
545
+ const rows = db
546
+ .query('SELECT name, key, options FROM indexes WHERE collection_id = ?')
547
+ .all(collectionId);
548
+ for (const row of rows) {
549
+ indexes.push({
550
+ v: 2,
551
+ key: JSON.parse(row.key),
552
+ name: row.name,
553
+ ...JSON.parse(row.options),
554
+ });
555
+ }
556
+ return indexes;
557
+ }
558
+ async createIndexes(dbName, collection, indexes) {
559
+ const db = this.getDatabase(dbName);
560
+ const collectionId = this.getOrCreateCollectionId(db, collection);
561
+ const createdNames = [];
562
+ const stmt = db.prepare('INSERT OR IGNORE INTO indexes (collection_id, name, key, options) VALUES (?, ?, ?, ?)');
563
+ for (const spec of indexes) {
564
+ const name = spec.name || this.generateIndexName(spec.key);
565
+ const keyJson = JSON.stringify(spec.key);
566
+ const options = {};
567
+ if (spec.unique)
568
+ options.unique = true;
569
+ if (spec.sparse)
570
+ options.sparse = true;
571
+ const result = stmt.run(collectionId, name, keyJson, JSON.stringify(options));
572
+ if (result.changes > 0) {
573
+ createdNames.push(name);
574
+ }
575
+ }
576
+ return createdNames;
577
+ }
578
+ async dropIndex(dbName, collection, indexName) {
579
+ const db = this.getDatabase(dbName);
580
+ const collectionId = this.getCollectionId(db, collection);
581
+ if (collectionId) {
582
+ db.query('DELETE FROM indexes WHERE collection_id = ? AND name = ?').run(collectionId, indexName);
583
+ }
584
+ }
585
+ async dropIndexes(dbName, collection) {
586
+ const db = this.getDatabase(dbName);
587
+ const collectionId = this.getCollectionId(db, collection);
588
+ if (collectionId) {
589
+ db.query("DELETE FROM indexes WHERE collection_id = ? AND name != '_id_'").run(collectionId);
590
+ }
591
+ }
592
+ // ============ Cursor Management ============
593
+ createCursor(state) {
594
+ this.cursors.set(state.id, state);
595
+ }
596
+ getCursor(id) {
597
+ return this.cursors.get(id);
598
+ }
599
+ advanceCursor(id, count) {
600
+ const cursor = this.cursors.get(id);
601
+ if (!cursor) {
602
+ return [];
603
+ }
604
+ const start = cursor.position;
605
+ const end = Math.min(start + count, cursor.documents.length);
606
+ cursor.position = end;
607
+ return cursor.documents.slice(start, end);
608
+ }
609
+ closeCursor(id) {
610
+ return this.cursors.delete(id);
611
+ }
612
+ cleanupExpiredCursors() {
613
+ const now = Date.now();
614
+ for (const [id, cursor] of this.cursors) {
615
+ if (now - cursor.createdAt > CURSOR_TIMEOUT_MS) {
616
+ this.cursors.delete(id);
617
+ }
618
+ }
619
+ }
620
+ // ============ Helper Methods ============
621
+ serializeId(id) {
622
+ if (id instanceof ObjectId) {
623
+ return id.toHexString();
624
+ }
625
+ if (typeof id === 'object' && id !== null && '$oid' in id) {
626
+ return id.$oid;
627
+ }
628
+ return String(id);
629
+ }
630
+ parseId(idStr) {
631
+ if (/^[0-9a-f]{24}$/i.test(idStr)) {
632
+ return new ObjectId(idStr);
633
+ }
634
+ return idStr;
635
+ }
636
+ generateIndexName(key) {
637
+ return Object.entries(key)
638
+ .map(([field, dir]) => `${field}_${dir}`)
639
+ .join('_');
640
+ }
641
+ /**
642
+ * Build simplified SQL filter from MongoDB query
643
+ */
644
+ buildFilterSql(filter, params) {
645
+ const conditions = [];
646
+ for (const [key, value] of Object.entries(filter)) {
647
+ if (key === '_id') {
648
+ params.push(this.serializeId(value));
649
+ conditions.push('_id = ?');
650
+ }
651
+ else if (key === '$and' && Array.isArray(value)) {
652
+ const subConditions = value
653
+ .map((sub) => this.buildFilterSql(sub, params))
654
+ .filter(Boolean);
655
+ if (subConditions.length > 0) {
656
+ conditions.push(`(${subConditions.join(' AND ')})`);
657
+ }
658
+ }
659
+ else if (key === '$or' && Array.isArray(value)) {
660
+ const subConditions = value
661
+ .map((sub) => this.buildFilterSql(sub, params))
662
+ .filter(Boolean);
663
+ if (subConditions.length > 0) {
664
+ conditions.push(`(${subConditions.join(' OR ')})`);
665
+ }
666
+ }
667
+ else if (typeof value === 'object' && value !== null && !Array.isArray(value)) {
668
+ // Handle operators
669
+ // Validate field name to prevent SQL injection
670
+ const safePath = safeJsonPath(validateFieldPath(key));
671
+ for (const [op, opValue] of Object.entries(value)) {
672
+ const path = `json_extract(data, '${safePath}')`;
673
+ switch (op) {
674
+ case '$eq':
675
+ params.push(opValue);
676
+ conditions.push(`${path} = ?`);
677
+ break;
678
+ case '$ne':
679
+ params.push(opValue);
680
+ conditions.push(`${path} != ?`);
681
+ break;
682
+ case '$gt':
683
+ params.push(opValue);
684
+ conditions.push(`${path} > ?`);
685
+ break;
686
+ case '$gte':
687
+ params.push(opValue);
688
+ conditions.push(`${path} >= ?`);
689
+ break;
690
+ case '$lt':
691
+ params.push(opValue);
692
+ conditions.push(`${path} < ?`);
693
+ break;
694
+ case '$lte':
695
+ params.push(opValue);
696
+ conditions.push(`${path} <= ?`);
697
+ break;
698
+ case '$exists':
699
+ conditions.push(opValue ? `${path} IS NOT NULL` : `${path} IS NULL`);
700
+ break;
701
+ case '$in':
702
+ if (Array.isArray(opValue) && opValue.length > 0) {
703
+ const placeholders = opValue.map(() => '?').join(', ');
704
+ params.push(...opValue);
705
+ conditions.push(`${path} IN (${placeholders})`);
706
+ }
707
+ break;
708
+ }
709
+ }
710
+ }
711
+ else {
712
+ // Direct equality
713
+ // Validate field name to prevent SQL injection
714
+ const safePath = safeJsonPath(validateFieldPath(key));
715
+ const sqlValue = typeof value === 'boolean' ? (value ? 1 : 0) : value;
716
+ params.push(sqlValue);
717
+ conditions.push(`json_extract(data, '${safePath}') = ?`);
718
+ }
719
+ }
720
+ return conditions.join(' AND ');
721
+ }
722
+ applyProjection(doc, projection) {
723
+ const includeFields = new Set();
724
+ const excludeFields = new Set();
725
+ let isInclusion = false;
726
+ for (const [field, value] of Object.entries(projection)) {
727
+ if (field === '_id' && (value === 0 || value === false)) {
728
+ excludeFields.add('_id');
729
+ continue;
730
+ }
731
+ if (value === 1 || value === true) {
732
+ includeFields.add(field);
733
+ isInclusion = true;
734
+ }
735
+ else if (value === 0 || value === false) {
736
+ excludeFields.add(field);
737
+ }
738
+ }
739
+ if (isInclusion) {
740
+ const result = {};
741
+ if (!excludeFields.has('_id')) {
742
+ result._id = doc._id;
743
+ }
744
+ for (const field of includeFields) {
745
+ if (field in doc) {
746
+ result[field] = doc[field];
747
+ }
748
+ }
749
+ return result;
750
+ }
751
+ const result = { ...doc };
752
+ for (const field of excludeFields) {
753
+ delete result[field];
754
+ }
755
+ return result;
756
+ }
757
+ applyUpdate(doc, update) {
758
+ const result = { ...doc };
759
+ if (update.$set) {
760
+ Object.assign(result, update.$set);
761
+ }
762
+ if (update.$unset) {
763
+ for (const key of Object.keys(update.$unset)) {
764
+ delete result[key];
765
+ }
766
+ }
767
+ if (update.$inc) {
768
+ for (const [key, value] of Object.entries(update.$inc)) {
769
+ const current = result[key] || 0;
770
+ result[key] = current + value;
771
+ }
772
+ }
773
+ if (update.$push) {
774
+ for (const [key, value] of Object.entries(update.$push)) {
775
+ const current = result[key] || [];
776
+ if (typeof value === 'object' && value !== null && '$each' in value) {
777
+ current.push(...value.$each);
778
+ }
779
+ else {
780
+ current.push(value);
781
+ }
782
+ result[key] = current;
783
+ }
784
+ }
785
+ // Handle replacement (no operators)
786
+ const hasOperators = Object.keys(update).some((k) => k.startsWith('$'));
787
+ if (!hasOperators) {
788
+ const id = result._id;
789
+ for (const key of Object.keys(result)) {
790
+ if (key !== '_id')
791
+ delete result[key];
792
+ }
793
+ Object.assign(result, update);
794
+ result._id = id;
795
+ }
796
+ return result;
797
+ }
798
+ applyPipeline(documents, pipeline) {
799
+ let result = [...documents];
800
+ for (const stage of pipeline) {
801
+ const entry = Object.entries(stage)[0];
802
+ if (!entry)
803
+ continue;
804
+ const [op, value] = entry;
805
+ switch (op) {
806
+ case '$match':
807
+ result = result.filter((doc) => this.matchDocument(doc, value));
808
+ break;
809
+ case '$project':
810
+ result = result.map((doc) => this.applyProjection(doc, value));
811
+ break;
812
+ case '$sort':
813
+ result = this.sortDocuments(result, value);
814
+ break;
815
+ case '$limit':
816
+ result = result.slice(0, value);
817
+ break;
818
+ case '$skip':
819
+ result = result.slice(value);
820
+ break;
821
+ case '$count':
822
+ result = [{ [value]: result.length }];
823
+ break;
824
+ case '$sample':
825
+ const size = value.size || 100;
826
+ result = this.shuffleArray(result).slice(0, size);
827
+ break;
828
+ case '$group':
829
+ result = this.groupDocuments(result, value);
830
+ break;
831
+ }
832
+ }
833
+ return result;
834
+ }
835
+ matchDocument(doc, query) {
836
+ for (const [key, value] of Object.entries(query)) {
837
+ if (key === '$and') {
838
+ if (!value.every((q) => this.matchDocument(doc, q))) {
839
+ return false;
840
+ }
841
+ continue;
842
+ }
843
+ if (key === '$or') {
844
+ if (!value.some((q) => this.matchDocument(doc, q))) {
845
+ return false;
846
+ }
847
+ continue;
848
+ }
849
+ const docValue = doc[key];
850
+ if (typeof value === 'object' && value !== null && !Array.isArray(value)) {
851
+ for (const [op, opValue] of Object.entries(value)) {
852
+ switch (op) {
853
+ case '$eq':
854
+ if (docValue !== opValue)
855
+ return false;
856
+ break;
857
+ case '$ne':
858
+ if (docValue === opValue)
859
+ return false;
860
+ break;
861
+ case '$gt':
862
+ if (!(docValue > opValue))
863
+ return false;
864
+ break;
865
+ case '$gte':
866
+ if (!(docValue >= opValue))
867
+ return false;
868
+ break;
869
+ case '$lt':
870
+ if (!(docValue < opValue))
871
+ return false;
872
+ break;
873
+ case '$lte':
874
+ if (!(docValue <= opValue))
875
+ return false;
876
+ break;
877
+ case '$in':
878
+ if (!opValue.includes(docValue))
879
+ return false;
880
+ break;
881
+ case '$exists':
882
+ if ((opValue && docValue === undefined) || (!opValue && docValue !== undefined))
883
+ return false;
884
+ break;
885
+ }
886
+ }
887
+ }
888
+ else {
889
+ if (docValue !== value)
890
+ return false;
891
+ }
892
+ }
893
+ return true;
894
+ }
895
+ sortDocuments(documents, sort) {
896
+ return [...documents].sort((a, b) => {
897
+ for (const [field, direction] of Object.entries(sort)) {
898
+ const aVal = a[field];
899
+ const bVal = b[field];
900
+ const dir = direction === -1 ? -1 : 1;
901
+ if (aVal === bVal)
902
+ continue;
903
+ if (aVal === undefined || aVal === null)
904
+ return dir;
905
+ if (bVal === undefined || bVal === null)
906
+ return -dir;
907
+ if (aVal < bVal)
908
+ return -dir;
909
+ if (aVal > bVal)
910
+ return dir;
911
+ }
912
+ return 0;
913
+ });
914
+ }
915
+ shuffleArray(array) {
916
+ const result = [...array];
917
+ for (let i = result.length - 1; i > 0; i--) {
918
+ const j = Math.floor(Math.random() * (i + 1));
919
+ const temp = result[i];
920
+ result[i] = result[j];
921
+ result[j] = temp;
922
+ }
923
+ return result;
924
+ }
925
+ groupDocuments(documents, groupSpec) {
926
+ const groups = new Map();
927
+ const idSpec = groupSpec._id;
928
+ for (const doc of documents) {
929
+ let groupKey;
930
+ if (idSpec === null) {
931
+ groupKey = '__all__';
932
+ }
933
+ else if (typeof idSpec === 'string' && idSpec.startsWith('$')) {
934
+ groupKey = JSON.stringify(doc[idSpec.slice(1)]);
935
+ }
936
+ else {
937
+ groupKey = JSON.stringify(idSpec);
938
+ }
939
+ if (!groups.has(groupKey)) {
940
+ groups.set(groupKey, []);
941
+ }
942
+ groups.get(groupKey).push(doc);
943
+ }
944
+ const result = [];
945
+ for (const [key, docs] of groups) {
946
+ const grouped = { _id: key === '__all__' ? null : JSON.parse(key) };
947
+ for (const [field, spec] of Object.entries(groupSpec)) {
948
+ if (field === '_id')
949
+ continue;
950
+ if (typeof spec === 'object' && spec !== null) {
951
+ const [op, value] = Object.entries(spec)[0];
952
+ const fieldPath = typeof value === 'string' && value.startsWith('$') ? value.slice(1) : null;
953
+ switch (op) {
954
+ case '$sum':
955
+ if (value === 1) {
956
+ grouped[field] = docs.length;
957
+ }
958
+ else if (fieldPath) {
959
+ grouped[field] = docs.reduce((sum, doc) => sum + (doc[fieldPath] || 0), 0);
960
+ }
961
+ break;
962
+ case '$avg':
963
+ if (fieldPath) {
964
+ const values = docs.map((doc) => doc[fieldPath]).filter((v) => typeof v === 'number');
965
+ grouped[field] = values.length > 0 ? values.reduce((a, b) => a + b, 0) / values.length : null;
966
+ }
967
+ break;
968
+ case '$first':
969
+ if (fieldPath && docs.length > 0) {
970
+ const firstDoc = docs[0];
971
+ if (firstDoc) {
972
+ grouped[field] = firstDoc[fieldPath];
973
+ }
974
+ }
975
+ break;
976
+ case '$last':
977
+ if (fieldPath && docs.length > 0) {
978
+ const lastDoc = docs[docs.length - 1];
979
+ if (lastDoc) {
980
+ grouped[field] = lastDoc[fieldPath];
981
+ }
982
+ }
983
+ break;
984
+ }
985
+ }
986
+ }
987
+ result.push(grouped);
988
+ }
989
+ return result;
990
+ }
991
+ /**
992
+ * Close all database connections
993
+ */
994
+ close() {
995
+ for (const db of this.databases.values()) {
996
+ db.close();
997
+ }
998
+ this.databases.clear();
999
+ this.cursors.clear();
1000
+ }
1001
+ }
1002
+ //# sourceMappingURL=local-sqlite.js.map