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.
- package/LICENSE +21 -0
- package/README.md +454 -0
- package/dist/agentfs/adapters/anthropic.d.ts +176 -0
- package/dist/agentfs/adapters/anthropic.d.ts.map +1 -0
- package/dist/agentfs/adapters/anthropic.js +629 -0
- package/dist/agentfs/adapters/anthropic.js.map +1 -0
- package/dist/agentfs/adapters/index.d.ts +21 -0
- package/dist/agentfs/adapters/index.d.ts.map +1 -0
- package/dist/agentfs/adapters/index.js +23 -0
- package/dist/agentfs/adapters/index.js.map +1 -0
- package/dist/agentfs/adapters/vercel.d.ts +260 -0
- package/dist/agentfs/adapters/vercel.d.ts.map +1 -0
- package/dist/agentfs/adapters/vercel.js +288 -0
- package/dist/agentfs/adapters/vercel.js.map +1 -0
- package/dist/agentfs/glob.d.ts +116 -0
- package/dist/agentfs/glob.d.ts.map +1 -0
- package/dist/agentfs/glob.js +270 -0
- package/dist/agentfs/glob.js.map +1 -0
- package/dist/agentfs/grep.d.ts +83 -0
- package/dist/agentfs/grep.d.ts.map +1 -0
- package/dist/agentfs/grep.js +193 -0
- package/dist/agentfs/grep.js.map +1 -0
- package/dist/agentfs/index.d.ts +22 -0
- package/dist/agentfs/index.d.ts.map +1 -0
- package/dist/agentfs/index.js +18 -0
- package/dist/agentfs/index.js.map +1 -0
- package/dist/agentfs/kv-store.d.ts +128 -0
- package/dist/agentfs/kv-store.d.ts.map +1 -0
- package/dist/agentfs/kv-store.js +227 -0
- package/dist/agentfs/kv-store.js.map +1 -0
- package/dist/agentfs/mondo-agent.d.ts +255 -0
- package/dist/agentfs/mondo-agent.d.ts.map +1 -0
- package/dist/agentfs/mondo-agent.js +879 -0
- package/dist/agentfs/mondo-agent.js.map +1 -0
- package/dist/agentfs/toolcalls.d.ts +130 -0
- package/dist/agentfs/toolcalls.d.ts.map +1 -0
- package/dist/agentfs/toolcalls.js +178 -0
- package/dist/agentfs/toolcalls.js.map +1 -0
- package/dist/agentfs/types.d.ts +171 -0
- package/dist/agentfs/types.d.ts.map +1 -0
- package/dist/agentfs/types.js +7 -0
- package/dist/agentfs/types.js.map +1 -0
- package/dist/agentfs/vfs.d.ts +249 -0
- package/dist/agentfs/vfs.d.ts.map +1 -0
- package/dist/agentfs/vfs.js +469 -0
- package/dist/agentfs/vfs.js.map +1 -0
- package/dist/cli/index.d.ts +15 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +219 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/mcp.d.ts +119 -0
- package/dist/cli/mcp.d.ts.map +1 -0
- package/dist/cli/mcp.js +418 -0
- package/dist/cli/mcp.js.map +1 -0
- package/dist/cli/server.d.ts +179 -0
- package/dist/cli/server.d.ts.map +1 -0
- package/dist/cli/server.js +441 -0
- package/dist/cli/server.js.map +1 -0
- package/dist/client/Collection.d.ts +199 -0
- package/dist/client/Collection.d.ts.map +1 -0
- package/dist/client/Collection.js +256 -0
- package/dist/client/Collection.js.map +1 -0
- package/dist/client/Database.d.ts +68 -0
- package/dist/client/Database.d.ts.map +1 -0
- package/dist/client/Database.js +105 -0
- package/dist/client/Database.js.map +1 -0
- package/dist/client/MongoClient.d.ts +165 -0
- package/dist/client/MongoClient.d.ts.map +1 -0
- package/dist/client/MongoClient.js +307 -0
- package/dist/client/MongoClient.js.map +1 -0
- package/dist/client/aggregation-cursor.d.ts +210 -0
- package/dist/client/aggregation-cursor.d.ts.map +1 -0
- package/dist/client/aggregation-cursor.js +509 -0
- package/dist/client/aggregation-cursor.js.map +1 -0
- package/dist/client/bulk-write.d.ts +216 -0
- package/dist/client/bulk-write.d.ts.map +1 -0
- package/dist/client/bulk-write.js +63 -0
- package/dist/client/bulk-write.js.map +1 -0
- package/dist/client/change-stream.d.ts +245 -0
- package/dist/client/change-stream.d.ts.map +1 -0
- package/dist/client/change-stream.js +429 -0
- package/dist/client/change-stream.js.map +1 -0
- package/dist/client/cursor.d.ts +85 -0
- package/dist/client/cursor.d.ts.map +1 -0
- package/dist/client/cursor.js +156 -0
- package/dist/client/cursor.js.map +1 -0
- package/dist/client/http-cursor.d.ts +233 -0
- package/dist/client/http-cursor.d.ts.map +1 -0
- package/dist/client/http-cursor.js +496 -0
- package/dist/client/http-cursor.js.map +1 -0
- package/dist/client/index.d.ts +18 -0
- package/dist/client/index.d.ts.map +1 -0
- package/dist/client/index.js +24 -0
- package/dist/client/index.js.map +1 -0
- package/dist/client/mongo-client.d.ts +60 -0
- package/dist/client/mongo-client.d.ts.map +1 -0
- package/dist/client/mongo-client.js +190 -0
- package/dist/client/mongo-client.js.map +1 -0
- package/dist/client/mongo-collection.d.ts +359 -0
- package/dist/client/mongo-collection.d.ts.map +1 -0
- package/dist/client/mongo-collection.js +1641 -0
- package/dist/client/mongo-collection.js.map +1 -0
- package/dist/client/mongo-cursor.d.ts +257 -0
- package/dist/client/mongo-cursor.d.ts.map +1 -0
- package/dist/client/mongo-cursor.js +621 -0
- package/dist/client/mongo-cursor.js.map +1 -0
- package/dist/client/mongo-database.d.ts +88 -0
- package/dist/client/mongo-database.d.ts.map +1 -0
- package/dist/client/mongo-database.js +139 -0
- package/dist/client/mongo-database.js.map +1 -0
- package/dist/client/session.d.ts +210 -0
- package/dist/client/session.d.ts.map +1 -0
- package/dist/client/session.js +326 -0
- package/dist/client/session.js.map +1 -0
- package/dist/durable-object/index-manager.d.ts +173 -0
- package/dist/durable-object/index-manager.d.ts.map +1 -0
- package/dist/durable-object/index-manager.js +764 -0
- package/dist/durable-object/index-manager.js.map +1 -0
- package/dist/durable-object/index.d.ts +12 -0
- package/dist/durable-object/index.d.ts.map +1 -0
- package/dist/durable-object/index.js +8 -0
- package/dist/durable-object/index.js.map +1 -0
- package/dist/durable-object/mcp-handler.d.ts +52 -0
- package/dist/durable-object/mcp-handler.d.ts.map +1 -0
- package/dist/durable-object/mcp-handler.js +186 -0
- package/dist/durable-object/mcp-handler.js.map +1 -0
- package/dist/durable-object/migrations.d.ts +40 -0
- package/dist/durable-object/migrations.d.ts.map +1 -0
- package/dist/durable-object/migrations.js +121 -0
- package/dist/durable-object/migrations.js.map +1 -0
- package/dist/durable-object/mondo-database.d.ts +148 -0
- package/dist/durable-object/mondo-database.d.ts.map +1 -0
- package/dist/durable-object/mondo-database.js +621 -0
- package/dist/durable-object/mondo-database.js.map +1 -0
- package/dist/durable-object/schema.d.ts +192 -0
- package/dist/durable-object/schema.d.ts.map +1 -0
- package/dist/durable-object/schema.js +186 -0
- package/dist/durable-object/schema.js.map +1 -0
- package/dist/embedding/document-serializer.d.ts +118 -0
- package/dist/embedding/document-serializer.d.ts.map +1 -0
- package/dist/embedding/document-serializer.js +339 -0
- package/dist/embedding/document-serializer.js.map +1 -0
- package/dist/embedding/embedding-manager.d.ts +136 -0
- package/dist/embedding/embedding-manager.d.ts.map +1 -0
- package/dist/embedding/embedding-manager.js +176 -0
- package/dist/embedding/embedding-manager.js.map +1 -0
- package/dist/embedding/index.d.ts +9 -0
- package/dist/embedding/index.d.ts.map +1 -0
- package/dist/embedding/index.js +9 -0
- package/dist/embedding/index.js.map +1 -0
- package/dist/executor/aggregation-executor.d.ts +93 -0
- package/dist/executor/aggregation-executor.d.ts.map +1 -0
- package/dist/executor/aggregation-executor.js +275 -0
- package/dist/executor/aggregation-executor.js.map +1 -0
- package/dist/executor/function-executor.d.ts +39 -0
- package/dist/executor/function-executor.d.ts.map +1 -0
- package/dist/executor/function-executor.js +168 -0
- package/dist/executor/function-executor.js.map +1 -0
- package/dist/executor/index.d.ts +4 -0
- package/dist/executor/index.d.ts.map +1 -0
- package/dist/executor/index.js +4 -0
- package/dist/executor/index.js.map +1 -0
- package/dist/executor/vector-search-executor.d.ts +71 -0
- package/dist/executor/vector-search-executor.d.ts.map +1 -0
- package/dist/executor/vector-search-executor.js +113 -0
- package/dist/executor/vector-search-executor.js.map +1 -0
- package/dist/index.d.ts +21 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +28 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp/adapters/anthropic-adapter.d.ts +256 -0
- package/dist/mcp/adapters/anthropic-adapter.d.ts.map +1 -0
- package/dist/mcp/adapters/anthropic-adapter.js +409 -0
- package/dist/mcp/adapters/anthropic-adapter.js.map +1 -0
- package/dist/mcp/adapters/base-adapter.d.ts +164 -0
- package/dist/mcp/adapters/base-adapter.d.ts.map +1 -0
- package/dist/mcp/adapters/base-adapter.js +277 -0
- package/dist/mcp/adapters/base-adapter.js.map +1 -0
- package/dist/mcp/adapters/errors.d.ts +173 -0
- package/dist/mcp/adapters/errors.d.ts.map +1 -0
- package/dist/mcp/adapters/errors.js +305 -0
- package/dist/mcp/adapters/errors.js.map +1 -0
- package/dist/mcp/adapters/index.d.ts +65 -0
- package/dist/mcp/adapters/index.d.ts.map +1 -0
- package/dist/mcp/adapters/index.js +92 -0
- package/dist/mcp/adapters/index.js.map +1 -0
- package/dist/mcp/adapters/streaming.d.ts +200 -0
- package/dist/mcp/adapters/streaming.d.ts.map +1 -0
- package/dist/mcp/adapters/streaming.js +381 -0
- package/dist/mcp/adapters/streaming.js.map +1 -0
- package/dist/mcp/adapters/vercel-adapter.d.ts +321 -0
- package/dist/mcp/adapters/vercel-adapter.d.ts.map +1 -0
- package/dist/mcp/adapters/vercel-adapter.js +487 -0
- package/dist/mcp/adapters/vercel-adapter.js.map +1 -0
- package/dist/mcp/agent.d.ts +192 -0
- package/dist/mcp/agent.d.ts.map +1 -0
- package/dist/mcp/agent.js +338 -0
- package/dist/mcp/agent.js.map +1 -0
- package/dist/mcp/cli.d.ts +71 -0
- package/dist/mcp/cli.d.ts.map +1 -0
- package/dist/mcp/cli.js +218 -0
- package/dist/mcp/cli.js.map +1 -0
- package/dist/mcp/index.d.ts +15 -0
- package/dist/mcp/index.d.ts.map +1 -0
- package/dist/mcp/index.js +20 -0
- package/dist/mcp/index.js.map +1 -0
- package/dist/mcp/sandbox/database-proxy.d.ts +118 -0
- package/dist/mcp/sandbox/database-proxy.d.ts.map +1 -0
- package/dist/mcp/sandbox/database-proxy.js +154 -0
- package/dist/mcp/sandbox/database-proxy.js.map +1 -0
- package/dist/mcp/sandbox/index.d.ts +8 -0
- package/dist/mcp/sandbox/index.d.ts.map +1 -0
- package/dist/mcp/sandbox/index.js +7 -0
- package/dist/mcp/sandbox/index.js.map +1 -0
- package/dist/mcp/sandbox/miniflare-evaluator.d.ts +72 -0
- package/dist/mcp/sandbox/miniflare-evaluator.d.ts.map +1 -0
- package/dist/mcp/sandbox/miniflare-evaluator.js +379 -0
- package/dist/mcp/sandbox/miniflare-evaluator.js.map +1 -0
- package/dist/mcp/sandbox/template.d.ts +48 -0
- package/dist/mcp/sandbox/template.d.ts.map +1 -0
- package/dist/mcp/sandbox/template.js +147 -0
- package/dist/mcp/sandbox/template.js.map +1 -0
- package/dist/mcp/sandbox/worker-evaluator.d.ts +160 -0
- package/dist/mcp/sandbox/worker-evaluator.d.ts.map +1 -0
- package/dist/mcp/sandbox/worker-evaluator.js +217 -0
- package/dist/mcp/sandbox/worker-evaluator.js.map +1 -0
- package/dist/mcp/server.d.ts +75 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +278 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/tool-call-auditor.d.ts +188 -0
- package/dist/mcp/tool-call-auditor.d.ts.map +1 -0
- package/dist/mcp/tool-call-auditor.js +198 -0
- package/dist/mcp/tool-call-auditor.js.map +1 -0
- package/dist/mcp/tools/do.d.ts +51 -0
- package/dist/mcp/tools/do.d.ts.map +1 -0
- package/dist/mcp/tools/do.js +113 -0
- package/dist/mcp/tools/do.js.map +1 -0
- package/dist/mcp/tools/fetch.d.ts +43 -0
- package/dist/mcp/tools/fetch.d.ts.map +1 -0
- package/dist/mcp/tools/fetch.js +127 -0
- package/dist/mcp/tools/fetch.js.map +1 -0
- package/dist/mcp/tools/index.d.ts +9 -0
- package/dist/mcp/tools/index.d.ts.map +1 -0
- package/dist/mcp/tools/index.js +9 -0
- package/dist/mcp/tools/index.js.map +1 -0
- package/dist/mcp/tools/search.d.ts +60 -0
- package/dist/mcp/tools/search.d.ts.map +1 -0
- package/dist/mcp/tools/search.js +278 -0
- package/dist/mcp/tools/search.js.map +1 -0
- package/dist/mcp/transport/http.d.ts +144 -0
- package/dist/mcp/transport/http.d.ts.map +1 -0
- package/dist/mcp/transport/http.js +545 -0
- package/dist/mcp/transport/http.js.map +1 -0
- package/dist/mcp/transport/index.d.ts +10 -0
- package/dist/mcp/transport/index.d.ts.map +1 -0
- package/dist/mcp/transport/index.js +12 -0
- package/dist/mcp/transport/index.js.map +1 -0
- package/dist/mcp/transport/stdio.d.ts +132 -0
- package/dist/mcp/transport/stdio.d.ts.map +1 -0
- package/dist/mcp/transport/stdio.js +466 -0
- package/dist/mcp/transport/stdio.js.map +1 -0
- package/dist/mcp/types.d.ts +476 -0
- package/dist/mcp/types.d.ts.map +1 -0
- package/dist/mcp/types.js +178 -0
- package/dist/mcp/types.js.map +1 -0
- package/dist/olap/cdc/cdc-buffer.d.ts +92 -0
- package/dist/olap/cdc/cdc-buffer.d.ts.map +1 -0
- package/dist/olap/cdc/cdc-buffer.js +146 -0
- package/dist/olap/cdc/cdc-buffer.js.map +1 -0
- package/dist/olap/cdc/cdc-emitter.d.ts +118 -0
- package/dist/olap/cdc/cdc-emitter.d.ts.map +1 -0
- package/dist/olap/cdc/cdc-emitter.js +217 -0
- package/dist/olap/cdc/cdc-emitter.js.map +1 -0
- package/dist/olap/cdc/cdc-schema.d.ts +119 -0
- package/dist/olap/cdc/cdc-schema.d.ts.map +1 -0
- package/dist/olap/cdc/cdc-schema.js +253 -0
- package/dist/olap/cdc/cdc-schema.js.map +1 -0
- package/dist/olap/cdc/index.d.ts +10 -0
- package/dist/olap/cdc/index.d.ts.map +1 -0
- package/dist/olap/cdc/index.js +10 -0
- package/dist/olap/cdc/index.js.map +1 -0
- package/dist/olap/clickhouse/iceberg.d.ts +164 -0
- package/dist/olap/clickhouse/iceberg.d.ts.map +1 -0
- package/dist/olap/clickhouse/iceberg.js +138 -0
- package/dist/olap/clickhouse/iceberg.js.map +1 -0
- package/dist/olap/clickhouse/index.d.ts +14 -0
- package/dist/olap/clickhouse/index.d.ts.map +1 -0
- package/dist/olap/clickhouse/index.js +14 -0
- package/dist/olap/clickhouse/index.js.map +1 -0
- package/dist/olap/clickhouse/mapper.d.ts +170 -0
- package/dist/olap/clickhouse/mapper.d.ts.map +1 -0
- package/dist/olap/clickhouse/mapper.js +654 -0
- package/dist/olap/clickhouse/mapper.js.map +1 -0
- package/dist/olap/clickhouse/olap-backend.d.ts +181 -0
- package/dist/olap/clickhouse/olap-backend.d.ts.map +1 -0
- package/dist/olap/clickhouse/olap-backend.js +1083 -0
- package/dist/olap/clickhouse/olap-backend.js.map +1 -0
- package/dist/olap/clickhouse/query-executor.d.ts +163 -0
- package/dist/olap/clickhouse/query-executor.d.ts.map +1 -0
- package/dist/olap/clickhouse/query-executor.js +560 -0
- package/dist/olap/clickhouse/query-executor.js.map +1 -0
- package/dist/olap/clickhouse/query.d.ts +134 -0
- package/dist/olap/clickhouse/query.d.ts.map +1 -0
- package/dist/olap/clickhouse/query.js +512 -0
- package/dist/olap/clickhouse/query.js.map +1 -0
- package/dist/olap/stage/index.d.ts +6 -0
- package/dist/olap/stage/index.d.ts.map +1 -0
- package/dist/olap/stage/index.js +6 -0
- package/dist/olap/stage/index.js.map +1 -0
- package/dist/olap/stage/parser.d.ts +68 -0
- package/dist/olap/stage/parser.d.ts.map +1 -0
- package/dist/olap/stage/parser.js +293 -0
- package/dist/olap/stage/parser.js.map +1 -0
- package/dist/olap/stage/router.d.ts +94 -0
- package/dist/olap/stage/router.d.ts.map +1 -0
- package/dist/olap/stage/router.js +390 -0
- package/dist/olap/stage/router.js.map +1 -0
- package/dist/rpc/endpoint.d.ts +52 -0
- package/dist/rpc/endpoint.d.ts.map +1 -0
- package/dist/rpc/endpoint.js +734 -0
- package/dist/rpc/endpoint.js.map +1 -0
- package/dist/rpc/index.d.ts +34 -0
- package/dist/rpc/index.d.ts.map +1 -0
- package/dist/rpc/index.js +45 -0
- package/dist/rpc/index.js.map +1 -0
- package/dist/rpc/rpc-client.d.ts +275 -0
- package/dist/rpc/rpc-client.d.ts.map +1 -0
- package/dist/rpc/rpc-client.js +735 -0
- package/dist/rpc/rpc-client.js.map +1 -0
- package/dist/rpc/rpc-target.d.ts +220 -0
- package/dist/rpc/rpc-target.d.ts.map +1 -0
- package/dist/rpc/rpc-target.js +500 -0
- package/dist/rpc/rpc-target.js.map +1 -0
- package/dist/rpc/worker-entrypoint.d.ts +159 -0
- package/dist/rpc/worker-entrypoint.d.ts.map +1 -0
- package/dist/rpc/worker-entrypoint.js +212 -0
- package/dist/rpc/worker-entrypoint.js.map +1 -0
- package/dist/server.d.ts +18 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +129 -0
- package/dist/server.js.map +1 -0
- package/dist/studio/components/browser/CollectionItem.d.ts +26 -0
- package/dist/studio/components/browser/CollectionItem.d.ts.map +1 -0
- package/dist/studio/components/browser/CollectionItem.js +143 -0
- package/dist/studio/components/browser/CollectionItem.js.map +1 -0
- package/dist/studio/components/browser/CollectionTree.d.ts +45 -0
- package/dist/studio/components/browser/CollectionTree.d.ts.map +1 -0
- package/dist/studio/components/browser/CollectionTree.js +207 -0
- package/dist/studio/components/browser/CollectionTree.js.map +1 -0
- package/dist/studio/components/browser/ConnectedDatabaseBrowser.d.ts +51 -0
- package/dist/studio/components/browser/ConnectedDatabaseBrowser.d.ts.map +1 -0
- package/dist/studio/components/browser/ConnectedDatabaseBrowser.js +185 -0
- package/dist/studio/components/browser/ConnectedDatabaseBrowser.js.map +1 -0
- package/dist/studio/components/browser/DatabaseBrowser.d.ts +46 -0
- package/dist/studio/components/browser/DatabaseBrowser.d.ts.map +1 -0
- package/dist/studio/components/browser/DatabaseBrowser.js +304 -0
- package/dist/studio/components/browser/DatabaseBrowser.js.map +1 -0
- package/dist/studio/components/browser/__tests__/CollectionItem.test.d.ts +5 -0
- package/dist/studio/components/browser/__tests__/CollectionItem.test.d.ts.map +1 -0
- package/dist/studio/components/browser/__tests__/CollectionItem.test.js +169 -0
- package/dist/studio/components/browser/__tests__/CollectionItem.test.js.map +1 -0
- package/dist/studio/components/browser/__tests__/CollectionTree.test.d.ts +5 -0
- package/dist/studio/components/browser/__tests__/CollectionTree.test.d.ts.map +1 -0
- package/dist/studio/components/browser/__tests__/CollectionTree.test.js +203 -0
- package/dist/studio/components/browser/__tests__/CollectionTree.test.js.map +1 -0
- package/dist/studio/components/browser/__tests__/DatabaseBrowser.e2e.test.d.ts +8 -0
- package/dist/studio/components/browser/__tests__/DatabaseBrowser.e2e.test.d.ts.map +1 -0
- package/dist/studio/components/browser/__tests__/DatabaseBrowser.e2e.test.js +522 -0
- package/dist/studio/components/browser/__tests__/DatabaseBrowser.e2e.test.js.map +1 -0
- package/dist/studio/components/browser/__tests__/DatabaseBrowser.test.d.ts +5 -0
- package/dist/studio/components/browser/__tests__/DatabaseBrowser.test.d.ts.map +1 -0
- package/dist/studio/components/browser/__tests__/DatabaseBrowser.test.js +518 -0
- package/dist/studio/components/browser/__tests__/DatabaseBrowser.test.js.map +1 -0
- package/dist/studio/components/browser/__tests__/setup.d.ts +5 -0
- package/dist/studio/components/browser/__tests__/setup.d.ts.map +1 -0
- package/dist/studio/components/browser/__tests__/setup.js +22 -0
- package/dist/studio/components/browser/__tests__/setup.js.map +1 -0
- package/dist/studio/components/browser/index.d.ts +15 -0
- package/dist/studio/components/browser/index.d.ts.map +1 -0
- package/dist/studio/components/browser/index.js +10 -0
- package/dist/studio/components/browser/index.js.map +1 -0
- package/dist/studio/components/browser/types.d.ts +33 -0
- package/dist/studio/components/browser/types.d.ts.map +1 -0
- package/dist/studio/components/browser/types.js +5 -0
- package/dist/studio/components/browser/types.js.map +1 -0
- package/dist/studio/components/connection/ConnectionForm.d.ts +59 -0
- package/dist/studio/components/connection/ConnectionForm.d.ts.map +1 -0
- package/dist/studio/components/connection/ConnectionForm.js +274 -0
- package/dist/studio/components/connection/ConnectionForm.js.map +1 -0
- package/dist/studio/components/connection/ConnectionList.d.ts +59 -0
- package/dist/studio/components/connection/ConnectionList.d.ts.map +1 -0
- package/dist/studio/components/connection/ConnectionList.js +286 -0
- package/dist/studio/components/connection/ConnectionList.js.map +1 -0
- package/dist/studio/components/connection/ConnectionPanel.d.ts +132 -0
- package/dist/studio/components/connection/ConnectionPanel.d.ts.map +1 -0
- package/dist/studio/components/connection/ConnectionPanel.js +293 -0
- package/dist/studio/components/connection/ConnectionPanel.js.map +1 -0
- package/dist/studio/components/connection/__tests__/ConnectionPanel.test.d.ts +8 -0
- package/dist/studio/components/connection/__tests__/ConnectionPanel.test.d.ts.map +1 -0
- package/dist/studio/components/connection/__tests__/ConnectionPanel.test.js +632 -0
- package/dist/studio/components/connection/__tests__/ConnectionPanel.test.js.map +1 -0
- package/dist/studio/components/connection/__tests__/setup.d.ts +5 -0
- package/dist/studio/components/connection/__tests__/setup.d.ts.map +1 -0
- package/dist/studio/components/connection/__tests__/setup.js +11 -0
- package/dist/studio/components/connection/__tests__/setup.js.map +1 -0
- package/dist/studio/components/connection/index.d.ts +10 -0
- package/dist/studio/components/connection/index.d.ts.map +1 -0
- package/dist/studio/components/connection/index.js +7 -0
- package/dist/studio/components/connection/index.js.map +1 -0
- package/dist/studio/components/crud/DeleteDocumentDialog.d.ts +91 -0
- package/dist/studio/components/crud/DeleteDocumentDialog.d.ts.map +1 -0
- package/dist/studio/components/crud/DeleteDocumentDialog.js +273 -0
- package/dist/studio/components/crud/DeleteDocumentDialog.js.map +1 -0
- package/dist/studio/components/crud/DocumentEditor.d.ts +32 -0
- package/dist/studio/components/crud/DocumentEditor.d.ts.map +1 -0
- package/dist/studio/components/crud/DocumentEditor.js +546 -0
- package/dist/studio/components/crud/DocumentEditor.js.map +1 -0
- package/dist/studio/components/crud/InsertDocumentDialog.d.ts +78 -0
- package/dist/studio/components/crud/InsertDocumentDialog.d.ts.map +1 -0
- package/dist/studio/components/crud/InsertDocumentDialog.js +323 -0
- package/dist/studio/components/crud/InsertDocumentDialog.js.map +1 -0
- package/dist/studio/components/crud/__tests__/DeleteDocumentDialog.test.d.ts +5 -0
- package/dist/studio/components/crud/__tests__/DeleteDocumentDialog.test.d.ts.map +1 -0
- package/dist/studio/components/crud/__tests__/DeleteDocumentDialog.test.js +298 -0
- package/dist/studio/components/crud/__tests__/DeleteDocumentDialog.test.js.map +1 -0
- package/dist/studio/components/crud/__tests__/DocumentEditor.test.d.ts +8 -0
- package/dist/studio/components/crud/__tests__/DocumentEditor.test.d.ts.map +1 -0
- package/dist/studio/components/crud/__tests__/DocumentEditor.test.js +368 -0
- package/dist/studio/components/crud/__tests__/DocumentEditor.test.js.map +1 -0
- package/dist/studio/components/crud/__tests__/InsertDocumentDialog.test.d.ts +2 -0
- package/dist/studio/components/crud/__tests__/InsertDocumentDialog.test.d.ts.map +1 -0
- package/dist/studio/components/crud/__tests__/InsertDocumentDialog.test.js +352 -0
- package/dist/studio/components/crud/__tests__/InsertDocumentDialog.test.js.map +1 -0
- package/dist/studio/components/crud/__tests__/setup.d.ts +5 -0
- package/dist/studio/components/crud/__tests__/setup.d.ts.map +1 -0
- package/dist/studio/components/crud/__tests__/setup.js +22 -0
- package/dist/studio/components/crud/__tests__/setup.js.map +1 -0
- package/dist/studio/components/crud/index.d.ts +12 -0
- package/dist/studio/components/crud/index.d.ts.map +1 -0
- package/dist/studio/components/crud/index.js +11 -0
- package/dist/studio/components/crud/index.js.map +1 -0
- package/dist/studio/hooks/useConnection.d.ts +127 -0
- package/dist/studio/hooks/useConnection.d.ts.map +1 -0
- package/dist/studio/hooks/useConnection.js +414 -0
- package/dist/studio/hooks/useConnection.js.map +1 -0
- package/dist/studio/hooks/useDatabaseBrowser.d.ts +107 -0
- package/dist/studio/hooks/useDatabaseBrowser.d.ts.map +1 -0
- package/dist/studio/hooks/useDatabaseBrowser.js +294 -0
- package/dist/studio/hooks/useDatabaseBrowser.js.map +1 -0
- package/dist/studio/index.d.ts +16 -0
- package/dist/studio/index.d.ts.map +1 -0
- package/dist/studio/index.js +14 -0
- package/dist/studio/index.js.map +1 -0
- package/dist/studio/types/connection.d.ts +266 -0
- package/dist/studio/types/connection.d.ts.map +1 -0
- package/dist/studio/types/connection.js +159 -0
- package/dist/studio/types/connection.js.map +1 -0
- package/dist/studio/vitest.config.d.ts +3 -0
- package/dist/studio/vitest.config.d.ts.map +1 -0
- package/dist/studio/vitest.config.js +33 -0
- package/dist/studio/vitest.config.js.map +1 -0
- package/dist/translator/aggregation-translator.d.ts +51 -0
- package/dist/translator/aggregation-translator.d.ts.map +1 -0
- package/dist/translator/aggregation-translator.js +324 -0
- package/dist/translator/aggregation-translator.js.map +1 -0
- package/dist/translator/dialect.d.ts +131 -0
- package/dist/translator/dialect.d.ts.map +1 -0
- package/dist/translator/dialect.js +276 -0
- package/dist/translator/dialect.js.map +1 -0
- package/dist/translator/geo-translator.d.ts +91 -0
- package/dist/translator/geo-translator.d.ts.map +1 -0
- package/dist/translator/geo-translator.js +587 -0
- package/dist/translator/geo-translator.js.map +1 -0
- package/dist/translator/hybrid-translator.d.ts +70 -0
- package/dist/translator/hybrid-translator.d.ts.map +1 -0
- package/dist/translator/hybrid-translator.js +193 -0
- package/dist/translator/hybrid-translator.js.map +1 -0
- package/dist/translator/index.d.ts +13 -0
- package/dist/translator/index.d.ts.map +1 -0
- package/dist/translator/index.js +11 -0
- package/dist/translator/index.js.map +1 -0
- package/dist/translator/query-translator.d.ts +211 -0
- package/dist/translator/query-translator.d.ts.map +1 -0
- package/dist/translator/query-translator.js +1276 -0
- package/dist/translator/query-translator.js.map +1 -0
- package/dist/translator/search-highlight.d.ts +83 -0
- package/dist/translator/search-highlight.d.ts.map +1 -0
- package/dist/translator/search-highlight.js +83 -0
- package/dist/translator/search-highlight.js.map +1 -0
- package/dist/translator/search-translator.d.ts +155 -0
- package/dist/translator/search-translator.d.ts.map +1 -0
- package/dist/translator/search-translator.js +241 -0
- package/dist/translator/search-translator.js.map +1 -0
- package/dist/translator/stages/add-fields-stage.d.ts +7 -0
- package/dist/translator/stages/add-fields-stage.d.ts.map +1 -0
- package/dist/translator/stages/add-fields-stage.js +72 -0
- package/dist/translator/stages/add-fields-stage.js.map +1 -0
- package/dist/translator/stages/bucket-stage.d.ts +7 -0
- package/dist/translator/stages/bucket-stage.d.ts.map +1 -0
- package/dist/translator/stages/bucket-stage.js +87 -0
- package/dist/translator/stages/bucket-stage.js.map +1 -0
- package/dist/translator/stages/count-stage.d.ts +7 -0
- package/dist/translator/stages/count-stage.d.ts.map +1 -0
- package/dist/translator/stages/count-stage.js +12 -0
- package/dist/translator/stages/count-stage.js.map +1 -0
- package/dist/translator/stages/expression-translator.d.ts +68 -0
- package/dist/translator/stages/expression-translator.d.ts.map +1 -0
- package/dist/translator/stages/expression-translator.js +467 -0
- package/dist/translator/stages/expression-translator.js.map +1 -0
- package/dist/translator/stages/facet-stage.d.ts +13 -0
- package/dist/translator/stages/facet-stage.d.ts.map +1 -0
- package/dist/translator/stages/facet-stage.js +26 -0
- package/dist/translator/stages/facet-stage.js.map +1 -0
- package/dist/translator/stages/fusion-stages.d.ts +118 -0
- package/dist/translator/stages/fusion-stages.d.ts.map +1 -0
- package/dist/translator/stages/fusion-stages.js +201 -0
- package/dist/translator/stages/fusion-stages.js.map +1 -0
- package/dist/translator/stages/group-stage.d.ts +8 -0
- package/dist/translator/stages/group-stage.d.ts.map +1 -0
- package/dist/translator/stages/group-stage.js +123 -0
- package/dist/translator/stages/group-stage.js.map +1 -0
- package/dist/translator/stages/index.d.ts +24 -0
- package/dist/translator/stages/index.d.ts.map +1 -0
- package/dist/translator/stages/index.js +24 -0
- package/dist/translator/stages/index.js.map +1 -0
- package/dist/translator/stages/join-optimizer.d.ts +37 -0
- package/dist/translator/stages/join-optimizer.d.ts.map +1 -0
- package/dist/translator/stages/join-optimizer.js +93 -0
- package/dist/translator/stages/join-optimizer.js.map +1 -0
- package/dist/translator/stages/limit-stage.d.ts +7 -0
- package/dist/translator/stages/limit-stage.d.ts.map +1 -0
- package/dist/translator/stages/limit-stage.js +11 -0
- package/dist/translator/stages/limit-stage.js.map +1 -0
- package/dist/translator/stages/lookup-stage.d.ts +7 -0
- package/dist/translator/stages/lookup-stage.d.ts.map +1 -0
- package/dist/translator/stages/lookup-stage.js +73 -0
- package/dist/translator/stages/lookup-stage.js.map +1 -0
- package/dist/translator/stages/match-stage.d.ts +7 -0
- package/dist/translator/stages/match-stage.d.ts.map +1 -0
- package/dist/translator/stages/match-stage.js +14 -0
- package/dist/translator/stages/match-stage.js.map +1 -0
- package/dist/translator/stages/optimizer.d.ts +15 -0
- package/dist/translator/stages/optimizer.d.ts.map +1 -0
- package/dist/translator/stages/optimizer.js +249 -0
- package/dist/translator/stages/optimizer.js.map +1 -0
- package/dist/translator/stages/parallel-facet.d.ts +47 -0
- package/dist/translator/stages/parallel-facet.d.ts.map +1 -0
- package/dist/translator/stages/parallel-facet.js +57 -0
- package/dist/translator/stages/parallel-facet.js.map +1 -0
- package/dist/translator/stages/project-stage.d.ts +8 -0
- package/dist/translator/stages/project-stage.d.ts.map +1 -0
- package/dist/translator/stages/project-stage.js +145 -0
- package/dist/translator/stages/project-stage.js.map +1 -0
- package/dist/translator/stages/search-stage.d.ts +60 -0
- package/dist/translator/stages/search-stage.d.ts.map +1 -0
- package/dist/translator/stages/search-stage.js +89 -0
- package/dist/translator/stages/search-stage.js.map +1 -0
- package/dist/translator/stages/skip-stage.d.ts +7 -0
- package/dist/translator/stages/skip-stage.d.ts.map +1 -0
- package/dist/translator/stages/skip-stage.js +11 -0
- package/dist/translator/stages/skip-stage.js.map +1 -0
- package/dist/translator/stages/sort-stage.d.ts +7 -0
- package/dist/translator/stages/sort-stage.d.ts.map +1 -0
- package/dist/translator/stages/sort-stage.js +21 -0
- package/dist/translator/stages/sort-stage.js.map +1 -0
- package/dist/translator/stages/types.d.ts +136 -0
- package/dist/translator/stages/types.d.ts.map +1 -0
- package/dist/translator/stages/types.js +5 -0
- package/dist/translator/stages/types.js.map +1 -0
- package/dist/translator/stages/unwind-stage.d.ts +7 -0
- package/dist/translator/stages/unwind-stage.d.ts.map +1 -0
- package/dist/translator/stages/unwind-stage.js +61 -0
- package/dist/translator/stages/unwind-stage.js.map +1 -0
- package/dist/translator/stages/vector-search-stage.d.ts +53 -0
- package/dist/translator/stages/vector-search-stage.d.ts.map +1 -0
- package/dist/translator/stages/vector-search-stage.js +62 -0
- package/dist/translator/stages/vector-search-stage.js.map +1 -0
- package/dist/translator/update-translator.d.ts +148 -0
- package/dist/translator/update-translator.d.ts.map +1 -0
- package/dist/translator/update-translator.js +819 -0
- package/dist/translator/update-translator.js.map +1 -0
- package/dist/translator/vector-translator.d.ts +89 -0
- package/dist/translator/vector-translator.d.ts.map +1 -0
- package/dist/translator/vector-translator.js +106 -0
- package/dist/translator/vector-translator.js.map +1 -0
- package/dist/types/env.d.ts +31 -0
- package/dist/types/env.d.ts.map +1 -0
- package/dist/types/env.js +5 -0
- package/dist/types/env.js.map +1 -0
- package/dist/types/function.d.ts +65 -0
- package/dist/types/function.d.ts.map +1 -0
- package/dist/types/function.js +5 -0
- package/dist/types/function.js.map +1 -0
- package/dist/types/index.d.ts +137 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +13 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/mongodb.d.ts +258 -0
- package/dist/types/mongodb.d.ts.map +1 -0
- package/dist/types/mongodb.js +5 -0
- package/dist/types/mongodb.js.map +1 -0
- package/dist/types/objectid.d.ts +130 -0
- package/dist/types/objectid.d.ts.map +1 -0
- package/dist/types/objectid.js +314 -0
- package/dist/types/objectid.js.map +1 -0
- package/dist/types/rpc.d.ts +313 -0
- package/dist/types/rpc.d.ts.map +1 -0
- package/dist/types/rpc.js +136 -0
- package/dist/types/rpc.js.map +1 -0
- package/dist/types/vectorize.d.ts +136 -0
- package/dist/types/vectorize.d.ts.map +1 -0
- package/dist/types/vectorize.js +8 -0
- package/dist/types/vectorize.js.map +1 -0
- package/dist/utils/sql-safety.d.ts +64 -0
- package/dist/utils/sql-safety.d.ts.map +1 -0
- package/dist/utils/sql-safety.js +112 -0
- package/dist/utils/sql-safety.js.map +1 -0
- package/dist/validation/document-validator.d.ts +195 -0
- package/dist/validation/document-validator.d.ts.map +1 -0
- package/dist/validation/document-validator.js +529 -0
- package/dist/validation/document-validator.js.map +1 -0
- package/dist/vectorize/document-serializer.d.ts +119 -0
- package/dist/vectorize/document-serializer.d.ts.map +1 -0
- package/dist/vectorize/document-serializer.js +320 -0
- package/dist/vectorize/document-serializer.js.map +1 -0
- package/dist/wire/auth/index.d.ts +5 -0
- package/dist/wire/auth/index.d.ts.map +1 -0
- package/dist/wire/auth/index.js +5 -0
- package/dist/wire/auth/index.js.map +1 -0
- package/dist/wire/auth/scram.d.ts +160 -0
- package/dist/wire/auth/scram.d.ts.map +1 -0
- package/dist/wire/auth/scram.js +425 -0
- package/dist/wire/auth/scram.js.map +1 -0
- package/dist/wire/backend/interface.d.ts +168 -0
- package/dist/wire/backend/interface.d.ts.map +1 -0
- package/dist/wire/backend/interface.js +10 -0
- package/dist/wire/backend/interface.js.map +1 -0
- package/dist/wire/backend/local-sqlite.d.ts +89 -0
- package/dist/wire/backend/local-sqlite.d.ts.map +1 -0
- package/dist/wire/backend/local-sqlite.js +1002 -0
- package/dist/wire/backend/local-sqlite.js.map +1 -0
- package/dist/wire/backend/query-router.d.ts +197 -0
- package/dist/wire/backend/query-router.d.ts.map +1 -0
- package/dist/wire/backend/query-router.js +590 -0
- package/dist/wire/backend/query-router.js.map +1 -0
- package/dist/wire/backend/validation.d.ts +26 -0
- package/dist/wire/backend/validation.d.ts.map +1 -0
- package/dist/wire/backend/validation.js +79 -0
- package/dist/wire/backend/validation.js.map +1 -0
- package/dist/wire/backend/workers-proxy.d.ts +95 -0
- package/dist/wire/backend/workers-proxy.d.ts.map +1 -0
- package/dist/wire/backend/workers-proxy.js +429 -0
- package/dist/wire/backend/workers-proxy.js.map +1 -0
- package/dist/wire/commands/admin.d.ts +49 -0
- package/dist/wire/commands/admin.d.ts.map +1 -0
- package/dist/wire/commands/admin.js +272 -0
- package/dist/wire/commands/admin.js.map +1 -0
- package/dist/wire/commands/aggregate.d.ts +15 -0
- package/dist/wire/commands/aggregate.d.ts.map +1 -0
- package/dist/wire/commands/aggregate.js +98 -0
- package/dist/wire/commands/aggregate.js.map +1 -0
- package/dist/wire/commands/auth.d.ts +58 -0
- package/dist/wire/commands/auth.d.ts.map +1 -0
- package/dist/wire/commands/auth.js +158 -0
- package/dist/wire/commands/auth.js.map +1 -0
- package/dist/wire/commands/crud.d.ts +49 -0
- package/dist/wire/commands/crud.d.ts.map +1 -0
- package/dist/wire/commands/crud.js +336 -0
- package/dist/wire/commands/crud.js.map +1 -0
- package/dist/wire/commands/hello.d.ts +35 -0
- package/dist/wire/commands/hello.d.ts.map +1 -0
- package/dist/wire/commands/hello.js +204 -0
- package/dist/wire/commands/hello.js.map +1 -0
- package/dist/wire/commands/index.d.ts +24 -0
- package/dist/wire/commands/index.d.ts.map +1 -0
- package/dist/wire/commands/index.js +145 -0
- package/dist/wire/commands/index.js.map +1 -0
- package/dist/wire/commands/router.d.ts +46 -0
- package/dist/wire/commands/router.d.ts.map +1 -0
- package/dist/wire/commands/router.js +151 -0
- package/dist/wire/commands/router.js.map +1 -0
- package/dist/wire/commands/types.d.ts +51 -0
- package/dist/wire/commands/types.d.ts.map +1 -0
- package/dist/wire/commands/types.js +15 -0
- package/dist/wire/commands/types.js.map +1 -0
- package/dist/wire/index.d.ts +15 -0
- package/dist/wire/index.d.ts.map +1 -0
- package/dist/wire/index.js +19 -0
- package/dist/wire/index.js.map +1 -0
- package/dist/wire/message.d.ts +49 -0
- package/dist/wire/message.d.ts.map +1 -0
- package/dist/wire/message.js +299 -0
- package/dist/wire/message.js.map +1 -0
- package/dist/wire/server.d.ts +145 -0
- package/dist/wire/server.d.ts.map +1 -0
- package/dist/wire/server.js +284 -0
- package/dist/wire/server.js.map +1 -0
- package/dist/wire/types.d.ts +140 -0
- package/dist/wire/types.d.ts.map +1 -0
- package/dist/wire/types.js +64 -0
- package/dist/wire/types.js.map +1 -0
- package/dist/worker.d.ts +17 -0
- package/dist/worker.d.ts.map +1 -0
- package/dist/worker.js +22 -0
- package/dist/worker.js.map +1 -0
- package/package.json +82 -0
|
@@ -0,0 +1,241 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SearchTranslator - Translates MongoDB Atlas Search syntax to SQLite FTS5 MATCH syntax
|
|
3
|
+
*
|
|
4
|
+
* MongoDB Atlas Search operators:
|
|
5
|
+
* - text: Full-text search on specified path(s)
|
|
6
|
+
* - phrase: Exact phrase search
|
|
7
|
+
* - wildcard: Wildcard pattern matching
|
|
8
|
+
* - compound: Boolean combinations (must, should, mustNot, filter)
|
|
9
|
+
*
|
|
10
|
+
* FTS5 MATCH syntax:
|
|
11
|
+
* - term: Simple word match
|
|
12
|
+
* - "phrase": Exact phrase match
|
|
13
|
+
* - prefix*: Prefix matching
|
|
14
|
+
* - term1 AND term2: Both must match
|
|
15
|
+
* - term1 OR term2: Either must match
|
|
16
|
+
* - NOT term: Exclude term
|
|
17
|
+
* - column:term: Match in specific column
|
|
18
|
+
*/
|
|
19
|
+
/**
|
|
20
|
+
* SearchTranslator converts MongoDB Atlas Search syntax to SQLite FTS5 MATCH syntax
|
|
21
|
+
*/
|
|
22
|
+
export class SearchTranslator {
|
|
23
|
+
/**
|
|
24
|
+
* Translate a MongoDB $search operator to FTS5 MATCH expression
|
|
25
|
+
*
|
|
26
|
+
* @param search The MongoDB $search operator value
|
|
27
|
+
* @param collection The collection name (used for FTS table naming)
|
|
28
|
+
* @returns SearchResult with FTS5 MATCH expression
|
|
29
|
+
*/
|
|
30
|
+
translateSearch(search, collection) {
|
|
31
|
+
const params = [];
|
|
32
|
+
const ftsMatch = this.translateOperator(search);
|
|
33
|
+
return {
|
|
34
|
+
ftsMatch,
|
|
35
|
+
params,
|
|
36
|
+
ftsTable: `${collection}_fts`,
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Translate a single search operator to FTS5 syntax
|
|
41
|
+
*/
|
|
42
|
+
translateOperator(operator) {
|
|
43
|
+
if (operator.text) {
|
|
44
|
+
return this.translateText(operator.text);
|
|
45
|
+
}
|
|
46
|
+
if (operator.phrase) {
|
|
47
|
+
return this.translatePhrase(operator.phrase);
|
|
48
|
+
}
|
|
49
|
+
if (operator.wildcard) {
|
|
50
|
+
return this.translateWildcard(operator.wildcard);
|
|
51
|
+
}
|
|
52
|
+
if (operator.compound) {
|
|
53
|
+
return this.translateCompound(operator.compound);
|
|
54
|
+
}
|
|
55
|
+
if (operator.autocomplete) {
|
|
56
|
+
return this.translateAutocomplete(operator.autocomplete);
|
|
57
|
+
}
|
|
58
|
+
return '*'; // Match all if no operator specified
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Translate text operator to FTS5 terms
|
|
62
|
+
*
|
|
63
|
+
* MongoDB: { text: { query: "hello world", path: "content" } }
|
|
64
|
+
* FTS5: content:hello content:world
|
|
65
|
+
*/
|
|
66
|
+
translateText(text) {
|
|
67
|
+
const { query, path } = text;
|
|
68
|
+
// Split query into terms and escape each term to prevent FTS5 injection
|
|
69
|
+
const terms = query.trim().split(/\s+/).filter(t => t.length > 0).map(t => this.escapeFTS5Term(t));
|
|
70
|
+
if (terms.length === 0) {
|
|
71
|
+
return '*';
|
|
72
|
+
}
|
|
73
|
+
// If path is specified, prefix each term with the column
|
|
74
|
+
if (path) {
|
|
75
|
+
const column = Array.isArray(path) ? path[0] : path;
|
|
76
|
+
return terms.map(term => `${column}:${term}`).join(' ');
|
|
77
|
+
}
|
|
78
|
+
// No path specified - search all fields
|
|
79
|
+
return terms.join(' ');
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Translate phrase operator to FTS5 quoted phrase
|
|
83
|
+
*
|
|
84
|
+
* MongoDB: { phrase: { query: "hello world", path: "title" } }
|
|
85
|
+
* FTS5: title:"hello world"
|
|
86
|
+
*/
|
|
87
|
+
translatePhrase(phrase) {
|
|
88
|
+
const { query, path } = phrase;
|
|
89
|
+
// Escape the phrase content to prevent FTS5 injection
|
|
90
|
+
// For phrases, we escape and then wrap in quotes
|
|
91
|
+
const escapedPhrase = this.escapeFTS5Term(query);
|
|
92
|
+
const quotedPhrase = `"${escapedPhrase}"`;
|
|
93
|
+
if (path) {
|
|
94
|
+
const column = Array.isArray(path) ? path[0] : path;
|
|
95
|
+
return `${column}:${quotedPhrase}`;
|
|
96
|
+
}
|
|
97
|
+
return quotedPhrase;
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Translate wildcard operator to FTS5 prefix matching
|
|
101
|
+
*
|
|
102
|
+
* MongoDB: { wildcard: { query: "data*", path: "content" } }
|
|
103
|
+
* FTS5: content:data*
|
|
104
|
+
*/
|
|
105
|
+
translateWildcard(wildcard) {
|
|
106
|
+
const { query, path } = wildcard;
|
|
107
|
+
// For wildcard queries, we need to escape special chars but preserve the wildcard (*) at the end
|
|
108
|
+
// First check if query ends with wildcard
|
|
109
|
+
const hasTrailingWildcard = query.endsWith('*');
|
|
110
|
+
const baseQuery = hasTrailingWildcard ? query.slice(0, -1) : query;
|
|
111
|
+
const escapedQuery = this.escapeFTS5Term(baseQuery) + (hasTrailingWildcard ? '*' : '');
|
|
112
|
+
if (path) {
|
|
113
|
+
const column = Array.isArray(path) ? path[0] : path;
|
|
114
|
+
return `${column}:${escapedQuery}`;
|
|
115
|
+
}
|
|
116
|
+
return escapedQuery;
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* Translate autocomplete operator to FTS5 prefix query
|
|
120
|
+
*
|
|
121
|
+
* MongoDB: { autocomplete: { query: "mach", path: "title" } }
|
|
122
|
+
* FTS5: title:mach*
|
|
123
|
+
*
|
|
124
|
+
* Autocomplete uses prefix matching (term*) to find partial word matches.
|
|
125
|
+
* When tokenOrder is 'sequential', terms must appear in order.
|
|
126
|
+
*/
|
|
127
|
+
translateAutocomplete(autocomplete) {
|
|
128
|
+
const { query, path, tokenOrder } = autocomplete;
|
|
129
|
+
// Split query into terms and escape each term to prevent FTS5 injection
|
|
130
|
+
const terms = query.trim().split(/\s+/).filter(t => t.length > 0).map(t => this.escapeFTS5Term(t));
|
|
131
|
+
if (terms.length === 0) {
|
|
132
|
+
return '*';
|
|
133
|
+
}
|
|
134
|
+
// Add prefix wildcard to each term for autocomplete
|
|
135
|
+
const prefixTerms = terms.map(term => `${term}*`);
|
|
136
|
+
// If path is specified, prefix each term with the column
|
|
137
|
+
if (path) {
|
|
138
|
+
const column = Array.isArray(path) ? path[0] : path;
|
|
139
|
+
if (tokenOrder === 'sequential' && prefixTerms.length > 1) {
|
|
140
|
+
// For sequential, terms must appear in order - use phrase-like matching
|
|
141
|
+
// FTS5 doesn't support prefix in phrases, so we use NEAR/0 for adjacent terms
|
|
142
|
+
// But for simplicity, we join with spaces which requires all terms
|
|
143
|
+
return prefixTerms.map(term => `${column}:${term}`).join(' ');
|
|
144
|
+
}
|
|
145
|
+
return prefixTerms.map(term => `${column}:${term}`).join(' ');
|
|
146
|
+
}
|
|
147
|
+
// No path specified - search all fields
|
|
148
|
+
if (tokenOrder === 'sequential' && prefixTerms.length > 1) {
|
|
149
|
+
return prefixTerms.join(' ');
|
|
150
|
+
}
|
|
151
|
+
return prefixTerms.join(' ');
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* Translate compound operator to FTS5 boolean expression
|
|
155
|
+
*
|
|
156
|
+
* MongoDB compound operators:
|
|
157
|
+
* - must: All clauses must match (AND)
|
|
158
|
+
* - should: At least one should match (OR)
|
|
159
|
+
* - mustNot: None should match (NOT)
|
|
160
|
+
* - filter: Same as must but without scoring
|
|
161
|
+
*/
|
|
162
|
+
translateCompound(compound) {
|
|
163
|
+
const parts = [];
|
|
164
|
+
// Process 'must' clauses (AND)
|
|
165
|
+
if (compound.must && compound.must.length > 0) {
|
|
166
|
+
const mustClauses = compound.must.map(op => this.translateOperator(op));
|
|
167
|
+
if (mustClauses.length === 1) {
|
|
168
|
+
parts.push(mustClauses[0]);
|
|
169
|
+
}
|
|
170
|
+
else {
|
|
171
|
+
parts.push(`(${mustClauses.join(' AND ')})`);
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
// Process 'filter' clauses (same as must)
|
|
175
|
+
if (compound.filter && compound.filter.length > 0) {
|
|
176
|
+
const filterClauses = compound.filter.map(op => this.translateOperator(op));
|
|
177
|
+
if (filterClauses.length === 1) {
|
|
178
|
+
parts.push(filterClauses[0]);
|
|
179
|
+
}
|
|
180
|
+
else {
|
|
181
|
+
parts.push(`(${filterClauses.join(' AND ')})`);
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
// Process 'should' clauses (OR)
|
|
185
|
+
if (compound.should && compound.should.length > 0) {
|
|
186
|
+
const shouldClauses = compound.should.map(op => this.translateOperator(op));
|
|
187
|
+
if (shouldClauses.length === 1) {
|
|
188
|
+
parts.push(shouldClauses[0]);
|
|
189
|
+
}
|
|
190
|
+
else {
|
|
191
|
+
parts.push(`(${shouldClauses.join(' OR ')})`);
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
// Process 'mustNot' clauses (NOT)
|
|
195
|
+
if (compound.mustNot && compound.mustNot.length > 0) {
|
|
196
|
+
const mustNotClauses = compound.mustNot.map(op => `NOT ${this.translateOperator(op)}`);
|
|
197
|
+
parts.push(...mustNotClauses);
|
|
198
|
+
}
|
|
199
|
+
if (parts.length === 0) {
|
|
200
|
+
return '*';
|
|
201
|
+
}
|
|
202
|
+
if (parts.length === 1) {
|
|
203
|
+
return parts[0];
|
|
204
|
+
}
|
|
205
|
+
// Join all parts with AND
|
|
206
|
+
return parts.join(' AND ');
|
|
207
|
+
}
|
|
208
|
+
/**
|
|
209
|
+
* Escape special FTS5 characters in a term
|
|
210
|
+
*/
|
|
211
|
+
escapeFTS5Term(term) {
|
|
212
|
+
// FTS5 special characters that need escaping
|
|
213
|
+
return term.replace(/[&|()^~*:"]/g, char => `\\${char}`);
|
|
214
|
+
}
|
|
215
|
+
/**
|
|
216
|
+
* Build the complete SQL query for a $search aggregation stage
|
|
217
|
+
*
|
|
218
|
+
* @param search The MongoDB $search operator
|
|
219
|
+
* @param collection The collection name
|
|
220
|
+
* @param documentsTable The documents table name (default: 'documents')
|
|
221
|
+
* @returns Complete SQL query with FTS5 join
|
|
222
|
+
*/
|
|
223
|
+
buildSearchSQL(search, collection, documentsTable = 'documents') {
|
|
224
|
+
const result = this.translateSearch(search, collection);
|
|
225
|
+
const ftsTable = result.ftsTable || `${collection}_fts`;
|
|
226
|
+
// Build SQL with FTS5 join
|
|
227
|
+
// FTS5 uses rowid for joining with the content table
|
|
228
|
+
const sql = `
|
|
229
|
+
SELECT ${documentsTable}.*, -bm25(${ftsTable}) AS _searchScore
|
|
230
|
+
FROM ${documentsTable}
|
|
231
|
+
JOIN ${ftsTable} ON ${documentsTable}.id = ${ftsTable}.rowid
|
|
232
|
+
WHERE ${ftsTable} MATCH ?
|
|
233
|
+
ORDER BY _searchScore DESC
|
|
234
|
+
`.trim();
|
|
235
|
+
return {
|
|
236
|
+
sql,
|
|
237
|
+
params: [result.ftsMatch],
|
|
238
|
+
};
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
//# sourceMappingURL=search-translator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"search-translator.js","sourceRoot":"","sources":["../../src/translator/search-translator.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* $addFields stage - Adds new fields to documents
|
|
3
|
+
* Translates to SQL using json_set (SQLite) or tuple functions (ClickHouse)
|
|
4
|
+
*/
|
|
5
|
+
import type { StageResult, StageContext } from './types';
|
|
6
|
+
export declare function translateAddFieldsStage(addFields: Record<string, unknown>, context: StageContext): StageResult;
|
|
7
|
+
//# sourceMappingURL=add-fields-stage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"add-fields-stage.d.ts","sourceRoot":"","sources":["../../../src/translator/stages/add-fields-stage.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AAKxD,wBAAgB,uBAAuB,CACrC,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAClC,OAAO,EAAE,YAAY,GACpB,WAAW,CA0Db"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* $addFields stage - Adds new fields to documents
|
|
3
|
+
* Translates to SQL using json_set (SQLite) or tuple functions (ClickHouse)
|
|
4
|
+
*/
|
|
5
|
+
import { translateExpressionValue, isFieldReference, getFieldPath } from './expression-translator';
|
|
6
|
+
import { validateFieldPath } from '../../utils/sql-safety.js';
|
|
7
|
+
import { jsonExtract as dialectJsonExtract } from '../dialect';
|
|
8
|
+
export function translateAddFieldsStage(addFields, context) {
|
|
9
|
+
const params = [];
|
|
10
|
+
const dialect = context.dialect || 'sqlite';
|
|
11
|
+
// Build nested json_set calls for each field
|
|
12
|
+
let result = 'data';
|
|
13
|
+
for (const [field, value] of Object.entries(addFields)) {
|
|
14
|
+
// Validate field name to prevent SQL injection
|
|
15
|
+
validateFieldPath(field);
|
|
16
|
+
const jsonPath = `'$.${field}'`;
|
|
17
|
+
if (typeof value === 'object' && value !== null && !Array.isArray(value)) {
|
|
18
|
+
// Expression
|
|
19
|
+
const exprSql = translateExpressionValue(value, params, dialect);
|
|
20
|
+
if (dialect === 'clickhouse') {
|
|
21
|
+
// ClickHouse would need different handling
|
|
22
|
+
result = `tuple(${result}, '${field}', ${exprSql})`;
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
result = `json_set(${result}, ${jsonPath}, ${exprSql})`;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
else if (isFieldReference(value)) {
|
|
29
|
+
// Field reference - getFieldPath validates the field
|
|
30
|
+
const fieldPath = getFieldPath(value);
|
|
31
|
+
const fieldExpr = dialectJsonExtract(dialect, 'data', fieldPath);
|
|
32
|
+
if (dialect === 'clickhouse') {
|
|
33
|
+
result = `tuple(${result}, '${field}', ${fieldExpr})`;
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
result = `json_set(${result}, ${jsonPath}, ${fieldExpr})`;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
else if (typeof value === 'string') {
|
|
40
|
+
params.push(value);
|
|
41
|
+
if (dialect === 'clickhouse') {
|
|
42
|
+
result = `tuple(${result}, '${field}', ?)`;
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
result = `json_set(${result}, ${jsonPath}, ?)`;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
else if (typeof value === 'number' || typeof value === 'boolean' || value === null) {
|
|
49
|
+
if (dialect === 'clickhouse') {
|
|
50
|
+
result = `tuple(${result}, '${field}', ${JSON.stringify(value)})`;
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
result = `json_set(${result}, ${jsonPath}, ${JSON.stringify(value)})`;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
else if (Array.isArray(value)) {
|
|
57
|
+
params.push(JSON.stringify(value));
|
|
58
|
+
if (dialect === 'clickhouse') {
|
|
59
|
+
result = `tuple(${result}, '${field}', ?)`;
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
result = `json_set(${result}, ${jsonPath}, json(?))`;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
return {
|
|
67
|
+
selectClause: `${result} AS data`,
|
|
68
|
+
params,
|
|
69
|
+
transformsShape: true
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
//# sourceMappingURL=add-fields-stage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"add-fields-stage.js","sourceRoot":"","sources":["../../../src/translator/stages/add-fields-stage.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* $bucket stage - Categorizes documents into groups (buckets) based on a specified expression
|
|
3
|
+
* Translates to SQL using CASE WHEN for bucket boundaries
|
|
4
|
+
*/
|
|
5
|
+
import type { StageResult, StageContext, BucketStage } from './types';
|
|
6
|
+
export declare function translateBucketStage(bucket: BucketStage, _context: StageContext): StageResult;
|
|
7
|
+
//# sourceMappingURL=bucket-stage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bucket-stage.d.ts","sourceRoot":"","sources":["../../../src/translator/stages/bucket-stage.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,WAAW,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAIrE,wBAAgB,oBAAoB,CAClC,MAAM,EAAE,WAAW,EACnB,QAAQ,EAAE,YAAY,GACrB,WAAW,CAmDb"}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* $bucket stage - Categorizes documents into groups (buckets) based on a specified expression
|
|
3
|
+
* Translates to SQL using CASE WHEN for bucket boundaries
|
|
4
|
+
*/
|
|
5
|
+
import { getFieldPath, translateExpressionValue } from './expression-translator';
|
|
6
|
+
import { validateFieldPath } from '../../utils/sql-safety.js';
|
|
7
|
+
export function translateBucketStage(bucket, _context) {
|
|
8
|
+
const params = [];
|
|
9
|
+
const { groupBy, boundaries, output } = bucket;
|
|
10
|
+
const defaultBucket = bucket.default;
|
|
11
|
+
// Get the field to bucket on - getFieldPath validates the field reference
|
|
12
|
+
// If not a $ reference, validate directly
|
|
13
|
+
let fieldPath;
|
|
14
|
+
if (groupBy.startsWith('$')) {
|
|
15
|
+
fieldPath = getFieldPath(groupBy);
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
validateFieldPath(groupBy);
|
|
19
|
+
fieldPath = `$.${groupBy}`;
|
|
20
|
+
}
|
|
21
|
+
const fieldExpr = `json_extract(data, '${fieldPath}')`;
|
|
22
|
+
// Build CASE WHEN expression for bucket assignment
|
|
23
|
+
const bucketCases = [];
|
|
24
|
+
for (let i = 0; i < boundaries.length - 1; i++) {
|
|
25
|
+
const lower = boundaries[i];
|
|
26
|
+
const upper = boundaries[i + 1];
|
|
27
|
+
bucketCases.push(`WHEN ${fieldExpr} >= ${lower} AND ${fieldExpr} < ${upper} THEN ${lower}`);
|
|
28
|
+
}
|
|
29
|
+
// Handle default bucket
|
|
30
|
+
const defaultCase = defaultBucket !== undefined
|
|
31
|
+
? `ELSE '${defaultBucket}'`
|
|
32
|
+
: `ELSE NULL`;
|
|
33
|
+
const bucketExpr = `CASE ${bucketCases.join(' ')} ${defaultCase} END`;
|
|
34
|
+
// Build the output accumulators
|
|
35
|
+
const selectParts = [`'_id', ${bucketExpr}`];
|
|
36
|
+
if (output) {
|
|
37
|
+
for (const [field, accumulator] of Object.entries(output)) {
|
|
38
|
+
const accSql = translateBucketAccumulator(accumulator, params);
|
|
39
|
+
selectParts.push(`'${field}', ${accSql}`);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
// Default output is count
|
|
44
|
+
selectParts.push(`'count', COUNT(*)`);
|
|
45
|
+
}
|
|
46
|
+
return {
|
|
47
|
+
selectClause: `json_object(${selectParts.join(', ')}) AS data`,
|
|
48
|
+
groupByClause: bucketExpr,
|
|
49
|
+
params,
|
|
50
|
+
transformsShape: true
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
function translateBucketAccumulator(accumulator, params) {
|
|
54
|
+
const operator = Object.keys(accumulator)[0];
|
|
55
|
+
const value = accumulator[operator];
|
|
56
|
+
switch (operator) {
|
|
57
|
+
case '$sum': {
|
|
58
|
+
if (typeof value === 'number') {
|
|
59
|
+
return `COUNT(*)`;
|
|
60
|
+
}
|
|
61
|
+
const expr = translateExpressionValue(value, params);
|
|
62
|
+
return `SUM(${expr})`;
|
|
63
|
+
}
|
|
64
|
+
case '$avg': {
|
|
65
|
+
const expr = translateExpressionValue(value, params);
|
|
66
|
+
return `AVG(${expr})`;
|
|
67
|
+
}
|
|
68
|
+
case '$min': {
|
|
69
|
+
const expr = translateExpressionValue(value, params);
|
|
70
|
+
return `MIN(${expr})`;
|
|
71
|
+
}
|
|
72
|
+
case '$max': {
|
|
73
|
+
const expr = translateExpressionValue(value, params);
|
|
74
|
+
return `MAX(${expr})`;
|
|
75
|
+
}
|
|
76
|
+
case '$count': {
|
|
77
|
+
return 'COUNT(*)';
|
|
78
|
+
}
|
|
79
|
+
case '$push': {
|
|
80
|
+
const expr = translateExpressionValue(value, params);
|
|
81
|
+
return `json_group_array(${expr})`;
|
|
82
|
+
}
|
|
83
|
+
default:
|
|
84
|
+
throw new Error(`Unknown bucket accumulator operator: ${operator}`);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
//# sourceMappingURL=bucket-stage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bucket-stage.js","sourceRoot":"","sources":["../../../src/translator/stages/bucket-stage.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* $count stage - Counts documents and returns a single document with the count
|
|
3
|
+
* Translates to SELECT COUNT(*) AS fieldName
|
|
4
|
+
*/
|
|
5
|
+
import type { StageResult, StageContext } from './types';
|
|
6
|
+
export declare function translateCountStage(fieldName: string, _context: StageContext): StageResult;
|
|
7
|
+
//# sourceMappingURL=count-stage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"count-stage.d.ts","sourceRoot":"","sources":["../../../src/translator/stages/count-stage.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AAExD,wBAAgB,mBAAmB,CACjC,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,YAAY,GACrB,WAAW,CAMb"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* $count stage - Counts documents and returns a single document with the count
|
|
3
|
+
* Translates to SELECT COUNT(*) AS fieldName
|
|
4
|
+
*/
|
|
5
|
+
export function translateCountStage(fieldName, _context) {
|
|
6
|
+
return {
|
|
7
|
+
selectClause: `json_object('${fieldName}', COUNT(*)) AS data`,
|
|
8
|
+
params: [],
|
|
9
|
+
transformsShape: true
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=count-stage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"count-stage.js","sourceRoot":"","sources":["../../../src/translator/stages/count-stage.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,MAAM,UAAU,mBAAmB,CACjC,SAAiB,EACjB,QAAsB;IAEtB,OAAO;QACL,YAAY,EAAE,gBAAgB,SAAS,sBAAsB;QAC7D,MAAM,EAAE,EAAE;QACV,eAAe,EAAE,IAAI;KACtB,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Expression Translator - Translates MongoDB aggregation expressions to SQL
|
|
3
|
+
* Handles arithmetic, string, conditional, comparison, and function operators
|
|
4
|
+
* Supports multiple SQL dialects (SQLite, ClickHouse)
|
|
5
|
+
*/
|
|
6
|
+
import type { FunctionSpec, FunctionExpression } from '../../types/function';
|
|
7
|
+
import { type SQLDialect } from '../dialect';
|
|
8
|
+
/**
|
|
9
|
+
* Check if a value is a field reference (starts with $)
|
|
10
|
+
*/
|
|
11
|
+
export declare function isFieldReference(value: unknown): value is string;
|
|
12
|
+
/**
|
|
13
|
+
* Get the JSON path for a field reference
|
|
14
|
+
*
|
|
15
|
+
* SECURITY: Validates field name to prevent SQL injection attacks.
|
|
16
|
+
* @throws Error if field contains invalid characters
|
|
17
|
+
*/
|
|
18
|
+
export declare function getFieldPath(fieldRef: string): string;
|
|
19
|
+
/**
|
|
20
|
+
* Translate an expression value (field reference, literal, or expression object)
|
|
21
|
+
*/
|
|
22
|
+
export declare function translateExpressionValue(value: unknown, params: unknown[], dialect?: SQLDialect): string;
|
|
23
|
+
/**
|
|
24
|
+
* Main expression translator
|
|
25
|
+
*/
|
|
26
|
+
export declare function translateExpression(expr: Record<string, unknown>, params: unknown[], dialect?: SQLDialect): string;
|
|
27
|
+
/**
|
|
28
|
+
* Function ID counter for placeholder identification
|
|
29
|
+
* Exported for testing purposes
|
|
30
|
+
*/
|
|
31
|
+
export declare let functionIdCounter: number;
|
|
32
|
+
/**
|
|
33
|
+
* Reset function ID counter (useful for testing)
|
|
34
|
+
*/
|
|
35
|
+
export declare function resetFunctionIdCounter(): void;
|
|
36
|
+
/**
|
|
37
|
+
* Check if a value is a $function operator
|
|
38
|
+
*/
|
|
39
|
+
export declare function isFunctionOperator(value: unknown): value is {
|
|
40
|
+
$function: FunctionSpec;
|
|
41
|
+
};
|
|
42
|
+
/**
|
|
43
|
+
* Create a FunctionExpression from a $function spec
|
|
44
|
+
* Utility for external code that needs to work with function expressions
|
|
45
|
+
*/
|
|
46
|
+
export declare function createFunctionExpression(spec: FunctionSpec): FunctionExpression;
|
|
47
|
+
/**
|
|
48
|
+
* Parse a function marker from SQL output
|
|
49
|
+
* Returns the parsed function expression or null if not a function marker
|
|
50
|
+
*/
|
|
51
|
+
export declare function parseFunctionPlaceholder(sql: string): {
|
|
52
|
+
__type: 'function';
|
|
53
|
+
body: string;
|
|
54
|
+
argPaths: string[];
|
|
55
|
+
literalArgs: Record<number, unknown>;
|
|
56
|
+
argOrder: Array<{
|
|
57
|
+
type: 'field';
|
|
58
|
+
path: string;
|
|
59
|
+
} | {
|
|
60
|
+
type: 'literal';
|
|
61
|
+
index: number;
|
|
62
|
+
}>;
|
|
63
|
+
} | null;
|
|
64
|
+
/**
|
|
65
|
+
* Check if SQL contains function markers
|
|
66
|
+
*/
|
|
67
|
+
export declare function hasFunctionPlaceholders(sql: string): boolean;
|
|
68
|
+
//# sourceMappingURL=expression-translator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"expression-translator.d.ts","sourceRoot":"","sources":["../../../src/translator/stages/expression-translator.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAA;AAE5E,OAAO,EACL,KAAK,UAAU,EAOhB,MAAM,YAAY,CAAA;AAEnB;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,OAAO,GAAG,KAAK,IAAI,MAAM,CAEhE;AAED;;;;;GAKG;AACH,wBAAgB,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAmBrD;AAED;;GAEG;AACH,wBAAgB,wBAAwB,CAAC,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,OAAO,GAAE,UAAqB,GAAG,MAAM,CAyBlH;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CACjC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC7B,MAAM,EAAE,OAAO,EAAE,EACjB,OAAO,GAAE,UAAqB,GAC7B,MAAM,CA+PR;AA2HD;;;GAGG;AACH,eAAO,IAAI,iBAAiB,QAAI,CAAA;AAEhC;;GAEG;AACH,wBAAgB,sBAAsB,IAAI,IAAI,CAE7C;AAED;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,OAAO,GAAG,KAAK,IAAI;IAAE,SAAS,EAAE,YAAY,CAAA;CAAE,CAMvF;AAED;;;GAGG;AACH,wBAAgB,wBAAwB,CAAC,IAAI,EAAE,YAAY,GAAG,kBAAkB,CAyB/E;AAED;;;GAGG;AACH,wBAAgB,wBAAwB,CAAC,GAAG,EAAE,MAAM,GAAG;IACrD,MAAM,EAAE,UAAU,CAAA;IAClB,IAAI,EAAE,MAAM,CAAA;IACZ,QAAQ,EAAE,MAAM,EAAE,CAAA;IAClB,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IACpC,QAAQ,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,OAAO,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,GAAG;QAAE,IAAI,EAAE,SAAS,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC,CAAA;CACtF,GAAG,IAAI,CAWP;AAED;;GAEG;AACH,wBAAgB,uBAAuB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAE5D"}
|