drizzle-cube 0.5.7 → 0.6.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/README.md +2 -0
- package/dist/adapters/adapters/hono/agent-handler.d.ts +9 -0
- package/dist/adapters/adapters/hono/mcp-handler.d.ts +37 -0
- package/dist/adapters/adapters/mcp-tools-handlers.d.ts +18 -0
- package/dist/adapters/adapters/nextjs/mcp-handler.d.ts +36 -0
- package/dist/adapters/{utils.d.ts → adapters/utils.d.ts} +6 -81
- package/dist/adapters/express/index.cjs +1 -1
- package/dist/adapters/express/index.js +50 -50
- package/dist/adapters/fastify/index.cjs +1 -1
- package/dist/adapters/fastify/index.js +78 -78
- package/dist/adapters/google-BOnRIN1w.cjs +2 -0
- package/dist/{server/google-CFYljAOF.js → adapters/google-CvKM9yVM.js} +83 -71
- package/dist/adapters/{handler-Dz1F4iwf.js → handler-CfgE0JSL.js} +515 -578
- package/dist/adapters/handler-Cn0dOctE.cjs +25 -0
- package/dist/adapters/hono/index.cjs +2 -2
- package/dist/adapters/hono/index.js +208 -178
- package/dist/adapters/locale-DDvZDFVn.js +8114 -0
- package/dist/adapters/locale-ZLUUNUxr.cjs +166 -0
- package/dist/adapters/mcp-tools.cjs +1 -1
- package/dist/adapters/mcp-tools.js +49 -38
- package/dist/adapters/mcp-transport-Chiaj4ll.cjs +40 -0
- package/dist/adapters/mcp-transport-H96VG3WY.js +591 -0
- package/dist/adapters/nextjs/index.cjs +1 -1
- package/dist/adapters/nextjs/index.js +190 -197
- package/dist/{server/openai-y7GhJNdn.js → adapters/openai-B5jEiqiB.js} +776 -719
- package/dist/adapters/openai-D0musiYP.cjs +17 -0
- package/dist/{server/openai-DiVskd89.js → adapters/openai-cDlFSTk6.js} +61 -59
- package/dist/adapters/openai-vXvLni8v.cjs +1 -0
- package/dist/adapters/{utils-DosuoabY.js → utils-BPWZsX7k.js} +1285 -1220
- package/dist/adapters/utils-_whV4fXL.cjs +128 -0
- package/dist/adapters/utils.cjs +1 -1
- package/dist/adapters/utils.js +2 -2
- package/dist/client/charts/ChartLoader.d.ts +3 -17
- package/dist/client/charts/chartComponentRegistry.d.ts +46 -0
- package/dist/client/charts/chartConfigHelpers.d.ts +38 -0
- package/dist/client/charts.js +14 -13
- package/dist/client/chunks/{DashboardEditModal-6KRE36mm.js → DashboardEditModal-okVfH8ZK.js} +5446 -4486
- package/dist/client/chunks/DashboardEditModal-okVfH8ZK.js.map +1 -0
- package/dist/client/chunks/{RetentionCombinedChart-CCpu0C-s.js → RetentionCombinedChart-BgbDhsPz.js} +10 -10
- package/dist/client/chunks/{RetentionCombinedChart-CCpu0C-s.js.map → RetentionCombinedChart-BgbDhsPz.js.map} +1 -1
- package/dist/client/chunks/{RetentionHeatmap-B24PiIfr.js → RetentionHeatmap-DjXZaTPq.js} +5 -5
- package/dist/client/chunks/{RetentionHeatmap-B24PiIfr.js.map → RetentionHeatmap-DjXZaTPq.js.map} +1 -1
- package/dist/client/chunks/analysis-builder-DB88FojM.js +5674 -0
- package/dist/client/chunks/analysis-builder-DB88FojM.js.map +1 -0
- package/dist/client/chunks/{analysis-builder-shared-x576-O5p.js → analysis-builder-shared-BVK4TYfR.js} +1578 -1292
- package/dist/client/chunks/analysis-builder-shared-BVK4TYfR.js.map +1 -0
- package/dist/client/chunks/{chart-activity-grid-CiHrLH6Y.js → chart-activity-grid-DX0SJbxs.js} +642 -494
- package/dist/client/chunks/chart-activity-grid-DX0SJbxs.js.map +1 -0
- package/dist/client/chunks/chart-area-of01_62R.js +775 -0
- package/dist/client/chunks/chart-area-of01_62R.js.map +1 -0
- package/dist/client/chunks/chart-bar-BqelQE_I.js +194 -0
- package/dist/client/chunks/chart-bar-BqelQE_I.js.map +1 -0
- package/dist/client/chunks/{chart-box-plot-Bu9hy-17.js → chart-box-plot-kkBixZ27.js} +2 -2
- package/dist/client/chunks/{chart-box-plot-Bu9hy-17.js.map → chart-box-plot-kkBixZ27.js.map} +1 -1
- package/dist/client/chunks/chart-bubble-B2he1--4.js +221 -0
- package/dist/client/chunks/chart-bubble-B2he1--4.js.map +1 -0
- package/dist/client/chunks/{chart-candlestick-Dau5AF4E.js → chart-candlestick-DZp19Tzh.js} +2 -2
- package/dist/client/chunks/{chart-candlestick-Dau5AF4E.js.map → chart-candlestick-DZp19Tzh.js.map} +1 -1
- package/dist/client/chunks/chart-config-area-BNigHUy8.js +124 -0
- package/dist/client/chunks/chart-config-area-BNigHUy8.js.map +1 -0
- package/dist/client/chunks/chart-config-bar-DSO_LRTx.js +54 -0
- package/dist/client/chunks/chart-config-bar-DSO_LRTx.js.map +1 -0
- package/dist/client/chunks/{chart-config-box-plot-DJ-dWWXA.js → chart-config-box-plot-oW8axV2q.js} +5 -10
- package/dist/client/chunks/chart-config-box-plot-oW8axV2q.js.map +1 -0
- package/dist/client/chunks/{chart-config-gauge-DSwC04l0.js → chart-config-gauge-Dq-_H9UN.js} +5 -7
- package/dist/client/chunks/chart-config-gauge-Dq-_H9UN.js.map +1 -0
- package/dist/client/chunks/{chart-config-kpi-delta-D6BIkHL3.js → chart-config-kpi-delta-DSQbvqu_.js} +5 -10
- package/dist/client/chunks/chart-config-kpi-delta-DSQbvqu_.js.map +1 -0
- package/dist/client/chunks/{chart-config-kpi-number-Bx-V9a62.js → chart-config-kpi-number-EFSWY1We.js} +5 -7
- package/dist/client/chunks/chart-config-kpi-number-EFSWY1We.js.map +1 -0
- package/dist/client/chunks/{chart-config-kpi-text-CcqC1u-8.js → chart-config-kpi-text-KM3V5X2u.js} +5 -7
- package/dist/client/chunks/chart-config-kpi-text-KM3V5X2u.js.map +1 -0
- package/dist/client/chunks/{chart-config-line-Db3jDsWc.js → chart-config-line-D6jG8PCH.js} +9 -36
- package/dist/client/chunks/chart-config-line-D6jG8PCH.js.map +1 -0
- package/dist/client/chunks/{chart-config-pie-DD4SmRTF.js → chart-config-pie-BhzW-fdn.js} +6 -16
- package/dist/client/chunks/chart-config-pie-BhzW-fdn.js.map +1 -0
- package/dist/client/chunks/{chart-config-radar-CC2XAaGr.js → chart-config-radar-D7REP1q_.js} +6 -16
- package/dist/client/chunks/chart-config-radar-D7REP1q_.js.map +1 -0
- package/dist/client/chunks/{chart-config-radial-bar-DmxKx1R0.js → chart-config-radial-bar-Byx6qOPU.js} +6 -16
- package/dist/client/chunks/chart-config-radial-bar-Byx6qOPU.js.map +1 -0
- package/dist/client/chunks/{chart-config-tree-map-BI-oQStO.js → chart-config-tree-map-DVrvf3yQ.js} +6 -16
- package/dist/client/chunks/chart-config-tree-map-DVrvf3yQ.js.map +1 -0
- package/dist/client/chunks/{chart-config-waterfall-DSnyixbI.js → chart-config-waterfall-DmFeQdIk.js} +5 -10
- package/dist/client/chunks/chart-config-waterfall-DmFeQdIk.js.map +1 -0
- package/dist/client/chunks/{chart-data-table-Cm5jrpaw.js → chart-data-table-CKauQXme.js} +1046 -1121
- package/dist/client/chunks/chart-data-table-CKauQXme.js.map +1 -0
- package/dist/client/chunks/{chart-funnel-Eke8IPtG.js → chart-funnel-CToKSBaL.js} +184 -222
- package/dist/client/chunks/chart-funnel-CToKSBaL.js.map +1 -0
- package/dist/client/chunks/chart-gauge-DTVezSk7.js +403 -0
- package/dist/client/chunks/chart-gauge-DTVezSk7.js.map +1 -0
- package/dist/client/chunks/chart-heat-map-DTuUl0BR.js +236 -0
- package/dist/client/chunks/chart-heat-map-DTuUl0BR.js.map +1 -0
- package/dist/client/chunks/chart-kpi-delta-Dn-jjO-2.js +408 -0
- package/dist/client/chunks/chart-kpi-delta-Dn-jjO-2.js.map +1 -0
- package/dist/client/chunks/chart-kpi-number-P_WBiO5S.js +244 -0
- package/dist/client/chunks/chart-kpi-number-P_WBiO5S.js.map +1 -0
- package/dist/client/chunks/chart-kpi-text-C-Y4eb5H.js +185 -0
- package/dist/client/chunks/chart-kpi-text-C-Y4eb5H.js.map +1 -0
- package/dist/client/chunks/chart-line-DKgrQA6c.js +101 -0
- package/dist/client/chunks/chart-line-DKgrQA6c.js.map +1 -0
- package/dist/client/chunks/{chart-markdown-BPW-EAm9.js → chart-markdown-CV75S_zL.js} +1359 -1240
- package/dist/client/chunks/chart-markdown-CV75S_zL.js.map +1 -0
- package/dist/client/chunks/{chart-measure-profile-BI3kADCp.js → chart-measure-profile-Ket8fJyf.js} +7 -7
- package/dist/client/chunks/{chart-measure-profile-BI3kADCp.js.map → chart-measure-profile-Ket8fJyf.js.map} +1 -1
- package/dist/client/chunks/chart-pie-ByieAX5H.js +119 -0
- package/dist/client/chunks/chart-pie-ByieAX5H.js.map +1 -0
- package/dist/client/chunks/chart-radar-CiSwHWp4.js +138 -0
- package/dist/client/chunks/chart-radar-CiSwHWp4.js.map +1 -0
- package/dist/client/chunks/chart-radial-bar-BF6Mhl6f.js +122 -0
- package/dist/client/chunks/chart-radial-bar-BF6Mhl6f.js.map +1 -0
- package/dist/client/chunks/{chart-sankey-CFzjGvZX.js → chart-sankey-DjrvKw6K.js} +36 -39
- package/dist/client/chunks/{chart-sankey-CFzjGvZX.js.map → chart-sankey-DjrvKw6K.js.map} +1 -1
- package/dist/client/chunks/chart-scatter-Dd9WFqnS.js +258 -0
- package/dist/client/chunks/chart-scatter-Dd9WFqnS.js.map +1 -0
- package/dist/client/chunks/{chart-sunburst-91Q2tzaB.js → chart-sunburst-leGpuDj7.js} +3 -3
- package/dist/client/chunks/{chart-sunburst-91Q2tzaB.js.map → chart-sunburst-leGpuDj7.js.map} +1 -1
- package/dist/client/chunks/chart-tree-map-Ceq5sLZA.js +323 -0
- package/dist/client/chunks/chart-tree-map-Ceq5sLZA.js.map +1 -0
- package/dist/client/chunks/{chart-waterfall-DcHbbPaG.js → chart-waterfall-DyvQReN5.js} +7 -7
- package/dist/client/chunks/{chart-waterfall-DcHbbPaG.js.map → chart-waterfall-DyvQReN5.js.map} +1 -1
- package/dist/client/chunks/{charts-core-CrBDYN6N.js → charts-core-DaXSt1Dd.js} +2 -2
- package/dist/client/chunks/{charts-core-CrBDYN6N.js.map → charts-core-DaXSt1Dd.js.map} +1 -1
- package/dist/client/chunks/charts-loader-DdTeCeNo.js +84 -0
- package/dist/client/chunks/charts-loader-DdTeCeNo.js.map +1 -0
- package/dist/client/chunks/{core-DsAWNRRv.js → core-D7vPfUIe.js} +2 -2
- package/dist/client/chunks/{core-DsAWNRRv.js.map → core-D7vPfUIe.js.map} +1 -1
- package/dist/client/chunks/{nl-NL-oyr2wENY.js → nl-NL-2zTAWTej.js} +8 -2
- package/dist/client/chunks/{nl-NL-oyr2wENY.js.map → nl-NL-2zTAWTej.js.map} +1 -1
- package/dist/client/chunks/retention-ChW9jYdy.js.map +1 -1
- package/dist/client/chunks/{schema-visualization-BszcrmZX.js → schema-visualization-Cb_E9_Gd.js} +12 -12
- package/dist/client/chunks/{schema-visualization-BszcrmZX.js.map → schema-visualization-Cb_E9_Gd.js.map} +1 -1
- package/dist/client/chunks/{useDirtyStateTracking-B5wCDJSj.js → useDirtyStateTracking-MbpxH_v6.js} +95 -84
- package/dist/client/chunks/useDirtyStateTracking-MbpxH_v6.js.map +1 -0
- package/dist/client/chunks/{useExplainAI-CCeCYzDm.js → useExplainAI-evnZkjCY.js} +14 -14
- package/dist/client/chunks/{useExplainAI-CCeCYzDm.js.map → useExplainAI-evnZkjCY.js.map} +1 -1
- package/dist/client/chunks/{utils-kqa-JIMg.js → utils-3P6z1vz5.js} +3 -3
- package/dist/client/chunks/{utils-kqa-JIMg.js.map → utils-3P6z1vz5.js.map} +1 -1
- package/dist/client/chunks/{vendor-0hJNlZXQ.js → vendor-DSpR0IW6.js} +43 -43
- package/dist/client/chunks/{vendor-0hJNlZXQ.js.map → vendor-DSpR0IW6.js.map} +1 -1
- package/dist/client/components/AgenticNotebook/agentChatParts.d.ts +34 -0
- package/dist/client/components/AgenticNotebook/chatMessageParts.d.ts +39 -0
- package/dist/client/components/AgenticNotebook/useAgentChatController.d.ts +25 -0
- package/dist/client/components/AgenticNotebook/useNotebookAutosave.d.ts +12 -0
- package/dist/client/components/AnalysisBuilder/AnalysisAIPanel.d.ts +1 -1
- package/dist/client/components/AnalysisBuilder/AnalysisAxisDropZone.d.ts +1 -1
- package/dist/client/components/AnalysisBuilder/AnalysisChartConfigPanel.d.ts +1 -1
- package/dist/client/components/AnalysisBuilder/AnalysisDisplayConfigPanel.d.ts +1 -1
- package/dist/client/components/AnalysisBuilder/AnalysisFilterGroup.d.ts +1 -1
- package/dist/client/components/AnalysisBuilder/AnalysisFilterItem.d.ts +1 -1
- package/dist/client/components/AnalysisBuilder/AnalysisFilterSection.d.ts +1 -1
- package/dist/client/components/AnalysisBuilder/AnalysisModeErrorBoundary.d.ts +1 -1
- package/dist/client/components/AnalysisBuilder/AnalysisQueryPanelParts.d.ts +64 -0
- package/dist/client/components/AnalysisBuilder/AnalysisResultsHeader.d.ts +67 -0
- package/dist/client/components/AnalysisBuilder/BreakdownComparisonToggle.d.ts +13 -0
- package/dist/client/components/AnalysisBuilder/BreakdownRow.d.ts +26 -0
- package/dist/client/components/AnalysisBuilder/DisplayOptionControl.d.ts +10 -0
- package/dist/client/components/AnalysisBuilder/ExecutionPlanPanelParts.d.ts +22 -0
- package/dist/client/components/AnalysisBuilder/ExplainAIPanel.d.ts +2 -1
- package/dist/client/components/AnalysisBuilder/FieldDetailPanel.d.ts +1 -1
- package/dist/client/components/AnalysisBuilder/FieldSearchItem.d.ts +1 -1
- package/dist/client/components/AnalysisBuilder/FieldSearchModal.d.ts +1 -1
- package/dist/client/components/AnalysisBuilder/FieldSearchResults.d.ts +16 -0
- package/dist/client/components/AnalysisBuilder/FilterConfigModal.d.ts +2 -1
- package/dist/client/components/AnalysisBuilder/FilterValueInput.d.ts +63 -0
- package/dist/client/components/AnalysisBuilder/FlowDepthControls.d.ts +10 -0
- package/dist/client/components/AnalysisBuilder/FlowVisualizationPicker.d.ts +7 -0
- package/dist/client/components/AnalysisBuilder/LegacyBooleanOptions.d.ts +8 -0
- package/dist/client/components/AnalysisBuilder/LimitSection.d.ts +1 -1
- package/dist/client/components/AnalysisBuilder/MetricRow.d.ts +23 -0
- package/dist/client/components/AnalysisBuilder/SectionHeading.d.ts +1 -1
- package/dist/client/components/AnalysisBuilder/SortToggleButton.d.ts +13 -0
- package/dist/client/components/AnalysisBuilder/StringArrayInput.d.ts +17 -0
- package/dist/client/components/AnalysisBuilder/filterConfigModalUtils.d.ts +30 -0
- package/dist/client/components/AnalysisBuilder/hooks/useAnalysisBuilderImperativeHandle.d.ts +13 -0
- package/dist/client/components/AnalysisBuilder/hooks/useDragReorder.d.ts +25 -0
- package/dist/client/components/AnalysisBuilder/hooks/useFieldSearchKeyboard.d.ts +11 -0
- package/dist/client/components/AnalysisBuilder/utils/axisConfigUtils.d.ts +23 -0
- package/dist/client/components/AnalysisBuilder/utils/executionPlanMarkdown.d.ts +8 -0
- package/dist/client/components/AnalysisBuilder/utils/fieldUtils.d.ts +5 -0
- package/dist/client/components/AnalysisBuilder/utils/resultsPanelDerive.d.ts +68 -0
- package/dist/client/components/AnalysisBuilder/utils/shareStateUtils.d.ts +68 -0
- package/dist/client/components/AnalysisBuilder/utils/sortUtils.d.ts +7 -0
- package/dist/client/components/AnalyticsDashboard.d.ts +1 -1
- package/dist/client/components/AnalyticsPage.d.ts +1 -1
- package/dist/client/components/ChartErrorBoundary.d.ts +1 -1
- package/dist/client/components/ChartTypeSelector.d.ts +1 -1
- package/dist/client/components/ColorPaletteSelector.d.ts +1 -1
- package/dist/client/components/DashboardEditModal.d.ts +2 -1
- package/dist/client/components/DashboardFilters/CompactFilterBarParts.d.ts +26 -0
- package/dist/client/components/DashboardFilters/DashboardFilterConfigModal.d.ts +1 -1
- package/dist/client/components/DashboardFilters/DashboardFilterConfigModalParts.d.ts +27 -0
- package/dist/client/components/DashboardFilters/DashboardFilterItem.d.ts +1 -1
- package/dist/client/components/DashboardFilters/DashboardFilterValueInput.d.ts +39 -0
- package/dist/client/components/DashboardFilters/dashboardFilterConfigModalUtils.d.ts +21 -0
- package/dist/client/components/DashboardFilters/useCompactFilterBar.d.ts +19 -0
- package/dist/client/components/DashboardFilters/useDashboardFilterConfigModal.d.ts +69 -0
- package/dist/client/components/DashboardFilters/useDateRangeState.d.ts +19 -0
- package/dist/client/components/DashboardFilters/useFilterDropdowns.d.ts +21 -0
- package/dist/client/components/DashboardFilters/useFilterValueFetch.d.ts +23 -0
- package/dist/client/components/DashboardGrid.d.ts +1 -1
- package/dist/client/components/DashboardPortletCard.d.ts +2 -57
- package/dist/client/components/DashboardThumbnailPlaceholder.d.ts +1 -1
- package/dist/client/components/DataBrowser/DataBrowserSidebar.d.ts +1 -1
- package/dist/client/components/DataBrowser/DataBrowserToolbar.d.ts +1 -1
- package/dist/client/components/DataBrowser/index.d.ts +1 -1
- package/dist/client/components/DataHistogram.d.ts +1 -1
- package/dist/client/components/DebugModal.d.ts +1 -1
- package/dist/client/components/DrillBreadcrumb.d.ts +2 -1
- package/dist/client/components/LoadingIndicator.d.ts +1 -1
- package/dist/client/components/MobileStackedLayout.d.ts +1 -1
- package/dist/client/components/PortletAnalysisModal.d.ts +1 -1
- package/dist/client/components/PortletContainer.d.ts +1 -1
- package/dist/client/components/PortletFilterConfigModal.d.ts +6 -4
- package/dist/client/components/RowManagedLayout.d.ts +1 -1
- package/dist/client/components/ScaledGridWrapper.d.ts +1 -1
- package/dist/client/components/SchemaVisualization/CubeNode.d.ts +1 -1
- package/dist/client/components/SchemaVisualization/FieldDetailPanel.d.ts +1 -1
- package/dist/client/components/SchemaVisualization/RelationshipEdge.d.ts +1 -1
- package/dist/client/components/SchemaVisualization/SchemaVisualizationLazy.d.ts +1 -1
- package/dist/client/components/SchemaVisualization/index.d.ts +1 -1
- package/dist/client/components/TextPortletModal.d.ts +1 -1
- package/dist/client/components/analyticsPortlet/PortletChart.d.ts +31 -0
- package/dist/client/components/analyticsPortlet/PortletChartView.d.ts +35 -0
- package/dist/client/components/analyticsPortlet/PortletStates.d.ts +65 -0
- package/dist/client/components/analyticsPortlet/parsePortletQuery.d.ts +22 -0
- package/dist/client/components/analyticsPortlet/portletRenderState.d.ts +31 -0
- package/dist/client/components/analyticsPortlet/usePortletDebugData.d.ts +37 -0
- package/dist/client/components/analyticsPortlet/usePortletDrillState.d.ts +17 -0
- package/dist/client/components/analyticsPortlet/usePortletQueryResults.d.ts +37 -0
- package/dist/client/components/charts/ActivityGridChart.helpers.d.ts +33 -0
- package/dist/client/components/charts/ActivityGridChart.render.d.ts +31 -0
- package/dist/client/components/charts/AxisFormatControls.d.ts +5 -3
- package/dist/client/components/charts/BarChart.helpers.d.ts +23 -0
- package/dist/client/components/charts/BarSeries.d.ts +29 -0
- package/dist/client/components/charts/BubbleChart.helpers.d.ts +43 -0
- package/dist/client/components/charts/BubbleChart.render.d.ts +21 -0
- package/dist/client/components/charts/ChartContainer.d.ts +1 -1
- package/dist/client/components/charts/ChartLegend.d.ts +1 -1
- package/dist/client/components/charts/ChartStates.d.ts +38 -0
- package/dist/client/components/charts/ChartTooltip.d.ts +1 -1
- package/dist/client/components/charts/FunnelChart.helpers.d.ts +25 -0
- package/dist/client/components/charts/FunnelViews.d.ts +16 -0
- package/dist/client/components/charts/HeatMapCanvas.d.ts +25 -0
- package/dist/client/components/charts/HeatMapChart.helpers.d.ts +64 -0
- package/dist/client/components/charts/KpiDelta.helpers.d.ts +20 -0
- package/dist/client/components/charts/KpiNumber.helpers.d.ts +30 -0
- package/dist/client/components/charts/KpiStates.d.ts +19 -0
- package/dist/client/components/charts/MissingDependencyFallback.d.ts +1 -1
- package/dist/client/components/charts/ScatterChart.helpers.d.ts +43 -0
- package/dist/client/components/charts/ScatterSeries.d.ts +17 -0
- package/dist/client/components/charts/ScatterTooltip.d.ts +21 -0
- package/dist/client/components/charts/TreeMapChart.helpers.d.ts +37 -0
- package/dist/client/components/charts/TreeMapContent.d.ts +24 -0
- package/dist/client/components/charts/TreeMapLegend.d.ts +13 -0
- package/dist/client/components/charts/cartesianChartHelpers.d.ts +126 -0
- package/dist/client/components/charts/chartAxisResolution.d.ts +32 -0
- package/dist/client/components/charts/chartScaffolding.d.ts +77 -0
- package/dist/client/components/charts/gaugeChartHelpers.d.ts +36 -0
- package/dist/client/components/charts/kpiTextHelpers.d.ts +46 -0
- package/dist/client/components/charts/radarChartHelpers.d.ts +14 -0
- package/dist/client/components/charts/radialBarChartHelpers.d.ts +22 -0
- package/dist/client/components/charts/useChartDimensions.d.ts +20 -0
- package/dist/client/components/charts/useKpiDimensions.d.ts +30 -0
- package/dist/client/components/dashboard/DashboardContext.d.ts +2 -2
- package/dist/client/components/dashboard/DashboardCoordinator.d.ts +1 -1
- package/dist/client/components/dashboard/DashboardEditBar.d.ts +5 -0
- package/dist/client/components/dashboard/DashboardFilterBar.d.ts +1 -1
- package/dist/client/components/dashboard/DashboardGridSurface.d.ts +1 -1
- package/dist/client/components/dashboard/DashboardModals.d.ts +1 -1
- package/dist/client/components/dashboard/DashboardProvider.d.ts +1 -1
- package/dist/client/components/dashboard/DashboardToolbar.d.ts +1 -1
- package/dist/client/components/dashboard/LayoutModeToggle.d.ts +10 -0
- package/dist/client/components/dashboard/dashboardGridUtils.d.ts +1 -1
- package/dist/client/components/dashboardPortletCard/FilterFieldChip.d.ts +12 -0
- package/dist/client/components/dashboardPortletCard/PortletCardHeader.d.ts +43 -0
- package/dist/client/components/dashboardPortletCard/cardStyles.d.ts +33 -0
- package/dist/client/components/dashboardPortletCard/filterField.d.ts +12 -0
- package/dist/client/components/dashboardPortletCard/propsEqual.d.ts +55 -0
- package/dist/client/components/dashboardPortletCard/usePortletCardActions.d.ts +16 -0
- package/dist/client/components/portletAnalysisModal/saveValidation.d.ts +8 -0
- package/dist/client/components/shared/dateRangeUtils.d.ts +40 -0
- package/dist/client/components/shared/filterDisplayUtils.d.ts +10 -0
- package/dist/client/components/shared/filterItem/FilterDateRangeSelector.d.ts +17 -0
- package/dist/client/components/shared/filterItem/FilterFieldDropdown.d.ts +16 -0
- package/dist/client/components/shared/filterItem/dateRangeSync.d.ts +14 -0
- package/dist/client/components/shared/filterItem/fieldVisuals.d.ts +5 -0
- package/dist/client/components/shared/filterValueSelector/FilterValueInputs.d.ts +55 -0
- package/dist/client/components/shared/filterValueSelector/useFilterValueSelectorState.d.ts +25 -0
- package/dist/client/components/shared/queryFieldUtils.d.ts +21 -0
- package/dist/client/components/shared/utils.d.ts +4 -43
- package/dist/client/components.js +3 -3
- package/dist/client/hooks/agentChatStream.d.ts +39 -0
- package/dist/client/hooks/analysisQueryExecutionModes.d.ts +133 -0
- package/dist/client/hooks/dashboard/useDashboardController.d.ts +2 -2
- package/dist/client/hooks/drillNavigation.d.ts +25 -0
- package/dist/client/hooks/useDashboardHook.d.ts +2 -2
- package/dist/client/hooks.js +3 -3
- package/dist/client/icons.d.ts +1 -1
- package/dist/client/icons.js +2 -2
- package/dist/client/index.js +816 -669
- package/dist/client/index.js.map +1 -1
- package/dist/client/providers/CubeApiProvider.d.ts +1 -1
- package/dist/client/providers/CubeFeaturesProvider.d.ts +1 -1
- package/dist/client/providers/CubeMetaProvider.d.ts +1 -1
- package/dist/client/providers/CubeProvider.d.ts +1 -1
- package/dist/client/providers/I18nProvider.d.ts +1 -1
- package/dist/client/providers.js +3 -3
- package/dist/client/schema.js +1 -1
- package/dist/client/shared/chartConfigBuilders.d.ts +18 -0
- package/dist/client/shared/components/QueryAnalysisPanel.sections.d.ts +41 -0
- package/dist/client/shared/queryTransforms.d.ts +20 -0
- package/dist/client/shared/utils.d.ts +2 -4
- package/dist/client/stores/analysisBuilderStore.d.ts +1 -1
- package/dist/client/stores/dashboardStore.d.ts +1 -1
- package/dist/client/stores/dataBrowserStore.d.ts +1 -1
- package/dist/client/stores/notebookStore.d.ts +1 -1
- package/dist/client/stores/optionsToAnalysisConfig.d.ts +17 -0
- package/dist/client/styles.css +1 -1
- package/dist/client/types/drill.d.ts +1 -1
- package/dist/client/types.d.ts +7 -2
- package/dist/client/utils/axisValueFormatting.d.ts +32 -0
- package/dist/client/utils/drillQueryBuilder.d.ts +2 -2
- package/dist/client/utils/filterUtils.d.ts +33 -5
- package/dist/client/utils/joinReachability.d.ts +27 -0
- package/dist/client/utils/timeValueFormatting.d.ts +32 -0
- package/dist/client/utils.js +6 -6
- package/dist/client-bundle-stats.html +1 -1
- package/dist/mcp-app/mcp-app.html +55 -55
- package/dist/server/google-BOnRIN1w.cjs +2 -0
- package/dist/{adapters/google-CFYljAOF.js → server/google-CvKM9yVM.js} +83 -71
- package/dist/server/index.cjs +179 -211
- package/dist/server/index.d.ts +2 -5050
- package/dist/server/index.js +6360 -6462
- package/dist/{adapters/openai-y7GhJNdn.js → server/openai-B5jEiqiB.js} +776 -719
- package/dist/server/openai-D0musiYP.cjs +17 -0
- package/dist/{adapters/openai-DiVskd89.js → server/openai-cDlFSTk6.js} +61 -59
- package/dist/server/openai-vXvLni8v.cjs +1 -0
- package/dist/server/server/adapters/base-adapter.d.ts +332 -0
- package/dist/server/server/adapters/databend-adapter.d.ts +63 -0
- package/dist/server/server/adapters/duckdb-adapter.d.ts +68 -0
- package/dist/server/server/adapters/mysql-adapter.d.ts +65 -0
- package/dist/server/server/adapters/postgres-adapter.d.ts +55 -0
- package/dist/server/server/adapters/singlestore-adapter.d.ts +4 -0
- package/dist/server/server/adapters/snowflake-adapter.d.ts +53 -0
- package/dist/server/server/adapters/sqlite-adapter.d.ts +120 -0
- package/dist/server/server/adapters/window-function-builder.d.ts +11 -0
- package/dist/server/server/agent/chart-validation.d.ts +22 -0
- package/dist/server/server/agent/handler-steps.d.ts +37 -0
- package/dist/server/server/agent/handler.d.ts +25 -0
- package/dist/server/server/agent/index.d.ts +11 -0
- package/dist/server/server/agent/providers/anthropic.d.ts +24 -0
- package/dist/server/server/agent/providers/factory.d.ts +12 -0
- package/dist/server/server/agent/providers/google.d.ts +23 -0
- package/dist/server/server/agent/providers/index.d.ts +6 -0
- package/dist/server/server/agent/providers/openai.d.ts +26 -0
- package/dist/server/server/agent/providers/types.d.ts +95 -0
- package/dist/server/server/agent/system-prompt.d.ts +5 -0
- package/dist/server/server/agent/tools.d.ts +28 -0
- package/dist/server/server/agent/types.d.ts +192 -0
- package/dist/server/server/ai/discovery-helpers.d.ts +29 -0
- package/dist/server/server/ai/discovery.d.ts +66 -0
- package/dist/server/server/ai/index.d.ts +10 -0
- package/dist/server/server/ai/mcp-prompts.d.ts +83 -0
- package/dist/server/server/ai/query-schema.d.ts +258 -0
- package/dist/server/server/ai/schemas.d.ts +63 -0
- package/dist/server/server/ai/suggestion-helpers.d.ts +33 -0
- package/dist/server/server/ai/suggestion.d.ts +16 -0
- package/dist/server/server/ai/validation-helpers.d.ts +21 -0
- package/dist/server/server/ai/validation.d.ts +31 -0
- package/dist/server/server/builders/analysis-utils.d.ts +106 -0
- package/dist/server/server/builders/comparison-query-builder.d.ts +70 -0
- package/dist/server/server/builders/cte-builder.d.ts +108 -0
- package/dist/server/server/builders/date-time-builder.d.ts +34 -0
- package/dist/server/server/builders/date-time-helpers.d.ts +34 -0
- package/dist/server/server/builders/filter-builder.d.ts +25 -0
- package/dist/server/server/builders/filter-operators.d.ts +23 -0
- package/dist/server/server/builders/flow-query-builder.d.ts +136 -0
- package/dist/server/server/builders/funnel-query-builder.d.ts +145 -0
- package/dist/server/server/builders/group-by-builder.d.ts +38 -0
- package/dist/server/server/builders/index.d.ts +13 -0
- package/dist/server/server/builders/measure-builder.d.ts +185 -0
- package/dist/server/server/builders/retention-query-builder.d.ts +98 -0
- package/dist/server/server/cache-providers/index.d.ts +5 -0
- package/dist/server/server/cache-providers/memory.d.ts +105 -0
- package/dist/server/server/cache-utils.d.ts +85 -0
- package/dist/server/server/compiler-metadata.d.ts +11 -0
- package/dist/server/server/compiler.d.ts +212 -0
- package/dist/server/server/cube-utils.d.ts +158 -0
- package/dist/server/server/database-utils.d.ts +18 -0
- package/dist/server/server/execution/annotation-builder.d.ts +12 -0
- package/dist/server/server/execution/filter-cache-preloader.d.ts +19 -0
- package/dist/server/server/execution/mode-router.d.ts +25 -0
- package/dist/server/server/execution/query-result-cache.d.ts +21 -0
- package/dist/server/server/execution/result-post-processor.d.ts +10 -0
- package/dist/server/server/executor.d.ts +186 -0
- package/dist/server/server/executors/base-executor.d.ts +16 -0
- package/dist/server/server/executors/databend-executor.d.ts +33 -0
- package/dist/server/server/executors/duckdb-executor.d.ts +33 -0
- package/dist/server/server/executors/explain-utils.d.ts +28 -0
- package/dist/server/server/executors/index.d.ts +21 -0
- package/dist/server/server/executors/mysql-executor.d.ts +27 -0
- package/dist/server/server/executors/postgres-executor.d.ts +27 -0
- package/dist/server/server/executors/singlestore-executor.d.ts +9 -0
- package/dist/server/server/executors/snowflake-executor.d.ts +33 -0
- package/dist/server/server/executors/sqlite-executor.d.ts +28 -0
- package/dist/server/server/explain/databend-parser.d.ts +16 -0
- package/dist/server/server/explain/duckdb-parser.d.ts +28 -0
- package/dist/server/server/explain/explain-tree.d.ts +20 -0
- package/dist/server/server/explain/index.d.ts +9 -0
- package/dist/server/server/explain/mysql-parser.d.ts +38 -0
- package/dist/server/server/explain/postgres-parser.d.ts +18 -0
- package/dist/server/server/explain/snowflake-parser.d.ts +17 -0
- package/dist/server/server/explain/sqlite-parser.d.ts +23 -0
- package/dist/server/server/filter-cache.d.ts +73 -0
- package/dist/server/server/gap-filler.d.ts +48 -0
- package/dist/server/server/index.d.ts +38 -0
- package/dist/server/server/logical-plan/cte-planner-helpers.d.ts +37 -0
- package/dist/server/server/logical-plan/cte-planner.d.ts +104 -0
- package/dist/server/server/logical-plan/filter-propagation.d.ts +44 -0
- package/dist/server/server/logical-plan/index.d.ts +19 -0
- package/dist/server/server/logical-plan/join-planner.d.ts +27 -0
- package/dist/server/server/logical-plan/logical-plan-builder.d.ts +58 -0
- package/dist/server/server/logical-plan/logical-planner.d.ts +39 -0
- package/dist/server/server/logical-plan/optimiser.d.ts +34 -0
- package/dist/server/server/logical-plan/plan-analysis-reporter.d.ts +59 -0
- package/dist/server/server/logical-plan/planner-utils.d.ts +20 -0
- package/dist/server/server/logical-plan/types.d.ts +199 -0
- package/dist/server/server/measure-classification.d.ts +40 -0
- package/dist/server/server/physical-plan/drizzle-plan-builder.d.ts +50 -0
- package/dist/server/server/physical-plan/drizzle-sql-builder.d.ts +118 -0
- package/dist/server/server/physical-plan/index.d.ts +2 -0
- package/dist/server/server/physical-plan/processors/cte-processor.d.ts +6 -0
- package/dist/server/server/physical-plan/processors/index.d.ts +8 -0
- package/dist/server/server/physical-plan/processors/joins-processor.d.ts +6 -0
- package/dist/server/server/physical-plan/processors/keys-dedup-processor.d.ts +13 -0
- package/dist/server/server/physical-plan/processors/multi-fact-processor.d.ts +13 -0
- package/dist/server/server/physical-plan/processors/predicates-processor.d.ts +6 -0
- package/dist/server/server/physical-plan/processors/selection-processor.d.ts +6 -0
- package/dist/server/server/physical-plan/processors/shared.d.ts +38 -0
- package/dist/server/server/physical-plan/processors/window-processor.d.ts +6 -0
- package/dist/server/server/prompts/explain-analysis-prompt.d.ts +47 -0
- package/dist/server/server/prompts/index.d.ts +27 -0
- package/dist/server/server/prompts/single-step-prompt.d.ts +31 -0
- package/dist/server/server/prompts/step0-validation-prompt.d.ts +39 -0
- package/dist/server/server/prompts/step1-shape-prompt.d.ts +29 -0
- package/dist/server/server/prompts/step2-complete-prompt.d.ts +19 -0
- package/dist/server/server/prompts/types.d.ts +37 -0
- package/dist/server/server/query-handlers.d.ts +79 -0
- package/dist/server/server/query-modes.d.ts +28 -0
- package/dist/server/server/query-validator.d.ts +9 -0
- package/dist/server/server/resolvers/calculated-measure-resolver.d.ts +98 -0
- package/dist/server/server/resolvers/index.d.ts +6 -0
- package/dist/server/server/resolvers/join-path-resolver.d.ts +158 -0
- package/dist/server/server/sql-format.d.ts +11 -0
- package/dist/server/server/template-substitution.d.ts +57 -0
- package/dist/server/server/types/analysis.d.ts +189 -0
- package/dist/server/server/types/cache.d.ts +132 -0
- package/dist/server/server/types/core.d.ts +164 -0
- package/dist/server/server/types/cube.d.ts +544 -0
- package/dist/server/server/types/executor.d.ts +156 -0
- package/dist/server/server/types/flow.d.ts +144 -0
- package/dist/server/server/types/funnel.d.ts +118 -0
- package/dist/server/server/types/index.d.ts +11 -0
- package/dist/server/server/types/metadata.d.ts +113 -0
- package/dist/server/server/types/query.d.ts +153 -0
- package/dist/server/server/types/retention.d.ts +141 -0
- package/dist/server/server/types/utils.d.ts +11 -0
- package/dist/server/server/types/validation.d.ts +14 -0
- package/package.json +15 -8
- package/dist/adapters/google-DUlXeeDA.cjs +0 -2
- package/dist/adapters/handler-C63rJUUK.cjs +0 -25
- package/dist/adapters/locale-CTNwPVZI.cjs +0 -198
- package/dist/adapters/locale-gU_d1Wja.js +0 -8249
- package/dist/adapters/mcp-transport-C4J4SAcn.cjs +0 -40
- package/dist/adapters/mcp-transport-CVUiifEc.js +0 -579
- package/dist/adapters/openai-6wrBvAnv.cjs +0 -1
- package/dist/adapters/openai-BDwb2u7y.cjs +0 -17
- package/dist/adapters/utils-CkEkU8Bo.cjs +0 -128
- package/dist/client/chunks/DashboardEditModal-6KRE36mm.js.map +0 -1
- package/dist/client/chunks/analysis-builder-shared-x576-O5p.js.map +0 -1
- package/dist/client/chunks/analysis-builder-zd48FVJO.js +0 -5367
- package/dist/client/chunks/analysis-builder-zd48FVJO.js.map +0 -1
- package/dist/client/chunks/chart-activity-grid-CiHrLH6Y.js.map +0 -1
- package/dist/client/chunks/chart-area-CXFK-Grv.js +0 -450
- package/dist/client/chunks/chart-area-CXFK-Grv.js.map +0 -1
- package/dist/client/chunks/chart-bar-DKXfLoGG.js +0 -271
- package/dist/client/chunks/chart-bar-DKXfLoGG.js.map +0 -1
- package/dist/client/chunks/chart-bubble-DGkTQlxM.js +0 -273
- package/dist/client/chunks/chart-bubble-DGkTQlxM.js.map +0 -1
- package/dist/client/chunks/chart-config-area-Bq_UsW3x.js +0 -101
- package/dist/client/chunks/chart-config-area-Bq_UsW3x.js.map +0 -1
- package/dist/client/chunks/chart-config-bar-_JEGZnAu.js +0 -95
- package/dist/client/chunks/chart-config-bar-_JEGZnAu.js.map +0 -1
- package/dist/client/chunks/chart-config-box-plot-DJ-dWWXA.js.map +0 -1
- package/dist/client/chunks/chart-config-gauge-DSwC04l0.js.map +0 -1
- package/dist/client/chunks/chart-config-kpi-delta-D6BIkHL3.js.map +0 -1
- package/dist/client/chunks/chart-config-kpi-number-Bx-V9a62.js.map +0 -1
- package/dist/client/chunks/chart-config-kpi-text-CcqC1u-8.js.map +0 -1
- package/dist/client/chunks/chart-config-line-Db3jDsWc.js.map +0 -1
- package/dist/client/chunks/chart-config-pie-DD4SmRTF.js.map +0 -1
- package/dist/client/chunks/chart-config-radar-CC2XAaGr.js.map +0 -1
- package/dist/client/chunks/chart-config-radial-bar-DmxKx1R0.js.map +0 -1
- package/dist/client/chunks/chart-config-tree-map-BI-oQStO.js.map +0 -1
- package/dist/client/chunks/chart-config-waterfall-DSnyixbI.js.map +0 -1
- package/dist/client/chunks/chart-data-table-Cm5jrpaw.js.map +0 -1
- package/dist/client/chunks/chart-funnel-Eke8IPtG.js.map +0 -1
- package/dist/client/chunks/chart-gauge-DeRZNsyl.js +0 -424
- package/dist/client/chunks/chart-gauge-DeRZNsyl.js.map +0 -1
- package/dist/client/chunks/chart-heat-map-C86thSJ4.js +0 -231
- package/dist/client/chunks/chart-heat-map-C86thSJ4.js.map +0 -1
- package/dist/client/chunks/chart-kpi-delta-CxOYD2f1.js +0 -343
- package/dist/client/chunks/chart-kpi-delta-CxOYD2f1.js.map +0 -1
- package/dist/client/chunks/chart-kpi-number-C6gWz-x4.js +0 -322
- package/dist/client/chunks/chart-kpi-number-C6gWz-x4.js.map +0 -1
- package/dist/client/chunks/chart-kpi-text-dDONrhS-.js +0 -149
- package/dist/client/chunks/chart-kpi-text-dDONrhS-.js.map +0 -1
- package/dist/client/chunks/chart-line-r4iWevKZ.js +0 -433
- package/dist/client/chunks/chart-line-r4iWevKZ.js.map +0 -1
- package/dist/client/chunks/chart-markdown-BPW-EAm9.js.map +0 -1
- package/dist/client/chunks/chart-pie-yqH2YVEI.js +0 -172
- package/dist/client/chunks/chart-pie-yqH2YVEI.js.map +0 -1
- package/dist/client/chunks/chart-radar-B-_3v-rE.js +0 -154
- package/dist/client/chunks/chart-radar-B-_3v-rE.js.map +0 -1
- package/dist/client/chunks/chart-radial-bar-C0EgzfAF.js +0 -148
- package/dist/client/chunks/chart-radial-bar-C0EgzfAF.js.map +0 -1
- package/dist/client/chunks/chart-scatter-DZPirzwX.js +0 -255
- package/dist/client/chunks/chart-scatter-DZPirzwX.js.map +0 -1
- package/dist/client/chunks/chart-tree-map-Bi4axCvh.js +0 -298
- package/dist/client/chunks/chart-tree-map-Bi4axCvh.js.map +0 -1
- package/dist/client/chunks/useDirtyStateTracking-B5wCDJSj.js.map +0 -1
- package/dist/server/google-DUlXeeDA.cjs +0 -2
- package/dist/server/openai-6wrBvAnv.cjs +0 -1
- package/dist/server/openai-BDwb2u7y.cjs +0 -17
- /package/dist/adapters/{express → adapters/express}/index.d.ts +0 -0
- /package/dist/adapters/{fastify → adapters/fastify}/index.d.ts +0 -0
- /package/dist/adapters/{hono → adapters/hono}/index.d.ts +0 -0
- /package/dist/adapters/{locale.d.ts → adapters/locale.d.ts} +0 -0
- /package/dist/adapters/{mcp-tools.d.ts → adapters/mcp-tools.d.ts} +0 -0
- /package/dist/adapters/{mcp-transport.d.ts → adapters/mcp-transport.d.ts} +0 -0
- /package/dist/adapters/{nextjs → adapters/nextjs}/index.d.ts +0 -0
- /package/dist/adapters/{types.d.ts → adapters/types.d.ts} +0 -0
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { SQL } from 'drizzle-orm';
|
|
2
|
+
import { Filter, FilterCondition, FilterCache } from './types';
|
|
3
|
+
/**
|
|
4
|
+
* Generates a deterministic cache key for a filter
|
|
5
|
+
* Keys are based on filter content (member, operator, values) not object identity
|
|
6
|
+
*/
|
|
7
|
+
export declare function getFilterKey(filter: Filter): string;
|
|
8
|
+
/**
|
|
9
|
+
* Generates a cache key for time dimension date range filters
|
|
10
|
+
*/
|
|
11
|
+
export declare function getTimeDimensionFilterKey(dimension: string, dateRange: string | string[]): string;
|
|
12
|
+
/**
|
|
13
|
+
* Cache statistics for debugging and monitoring
|
|
14
|
+
*/
|
|
15
|
+
export interface FilterCacheStats {
|
|
16
|
+
hits: number;
|
|
17
|
+
misses: number;
|
|
18
|
+
cacheSize: number;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Manages filter SQL caching for a single query execution
|
|
22
|
+
*
|
|
23
|
+
* Design principles:
|
|
24
|
+
* - Immutable SQL: Once cached, SQL objects are never modified
|
|
25
|
+
* - Cache lifetime: Created at query start, discarded after query execution
|
|
26
|
+
* - Key by content: Filters with same member/operator/values share SQL
|
|
27
|
+
* - Thread-safe: No shared mutable state between queries
|
|
28
|
+
*/
|
|
29
|
+
export declare class FilterCacheManager implements FilterCache {
|
|
30
|
+
private cache;
|
|
31
|
+
private stats;
|
|
32
|
+
/**
|
|
33
|
+
* Get cached SQL or build and cache it
|
|
34
|
+
*
|
|
35
|
+
* @param key - The cache key (use getFilterKey or getTimeDimensionFilterKey)
|
|
36
|
+
* @param builder - Function to build the SQL if not cached
|
|
37
|
+
* @returns The cached or freshly built SQL, or null if builder returns null
|
|
38
|
+
*/
|
|
39
|
+
getOrBuild(key: string, builder: () => SQL | null): SQL | null;
|
|
40
|
+
/**
|
|
41
|
+
* Check if a key exists in the cache without affecting stats
|
|
42
|
+
*/
|
|
43
|
+
has(key: string): boolean;
|
|
44
|
+
/**
|
|
45
|
+
* Get cached SQL without building (returns undefined if not cached)
|
|
46
|
+
*/
|
|
47
|
+
get(key: string): SQL | undefined;
|
|
48
|
+
/**
|
|
49
|
+
* Pre-populate cache with multiple filters
|
|
50
|
+
* Useful for batch initialization at query start
|
|
51
|
+
*/
|
|
52
|
+
preload(entries: Array<{
|
|
53
|
+
key: string;
|
|
54
|
+
sql: SQL;
|
|
55
|
+
}>): void;
|
|
56
|
+
/**
|
|
57
|
+
* Store a single entry in the cache
|
|
58
|
+
*/
|
|
59
|
+
set(key: string, sql: SQL): void;
|
|
60
|
+
/**
|
|
61
|
+
* Get cache statistics for debugging
|
|
62
|
+
*/
|
|
63
|
+
getStats(): FilterCacheStats;
|
|
64
|
+
/**
|
|
65
|
+
* Clear the cache (normally not needed as cache is per-query)
|
|
66
|
+
*/
|
|
67
|
+
clear(): void;
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Flatten nested AND/OR filters into individual filter conditions
|
|
71
|
+
* Useful for pre-building all filters at query start
|
|
72
|
+
*/
|
|
73
|
+
export declare function flattenFilters(filters: Filter[]): FilterCondition[];
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { SemanticQuery } from './types/query';
|
|
2
|
+
import { TimeGranularity } from './types/core';
|
|
3
|
+
/**
|
|
4
|
+
* Maximum number of time buckets gap filling will generate. Beyond this, gap
|
|
5
|
+
* filling is skipped entirely (data is returned unmodified) to avoid both
|
|
6
|
+
* runaway memory use and silent truncation of real rows.
|
|
7
|
+
*/
|
|
8
|
+
export declare const MAX_GAP_FILL_BUCKETS = 10000;
|
|
9
|
+
export interface GapFillerConfig {
|
|
10
|
+
/** The time dimension key (e.g., 'Sales.date') */
|
|
11
|
+
timeDimensionKey: string;
|
|
12
|
+
/** Time granularity for bucket generation */
|
|
13
|
+
granularity: TimeGranularity;
|
|
14
|
+
/** Date range [start, end] */
|
|
15
|
+
dateRange: [Date, Date];
|
|
16
|
+
/** Value to fill for missing measures (default: 0) */
|
|
17
|
+
fillValue: number | null;
|
|
18
|
+
/** List of measure keys in the data */
|
|
19
|
+
measures: string[];
|
|
20
|
+
/** List of dimension keys in the data (excluding time dimensions) */
|
|
21
|
+
dimensions: string[];
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Generate all time buckets for a given date range and granularity
|
|
25
|
+
*/
|
|
26
|
+
export declare function generateTimeBuckets(startDate: Date, endDate: Date, granularity: TimeGranularity): Date[];
|
|
27
|
+
/**
|
|
28
|
+
* Fill time series gaps in query result data
|
|
29
|
+
*
|
|
30
|
+
* @param data - Original query result data
|
|
31
|
+
* @param config - Gap filling configuration
|
|
32
|
+
* @returns Data with gaps filled
|
|
33
|
+
*/
|
|
34
|
+
export declare function fillTimeSeriesGaps(data: Record<string, unknown>[], config: GapFillerConfig): Record<string, unknown>[];
|
|
35
|
+
/**
|
|
36
|
+
* Parse date range from query time dimension
|
|
37
|
+
* Handles both array format ['2024-01-01', '2024-01-31'] and string format
|
|
38
|
+
*/
|
|
39
|
+
export declare function parseDateRange(dateRange: string | string[] | undefined): [Date, Date] | null;
|
|
40
|
+
/**
|
|
41
|
+
* Apply gap filling to query result data based on query configuration
|
|
42
|
+
*
|
|
43
|
+
* @param data - Original query result data
|
|
44
|
+
* @param query - The semantic query
|
|
45
|
+
* @param measures - List of measure names in the result
|
|
46
|
+
* @returns Data with gaps filled (if applicable)
|
|
47
|
+
*/
|
|
48
|
+
export declare function applyGapFilling(data: Record<string, unknown>[], query: SemanticQuery, measures: string[]): Record<string, unknown>[];
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { DrizzleDatabase } from './types';
|
|
2
|
+
import { SemanticLayerCompiler } from './compiler';
|
|
3
|
+
/**
|
|
4
|
+
* Drizzle Cube - Semantic Layer for Drizzle ORM
|
|
5
|
+
* Drizzle ORM-first semantic layer with Cube.js compatibility
|
|
6
|
+
*/
|
|
7
|
+
export { SemanticLayerCompiler } from './compiler';
|
|
8
|
+
export { QueryExecutor } from './executor';
|
|
9
|
+
export { detectQueryMode, detectQueryModes, getActiveQueryModes, hasComparisonMode, hasFunnelMode, hasFlowMode, hasRetentionMode } from './query-modes';
|
|
10
|
+
export type { QueryMode, QueryModeFlags } from './query-modes';
|
|
11
|
+
export { LogicalPlanner } from './logical-plan';
|
|
12
|
+
export { DrizzleSqlBuilder } from './physical-plan';
|
|
13
|
+
export { CTEBuilder, ComparisonQueryBuilder, FunnelQueryBuilder, FlowQueryBuilder, RetentionQueryBuilder } from './builders';
|
|
14
|
+
export { CalculatedMeasureResolver, JoinPathResolver } from './resolvers';
|
|
15
|
+
export { LogicalPlanBuilder, IdentityOptimiser, OptimiserPipeline } from './logical-plan';
|
|
16
|
+
export type { LogicalNode, QueryNode, SimpleSource, CTEPreAggregate, CubeRef, MeasureRef, DimensionRef, LogicalPlanWithAnalysis, PlanOptimiser, OptimiserContext } from './logical-plan';
|
|
17
|
+
export { DrizzlePlanBuilder } from './physical-plan';
|
|
18
|
+
export { createDatabaseExecutor, createPostgresExecutor, createSQLiteExecutor, createMySQLExecutor, createDuckDBExecutor, createDatabendExecutor, createSnowflakeExecutor, BaseDatabaseExecutor, PostgresExecutor, SQLiteExecutor, MySQLExecutor, DuckDBExecutor, DatabendExecutor, SnowflakeExecutor } from './executors';
|
|
19
|
+
export { resolveSqlExpression, createMultiCubeContext, resolveCubeReference, getJoinType } from './cube-utils';
|
|
20
|
+
export { defineCube } from './cube-utils';
|
|
21
|
+
export { generateCacheKey, normalizeQuery, fnv1aHash, strongHash, getCubeInvalidationPattern } from './cache-utils';
|
|
22
|
+
export { MemoryCacheProvider } from './cache-providers';
|
|
23
|
+
export { STEP0_VALIDATION_PROMPT, SYSTEM_PROMPT_TEMPLATE, STEP1_SYSTEM_PROMPT, STEP2_SYSTEM_PROMPT, buildStep0Prompt, buildSystemPrompt, buildStep1Prompt, buildStep2Prompt, EXPLAIN_ANALYSIS_PROMPT, buildExplainAnalysisPrompt, formatCubeSchemaForExplain, formatExistingIndexes } from './prompts';
|
|
24
|
+
export type { Step0Result, PromptContext, DimensionValues, Step1Result } from './prompts';
|
|
25
|
+
export { handleAgentChat, getToolDefinitions, createToolExecutor, buildAgentSystemPrompt } from './agent';
|
|
26
|
+
export type { AgentChatRequest, AgentConfig, AgentObservabilityHooks, AgentSSEEvent, PortletBlockData, MarkdownBlockData, ToolExecutionResult } from './agent';
|
|
27
|
+
export { discoverCubes, findBestFieldMatch, suggestQuery, validateQuery as aiValidateQuery } from './ai';
|
|
28
|
+
export type { CubeDiscoveryResult, DiscoveryOptions, QuerySuggestion, ValidationResult as AIValidationResult, ValidationError as AIValidationError, ValidationWarning as AIValidationWarning } from './ai';
|
|
29
|
+
export type * from './types';
|
|
30
|
+
export type { SQL } from 'drizzle-orm';
|
|
31
|
+
/**
|
|
32
|
+
* Create a new semantic layer instance with Drizzle integration
|
|
33
|
+
* Use this when you need multiple isolated instances
|
|
34
|
+
*/
|
|
35
|
+
export declare function createDrizzleSemanticLayer(options: {
|
|
36
|
+
drizzle: DrizzleDatabase;
|
|
37
|
+
schema?: any;
|
|
38
|
+
}): SemanticLayerCompiler;
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { Cube, CubeJoin, SemanticQuery } from '../types';
|
|
2
|
+
/** A resolved CTE join key (column names plus the underlying column objects). */
|
|
3
|
+
export interface CTEJoinKey {
|
|
4
|
+
sourceColumn: string;
|
|
5
|
+
targetColumn: string;
|
|
6
|
+
sourceColumnObj: any;
|
|
7
|
+
targetColumnObj: any;
|
|
8
|
+
}
|
|
9
|
+
/** A join definition located relative to a primary/target cube pair. */
|
|
10
|
+
export interface FoundJoinInfo {
|
|
11
|
+
sourceCube: Cube;
|
|
12
|
+
joinDef: CubeJoin;
|
|
13
|
+
reversed?: boolean;
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Derive the CTE join keys for a located join definition, handling
|
|
17
|
+
* belongsToMany junctions and reversed (belongsTo-back-to-primary) joins.
|
|
18
|
+
*/
|
|
19
|
+
export declare function deriveCTEJoinKeys(joinInfo: FoundJoinInfo, primaryCube: Cube): CTEJoinKey[];
|
|
20
|
+
/**
|
|
21
|
+
* Derive the join keys connecting a downstream dimension cube through the CTE
|
|
22
|
+
* cube, handling belongsToMany (via junction sourceKey) and regular joins.
|
|
23
|
+
*/
|
|
24
|
+
export declare function deriveDownstreamJoinKeys(joinDef: CubeJoin): CTEJoinKey[];
|
|
25
|
+
/**
|
|
26
|
+
* Find join information for a target cube, searching (in priority order):
|
|
27
|
+
* 1. The primary cube's direct join to the target.
|
|
28
|
+
* 2. The target cube's join back to the primary (reverse lookup → reversed).
|
|
29
|
+
* 3. Any other registered cube's join to the target.
|
|
30
|
+
*/
|
|
31
|
+
export declare function findJoinInfoForCube(cubes: Map<string, Cube>, primaryCube: Cube, targetCubeName: string): FoundJoinInfo | null;
|
|
32
|
+
/**
|
|
33
|
+
* Collect the names of cubes (other than the CTE cube) that contribute
|
|
34
|
+
* dimensions, time dimensions, or filter members to the query. These are the
|
|
35
|
+
* candidate downstream cubes that may need to join through the CTE.
|
|
36
|
+
*/
|
|
37
|
+
export declare function collectDimensionCubeNames(query: SemanticQuery, cteCubeName: string): Set<string>;
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { Cube, QueryContext, PhysicalQueryPlan, SemanticQuery } from '../types';
|
|
2
|
+
import { ResolverCache } from './planner-utils';
|
|
3
|
+
import { FilterPropagation } from './filter-propagation';
|
|
4
|
+
import { JoinRef } from './types';
|
|
5
|
+
export declare class CTEPlanner {
|
|
6
|
+
private readonly resolverCache;
|
|
7
|
+
private readonly filterPropagation;
|
|
8
|
+
constructor(resolverCache: ResolverCache, filterPropagation: FilterPropagation);
|
|
9
|
+
/**
|
|
10
|
+
* Plan pre-aggregation CTEs for hasMany relationships to prevent fan-out
|
|
11
|
+
* Note: belongsToMany relationships handle fan-out differently through their junction table structure
|
|
12
|
+
* and don't require CTEs - the two-hop join with the junction table provides natural grouping
|
|
13
|
+
*
|
|
14
|
+
* CRITICAL FAN-OUT PREVENTION LOGIC:
|
|
15
|
+
* When a query contains ANY hasMany relationship in the join graph, ALL cubes with measures
|
|
16
|
+
* that could be affected by row multiplication need CTEs. This includes:
|
|
17
|
+
*
|
|
18
|
+
* 1. Cubes with direct hasMany FROM primary (existing logic)
|
|
19
|
+
* 2. Cubes with measures that would be multiplied due to hasMany elsewhere in the query
|
|
20
|
+
* - Example: Query has Departments.totalBudget + Productivity.recordCount
|
|
21
|
+
* - Employees hasMany → Productivity causes row multiplication
|
|
22
|
+
* - Departments.totalBudget would be inflated without CTE pre-aggregation
|
|
23
|
+
*/
|
|
24
|
+
planPreAggregationCTEs(cubes: Map<string, Cube>, primaryCube: Cube, joinCubes: JoinRef[], query: SemanticQuery, _ctx: QueryContext): PhysicalQueryPlan['preAggregationCTEs'];
|
|
25
|
+
/**
|
|
26
|
+
* Build a single pre-aggregation CTE for one join-cube entry, or return null
|
|
27
|
+
* when the cube contributes no aggregate measures / has no resolvable join.
|
|
28
|
+
*/
|
|
29
|
+
private buildCTEForJoinCube;
|
|
30
|
+
/**
|
|
31
|
+
* Resolve the join keys (and any intermediate joins to absorb) for a CTE cube.
|
|
32
|
+
*
|
|
33
|
+
* Analyses the path from primary to the CTE cube: if an intermediate hasMany
|
|
34
|
+
* exists, returns the corrected keys plus intermediate joins; otherwise locates
|
|
35
|
+
* the join definition and derives keys from it.
|
|
36
|
+
*/
|
|
37
|
+
private resolveCTEJoinKeys;
|
|
38
|
+
/**
|
|
39
|
+
* Locate the join definition for a CTE cube, preferring the final step of the
|
|
40
|
+
* analysed path and falling back to a primary/reverse/any-cube search.
|
|
41
|
+
*/
|
|
42
|
+
private locateJoinInfo;
|
|
43
|
+
/**
|
|
44
|
+
* Analyze the join path from primary cube to a target CTE cube.
|
|
45
|
+
* Detects if there are intermediate hasMany relationships that would cause fan-out.
|
|
46
|
+
*
|
|
47
|
+
* Returns information about:
|
|
48
|
+
* - The full join path
|
|
49
|
+
* - Whether there are hasMany relationships ON the path (not just at the end)
|
|
50
|
+
* - Which intermediate tables need to be absorbed into the CTE
|
|
51
|
+
* - The correct join key to use (from primary cube's connection point)
|
|
52
|
+
*
|
|
53
|
+
* @param cubes Map of all registered cubes
|
|
54
|
+
* @param primaryCube The primary cube (FROM clause)
|
|
55
|
+
* @param targetCubeName The CTE cube we're analyzing the path to
|
|
56
|
+
* @param query The semantic query (drives query-aware path selection)
|
|
57
|
+
*/
|
|
58
|
+
private analyzeJoinPathToPrimary;
|
|
59
|
+
/**
|
|
60
|
+
* Compute CTE reasons from the actual join plan entries.
|
|
61
|
+
*
|
|
62
|
+
* Instead of scanning all registered cubes (which causes false positives when
|
|
63
|
+
* unrelated hasMany relationships exist), this walks only the planned joins
|
|
64
|
+
* using the `relationship` field now stored on each JoinCubePlanEntry.
|
|
65
|
+
*
|
|
66
|
+
* Algorithm:
|
|
67
|
+
* 1. Scan join plan entries for hasMany/belongsToMany relationships
|
|
68
|
+
* 2. If none found → return empty map (no CTEs needed)
|
|
69
|
+
* 3. hasMany/belongsToMany targets with measures → 'hasMany'
|
|
70
|
+
* 4. Other join cubes with measures (not hasMany source) → 'fanOutPrevention'
|
|
71
|
+
*/
|
|
72
|
+
private computeCTEReasons;
|
|
73
|
+
/**
|
|
74
|
+
* Find downstream cubes that need join keys included in the CTE.
|
|
75
|
+
*
|
|
76
|
+
* When a query has dimensions from a cube (e.g., Teams.name) and measures from
|
|
77
|
+
* a junction cube (e.g., EmployeeTeams.count), the junction CTE needs to include
|
|
78
|
+
* the join key to the dimension cube (team_id) so the dimension cube can be
|
|
79
|
+
* joined through the CTE instead of via an alternative path.
|
|
80
|
+
*
|
|
81
|
+
* @param cteCube The cube being converted to a CTE (e.g., EmployeeTeams)
|
|
82
|
+
* @param query The semantic query with dimensions and measures
|
|
83
|
+
* @param allCubes Map of all registered cubes
|
|
84
|
+
* @returns Array of downstream join key info for cubes needing join through this CTE
|
|
85
|
+
*/
|
|
86
|
+
private findDownstreamJoinKeys;
|
|
87
|
+
/**
|
|
88
|
+
* Expand calculated measures to include their dependencies
|
|
89
|
+
*/
|
|
90
|
+
private expandCalculatedMeasureDependencies;
|
|
91
|
+
/**
|
|
92
|
+
* Extract measure references from calculatedSql template
|
|
93
|
+
*/
|
|
94
|
+
private extractDependenciesFromTemplate;
|
|
95
|
+
/**
|
|
96
|
+
* Extract measures referenced in filters (for CTE inclusion)
|
|
97
|
+
*/
|
|
98
|
+
private extractMeasuresFromFilters;
|
|
99
|
+
/**
|
|
100
|
+
* Recursively extract measures from filters for a specific cube
|
|
101
|
+
* Only includes filter members that are actually measures (not dimensions)
|
|
102
|
+
*/
|
|
103
|
+
private extractMeasuresFromFilter;
|
|
104
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { Cube, SemanticQuery, PropagatingFilter, Filter } from '../types';
|
|
2
|
+
export declare class FilterPropagation {
|
|
3
|
+
/**
|
|
4
|
+
* Find filters that need to propagate from related cubes to a CTE cube.
|
|
5
|
+
* When cube A has filters and a hasMany relationship to cube B (the CTE cube),
|
|
6
|
+
* A's filters should propagate into B's CTE via a subquery.
|
|
7
|
+
*
|
|
8
|
+
* Example: Employees.createdAt filter should propagate to Productivity CTE
|
|
9
|
+
* via: employee_id IN (SELECT id FROM employees WHERE created_at >= $date)
|
|
10
|
+
*/
|
|
11
|
+
findPropagatingFilters(query: SemanticQuery, cteCube: Cube, allCubes: Map<string, Cube>): PropagatingFilter[];
|
|
12
|
+
/**
|
|
13
|
+
* Collect cube names referenced by filters and by time-dimension date ranges.
|
|
14
|
+
*/
|
|
15
|
+
private collectFilterCubeNames;
|
|
16
|
+
/**
|
|
17
|
+
* Build a single PropagatingFilter for a filterCube → cteCube hasMany edge,
|
|
18
|
+
* or null when the cube contributes no filters / the join has no keys.
|
|
19
|
+
*/
|
|
20
|
+
private buildPropagatingFilter;
|
|
21
|
+
/**
|
|
22
|
+
* Extract cube names from filters into a Set (helper for findPropagatingFilters)
|
|
23
|
+
*/
|
|
24
|
+
extractFilterCubeNamesToSet(filters: Filter[], cubesSet: Set<string>): void;
|
|
25
|
+
/**
|
|
26
|
+
* Extract filters for a specific cube from the filter array
|
|
27
|
+
*
|
|
28
|
+
* Logic for preserving filter semantics:
|
|
29
|
+
* - AND: Safe to extract only matching branches (AND of fewer conditions is more permissive)
|
|
30
|
+
* - OR: Must include ALL branches or skip entirely (partial OR changes semantics)
|
|
31
|
+
* If any branch belongs to another cube, skip the entire OR to be safe
|
|
32
|
+
* since we can't evaluate the other cube's conditions
|
|
33
|
+
*/
|
|
34
|
+
extractFiltersForCube(filters: Filter[], targetCubeName: string): Filter[];
|
|
35
|
+
/**
|
|
36
|
+
* Check if all simple filters in a filter array belong to the specified cube
|
|
37
|
+
* Recursively checks nested AND/OR filters
|
|
38
|
+
*/
|
|
39
|
+
allFiltersFromCube(filters: Filter[], targetCubeName: string): boolean;
|
|
40
|
+
/**
|
|
41
|
+
* Extract time dimension date range filters as regular filters for a specific cube
|
|
42
|
+
*/
|
|
43
|
+
extractTimeDimensionFiltersForCube(query: SemanticQuery, targetCubeName: string): Filter[];
|
|
44
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Logical Plan module — multi-stage query pipeline.
|
|
3
|
+
*
|
|
4
|
+
* Exports:
|
|
5
|
+
* - Types: LogicalNode tree types
|
|
6
|
+
* - LogicalPlanBuilder: SemanticQuery → LogicalNode tree
|
|
7
|
+
* - Optimisers: PlanOptimiser interface and built-in passes
|
|
8
|
+
*/
|
|
9
|
+
export type { LogicalNode, LogicalNodeType, LogicalNodeBase, QueryNode, SimpleSource, FullKeyAggregate, CTEPreAggregate, KeysDeduplication, MultiFactMerge, CubeRef, MeasureRef, DimensionRef, TimeDimensionRef, ColumnRef, OrderByRef, JoinRef, LogicalSchema } from './types';
|
|
10
|
+
export { LogicalPlanner } from './logical-planner';
|
|
11
|
+
export { LogicalPlanBuilder } from './logical-plan-builder';
|
|
12
|
+
export type { LogicalPlanWithAnalysis } from './logical-plan-builder';
|
|
13
|
+
export { JoinPlanner } from './join-planner';
|
|
14
|
+
export { CTEPlanner } from './cte-planner';
|
|
15
|
+
export { FilterPropagation } from './filter-propagation';
|
|
16
|
+
export { PlanAnalysisReporter } from './plan-analysis-reporter';
|
|
17
|
+
export { ResolverCache, analyzeCubeUsage, extractCubeNamesFromFilter } from './planner-utils';
|
|
18
|
+
export type { PlanOptimiser, OptimiserContext, OptimiserEngineType } from './optimiser';
|
|
19
|
+
export { IdentityOptimiser, OptimiserPipeline } from './optimiser';
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { Cube, CubeJoin, SemanticQuery } from '../types';
|
|
2
|
+
import { ResolverCache } from './planner-utils';
|
|
3
|
+
import { JoinRef } from './types';
|
|
4
|
+
export declare class JoinPlanner {
|
|
5
|
+
private readonly resolverCache;
|
|
6
|
+
constructor(resolverCache: ResolverCache);
|
|
7
|
+
/**
|
|
8
|
+
* Build join plan for multi-cube query
|
|
9
|
+
* Supports both direct joins and transitive joins through intermediate cubes
|
|
10
|
+
*
|
|
11
|
+
* Uses query-aware path selection to prefer joining through cubes that have
|
|
12
|
+
* measures in the query (e.g., joining Teams through EmployeeTeams when
|
|
13
|
+
* EmployeeTeams.count is a measure)
|
|
14
|
+
*/
|
|
15
|
+
buildJoinPlan(cubes: Map<string, Cube>, primaryCube: Cube, cubeNames: string[], _ctx: unknown, query: SemanticQuery): JoinRef[];
|
|
16
|
+
/**
|
|
17
|
+
* Build a single symbolic JoinRef for a join-path step. Handles belongsToMany
|
|
18
|
+
* (junction-table) joins and regular (belongsTo/hasOne/hasMany) joins. The join
|
|
19
|
+
* conditions and security WHERE are materialized later by DrizzlePlanBuilder;
|
|
20
|
+
* only the join type is resolved here (it depends on the effective relationship).
|
|
21
|
+
*/
|
|
22
|
+
private buildJoinRef;
|
|
23
|
+
/**
|
|
24
|
+
* Find hasMany join definition from primary cube to target cube
|
|
25
|
+
*/
|
|
26
|
+
findHasManyJoinDef(primaryCube: Cube, targetCubeName: string, cubes?: Map<string, Cube>): CubeJoin | null;
|
|
27
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { Cube, QueryContext } from '../types';
|
|
2
|
+
import { QueryAnalysis } from '../types/analysis';
|
|
3
|
+
import { SemanticQuery } from '../types/query';
|
|
4
|
+
import { LogicalPlanner } from './logical-planner';
|
|
5
|
+
import { QueryNode } from './types';
|
|
6
|
+
export interface LogicalPlanWithAnalysis {
|
|
7
|
+
plan: QueryNode;
|
|
8
|
+
analysis: QueryAnalysis;
|
|
9
|
+
}
|
|
10
|
+
export declare class LogicalPlanBuilder {
|
|
11
|
+
private readonly queryPlanner;
|
|
12
|
+
constructor(queryPlanner: LogicalPlanner);
|
|
13
|
+
/**
|
|
14
|
+
* Build a logical plan from a semantic query.
|
|
15
|
+
*/
|
|
16
|
+
plan(cubes: Map<string, Cube>, query: SemanticQuery, ctx: QueryContext): QueryNode;
|
|
17
|
+
/**
|
|
18
|
+
* Build a logical plan and an explicit decision trace for dry-run/explain.
|
|
19
|
+
* The analysis is produced from the same phase outputs used to build the plan.
|
|
20
|
+
*/
|
|
21
|
+
planWithAnalysis(cubes: Map<string, Cube>, query: SemanticQuery, ctx: QueryContext): LogicalPlanWithAnalysis;
|
|
22
|
+
private buildSourceFromPhases;
|
|
23
|
+
private buildSimpleSourceFromPhases;
|
|
24
|
+
/**
|
|
25
|
+
* Detect and build multi-fact merge for star-schema style queries where:
|
|
26
|
+
* - measures come from 2+ cubes
|
|
27
|
+
* - all grouping dimensions/timeDimensions come from one shared dimension cube
|
|
28
|
+
* - each measure cube directly belongsTo/hasOne that shared cube
|
|
29
|
+
*/
|
|
30
|
+
private tryBuildMultiFactMergeSource;
|
|
31
|
+
private hasDirectJoinToSharedDimension;
|
|
32
|
+
private buildGroupQueryNode;
|
|
33
|
+
private projectFiltersToAllowedCubes;
|
|
34
|
+
private projectFilterNodeToAllowedCubes;
|
|
35
|
+
private classifyMeasuresForStrategy;
|
|
36
|
+
private selectMeasureStrategy;
|
|
37
|
+
/**
|
|
38
|
+
* Initial execution scope for keys deduplication:
|
|
39
|
+
* - exactly one multiplied cube
|
|
40
|
+
* - all query measures belong to that cube
|
|
41
|
+
* - only additive measure types currently handled by the physical keys path
|
|
42
|
+
* - no measure filters (HAVING) in the query
|
|
43
|
+
*/
|
|
44
|
+
private isKeysDeduplicationExecutionSupported;
|
|
45
|
+
private queryHasMeasureFilter;
|
|
46
|
+
private buildKeysDeduplicationSource;
|
|
47
|
+
private isDeduplicationSafeMeasure;
|
|
48
|
+
private getPrimaryKeyColumns;
|
|
49
|
+
private deduplicateColumnRefs;
|
|
50
|
+
private buildQueryNode;
|
|
51
|
+
private buildPreAggregationAnalysis;
|
|
52
|
+
private buildMeasureRefs;
|
|
53
|
+
private buildDimensionRefs;
|
|
54
|
+
private buildTimeDimensionRefs;
|
|
55
|
+
private buildOrderByRefs;
|
|
56
|
+
private toCubeRef;
|
|
57
|
+
private buildCTESchema;
|
|
58
|
+
}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { Cube, QueryContext, PhysicalQueryPlan, SemanticQuery, PrimaryCubeAnalysis, JoinPathAnalysis, QueryWarning } from '../types';
|
|
2
|
+
import { JoinRef } from './types';
|
|
3
|
+
export declare class LogicalPlanner {
|
|
4
|
+
private readonly resolverCache;
|
|
5
|
+
private readonly joinPlanner;
|
|
6
|
+
private readonly ctePlanner;
|
|
7
|
+
private readonly reporter;
|
|
8
|
+
/**
|
|
9
|
+
* Analyze a semantic query to determine which cubes are involved
|
|
10
|
+
*/
|
|
11
|
+
analyzeCubeUsage(query: SemanticQuery): Set<string>;
|
|
12
|
+
/**
|
|
13
|
+
* Analyze primary cube selection with candidate details.
|
|
14
|
+
* Exposed for LogicalPlanBuilder so dry-run/analyze can report
|
|
15
|
+
* exactly which selection rule was used.
|
|
16
|
+
*/
|
|
17
|
+
analyzePrimaryCube(cubeNames: string[], query: SemanticQuery, cubes: Map<string, Cube>): PrimaryCubeAnalysis;
|
|
18
|
+
/**
|
|
19
|
+
* Analyze join path for a specific target cube.
|
|
20
|
+
* Exposed for LogicalPlanBuilder to provide join decision trace.
|
|
21
|
+
*/
|
|
22
|
+
analyzeJoinPathForTarget(cubes: Map<string, Cube>, fromCube: string, toCube: string, query?: SemanticQuery): JoinPathAnalysis;
|
|
23
|
+
/**
|
|
24
|
+
* Build join plan for a known primary cube.
|
|
25
|
+
* Exposed for LogicalPlanBuilder so logical planning can compose
|
|
26
|
+
* planner phases directly.
|
|
27
|
+
*/
|
|
28
|
+
buildJoinPlanForPrimary(cubes: Map<string, Cube>, primaryCube: Cube, cubeNames: string[], ctx: QueryContext, query: SemanticQuery): JoinRef[];
|
|
29
|
+
/**
|
|
30
|
+
* Build pre-aggregation CTE plan from a primary cube and join plan.
|
|
31
|
+
* Exposed for LogicalPlanBuilder phase composition.
|
|
32
|
+
*/
|
|
33
|
+
buildPreAggregationCTEs(cubes: Map<string, Cube>, primaryCube: Cube, joinCubes: JoinRef[], query: SemanticQuery, ctx: QueryContext): PhysicalQueryPlan['preAggregationCTEs'];
|
|
34
|
+
/**
|
|
35
|
+
* Generate query warnings from pre-aggregation analysis.
|
|
36
|
+
* Exposed for LogicalPlanBuilder phase composition.
|
|
37
|
+
*/
|
|
38
|
+
buildWarnings(query: SemanticQuery, preAggregationCTEs?: PhysicalQueryPlan['preAggregationCTEs']): QueryWarning[];
|
|
39
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { LogicalNode } from './types';
|
|
2
|
+
/** Database engine the optimiser is targeting (all 7 supported engines). */
|
|
3
|
+
export type OptimiserEngineType = 'postgres' | 'mysql' | 'sqlite' | 'singlestore' | 'duckdb' | 'databend' | 'snowflake';
|
|
4
|
+
/** Context available to optimiser passes */
|
|
5
|
+
export interface OptimiserContext {
|
|
6
|
+
/** Database engine type for engine-specific rewrites */
|
|
7
|
+
engineType: OptimiserEngineType;
|
|
8
|
+
}
|
|
9
|
+
/** A single optimiser pass that rewrites a logical plan */
|
|
10
|
+
export interface PlanOptimiser {
|
|
11
|
+
/** Human-readable name for debugging / explain output */
|
|
12
|
+
readonly name: string;
|
|
13
|
+
/** Rewrite the plan tree. Must return a valid plan (may return the same reference). */
|
|
14
|
+
optimise(plan: LogicalNode, context: OptimiserContext): LogicalNode;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* No-op optimiser — returns the plan unchanged.
|
|
18
|
+
* Used as the default in Phase 1 and as a baseline for testing.
|
|
19
|
+
*/
|
|
20
|
+
export declare class IdentityOptimiser implements PlanOptimiser {
|
|
21
|
+
readonly name = "identity";
|
|
22
|
+
optimise(plan: LogicalNode): LogicalNode;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Runs a sequence of optimiser passes in order.
|
|
26
|
+
* Short-circuits if a pass returns a different reference (for future use).
|
|
27
|
+
*/
|
|
28
|
+
export declare class OptimiserPipeline implements PlanOptimiser {
|
|
29
|
+
readonly name = "pipeline";
|
|
30
|
+
private passes;
|
|
31
|
+
constructor(passes?: PlanOptimiser[]);
|
|
32
|
+
optimise(plan: LogicalNode, context: OptimiserContext): LogicalNode;
|
|
33
|
+
addPass(pass: PlanOptimiser): void;
|
|
34
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { Cube, PhysicalQueryPlan, SemanticQuery, PrimaryCubeAnalysis, JoinPathAnalysis, QueryWarning } from '../types';
|
|
2
|
+
import { ResolverCache } from './planner-utils';
|
|
3
|
+
export declare class PlanAnalysisReporter {
|
|
4
|
+
private readonly resolverCache;
|
|
5
|
+
constructor(resolverCache: ResolverCache);
|
|
6
|
+
/**
|
|
7
|
+
* Analyze why a particular cube was chosen as primary
|
|
8
|
+
*/
|
|
9
|
+
analyzePrimaryCubeSelection(cubeNames: string[], query: SemanticQuery, cubes: Map<string, Cube>): PrimaryCubeAnalysis;
|
|
10
|
+
/**
|
|
11
|
+
* Build the scored candidate list (dimension count, join count, reachability).
|
|
12
|
+
*/
|
|
13
|
+
private buildPrimaryCubeCandidates;
|
|
14
|
+
/**
|
|
15
|
+
* Tier 1: select the cube with the most query dimensions that can reach all
|
|
16
|
+
* others. Returns null when no dimension-based winner applies.
|
|
17
|
+
*/
|
|
18
|
+
private selectByDimensions;
|
|
19
|
+
/**
|
|
20
|
+
* Tier 2: among cubes that can reach all others, select the most connected.
|
|
21
|
+
* Returns null when no candidate can reach all others.
|
|
22
|
+
*/
|
|
23
|
+
private selectByConnectivity;
|
|
24
|
+
/**
|
|
25
|
+
* Analyze the join path between two cubes with detailed step information
|
|
26
|
+
*
|
|
27
|
+
* Uses JoinPathResolver.findPath() for the actual path finding,
|
|
28
|
+
* then converts the result to human-readable analysis format.
|
|
29
|
+
*/
|
|
30
|
+
analyzeJoinPath(cubes: Map<string, Cube>, fromCube: string, toCube: string, query?: SemanticQuery): JoinPathAnalysis;
|
|
31
|
+
private convertInternalPathToJoinPathSteps;
|
|
32
|
+
private buildJoinPathSelectionAnalysis;
|
|
33
|
+
private mapPreferredCandidate;
|
|
34
|
+
/**
|
|
35
|
+
* Generate warnings for query edge cases that users should be aware of.
|
|
36
|
+
* Currently detects:
|
|
37
|
+
* - FAN_OUT_NO_DIMENSIONS: Query has hasMany CTEs but no dimensions to group by
|
|
38
|
+
*
|
|
39
|
+
* Note: AVG measures in hasMany CTEs can produce mathematically imprecise results
|
|
40
|
+
* (average of averages vs weighted average), but this warning was removed as it
|
|
41
|
+
* fired too aggressively. The issue only occurs when the outer grouping is coarser
|
|
42
|
+
* than the CTE grouping, which is rare in practice. The limitation is documented
|
|
43
|
+
* in executor.ts comments.
|
|
44
|
+
*/
|
|
45
|
+
generateWarnings(query: SemanticQuery, preAggregationCTEs?: PhysicalQueryPlan['preAggregationCTEs']): QueryWarning[];
|
|
46
|
+
/**
|
|
47
|
+
* Detect when a query has measures from multiple cubes with hasMany relationships
|
|
48
|
+
* but no dimensions to provide grouping context.
|
|
49
|
+
*
|
|
50
|
+
* This is an edge case where:
|
|
51
|
+
* - Query has measures from 2+ cubes
|
|
52
|
+
* - At least one CTE exists (indicating hasMany relationship)
|
|
53
|
+
* - Query has NO dimensions AND NO time dimensions with granularity
|
|
54
|
+
*
|
|
55
|
+
* The SQL is technically correct (CTEs with GROUP BY on join keys), but users
|
|
56
|
+
* may be confused by the aggregated results without visible grouping.
|
|
57
|
+
*/
|
|
58
|
+
private checkFanOutNoDimensions;
|
|
59
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Cube, SemanticQuery } from '../types';
|
|
2
|
+
import { JoinPathResolver } from '../resolvers/join-path-resolver';
|
|
3
|
+
/**
|
|
4
|
+
* Caches a JoinPathResolver per cubes map to avoid repeated instantiation.
|
|
5
|
+
* Shared by all sub-planners so a single query reuses one resolver per cubes map.
|
|
6
|
+
*/
|
|
7
|
+
export declare class ResolverCache {
|
|
8
|
+
private cache;
|
|
9
|
+
get(cubes: Map<string, Cube>): JoinPathResolver;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Analyze a semantic query to determine which cubes are involved.
|
|
13
|
+
* Scans measures, dimensions, time dimensions, filters and ORDER BY members.
|
|
14
|
+
*/
|
|
15
|
+
export declare function analyzeCubeUsage(query: SemanticQuery): Set<string>;
|
|
16
|
+
/**
|
|
17
|
+
* Recursively extract cube names from a filter (handles logical AND/OR filters)
|
|
18
|
+
* into the provided set.
|
|
19
|
+
*/
|
|
20
|
+
export declare function extractCubeNamesFromFilter(filter: any, cubesUsed: Set<string>): void;
|