mongo.do 0.1.0 → 0.1.1
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/dist/cli/index.d.ts +1 -15
- package/dist/cli/index.js +4083 -196
- package/dist/cli/index.js.map +1 -1
- package/dist/index.d.ts +2740 -20
- package/dist/index.js +9375 -27
- package/dist/index.js.map +1 -1
- package/dist/worker-entrypoint-BEW23Gmp.d.ts +1331 -0
- package/dist/worker.d.ts +6 -5
- package/dist/worker.js +5477 -18
- package/dist/worker.js.map +1 -1
- package/package.json +3 -2
- package/dist/agentfs/adapters/anthropic.d.ts +0 -176
- package/dist/agentfs/adapters/anthropic.d.ts.map +0 -1
- package/dist/agentfs/adapters/anthropic.js +0 -629
- package/dist/agentfs/adapters/anthropic.js.map +0 -1
- package/dist/agentfs/adapters/index.d.ts +0 -21
- package/dist/agentfs/adapters/index.d.ts.map +0 -1
- package/dist/agentfs/adapters/index.js +0 -23
- package/dist/agentfs/adapters/index.js.map +0 -1
- package/dist/agentfs/adapters/vercel.d.ts +0 -260
- package/dist/agentfs/adapters/vercel.d.ts.map +0 -1
- package/dist/agentfs/adapters/vercel.js +0 -288
- package/dist/agentfs/adapters/vercel.js.map +0 -1
- package/dist/agentfs/glob.d.ts +0 -116
- package/dist/agentfs/glob.d.ts.map +0 -1
- package/dist/agentfs/glob.js +0 -270
- package/dist/agentfs/glob.js.map +0 -1
- package/dist/agentfs/grep.d.ts +0 -83
- package/dist/agentfs/grep.d.ts.map +0 -1
- package/dist/agentfs/grep.js +0 -193
- package/dist/agentfs/grep.js.map +0 -1
- package/dist/agentfs/index.d.ts +0 -22
- package/dist/agentfs/index.d.ts.map +0 -1
- package/dist/agentfs/index.js +0 -18
- package/dist/agentfs/index.js.map +0 -1
- package/dist/agentfs/kv-store.d.ts +0 -128
- package/dist/agentfs/kv-store.d.ts.map +0 -1
- package/dist/agentfs/kv-store.js +0 -227
- package/dist/agentfs/kv-store.js.map +0 -1
- package/dist/agentfs/mondo-agent.d.ts +0 -255
- package/dist/agentfs/mondo-agent.d.ts.map +0 -1
- package/dist/agentfs/mondo-agent.js +0 -879
- package/dist/agentfs/mondo-agent.js.map +0 -1
- package/dist/agentfs/toolcalls.d.ts +0 -130
- package/dist/agentfs/toolcalls.d.ts.map +0 -1
- package/dist/agentfs/toolcalls.js +0 -178
- package/dist/agentfs/toolcalls.js.map +0 -1
- package/dist/agentfs/types.d.ts +0 -171
- package/dist/agentfs/types.d.ts.map +0 -1
- package/dist/agentfs/types.js +0 -7
- package/dist/agentfs/types.js.map +0 -1
- package/dist/agentfs/vfs.d.ts +0 -249
- package/dist/agentfs/vfs.d.ts.map +0 -1
- package/dist/agentfs/vfs.js +0 -469
- package/dist/agentfs/vfs.js.map +0 -1
- package/dist/cli/index.d.ts.map +0 -1
- package/dist/cli/mcp.d.ts +0 -119
- package/dist/cli/mcp.d.ts.map +0 -1
- package/dist/cli/mcp.js +0 -418
- package/dist/cli/mcp.js.map +0 -1
- package/dist/cli/server.d.ts +0 -179
- package/dist/cli/server.d.ts.map +0 -1
- package/dist/cli/server.js +0 -441
- package/dist/cli/server.js.map +0 -1
- package/dist/client/Collection.d.ts +0 -199
- package/dist/client/Collection.d.ts.map +0 -1
- package/dist/client/Collection.js +0 -256
- package/dist/client/Collection.js.map +0 -1
- package/dist/client/Database.d.ts +0 -68
- package/dist/client/Database.d.ts.map +0 -1
- package/dist/client/Database.js +0 -105
- package/dist/client/Database.js.map +0 -1
- package/dist/client/MongoClient.d.ts +0 -165
- package/dist/client/MongoClient.d.ts.map +0 -1
- package/dist/client/MongoClient.js +0 -307
- package/dist/client/MongoClient.js.map +0 -1
- package/dist/client/aggregation-cursor.d.ts +0 -210
- package/dist/client/aggregation-cursor.d.ts.map +0 -1
- package/dist/client/aggregation-cursor.js +0 -509
- package/dist/client/aggregation-cursor.js.map +0 -1
- package/dist/client/bulk-write.d.ts +0 -216
- package/dist/client/bulk-write.d.ts.map +0 -1
- package/dist/client/bulk-write.js +0 -63
- package/dist/client/bulk-write.js.map +0 -1
- package/dist/client/change-stream.d.ts +0 -245
- package/dist/client/change-stream.d.ts.map +0 -1
- package/dist/client/change-stream.js +0 -429
- package/dist/client/change-stream.js.map +0 -1
- package/dist/client/cursor.d.ts +0 -85
- package/dist/client/cursor.d.ts.map +0 -1
- package/dist/client/cursor.js +0 -156
- package/dist/client/cursor.js.map +0 -1
- package/dist/client/http-cursor.d.ts +0 -233
- package/dist/client/http-cursor.d.ts.map +0 -1
- package/dist/client/http-cursor.js +0 -496
- package/dist/client/http-cursor.js.map +0 -1
- package/dist/client/index.d.ts +0 -18
- package/dist/client/index.d.ts.map +0 -1
- package/dist/client/index.js +0 -24
- package/dist/client/index.js.map +0 -1
- package/dist/client/mongo-client.d.ts +0 -60
- package/dist/client/mongo-client.d.ts.map +0 -1
- package/dist/client/mongo-client.js +0 -190
- package/dist/client/mongo-client.js.map +0 -1
- package/dist/client/mongo-collection.d.ts +0 -359
- package/dist/client/mongo-collection.d.ts.map +0 -1
- package/dist/client/mongo-collection.js +0 -1641
- package/dist/client/mongo-collection.js.map +0 -1
- package/dist/client/mongo-cursor.d.ts +0 -257
- package/dist/client/mongo-cursor.d.ts.map +0 -1
- package/dist/client/mongo-cursor.js +0 -621
- package/dist/client/mongo-cursor.js.map +0 -1
- package/dist/client/mongo-database.d.ts +0 -88
- package/dist/client/mongo-database.d.ts.map +0 -1
- package/dist/client/mongo-database.js +0 -139
- package/dist/client/mongo-database.js.map +0 -1
- package/dist/client/session.d.ts +0 -210
- package/dist/client/session.d.ts.map +0 -1
- package/dist/client/session.js +0 -326
- package/dist/client/session.js.map +0 -1
- package/dist/durable-object/index-manager.d.ts +0 -173
- package/dist/durable-object/index-manager.d.ts.map +0 -1
- package/dist/durable-object/index-manager.js +0 -764
- package/dist/durable-object/index-manager.js.map +0 -1
- package/dist/durable-object/index.d.ts +0 -12
- package/dist/durable-object/index.d.ts.map +0 -1
- package/dist/durable-object/index.js +0 -8
- package/dist/durable-object/index.js.map +0 -1
- package/dist/durable-object/mcp-handler.d.ts +0 -52
- package/dist/durable-object/mcp-handler.d.ts.map +0 -1
- package/dist/durable-object/mcp-handler.js +0 -186
- package/dist/durable-object/mcp-handler.js.map +0 -1
- package/dist/durable-object/migrations.d.ts +0 -40
- package/dist/durable-object/migrations.d.ts.map +0 -1
- package/dist/durable-object/migrations.js +0 -121
- package/dist/durable-object/migrations.js.map +0 -1
- package/dist/durable-object/mondo-database.d.ts +0 -148
- package/dist/durable-object/mondo-database.d.ts.map +0 -1
- package/dist/durable-object/mondo-database.js +0 -621
- package/dist/durable-object/mondo-database.js.map +0 -1
- package/dist/durable-object/schema.d.ts +0 -192
- package/dist/durable-object/schema.d.ts.map +0 -1
- package/dist/durable-object/schema.js +0 -186
- package/dist/durable-object/schema.js.map +0 -1
- package/dist/embedding/document-serializer.d.ts +0 -118
- package/dist/embedding/document-serializer.d.ts.map +0 -1
- package/dist/embedding/document-serializer.js +0 -339
- package/dist/embedding/document-serializer.js.map +0 -1
- package/dist/embedding/embedding-manager.d.ts +0 -136
- package/dist/embedding/embedding-manager.d.ts.map +0 -1
- package/dist/embedding/embedding-manager.js +0 -176
- package/dist/embedding/embedding-manager.js.map +0 -1
- package/dist/embedding/index.d.ts +0 -9
- package/dist/embedding/index.d.ts.map +0 -1
- package/dist/embedding/index.js +0 -9
- package/dist/embedding/index.js.map +0 -1
- package/dist/executor/aggregation-executor.d.ts +0 -93
- package/dist/executor/aggregation-executor.d.ts.map +0 -1
- package/dist/executor/aggregation-executor.js +0 -275
- package/dist/executor/aggregation-executor.js.map +0 -1
- package/dist/executor/function-executor.d.ts +0 -39
- package/dist/executor/function-executor.d.ts.map +0 -1
- package/dist/executor/function-executor.js +0 -168
- package/dist/executor/function-executor.js.map +0 -1
- package/dist/executor/index.d.ts +0 -4
- package/dist/executor/index.d.ts.map +0 -1
- package/dist/executor/index.js +0 -4
- package/dist/executor/index.js.map +0 -1
- package/dist/executor/vector-search-executor.d.ts +0 -71
- package/dist/executor/vector-search-executor.d.ts.map +0 -1
- package/dist/executor/vector-search-executor.js +0 -113
- package/dist/executor/vector-search-executor.js.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/mcp/adapters/anthropic-adapter.d.ts +0 -256
- package/dist/mcp/adapters/anthropic-adapter.d.ts.map +0 -1
- package/dist/mcp/adapters/anthropic-adapter.js +0 -409
- package/dist/mcp/adapters/anthropic-adapter.js.map +0 -1
- package/dist/mcp/adapters/base-adapter.d.ts +0 -164
- package/dist/mcp/adapters/base-adapter.d.ts.map +0 -1
- package/dist/mcp/adapters/base-adapter.js +0 -277
- package/dist/mcp/adapters/base-adapter.js.map +0 -1
- package/dist/mcp/adapters/errors.d.ts +0 -173
- package/dist/mcp/adapters/errors.d.ts.map +0 -1
- package/dist/mcp/adapters/errors.js +0 -305
- package/dist/mcp/adapters/errors.js.map +0 -1
- package/dist/mcp/adapters/index.d.ts +0 -65
- package/dist/mcp/adapters/index.d.ts.map +0 -1
- package/dist/mcp/adapters/index.js +0 -92
- package/dist/mcp/adapters/index.js.map +0 -1
- package/dist/mcp/adapters/streaming.d.ts +0 -200
- package/dist/mcp/adapters/streaming.d.ts.map +0 -1
- package/dist/mcp/adapters/streaming.js +0 -381
- package/dist/mcp/adapters/streaming.js.map +0 -1
- package/dist/mcp/adapters/vercel-adapter.d.ts +0 -321
- package/dist/mcp/adapters/vercel-adapter.d.ts.map +0 -1
- package/dist/mcp/adapters/vercel-adapter.js +0 -487
- package/dist/mcp/adapters/vercel-adapter.js.map +0 -1
- package/dist/mcp/agent.d.ts +0 -192
- package/dist/mcp/agent.d.ts.map +0 -1
- package/dist/mcp/agent.js +0 -338
- package/dist/mcp/agent.js.map +0 -1
- package/dist/mcp/cli.d.ts +0 -71
- package/dist/mcp/cli.d.ts.map +0 -1
- package/dist/mcp/cli.js +0 -218
- package/dist/mcp/cli.js.map +0 -1
- package/dist/mcp/index.d.ts +0 -15
- package/dist/mcp/index.d.ts.map +0 -1
- package/dist/mcp/index.js +0 -20
- package/dist/mcp/index.js.map +0 -1
- package/dist/mcp/sandbox/database-proxy.d.ts +0 -118
- package/dist/mcp/sandbox/database-proxy.d.ts.map +0 -1
- package/dist/mcp/sandbox/database-proxy.js +0 -154
- package/dist/mcp/sandbox/database-proxy.js.map +0 -1
- package/dist/mcp/sandbox/index.d.ts +0 -8
- package/dist/mcp/sandbox/index.d.ts.map +0 -1
- package/dist/mcp/sandbox/index.js +0 -7
- package/dist/mcp/sandbox/index.js.map +0 -1
- package/dist/mcp/sandbox/miniflare-evaluator.d.ts +0 -72
- package/dist/mcp/sandbox/miniflare-evaluator.d.ts.map +0 -1
- package/dist/mcp/sandbox/miniflare-evaluator.js +0 -379
- package/dist/mcp/sandbox/miniflare-evaluator.js.map +0 -1
- package/dist/mcp/sandbox/template.d.ts +0 -48
- package/dist/mcp/sandbox/template.d.ts.map +0 -1
- package/dist/mcp/sandbox/template.js +0 -147
- package/dist/mcp/sandbox/template.js.map +0 -1
- package/dist/mcp/sandbox/worker-evaluator.d.ts +0 -160
- package/dist/mcp/sandbox/worker-evaluator.d.ts.map +0 -1
- package/dist/mcp/sandbox/worker-evaluator.js +0 -217
- package/dist/mcp/sandbox/worker-evaluator.js.map +0 -1
- package/dist/mcp/server.d.ts +0 -75
- package/dist/mcp/server.d.ts.map +0 -1
- package/dist/mcp/server.js +0 -278
- package/dist/mcp/server.js.map +0 -1
- package/dist/mcp/tool-call-auditor.d.ts +0 -188
- package/dist/mcp/tool-call-auditor.d.ts.map +0 -1
- package/dist/mcp/tool-call-auditor.js +0 -198
- package/dist/mcp/tool-call-auditor.js.map +0 -1
- package/dist/mcp/tools/do.d.ts +0 -51
- package/dist/mcp/tools/do.d.ts.map +0 -1
- package/dist/mcp/tools/do.js +0 -113
- package/dist/mcp/tools/do.js.map +0 -1
- package/dist/mcp/tools/fetch.d.ts +0 -43
- package/dist/mcp/tools/fetch.d.ts.map +0 -1
- package/dist/mcp/tools/fetch.js +0 -127
- package/dist/mcp/tools/fetch.js.map +0 -1
- package/dist/mcp/tools/index.d.ts +0 -9
- package/dist/mcp/tools/index.d.ts.map +0 -1
- package/dist/mcp/tools/index.js +0 -9
- package/dist/mcp/tools/index.js.map +0 -1
- package/dist/mcp/tools/search.d.ts +0 -60
- package/dist/mcp/tools/search.d.ts.map +0 -1
- package/dist/mcp/tools/search.js +0 -278
- package/dist/mcp/tools/search.js.map +0 -1
- package/dist/mcp/transport/http.d.ts +0 -144
- package/dist/mcp/transport/http.d.ts.map +0 -1
- package/dist/mcp/transport/http.js +0 -545
- package/dist/mcp/transport/http.js.map +0 -1
- package/dist/mcp/transport/index.d.ts +0 -10
- package/dist/mcp/transport/index.d.ts.map +0 -1
- package/dist/mcp/transport/index.js +0 -12
- package/dist/mcp/transport/index.js.map +0 -1
- package/dist/mcp/transport/stdio.d.ts +0 -132
- package/dist/mcp/transport/stdio.d.ts.map +0 -1
- package/dist/mcp/transport/stdio.js +0 -466
- package/dist/mcp/transport/stdio.js.map +0 -1
- package/dist/mcp/types.d.ts +0 -476
- package/dist/mcp/types.d.ts.map +0 -1
- package/dist/mcp/types.js +0 -178
- package/dist/mcp/types.js.map +0 -1
- package/dist/olap/cdc/cdc-buffer.d.ts +0 -92
- package/dist/olap/cdc/cdc-buffer.d.ts.map +0 -1
- package/dist/olap/cdc/cdc-buffer.js +0 -146
- package/dist/olap/cdc/cdc-buffer.js.map +0 -1
- package/dist/olap/cdc/cdc-emitter.d.ts +0 -118
- package/dist/olap/cdc/cdc-emitter.d.ts.map +0 -1
- package/dist/olap/cdc/cdc-emitter.js +0 -217
- package/dist/olap/cdc/cdc-emitter.js.map +0 -1
- package/dist/olap/cdc/cdc-schema.d.ts +0 -119
- package/dist/olap/cdc/cdc-schema.d.ts.map +0 -1
- package/dist/olap/cdc/cdc-schema.js +0 -253
- package/dist/olap/cdc/cdc-schema.js.map +0 -1
- package/dist/olap/cdc/index.d.ts +0 -10
- package/dist/olap/cdc/index.d.ts.map +0 -1
- package/dist/olap/cdc/index.js +0 -10
- package/dist/olap/cdc/index.js.map +0 -1
- package/dist/olap/clickhouse/iceberg.d.ts +0 -164
- package/dist/olap/clickhouse/iceberg.d.ts.map +0 -1
- package/dist/olap/clickhouse/iceberg.js +0 -138
- package/dist/olap/clickhouse/iceberg.js.map +0 -1
- package/dist/olap/clickhouse/index.d.ts +0 -14
- package/dist/olap/clickhouse/index.d.ts.map +0 -1
- package/dist/olap/clickhouse/index.js +0 -14
- package/dist/olap/clickhouse/index.js.map +0 -1
- package/dist/olap/clickhouse/mapper.d.ts +0 -170
- package/dist/olap/clickhouse/mapper.d.ts.map +0 -1
- package/dist/olap/clickhouse/mapper.js +0 -654
- package/dist/olap/clickhouse/mapper.js.map +0 -1
- package/dist/olap/clickhouse/olap-backend.d.ts +0 -181
- package/dist/olap/clickhouse/olap-backend.d.ts.map +0 -1
- package/dist/olap/clickhouse/olap-backend.js +0 -1083
- package/dist/olap/clickhouse/olap-backend.js.map +0 -1
- package/dist/olap/clickhouse/query-executor.d.ts +0 -163
- package/dist/olap/clickhouse/query-executor.d.ts.map +0 -1
- package/dist/olap/clickhouse/query-executor.js +0 -560
- package/dist/olap/clickhouse/query-executor.js.map +0 -1
- package/dist/olap/clickhouse/query.d.ts +0 -134
- package/dist/olap/clickhouse/query.d.ts.map +0 -1
- package/dist/olap/clickhouse/query.js +0 -512
- package/dist/olap/clickhouse/query.js.map +0 -1
- package/dist/olap/stage/index.d.ts +0 -6
- package/dist/olap/stage/index.d.ts.map +0 -1
- package/dist/olap/stage/index.js +0 -6
- package/dist/olap/stage/index.js.map +0 -1
- package/dist/olap/stage/parser.d.ts +0 -68
- package/dist/olap/stage/parser.d.ts.map +0 -1
- package/dist/olap/stage/parser.js +0 -293
- package/dist/olap/stage/parser.js.map +0 -1
- package/dist/olap/stage/router.d.ts +0 -94
- package/dist/olap/stage/router.d.ts.map +0 -1
- package/dist/olap/stage/router.js +0 -390
- package/dist/olap/stage/router.js.map +0 -1
- package/dist/rpc/endpoint.d.ts +0 -52
- package/dist/rpc/endpoint.d.ts.map +0 -1
- package/dist/rpc/endpoint.js +0 -734
- package/dist/rpc/endpoint.js.map +0 -1
- package/dist/rpc/index.d.ts +0 -34
- package/dist/rpc/index.d.ts.map +0 -1
- package/dist/rpc/index.js +0 -45
- package/dist/rpc/index.js.map +0 -1
- package/dist/rpc/rpc-client.d.ts +0 -275
- package/dist/rpc/rpc-client.d.ts.map +0 -1
- package/dist/rpc/rpc-client.js +0 -735
- package/dist/rpc/rpc-client.js.map +0 -1
- package/dist/rpc/rpc-target.d.ts +0 -220
- package/dist/rpc/rpc-target.d.ts.map +0 -1
- package/dist/rpc/rpc-target.js +0 -500
- package/dist/rpc/rpc-target.js.map +0 -1
- package/dist/rpc/worker-entrypoint.d.ts +0 -159
- package/dist/rpc/worker-entrypoint.d.ts.map +0 -1
- package/dist/rpc/worker-entrypoint.js +0 -212
- package/dist/rpc/worker-entrypoint.js.map +0 -1
- package/dist/server.d.ts +0 -18
- package/dist/server.d.ts.map +0 -1
- package/dist/server.js +0 -129
- package/dist/server.js.map +0 -1
- package/dist/studio/components/browser/CollectionItem.d.ts +0 -26
- package/dist/studio/components/browser/CollectionItem.d.ts.map +0 -1
- package/dist/studio/components/browser/CollectionItem.js +0 -143
- package/dist/studio/components/browser/CollectionItem.js.map +0 -1
- package/dist/studio/components/browser/CollectionTree.d.ts +0 -45
- package/dist/studio/components/browser/CollectionTree.d.ts.map +0 -1
- package/dist/studio/components/browser/CollectionTree.js +0 -207
- package/dist/studio/components/browser/CollectionTree.js.map +0 -1
- package/dist/studio/components/browser/ConnectedDatabaseBrowser.d.ts +0 -51
- package/dist/studio/components/browser/ConnectedDatabaseBrowser.d.ts.map +0 -1
- package/dist/studio/components/browser/ConnectedDatabaseBrowser.js +0 -185
- package/dist/studio/components/browser/ConnectedDatabaseBrowser.js.map +0 -1
- package/dist/studio/components/browser/DatabaseBrowser.d.ts +0 -46
- package/dist/studio/components/browser/DatabaseBrowser.d.ts.map +0 -1
- package/dist/studio/components/browser/DatabaseBrowser.js +0 -304
- package/dist/studio/components/browser/DatabaseBrowser.js.map +0 -1
- package/dist/studio/components/browser/__tests__/CollectionItem.test.d.ts +0 -5
- package/dist/studio/components/browser/__tests__/CollectionItem.test.d.ts.map +0 -1
- package/dist/studio/components/browser/__tests__/CollectionItem.test.js +0 -169
- package/dist/studio/components/browser/__tests__/CollectionItem.test.js.map +0 -1
- package/dist/studio/components/browser/__tests__/CollectionTree.test.d.ts +0 -5
- package/dist/studio/components/browser/__tests__/CollectionTree.test.d.ts.map +0 -1
- package/dist/studio/components/browser/__tests__/CollectionTree.test.js +0 -203
- package/dist/studio/components/browser/__tests__/CollectionTree.test.js.map +0 -1
- package/dist/studio/components/browser/__tests__/DatabaseBrowser.e2e.test.d.ts +0 -8
- package/dist/studio/components/browser/__tests__/DatabaseBrowser.e2e.test.d.ts.map +0 -1
- package/dist/studio/components/browser/__tests__/DatabaseBrowser.e2e.test.js +0 -522
- package/dist/studio/components/browser/__tests__/DatabaseBrowser.e2e.test.js.map +0 -1
- package/dist/studio/components/browser/__tests__/DatabaseBrowser.test.d.ts +0 -5
- package/dist/studio/components/browser/__tests__/DatabaseBrowser.test.d.ts.map +0 -1
- package/dist/studio/components/browser/__tests__/DatabaseBrowser.test.js +0 -518
- package/dist/studio/components/browser/__tests__/DatabaseBrowser.test.js.map +0 -1
- package/dist/studio/components/browser/__tests__/setup.d.ts +0 -5
- package/dist/studio/components/browser/__tests__/setup.d.ts.map +0 -1
- package/dist/studio/components/browser/__tests__/setup.js +0 -22
- package/dist/studio/components/browser/__tests__/setup.js.map +0 -1
- package/dist/studio/components/browser/index.d.ts +0 -15
- package/dist/studio/components/browser/index.d.ts.map +0 -1
- package/dist/studio/components/browser/index.js +0 -10
- package/dist/studio/components/browser/index.js.map +0 -1
- package/dist/studio/components/browser/types.d.ts +0 -33
- package/dist/studio/components/browser/types.d.ts.map +0 -1
- package/dist/studio/components/browser/types.js +0 -5
- package/dist/studio/components/browser/types.js.map +0 -1
- package/dist/studio/components/connection/ConnectionForm.d.ts +0 -59
- package/dist/studio/components/connection/ConnectionForm.d.ts.map +0 -1
- package/dist/studio/components/connection/ConnectionForm.js +0 -274
- package/dist/studio/components/connection/ConnectionForm.js.map +0 -1
- package/dist/studio/components/connection/ConnectionList.d.ts +0 -59
- package/dist/studio/components/connection/ConnectionList.d.ts.map +0 -1
- package/dist/studio/components/connection/ConnectionList.js +0 -286
- package/dist/studio/components/connection/ConnectionList.js.map +0 -1
- package/dist/studio/components/connection/ConnectionPanel.d.ts +0 -132
- package/dist/studio/components/connection/ConnectionPanel.d.ts.map +0 -1
- package/dist/studio/components/connection/ConnectionPanel.js +0 -293
- package/dist/studio/components/connection/ConnectionPanel.js.map +0 -1
- package/dist/studio/components/connection/__tests__/ConnectionPanel.test.d.ts +0 -8
- package/dist/studio/components/connection/__tests__/ConnectionPanel.test.d.ts.map +0 -1
- package/dist/studio/components/connection/__tests__/ConnectionPanel.test.js +0 -632
- package/dist/studio/components/connection/__tests__/ConnectionPanel.test.js.map +0 -1
- package/dist/studio/components/connection/__tests__/setup.d.ts +0 -5
- package/dist/studio/components/connection/__tests__/setup.d.ts.map +0 -1
- package/dist/studio/components/connection/__tests__/setup.js +0 -11
- package/dist/studio/components/connection/__tests__/setup.js.map +0 -1
- package/dist/studio/components/connection/index.d.ts +0 -10
- package/dist/studio/components/connection/index.d.ts.map +0 -1
- package/dist/studio/components/connection/index.js +0 -7
- package/dist/studio/components/connection/index.js.map +0 -1
- package/dist/studio/components/crud/DeleteDocumentDialog.d.ts +0 -91
- package/dist/studio/components/crud/DeleteDocumentDialog.d.ts.map +0 -1
- package/dist/studio/components/crud/DeleteDocumentDialog.js +0 -273
- package/dist/studio/components/crud/DeleteDocumentDialog.js.map +0 -1
- package/dist/studio/components/crud/DocumentEditor.d.ts +0 -32
- package/dist/studio/components/crud/DocumentEditor.d.ts.map +0 -1
- package/dist/studio/components/crud/DocumentEditor.js +0 -546
- package/dist/studio/components/crud/DocumentEditor.js.map +0 -1
- package/dist/studio/components/crud/InsertDocumentDialog.d.ts +0 -78
- package/dist/studio/components/crud/InsertDocumentDialog.d.ts.map +0 -1
- package/dist/studio/components/crud/InsertDocumentDialog.js +0 -323
- package/dist/studio/components/crud/InsertDocumentDialog.js.map +0 -1
- package/dist/studio/components/crud/__tests__/DeleteDocumentDialog.test.d.ts +0 -5
- package/dist/studio/components/crud/__tests__/DeleteDocumentDialog.test.d.ts.map +0 -1
- package/dist/studio/components/crud/__tests__/DeleteDocumentDialog.test.js +0 -298
- package/dist/studio/components/crud/__tests__/DeleteDocumentDialog.test.js.map +0 -1
- package/dist/studio/components/crud/__tests__/DocumentEditor.test.d.ts +0 -8
- package/dist/studio/components/crud/__tests__/DocumentEditor.test.d.ts.map +0 -1
- package/dist/studio/components/crud/__tests__/DocumentEditor.test.js +0 -368
- package/dist/studio/components/crud/__tests__/DocumentEditor.test.js.map +0 -1
- package/dist/studio/components/crud/__tests__/InsertDocumentDialog.test.d.ts +0 -2
- package/dist/studio/components/crud/__tests__/InsertDocumentDialog.test.d.ts.map +0 -1
- package/dist/studio/components/crud/__tests__/InsertDocumentDialog.test.js +0 -352
- package/dist/studio/components/crud/__tests__/InsertDocumentDialog.test.js.map +0 -1
- package/dist/studio/components/crud/__tests__/setup.d.ts +0 -5
- package/dist/studio/components/crud/__tests__/setup.d.ts.map +0 -1
- package/dist/studio/components/crud/__tests__/setup.js +0 -22
- package/dist/studio/components/crud/__tests__/setup.js.map +0 -1
- package/dist/studio/components/crud/index.d.ts +0 -12
- package/dist/studio/components/crud/index.d.ts.map +0 -1
- package/dist/studio/components/crud/index.js +0 -11
- package/dist/studio/components/crud/index.js.map +0 -1
- package/dist/studio/hooks/useConnection.d.ts +0 -127
- package/dist/studio/hooks/useConnection.d.ts.map +0 -1
- package/dist/studio/hooks/useConnection.js +0 -414
- package/dist/studio/hooks/useConnection.js.map +0 -1
- package/dist/studio/hooks/useDatabaseBrowser.d.ts +0 -107
- package/dist/studio/hooks/useDatabaseBrowser.d.ts.map +0 -1
- package/dist/studio/hooks/useDatabaseBrowser.js +0 -294
- package/dist/studio/hooks/useDatabaseBrowser.js.map +0 -1
- package/dist/studio/index.d.ts +0 -16
- package/dist/studio/index.d.ts.map +0 -1
- package/dist/studio/index.js +0 -14
- package/dist/studio/index.js.map +0 -1
- package/dist/studio/types/connection.d.ts +0 -266
- package/dist/studio/types/connection.d.ts.map +0 -1
- package/dist/studio/types/connection.js +0 -159
- package/dist/studio/types/connection.js.map +0 -1
- package/dist/studio/vitest.config.d.ts +0 -3
- package/dist/studio/vitest.config.d.ts.map +0 -1
- package/dist/studio/vitest.config.js +0 -33
- package/dist/studio/vitest.config.js.map +0 -1
- package/dist/translator/aggregation-translator.d.ts +0 -51
- package/dist/translator/aggregation-translator.d.ts.map +0 -1
- package/dist/translator/aggregation-translator.js +0 -324
- package/dist/translator/aggregation-translator.js.map +0 -1
- package/dist/translator/dialect.d.ts +0 -131
- package/dist/translator/dialect.d.ts.map +0 -1
- package/dist/translator/dialect.js +0 -276
- package/dist/translator/dialect.js.map +0 -1
- package/dist/translator/geo-translator.d.ts +0 -91
- package/dist/translator/geo-translator.d.ts.map +0 -1
- package/dist/translator/geo-translator.js +0 -587
- package/dist/translator/geo-translator.js.map +0 -1
- package/dist/translator/hybrid-translator.d.ts +0 -70
- package/dist/translator/hybrid-translator.d.ts.map +0 -1
- package/dist/translator/hybrid-translator.js +0 -193
- package/dist/translator/hybrid-translator.js.map +0 -1
- package/dist/translator/index.d.ts +0 -13
- package/dist/translator/index.d.ts.map +0 -1
- package/dist/translator/index.js +0 -11
- package/dist/translator/index.js.map +0 -1
- package/dist/translator/query-translator.d.ts +0 -211
- package/dist/translator/query-translator.d.ts.map +0 -1
- package/dist/translator/query-translator.js +0 -1276
- package/dist/translator/query-translator.js.map +0 -1
- package/dist/translator/search-highlight.d.ts +0 -83
- package/dist/translator/search-highlight.d.ts.map +0 -1
- package/dist/translator/search-highlight.js +0 -83
- package/dist/translator/search-highlight.js.map +0 -1
- package/dist/translator/search-translator.d.ts +0 -155
- package/dist/translator/search-translator.d.ts.map +0 -1
- package/dist/translator/search-translator.js +0 -241
- package/dist/translator/search-translator.js.map +0 -1
- package/dist/translator/stages/add-fields-stage.d.ts +0 -7
- package/dist/translator/stages/add-fields-stage.d.ts.map +0 -1
- package/dist/translator/stages/add-fields-stage.js +0 -72
- package/dist/translator/stages/add-fields-stage.js.map +0 -1
- package/dist/translator/stages/bucket-stage.d.ts +0 -7
- package/dist/translator/stages/bucket-stage.d.ts.map +0 -1
- package/dist/translator/stages/bucket-stage.js +0 -87
- package/dist/translator/stages/bucket-stage.js.map +0 -1
- package/dist/translator/stages/count-stage.d.ts +0 -7
- package/dist/translator/stages/count-stage.d.ts.map +0 -1
- package/dist/translator/stages/count-stage.js +0 -12
- package/dist/translator/stages/count-stage.js.map +0 -1
- package/dist/translator/stages/expression-translator.d.ts +0 -68
- package/dist/translator/stages/expression-translator.d.ts.map +0 -1
- package/dist/translator/stages/expression-translator.js +0 -467
- package/dist/translator/stages/expression-translator.js.map +0 -1
- package/dist/translator/stages/facet-stage.d.ts +0 -13
- package/dist/translator/stages/facet-stage.d.ts.map +0 -1
- package/dist/translator/stages/facet-stage.js +0 -26
- package/dist/translator/stages/facet-stage.js.map +0 -1
- package/dist/translator/stages/fusion-stages.d.ts +0 -118
- package/dist/translator/stages/fusion-stages.d.ts.map +0 -1
- package/dist/translator/stages/fusion-stages.js +0 -201
- package/dist/translator/stages/fusion-stages.js.map +0 -1
- package/dist/translator/stages/group-stage.d.ts +0 -8
- package/dist/translator/stages/group-stage.d.ts.map +0 -1
- package/dist/translator/stages/group-stage.js +0 -123
- package/dist/translator/stages/group-stage.js.map +0 -1
- package/dist/translator/stages/index.d.ts +0 -24
- package/dist/translator/stages/index.d.ts.map +0 -1
- package/dist/translator/stages/index.js +0 -24
- package/dist/translator/stages/index.js.map +0 -1
- package/dist/translator/stages/join-optimizer.d.ts +0 -37
- package/dist/translator/stages/join-optimizer.d.ts.map +0 -1
- package/dist/translator/stages/join-optimizer.js +0 -93
- package/dist/translator/stages/join-optimizer.js.map +0 -1
- package/dist/translator/stages/limit-stage.d.ts +0 -7
- package/dist/translator/stages/limit-stage.d.ts.map +0 -1
- package/dist/translator/stages/limit-stage.js +0 -11
- package/dist/translator/stages/limit-stage.js.map +0 -1
- package/dist/translator/stages/lookup-stage.d.ts +0 -7
- package/dist/translator/stages/lookup-stage.d.ts.map +0 -1
- package/dist/translator/stages/lookup-stage.js +0 -73
- package/dist/translator/stages/lookup-stage.js.map +0 -1
- package/dist/translator/stages/match-stage.d.ts +0 -7
- package/dist/translator/stages/match-stage.d.ts.map +0 -1
- package/dist/translator/stages/match-stage.js +0 -14
- package/dist/translator/stages/match-stage.js.map +0 -1
- package/dist/translator/stages/optimizer.d.ts +0 -15
- package/dist/translator/stages/optimizer.d.ts.map +0 -1
- package/dist/translator/stages/optimizer.js +0 -249
- package/dist/translator/stages/optimizer.js.map +0 -1
- package/dist/translator/stages/parallel-facet.d.ts +0 -47
- package/dist/translator/stages/parallel-facet.d.ts.map +0 -1
- package/dist/translator/stages/parallel-facet.js +0 -57
- package/dist/translator/stages/parallel-facet.js.map +0 -1
- package/dist/translator/stages/project-stage.d.ts +0 -8
- package/dist/translator/stages/project-stage.d.ts.map +0 -1
- package/dist/translator/stages/project-stage.js +0 -145
- package/dist/translator/stages/project-stage.js.map +0 -1
- package/dist/translator/stages/search-stage.d.ts +0 -60
- package/dist/translator/stages/search-stage.d.ts.map +0 -1
- package/dist/translator/stages/search-stage.js +0 -89
- package/dist/translator/stages/search-stage.js.map +0 -1
- package/dist/translator/stages/skip-stage.d.ts +0 -7
- package/dist/translator/stages/skip-stage.d.ts.map +0 -1
- package/dist/translator/stages/skip-stage.js +0 -11
- package/dist/translator/stages/skip-stage.js.map +0 -1
- package/dist/translator/stages/sort-stage.d.ts +0 -7
- package/dist/translator/stages/sort-stage.d.ts.map +0 -1
- package/dist/translator/stages/sort-stage.js +0 -21
- package/dist/translator/stages/sort-stage.js.map +0 -1
- package/dist/translator/stages/types.d.ts +0 -136
- package/dist/translator/stages/types.d.ts.map +0 -1
- package/dist/translator/stages/types.js +0 -5
- package/dist/translator/stages/types.js.map +0 -1
- package/dist/translator/stages/unwind-stage.d.ts +0 -7
- package/dist/translator/stages/unwind-stage.d.ts.map +0 -1
- package/dist/translator/stages/unwind-stage.js +0 -61
- package/dist/translator/stages/unwind-stage.js.map +0 -1
- package/dist/translator/stages/vector-search-stage.d.ts +0 -53
- package/dist/translator/stages/vector-search-stage.d.ts.map +0 -1
- package/dist/translator/stages/vector-search-stage.js +0 -62
- package/dist/translator/stages/vector-search-stage.js.map +0 -1
- package/dist/translator/update-translator.d.ts +0 -148
- package/dist/translator/update-translator.d.ts.map +0 -1
- package/dist/translator/update-translator.js +0 -819
- package/dist/translator/update-translator.js.map +0 -1
- package/dist/translator/vector-translator.d.ts +0 -89
- package/dist/translator/vector-translator.d.ts.map +0 -1
- package/dist/translator/vector-translator.js +0 -106
- package/dist/translator/vector-translator.js.map +0 -1
- package/dist/types/env.d.ts +0 -31
- package/dist/types/env.d.ts.map +0 -1
- package/dist/types/env.js +0 -5
- package/dist/types/env.js.map +0 -1
- package/dist/types/function.d.ts +0 -65
- package/dist/types/function.d.ts.map +0 -1
- package/dist/types/function.js +0 -5
- package/dist/types/function.js.map +0 -1
- package/dist/types/index.d.ts +0 -137
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/index.js +0 -13
- package/dist/types/index.js.map +0 -1
- package/dist/types/mongodb.d.ts +0 -258
- package/dist/types/mongodb.d.ts.map +0 -1
- package/dist/types/mongodb.js +0 -5
- package/dist/types/mongodb.js.map +0 -1
- package/dist/types/objectid.d.ts +0 -130
- package/dist/types/objectid.d.ts.map +0 -1
- package/dist/types/objectid.js +0 -314
- package/dist/types/objectid.js.map +0 -1
- package/dist/types/rpc.d.ts +0 -313
- package/dist/types/rpc.d.ts.map +0 -1
- package/dist/types/rpc.js +0 -136
- package/dist/types/rpc.js.map +0 -1
- package/dist/types/vectorize.d.ts +0 -136
- package/dist/types/vectorize.d.ts.map +0 -1
- package/dist/types/vectorize.js +0 -8
- package/dist/types/vectorize.js.map +0 -1
- package/dist/utils/sql-safety.d.ts +0 -64
- package/dist/utils/sql-safety.d.ts.map +0 -1
- package/dist/utils/sql-safety.js +0 -112
- package/dist/utils/sql-safety.js.map +0 -1
- package/dist/validation/document-validator.d.ts +0 -195
- package/dist/validation/document-validator.d.ts.map +0 -1
- package/dist/validation/document-validator.js +0 -529
- package/dist/validation/document-validator.js.map +0 -1
- package/dist/vectorize/document-serializer.d.ts +0 -119
- package/dist/vectorize/document-serializer.d.ts.map +0 -1
- package/dist/vectorize/document-serializer.js +0 -320
- package/dist/vectorize/document-serializer.js.map +0 -1
- package/dist/wire/auth/index.d.ts +0 -5
- package/dist/wire/auth/index.d.ts.map +0 -1
- package/dist/wire/auth/index.js +0 -5
- package/dist/wire/auth/index.js.map +0 -1
- package/dist/wire/auth/scram.d.ts +0 -160
- package/dist/wire/auth/scram.d.ts.map +0 -1
- package/dist/wire/auth/scram.js +0 -425
- package/dist/wire/auth/scram.js.map +0 -1
- package/dist/wire/backend/interface.d.ts +0 -168
- package/dist/wire/backend/interface.d.ts.map +0 -1
- package/dist/wire/backend/interface.js +0 -10
- package/dist/wire/backend/interface.js.map +0 -1
- package/dist/wire/backend/local-sqlite.d.ts +0 -89
- package/dist/wire/backend/local-sqlite.d.ts.map +0 -1
- package/dist/wire/backend/local-sqlite.js +0 -1002
- package/dist/wire/backend/local-sqlite.js.map +0 -1
- package/dist/wire/backend/query-router.d.ts +0 -197
- package/dist/wire/backend/query-router.d.ts.map +0 -1
- package/dist/wire/backend/query-router.js +0 -590
- package/dist/wire/backend/query-router.js.map +0 -1
- package/dist/wire/backend/validation.d.ts +0 -26
- package/dist/wire/backend/validation.d.ts.map +0 -1
- package/dist/wire/backend/validation.js +0 -79
- package/dist/wire/backend/validation.js.map +0 -1
- package/dist/wire/backend/workers-proxy.d.ts +0 -95
- package/dist/wire/backend/workers-proxy.d.ts.map +0 -1
- package/dist/wire/backend/workers-proxy.js +0 -429
- package/dist/wire/backend/workers-proxy.js.map +0 -1
- package/dist/wire/commands/admin.d.ts +0 -49
- package/dist/wire/commands/admin.d.ts.map +0 -1
- package/dist/wire/commands/admin.js +0 -272
- package/dist/wire/commands/admin.js.map +0 -1
- package/dist/wire/commands/aggregate.d.ts +0 -15
- package/dist/wire/commands/aggregate.d.ts.map +0 -1
- package/dist/wire/commands/aggregate.js +0 -98
- package/dist/wire/commands/aggregate.js.map +0 -1
- package/dist/wire/commands/auth.d.ts +0 -58
- package/dist/wire/commands/auth.d.ts.map +0 -1
- package/dist/wire/commands/auth.js +0 -158
- package/dist/wire/commands/auth.js.map +0 -1
- package/dist/wire/commands/crud.d.ts +0 -49
- package/dist/wire/commands/crud.d.ts.map +0 -1
- package/dist/wire/commands/crud.js +0 -336
- package/dist/wire/commands/crud.js.map +0 -1
- package/dist/wire/commands/hello.d.ts +0 -35
- package/dist/wire/commands/hello.d.ts.map +0 -1
- package/dist/wire/commands/hello.js +0 -204
- package/dist/wire/commands/hello.js.map +0 -1
- package/dist/wire/commands/index.d.ts +0 -24
- package/dist/wire/commands/index.d.ts.map +0 -1
- package/dist/wire/commands/index.js +0 -145
- package/dist/wire/commands/index.js.map +0 -1
- package/dist/wire/commands/router.d.ts +0 -46
- package/dist/wire/commands/router.d.ts.map +0 -1
- package/dist/wire/commands/router.js +0 -151
- package/dist/wire/commands/router.js.map +0 -1
- package/dist/wire/commands/types.d.ts +0 -51
- package/dist/wire/commands/types.d.ts.map +0 -1
- package/dist/wire/commands/types.js +0 -15
- package/dist/wire/commands/types.js.map +0 -1
- package/dist/wire/index.d.ts +0 -15
- package/dist/wire/index.d.ts.map +0 -1
- package/dist/wire/index.js +0 -19
- package/dist/wire/index.js.map +0 -1
- package/dist/wire/message.d.ts +0 -49
- package/dist/wire/message.d.ts.map +0 -1
- package/dist/wire/message.js +0 -299
- package/dist/wire/message.js.map +0 -1
- package/dist/wire/server.d.ts +0 -145
- package/dist/wire/server.d.ts.map +0 -1
- package/dist/wire/server.js +0 -284
- package/dist/wire/server.js.map +0 -1
- package/dist/wire/types.d.ts +0 -140
- package/dist/wire/types.d.ts.map +0 -1
- package/dist/wire/types.js +0 -64
- package/dist/wire/types.js.map +0 -1
- package/dist/worker.d.ts.map +0 -1
|
@@ -1,131 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* SQL Dialect Support - Types and helpers for multi-database SQL generation
|
|
3
|
-
*
|
|
4
|
-
* Supports:
|
|
5
|
-
* - sqlite: Default dialect, uses json_extract, CAST, etc.
|
|
6
|
-
* - clickhouse: Uses JSONExtract*, toInt32, groupArray, etc.
|
|
7
|
-
*/
|
|
8
|
-
export type SQLDialect = 'sqlite' | 'clickhouse';
|
|
9
|
-
export interface DialectOptions {
|
|
10
|
-
/** SQL dialect to use (default: 'sqlite') */
|
|
11
|
-
dialect?: SQLDialect;
|
|
12
|
-
/** For ClickHouse: use positional ? parameters instead of typed {name:Type} */
|
|
13
|
-
parameterMode?: 'positional' | 'typed';
|
|
14
|
-
/** For ClickHouse: add WITH TOTALS to GROUP BY */
|
|
15
|
-
withTotals?: boolean;
|
|
16
|
-
/** For ClickHouse: add FINAL modifier for ReplacingMergeTree tables */
|
|
17
|
-
useFinal?: boolean;
|
|
18
|
-
/** For ClickHouse: use PREWHERE instead of WHERE for optimization */
|
|
19
|
-
usePrewhere?: boolean;
|
|
20
|
-
}
|
|
21
|
-
/**
|
|
22
|
-
* Validate dialect option and return normalized value
|
|
23
|
-
*/
|
|
24
|
-
export declare function validateDialect(dialect?: SQLDialect): SQLDialect;
|
|
25
|
-
/**
|
|
26
|
-
* Helper to choose SQL syntax based on dialect
|
|
27
|
-
* @param dialect The SQL dialect
|
|
28
|
-
* @param options Object with dialect-specific SQL strings
|
|
29
|
-
*/
|
|
30
|
-
export declare function dialectFn<T>(dialect: SQLDialect, options: {
|
|
31
|
-
sqlite: T;
|
|
32
|
-
clickhouse: T;
|
|
33
|
-
}): T;
|
|
34
|
-
/**
|
|
35
|
-
* JSON Extract functions by dialect
|
|
36
|
-
*/
|
|
37
|
-
export declare function jsonExtract(dialect: SQLDialect, dataColumn: string, path: string): string;
|
|
38
|
-
/**
|
|
39
|
-
* JSON type checking by dialect
|
|
40
|
-
*/
|
|
41
|
-
export declare function jsonType(dialect: SQLDialect, dataColumn: string, path: string): string;
|
|
42
|
-
/**
|
|
43
|
-
* JSON type checking with path argument directly (for $exists)
|
|
44
|
-
*/
|
|
45
|
-
export declare function jsonTypeWithPath(dialect: SQLDialect, dataColumn: string, path: string): string;
|
|
46
|
-
/**
|
|
47
|
-
* JSON array length by dialect
|
|
48
|
-
*/
|
|
49
|
-
export declare function jsonArrayLength(dialect: SQLDialect, dataColumn: string, path: string): string;
|
|
50
|
-
/**
|
|
51
|
-
* Type casting by dialect
|
|
52
|
-
*/
|
|
53
|
-
export interface CastOptions {
|
|
54
|
-
toInt: (expr: string) => string;
|
|
55
|
-
toDouble: (expr: string) => string;
|
|
56
|
-
toString: (expr: string) => string;
|
|
57
|
-
toDate: (expr: string) => string;
|
|
58
|
-
toDecimal: (expr: string) => string;
|
|
59
|
-
}
|
|
60
|
-
export declare function getCastFunctions(dialect: SQLDialect): CastOptions;
|
|
61
|
-
/**
|
|
62
|
-
* Aggregation functions by dialect
|
|
63
|
-
*/
|
|
64
|
-
export interface AggregationFunctions {
|
|
65
|
-
push: (expr: string) => string;
|
|
66
|
-
addToSet: (expr: string) => string;
|
|
67
|
-
first: (expr: string) => string;
|
|
68
|
-
last: (expr: string) => string;
|
|
69
|
-
sum: (expr: string) => string;
|
|
70
|
-
avg: (expr: string) => string;
|
|
71
|
-
min: (expr: string) => string;
|
|
72
|
-
max: (expr: string) => string;
|
|
73
|
-
count: () => string;
|
|
74
|
-
}
|
|
75
|
-
export declare function getAggregationFunctions(dialect: SQLDialect): AggregationFunctions;
|
|
76
|
-
/**
|
|
77
|
-
* String functions by dialect
|
|
78
|
-
*/
|
|
79
|
-
export interface StringFunctions {
|
|
80
|
-
indexOf: (str: string, search: string) => string;
|
|
81
|
-
strLength: (str: string) => string;
|
|
82
|
-
replaceAll: (str: string, find: string, replace: string) => string;
|
|
83
|
-
lower: (str: string) => string;
|
|
84
|
-
upper: (str: string) => string;
|
|
85
|
-
substr: (str: string, start: string, len: string) => string;
|
|
86
|
-
concat: (parts: string[]) => string;
|
|
87
|
-
}
|
|
88
|
-
export declare function getStringFunctions(dialect: SQLDialect): StringFunctions;
|
|
89
|
-
/**
|
|
90
|
-
* Date functions by dialect
|
|
91
|
-
*/
|
|
92
|
-
export interface DateFunctions {
|
|
93
|
-
fromString: (str: string) => string;
|
|
94
|
-
toString: (date: string, format: string) => string;
|
|
95
|
-
year: (date: string) => string;
|
|
96
|
-
month: (date: string) => string;
|
|
97
|
-
day: (date: string) => string;
|
|
98
|
-
hour: (date: string) => string;
|
|
99
|
-
minute: (date: string) => string;
|
|
100
|
-
second: (date: string) => string;
|
|
101
|
-
dateDiff: (unit: string, start: string, end: string) => string;
|
|
102
|
-
dateAdd: (date: string, unit: string, amount: string) => string;
|
|
103
|
-
dateTrunc: (date: string, unit: string) => string;
|
|
104
|
-
}
|
|
105
|
-
export declare function getDateFunctions(dialect: SQLDialect): DateFunctions;
|
|
106
|
-
/**
|
|
107
|
-
* Array functions by dialect
|
|
108
|
-
*/
|
|
109
|
-
export interface ArrayFunctions {
|
|
110
|
-
unwind: (source: string, arrayPath: string, aliasName: string) => {
|
|
111
|
-
sql: string;
|
|
112
|
-
joinType: 'JOIN' | 'ARRAY JOIN';
|
|
113
|
-
};
|
|
114
|
-
filter: (array: string, varName: string, condition: string) => string;
|
|
115
|
-
map: (array: string, varName: string, expr: string) => string;
|
|
116
|
-
reduce: (array: string, initial: string, varName: string, accName: string, expr: string) => string;
|
|
117
|
-
slice: (array: string, start: string, count?: string) => string;
|
|
118
|
-
concat: (arrays: string[]) => string;
|
|
119
|
-
in: (value: string, array: string) => string;
|
|
120
|
-
}
|
|
121
|
-
export declare function getArrayFunctions(dialect: SQLDialect): ArrayFunctions;
|
|
122
|
-
/**
|
|
123
|
-
* Regex/pattern matching by dialect
|
|
124
|
-
*/
|
|
125
|
-
export declare function regexMatch(dialect: SQLDialect, column: string, pattern: string, caseInsensitive: boolean): string;
|
|
126
|
-
/**
|
|
127
|
-
* NULL handling by dialect
|
|
128
|
-
*/
|
|
129
|
-
export declare function nullCheck(_dialect: SQLDialect, column: string): string;
|
|
130
|
-
export declare function ifNull(dialect: SQLDialect, exprs: string[]): string;
|
|
131
|
-
//# sourceMappingURL=dialect.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dialect.d.ts","sourceRoot":"","sources":["../../src/translator/dialect.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,276 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* SQL Dialect Support - Types and helpers for multi-database SQL generation
|
|
3
|
-
*
|
|
4
|
-
* Supports:
|
|
5
|
-
* - sqlite: Default dialect, uses json_extract, CAST, etc.
|
|
6
|
-
* - clickhouse: Uses JSONExtract*, toInt32, groupArray, etc.
|
|
7
|
-
*/
|
|
8
|
-
const VALID_DIALECTS = ['sqlite', 'clickhouse'];
|
|
9
|
-
/**
|
|
10
|
-
* Validate dialect option and return normalized value
|
|
11
|
-
*/
|
|
12
|
-
export function validateDialect(dialect) {
|
|
13
|
-
if (!dialect)
|
|
14
|
-
return 'sqlite';
|
|
15
|
-
if (!VALID_DIALECTS.includes(dialect)) {
|
|
16
|
-
throw new Error(`Invalid dialect '${dialect}'. Supported dialects: ${VALID_DIALECTS.join(', ')}`);
|
|
17
|
-
}
|
|
18
|
-
return dialect;
|
|
19
|
-
}
|
|
20
|
-
/**
|
|
21
|
-
* Helper to choose SQL syntax based on dialect
|
|
22
|
-
* @param dialect The SQL dialect
|
|
23
|
-
* @param options Object with dialect-specific SQL strings
|
|
24
|
-
*/
|
|
25
|
-
export function dialectFn(dialect, options) {
|
|
26
|
-
return options[dialect];
|
|
27
|
-
}
|
|
28
|
-
/**
|
|
29
|
-
* JSON Extract functions by dialect
|
|
30
|
-
*/
|
|
31
|
-
export function jsonExtract(dialect, dataColumn, path) {
|
|
32
|
-
if (dialect === 'clickhouse') {
|
|
33
|
-
// Convert $.field.nested to 'field', 'nested' format
|
|
34
|
-
const parts = path.replace(/^\$\.?/, '').split('.');
|
|
35
|
-
if (parts.length === 1 && parts[0] === '') {
|
|
36
|
-
return dataColumn; // root path
|
|
37
|
-
}
|
|
38
|
-
const pathArgs = parts.map(p => `'${p}'`).join(', ');
|
|
39
|
-
return `JSONExtractRaw(${dataColumn}, ${pathArgs})`;
|
|
40
|
-
}
|
|
41
|
-
// SQLite
|
|
42
|
-
return `json_extract(${dataColumn}, '${path}')`;
|
|
43
|
-
}
|
|
44
|
-
/**
|
|
45
|
-
* JSON type checking by dialect
|
|
46
|
-
*/
|
|
47
|
-
export function jsonType(dialect, dataColumn, path) {
|
|
48
|
-
if (dialect === 'clickhouse') {
|
|
49
|
-
const parts = path.replace(/^\$\.?/, '').split('.');
|
|
50
|
-
const pathArgs = parts.filter(p => p).map(p => `'${p}'`).join(', ');
|
|
51
|
-
if (pathArgs) {
|
|
52
|
-
return `JSONType(${dataColumn}, ${pathArgs})`;
|
|
53
|
-
}
|
|
54
|
-
return `JSONType(${dataColumn})`;
|
|
55
|
-
}
|
|
56
|
-
// SQLite - use json_extract then json_type for consistency
|
|
57
|
-
return `json_type(json_extract(${dataColumn}, '${path}'))`;
|
|
58
|
-
}
|
|
59
|
-
/**
|
|
60
|
-
* JSON type checking with path argument directly (for $exists)
|
|
61
|
-
*/
|
|
62
|
-
export function jsonTypeWithPath(dialect, dataColumn, path) {
|
|
63
|
-
if (dialect === 'clickhouse') {
|
|
64
|
-
const parts = path.replace(/^\$\.?/, '').split('.');
|
|
65
|
-
const pathArgs = parts.filter(p => p).map(p => `'${p}'`).join(', ');
|
|
66
|
-
if (pathArgs) {
|
|
67
|
-
return `JSONType(${dataColumn}, ${pathArgs})`;
|
|
68
|
-
}
|
|
69
|
-
return `JSONType(${dataColumn})`;
|
|
70
|
-
}
|
|
71
|
-
// SQLite - json_type can take data and path directly for existence checks
|
|
72
|
-
return `json_type(${dataColumn}, '${path}')`;
|
|
73
|
-
}
|
|
74
|
-
/**
|
|
75
|
-
* JSON array length by dialect
|
|
76
|
-
*/
|
|
77
|
-
export function jsonArrayLength(dialect, dataColumn, path) {
|
|
78
|
-
if (dialect === 'clickhouse') {
|
|
79
|
-
const parts = path.replace(/^\$\.?/, '').split('.');
|
|
80
|
-
const pathArgs = parts.filter(p => p).map(p => `'${p}'`).join(', ');
|
|
81
|
-
return `JSONLength(${dataColumn}, ${pathArgs})`;
|
|
82
|
-
}
|
|
83
|
-
// SQLite
|
|
84
|
-
return `json_array_length(json_extract(${dataColumn}, '${path}'))`;
|
|
85
|
-
}
|
|
86
|
-
export function getCastFunctions(dialect) {
|
|
87
|
-
if (dialect === 'clickhouse') {
|
|
88
|
-
return {
|
|
89
|
-
toInt: (expr) => `toInt64(${expr})`,
|
|
90
|
-
toDouble: (expr) => `toFloat64(${expr})`,
|
|
91
|
-
toString: (expr) => `toString(${expr})`,
|
|
92
|
-
toDate: (expr) => `toDateTime(${expr})`,
|
|
93
|
-
toDecimal: (expr) => `toDecimal64(${expr}, 4)`
|
|
94
|
-
};
|
|
95
|
-
}
|
|
96
|
-
// SQLite
|
|
97
|
-
return {
|
|
98
|
-
toInt: (expr) => `CAST(${expr} AS INTEGER)`,
|
|
99
|
-
toDouble: (expr) => `CAST(${expr} AS REAL)`,
|
|
100
|
-
toString: (expr) => `CAST(${expr} AS TEXT)`,
|
|
101
|
-
toDate: (expr) => `datetime(${expr})`,
|
|
102
|
-
toDecimal: (expr) => `CAST(${expr} AS REAL)`
|
|
103
|
-
};
|
|
104
|
-
}
|
|
105
|
-
export function getAggregationFunctions(dialect) {
|
|
106
|
-
if (dialect === 'clickhouse') {
|
|
107
|
-
return {
|
|
108
|
-
push: (expr) => `groupArray(${expr})`,
|
|
109
|
-
addToSet: (expr) => `groupUniqArray(${expr})`,
|
|
110
|
-
first: (expr) => `any(${expr})`,
|
|
111
|
-
last: (expr) => `anyLast(${expr})`,
|
|
112
|
-
sum: (expr) => `sum(${expr})`,
|
|
113
|
-
avg: (expr) => `avg(${expr})`,
|
|
114
|
-
min: (expr) => `min(${expr})`,
|
|
115
|
-
max: (expr) => `max(${expr})`,
|
|
116
|
-
count: () => `count()`
|
|
117
|
-
};
|
|
118
|
-
}
|
|
119
|
-
// SQLite
|
|
120
|
-
return {
|
|
121
|
-
push: (expr) => `json_group_array(${expr})`,
|
|
122
|
-
addToSet: (expr) => `json_group_array(DISTINCT ${expr})`,
|
|
123
|
-
first: (expr) => `(SELECT ${expr} LIMIT 1)`,
|
|
124
|
-
last: (expr) => `(SELECT ${expr} ORDER BY ROWID DESC LIMIT 1)`,
|
|
125
|
-
sum: (expr) => `SUM(${expr})`,
|
|
126
|
-
avg: (expr) => `AVG(${expr})`,
|
|
127
|
-
min: (expr) => `MIN(${expr})`,
|
|
128
|
-
max: (expr) => `MAX(${expr})`,
|
|
129
|
-
count: () => `COUNT(*)`
|
|
130
|
-
};
|
|
131
|
-
}
|
|
132
|
-
export function getStringFunctions(dialect) {
|
|
133
|
-
if (dialect === 'clickhouse') {
|
|
134
|
-
return {
|
|
135
|
-
indexOf: (str, search) => `position(${str}, ${search})`,
|
|
136
|
-
strLength: (str) => `length(${str})`,
|
|
137
|
-
replaceAll: (str, find, replace) => `replaceAll(${str}, ${find}, ${replace})`,
|
|
138
|
-
lower: (str) => `lower(${str})`,
|
|
139
|
-
upper: (str) => `upper(${str})`,
|
|
140
|
-
substr: (str, start, len) => `substring(${str}, ${start} + 1, ${len})`,
|
|
141
|
-
concat: (parts) => `concat(${parts.join(', ')})`
|
|
142
|
-
};
|
|
143
|
-
}
|
|
144
|
-
// SQLite
|
|
145
|
-
return {
|
|
146
|
-
indexOf: (str, search) => `INSTR(${str}, ${search})`,
|
|
147
|
-
strLength: (str) => `LENGTH(${str})`,
|
|
148
|
-
replaceAll: (str, find, replace) => `REPLACE(${str}, ${find}, ${replace})`,
|
|
149
|
-
lower: (str) => `LOWER(${str})`,
|
|
150
|
-
upper: (str) => `UPPER(${str})`,
|
|
151
|
-
substr: (str, start, len) => `SUBSTR(${str}, ${start} + 1, ${len})`,
|
|
152
|
-
concat: (parts) => parts.join(' || ')
|
|
153
|
-
};
|
|
154
|
-
}
|
|
155
|
-
export function getDateFunctions(dialect) {
|
|
156
|
-
if (dialect === 'clickhouse') {
|
|
157
|
-
return {
|
|
158
|
-
fromString: (str) => `parseDateTimeBestEffort(${str})`,
|
|
159
|
-
toString: (date, format) => `formatDateTime(${date}, ${format})`,
|
|
160
|
-
year: (date) => `toYear(${date})`,
|
|
161
|
-
month: (date) => `toMonth(${date})`,
|
|
162
|
-
day: (date) => `toDayOfMonth(${date})`,
|
|
163
|
-
hour: (date) => `toHour(${date})`,
|
|
164
|
-
minute: (date) => `toMinute(${date})`,
|
|
165
|
-
second: (date) => `toSecond(${date})`,
|
|
166
|
-
dateDiff: (unit, start, end) => `dateDiff('${unit}', ${start}, ${end})`,
|
|
167
|
-
dateAdd: (date, unit, amount) => `dateAdd(${unit}, ${amount}, ${date})`,
|
|
168
|
-
dateTrunc: (date, unit) => {
|
|
169
|
-
const fnMap = {
|
|
170
|
-
day: 'toStartOfDay',
|
|
171
|
-
month: 'toStartOfMonth',
|
|
172
|
-
year: 'toStartOfYear',
|
|
173
|
-
hour: 'toStartOfHour',
|
|
174
|
-
minute: 'toStartOfMinute'
|
|
175
|
-
};
|
|
176
|
-
return `${fnMap[unit] || 'toStartOfDay'}(${date})`;
|
|
177
|
-
}
|
|
178
|
-
};
|
|
179
|
-
}
|
|
180
|
-
// SQLite
|
|
181
|
-
return {
|
|
182
|
-
fromString: (str) => `datetime(${str})`,
|
|
183
|
-
toString: (date, format) => `strftime(${format}, ${date})`,
|
|
184
|
-
year: (date) => `CAST(strftime('%Y', ${date}) AS INTEGER)`,
|
|
185
|
-
month: (date) => `CAST(strftime('%m', ${date}) AS INTEGER)`,
|
|
186
|
-
day: (date) => `CAST(strftime('%d', ${date}) AS INTEGER)`,
|
|
187
|
-
hour: (date) => `CAST(strftime('%H', ${date}) AS INTEGER)`,
|
|
188
|
-
minute: (date) => `CAST(strftime('%M', ${date}) AS INTEGER)`,
|
|
189
|
-
second: (date) => `CAST(strftime('%S', ${date}) AS INTEGER)`,
|
|
190
|
-
dateDiff: (unit, start, end) => {
|
|
191
|
-
if (unit === 'day') {
|
|
192
|
-
return `CAST(julianday(${end}) - julianday(${start}) AS INTEGER)`;
|
|
193
|
-
}
|
|
194
|
-
return `CAST((julianday(${end}) - julianday(${start})) * 24 AS INTEGER)`; // hours
|
|
195
|
-
},
|
|
196
|
-
dateAdd: (date, unit, amount) => `datetime(${date}, '+' || ${amount} || ' ${unit}')`,
|
|
197
|
-
dateTrunc: (date, unit) => {
|
|
198
|
-
if (unit === 'day') {
|
|
199
|
-
return `date(${date})`;
|
|
200
|
-
}
|
|
201
|
-
if (unit === 'month') {
|
|
202
|
-
return `date(${date}, 'start of month')`;
|
|
203
|
-
}
|
|
204
|
-
if (unit === 'year') {
|
|
205
|
-
return `date(${date}, 'start of year')`;
|
|
206
|
-
}
|
|
207
|
-
return `datetime(${date})`;
|
|
208
|
-
}
|
|
209
|
-
};
|
|
210
|
-
}
|
|
211
|
-
export function getArrayFunctions(dialect) {
|
|
212
|
-
if (dialect === 'clickhouse') {
|
|
213
|
-
return {
|
|
214
|
-
unwind: (_source, arrayPath, aliasName) => ({
|
|
215
|
-
sql: `${arrayPath} AS ${aliasName}`,
|
|
216
|
-
joinType: 'ARRAY JOIN'
|
|
217
|
-
}),
|
|
218
|
-
filter: (array, varName, condition) => `arrayFilter(${varName} -> ${condition}, ${array})`,
|
|
219
|
-
map: (array, varName, expr) => `arrayMap(${varName} -> ${expr}, ${array})`,
|
|
220
|
-
reduce: (array, _initial, _varName, _accName, _expr) => `arrayReduce('sumState', ${array})`,
|
|
221
|
-
slice: (array, start, count) => count ? `arraySlice(${array}, ${start}, ${count})` : `arraySlice(${array}, ${start})`,
|
|
222
|
-
concat: (arrays) => `arrayConcat(${arrays.join(', ')})`,
|
|
223
|
-
in: (value, array) => `has(${array}, ${value})`
|
|
224
|
-
};
|
|
225
|
-
}
|
|
226
|
-
// SQLite
|
|
227
|
-
return {
|
|
228
|
-
unwind: (_source, arrayPath, aliasName) => ({
|
|
229
|
-
sql: `json_each(${arrayPath}) AS ${aliasName}`,
|
|
230
|
-
joinType: 'JOIN'
|
|
231
|
-
}),
|
|
232
|
-
filter: (array, varName, condition) => `(SELECT json_group_array(value) FROM json_each(${array}) WHERE ${condition.replace(new RegExp(varName, 'g'), 'value')})`,
|
|
233
|
-
map: (array, varName, expr) => `(SELECT json_group_array(${expr.replace(new RegExp(varName, 'g'), 'value')}) FROM json_each(${array}))`,
|
|
234
|
-
reduce: (array, initial, _varName, _accName, _expr) => `(SELECT ${initial} + TOTAL(value) FROM json_each(${array}))`,
|
|
235
|
-
slice: (array, start, count) => count
|
|
236
|
-
? `(SELECT json_group_array(value) FROM (SELECT value FROM json_each(${array}) LIMIT ${count} OFFSET ${start}))`
|
|
237
|
-
: `(SELECT json_group_array(value) FROM (SELECT value FROM json_each(${array}) OFFSET ${start}))`,
|
|
238
|
-
concat: (arrays) => arrays.length === 2 ? `json_array(${arrays[0]}, ${arrays[1]})` : `json_array(${arrays.join(', ')})`,
|
|
239
|
-
in: (value, array) => `EXISTS (SELECT 1 FROM json_each(${array}) WHERE value = ${value})`
|
|
240
|
-
};
|
|
241
|
-
}
|
|
242
|
-
/**
|
|
243
|
-
* Regex/pattern matching by dialect
|
|
244
|
-
*/
|
|
245
|
-
export function regexMatch(dialect, column, pattern, caseInsensitive) {
|
|
246
|
-
if (dialect === 'clickhouse') {
|
|
247
|
-
if (caseInsensitive) {
|
|
248
|
-
return `${column} ILIKE ${pattern}`;
|
|
249
|
-
}
|
|
250
|
-
return `${column} LIKE ${pattern}`;
|
|
251
|
-
}
|
|
252
|
-
// SQLite
|
|
253
|
-
if (caseInsensitive) {
|
|
254
|
-
return `LOWER(${column}) LIKE LOWER(${pattern})`;
|
|
255
|
-
}
|
|
256
|
-
return `${column} LIKE ${pattern}`;
|
|
257
|
-
}
|
|
258
|
-
/**
|
|
259
|
-
* NULL handling by dialect
|
|
260
|
-
*/
|
|
261
|
-
export function nullCheck(_dialect, column) {
|
|
262
|
-
// Both dialects support IS NULL
|
|
263
|
-
return `${column} IS NULL`;
|
|
264
|
-
}
|
|
265
|
-
export function ifNull(dialect, exprs) {
|
|
266
|
-
if (dialect === 'clickhouse') {
|
|
267
|
-
// ClickHouse supports ifNull for 2 args, coalesce for more
|
|
268
|
-
if (exprs.length === 2) {
|
|
269
|
-
return `ifNull(${exprs[0]}, ${exprs[1]})`;
|
|
270
|
-
}
|
|
271
|
-
return `coalesce(${exprs.join(', ')})`;
|
|
272
|
-
}
|
|
273
|
-
// SQLite uses COALESCE
|
|
274
|
-
return `COALESCE(${exprs.join(', ')})`;
|
|
275
|
-
}
|
|
276
|
-
//# sourceMappingURL=dialect.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dialect.js","sourceRoot":"","sources":["../../src/translator/dialect.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,91 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* GeoTranslator - Translates MongoDB geospatial queries to SQLite SQL
|
|
3
|
-
*
|
|
4
|
-
* Supports:
|
|
5
|
-
* - $geoWithin: Find documents within a specified shape
|
|
6
|
-
* - $geoIntersects: Find documents that intersect with a GeoJSON shape
|
|
7
|
-
* - $near: Find documents near a point (sorted by distance)
|
|
8
|
-
* - $nearSphere: Find documents near a point on a sphere (sorted by distance)
|
|
9
|
-
*
|
|
10
|
-
* GeoJSON Types:
|
|
11
|
-
* - Point
|
|
12
|
-
* - Polygon
|
|
13
|
-
* - LineString
|
|
14
|
-
* - MultiPoint
|
|
15
|
-
*
|
|
16
|
-
* Uses Haversine formula for spherical distance calculations
|
|
17
|
-
*/
|
|
18
|
-
export interface GeoPoint {
|
|
19
|
-
type: 'Point';
|
|
20
|
-
coordinates: [number, number];
|
|
21
|
-
}
|
|
22
|
-
export interface GeoPolygon {
|
|
23
|
-
type: 'Polygon';
|
|
24
|
-
coordinates: [number, number][][];
|
|
25
|
-
}
|
|
26
|
-
export interface GeoLineString {
|
|
27
|
-
type: 'LineString';
|
|
28
|
-
coordinates: [number, number][];
|
|
29
|
-
}
|
|
30
|
-
export interface GeoMultiPoint {
|
|
31
|
-
type: 'MultiPoint';
|
|
32
|
-
coordinates: [number, number][];
|
|
33
|
-
}
|
|
34
|
-
export type GeoJSON = GeoPoint | GeoPolygon | GeoLineString | GeoMultiPoint;
|
|
35
|
-
export interface TranslatedGeoQuery {
|
|
36
|
-
sql: string;
|
|
37
|
-
params: unknown[];
|
|
38
|
-
orderBy?: string;
|
|
39
|
-
}
|
|
40
|
-
export declare class GeoTranslator {
|
|
41
|
-
private geoOperators;
|
|
42
|
-
constructor();
|
|
43
|
-
/**
|
|
44
|
-
* Validates a GeoJSON object
|
|
45
|
-
*/
|
|
46
|
-
isValidGeoJSON(geo: unknown): boolean;
|
|
47
|
-
private isValidPoint;
|
|
48
|
-
private isValidPolygon;
|
|
49
|
-
private isValidLineString;
|
|
50
|
-
private isValidMultiPoint;
|
|
51
|
-
/**
|
|
52
|
-
* Calculate Haversine distance between two points in meters
|
|
53
|
-
*/
|
|
54
|
-
calculateHaversineDistance(lng1: number, lat1: number, lng2: number, lat2: number): number;
|
|
55
|
-
/**
|
|
56
|
-
* Generate SQL for Haversine distance calculation
|
|
57
|
-
*/
|
|
58
|
-
private generateHaversineSQL;
|
|
59
|
-
/**
|
|
60
|
-
* Ray casting algorithm to determine if a point is inside a polygon
|
|
61
|
-
*/
|
|
62
|
-
isPointInPolygon(point: [number, number], polygon: [number, number][]): boolean;
|
|
63
|
-
/**
|
|
64
|
-
* Check if a point is within a bounding box
|
|
65
|
-
*/
|
|
66
|
-
isPointInBox(point: [number, number], bottomLeft: [number, number], topRight: [number, number]): boolean;
|
|
67
|
-
/**
|
|
68
|
-
* Check if two line segments intersect
|
|
69
|
-
*/
|
|
70
|
-
doLinesIntersect(line1: [[number, number], [number, number]], line2: [[number, number], [number, number]]): boolean;
|
|
71
|
-
/**
|
|
72
|
-
* Translate a MongoDB geospatial query to SQL
|
|
73
|
-
*/
|
|
74
|
-
translate(query: Record<string, unknown>): TranslatedGeoQuery;
|
|
75
|
-
private translateLogicalOperator;
|
|
76
|
-
private translateFieldCondition;
|
|
77
|
-
private translateRegularFieldCondition;
|
|
78
|
-
private translateGeoWithin;
|
|
79
|
-
private translateGeoWithinPolygon;
|
|
80
|
-
private translateGeoWithinBox;
|
|
81
|
-
private translateGeoWithinCircle;
|
|
82
|
-
private translateGeoWithinSphere;
|
|
83
|
-
private translateGeoIntersects;
|
|
84
|
-
private translateNear;
|
|
85
|
-
private translateNearSphere;
|
|
86
|
-
private translateNearLegacy;
|
|
87
|
-
private translateNearSphereLegacy;
|
|
88
|
-
private fieldToJsonPath;
|
|
89
|
-
}
|
|
90
|
-
export default GeoTranslator;
|
|
91
|
-
//# sourceMappingURL=geo-translator.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"geo-translator.d.ts","sourceRoot":"","sources":["../../src/translator/geo-translator.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;GAgBG;AASH,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE,OAAO,CAAC;IACd,WAAW,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAC/B;AAED,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,SAAS,CAAC;IAChB,WAAW,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC;CACnC;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,YAAY,CAAC;IACnB,WAAW,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC;CACjC;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,YAAY,CAAC;IACnB,WAAW,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC;CACjC;AAED,MAAM,MAAM,OAAO,GAAG,QAAQ,GAAG,UAAU,GAAG,aAAa,GAAG,aAAa,CAAC;AAE5E,MAAM,WAAW,kBAAkB;IACjC,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,OAAO,EAAE,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAYD,qBAAa,aAAa;IACxB,OAAO,CAAC,YAAY,CAAqC;;IAezD;;OAEG;IACH,cAAc,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO;IA2BrC,OAAO,CAAC,YAAY;IAcpB,OAAO,CAAC,cAAc;IA6BtB,OAAO,CAAC,iBAAiB;IAczB,OAAO,CAAC,iBAAiB;IAkBzB;;OAEG;IACH,0BAA0B,CACxB,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,GACX,MAAM;IAkBT;;OAEG;IACH,OAAO,CAAC,oBAAoB;IA2B5B;;OAEG;IACH,gBAAgB,CACd,KAAK,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EACvB,OAAO,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,GAC1B,OAAO;IAiCV;;OAEG;IACH,YAAY,CACV,KAAK,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EACvB,UAAU,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAC5B,QAAQ,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,GACzB,OAAO;IAQV;;OAEG;IACH,gBAAgB,CACd,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,EAC3C,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,GAC1C,OAAO;IAoBV;;OAEG;IACH,SAAS,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,kBAAkB;IA+B7D,OAAO,CAAC,wBAAwB;IAqChC,OAAO,CAAC,uBAAuB;IAsD/B,OAAO,CAAC,8BAA8B;IA2EtC,OAAO,CAAC,kBAAkB;IAwC1B,OAAO,CAAC,yBAAyB;IAmBjC,OAAO,CAAC,qBAAqB;IAiB7B,OAAO,CAAC,wBAAwB;IAiBhC,OAAO,CAAC,wBAAwB;IAsBhC,OAAO,CAAC,sBAAsB;IA+B9B,OAAO,CAAC,aAAa;IAmDrB,OAAO,CAAC,mBAAmB;IA+C3B,OAAO,CAAC,mBAAmB;IAwC3B,OAAO,CAAC,yBAAyB;IA2CjC,OAAO,CAAC,eAAe;CAcxB;AAED,eAAe,aAAa,CAAC"}
|