@lightdash/common 0.2650.0 → 0.2652.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/dist/cjs/.tsbuildinfo +1 -1
- package/dist/cjs/compiler/translator.d.ts +10 -1
- package/dist/cjs/compiler/translator.d.ts.map +1 -1
- package/dist/cjs/compiler/translator.js +15 -31
- package/dist/cjs/compiler/translator.js.map +1 -1
- package/dist/cjs/compiler/translator.test.js +0 -259
- package/dist/cjs/compiler/translator.test.js.map +1 -1
- package/dist/cjs/index.d.ts +0 -1
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +0 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/types/analytics.d.ts +1 -0
- package/dist/cjs/types/analytics.d.ts.map +1 -1
- package/dist/cjs/types/analytics.js +1 -0
- package/dist/cjs/types/analytics.js.map +1 -1
- package/dist/cjs/types/featureFlags.d.ts +7 -1
- package/dist/cjs/types/featureFlags.d.ts.map +1 -1
- package/dist/cjs/types/featureFlags.js +6 -0
- package/dist/cjs/types/featureFlags.js.map +1 -1
- package/dist/cjs/types/scheduler.d.ts +18 -3
- package/dist/cjs/types/scheduler.d.ts.map +1 -1
- package/dist/cjs/types/scheduler.js +27 -2
- package/dist/cjs/types/scheduler.js.map +1 -1
- package/dist/cjs/types/schedulerLog.d.ts +7 -2
- package/dist/cjs/types/schedulerLog.d.ts.map +1 -1
- package/dist/cjs/types/schedulerLog.js +7 -1
- package/dist/cjs/types/schedulerLog.js.map +1 -1
- package/dist/esm/.tsbuildinfo +1 -1
- package/dist/esm/compiler/translator.d.ts +10 -1
- package/dist/esm/compiler/translator.d.ts.map +1 -1
- package/dist/esm/compiler/translator.js +16 -32
- package/dist/esm/compiler/translator.js.map +1 -1
- package/dist/esm/compiler/translator.test.js +1 -260
- package/dist/esm/compiler/translator.test.js.map +1 -1
- package/dist/esm/index.d.ts +0 -1
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +0 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/types/analytics.d.ts +1 -0
- package/dist/esm/types/analytics.d.ts.map +1 -1
- package/dist/esm/types/analytics.js +1 -0
- package/dist/esm/types/analytics.js.map +1 -1
- package/dist/esm/types/featureFlags.d.ts +7 -1
- package/dist/esm/types/featureFlags.d.ts.map +1 -1
- package/dist/esm/types/featureFlags.js +6 -0
- package/dist/esm/types/featureFlags.js.map +1 -1
- package/dist/esm/types/scheduler.d.ts +18 -3
- package/dist/esm/types/scheduler.d.ts.map +1 -1
- package/dist/esm/types/scheduler.js +24 -1
- package/dist/esm/types/scheduler.js.map +1 -1
- package/dist/esm/types/schedulerLog.d.ts +7 -2
- package/dist/esm/types/schedulerLog.d.ts.map +1 -1
- package/dist/esm/types/schedulerLog.js +6 -0
- package/dist/esm/types/schedulerLog.js.map +1 -1
- package/dist/types/.tsbuildinfo +1 -1
- package/dist/types/compiler/translator.d.ts +10 -1
- package/dist/types/compiler/translator.d.ts.map +1 -1
- package/dist/types/compiler/translator.js +16 -32
- package/dist/types/compiler/translator.js.map +1 -1
- package/dist/types/compiler/translator.test.js +1 -260
- package/dist/types/compiler/translator.test.js.map +1 -1
- package/dist/types/index.d.ts +0 -1
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +0 -1
- package/dist/types/index.js.map +1 -1
- package/dist/types/types/analytics.d.ts +1 -0
- package/dist/types/types/analytics.d.ts.map +1 -1
- package/dist/types/types/analytics.js +1 -0
- package/dist/types/types/analytics.js.map +1 -1
- package/dist/types/types/featureFlags.d.ts +7 -1
- package/dist/types/types/featureFlags.d.ts.map +1 -1
- package/dist/types/types/featureFlags.js +6 -0
- package/dist/types/types/featureFlags.js.map +1 -1
- package/dist/types/types/scheduler.d.ts +18 -3
- package/dist/types/types/scheduler.d.ts.map +1 -1
- package/dist/types/types/scheduler.js +24 -1
- package/dist/types/types/scheduler.js.map +1 -1
- package/dist/types/types/schedulerLog.d.ts +7 -2
- package/dist/types/types/schedulerLog.d.ts.map +1 -1
- package/dist/types/types/schedulerLog.js +6 -0
- package/dist/types/types/schedulerLog.js.map +1 -1
- package/package.json +1 -1
- package/dist/cjs/preAggregates/additivity.d.ts +0 -9
- package/dist/cjs/preAggregates/additivity.d.ts.map +0 -1
- package/dist/cjs/preAggregates/additivity.js +0 -54
- package/dist/cjs/preAggregates/additivity.js.map +0 -1
- package/dist/cjs/preAggregates/buildPreAggregateExplore.d.ts +0 -5
- package/dist/cjs/preAggregates/buildPreAggregateExplore.d.ts.map +0 -1
- package/dist/cjs/preAggregates/buildPreAggregateExplore.js +0 -242
- package/dist/cjs/preAggregates/buildPreAggregateExplore.js.map +0 -1
- package/dist/cjs/preAggregates/buildPreAggregateExplore.test.d.ts +0 -2
- package/dist/cjs/preAggregates/buildPreAggregateExplore.test.d.ts.map +0 -1
- package/dist/cjs/preAggregates/buildPreAggregateExplore.test.js +0 -233
- package/dist/cjs/preAggregates/buildPreAggregateExplore.test.js.map +0 -1
- package/dist/cjs/preAggregates/definition.d.ts +0 -5
- package/dist/cjs/preAggregates/definition.d.ts.map +0 -1
- package/dist/cjs/preAggregates/definition.js +0 -73
- package/dist/cjs/preAggregates/definition.js.map +0 -1
- package/dist/cjs/preAggregates/generatePreAggregateExplores.d.ts +0 -7
- package/dist/cjs/preAggregates/generatePreAggregateExplores.d.ts.map +0 -1
- package/dist/cjs/preAggregates/generatePreAggregateExplores.js +0 -51
- package/dist/cjs/preAggregates/generatePreAggregateExplores.js.map +0 -1
- package/dist/cjs/preAggregates/index.d.ts +0 -9
- package/dist/cjs/preAggregates/index.d.ts.map +0 -1
- package/dist/cjs/preAggregates/index.js +0 -12
- package/dist/cjs/preAggregates/index.js.map +0 -1
- package/dist/cjs/preAggregates/matcher.d.ts +0 -14
- package/dist/cjs/preAggregates/matcher.d.ts.map +0 -1
- package/dist/cjs/preAggregates/matcher.js +0 -221
- package/dist/cjs/preAggregates/matcher.js.map +0 -1
- package/dist/cjs/preAggregates/matcher.test.d.ts +0 -2
- package/dist/cjs/preAggregates/matcher.test.d.ts.map +0 -1
- package/dist/cjs/preAggregates/matcher.test.js +0 -593
- package/dist/cjs/preAggregates/matcher.test.js.map +0 -1
- package/dist/cjs/preAggregates/metricRepresentation.d.ts +0 -21
- package/dist/cjs/preAggregates/metricRepresentation.d.ts.map +0 -1
- package/dist/cjs/preAggregates/metricRepresentation.js +0 -68
- package/dist/cjs/preAggregates/metricRepresentation.js.map +0 -1
- package/dist/cjs/preAggregates/naming.d.ts +0 -8
- package/dist/cjs/preAggregates/naming.d.ts.map +0 -1
- package/dist/cjs/preAggregates/naming.js +0 -15
- package/dist/cjs/preAggregates/naming.js.map +0 -1
- package/dist/cjs/preAggregates/references.d.ts +0 -21
- package/dist/cjs/preAggregates/references.d.ts.map +0 -1
- package/dist/cjs/preAggregates/references.js +0 -40
- package/dist/cjs/preAggregates/references.js.map +0 -1
- package/dist/esm/preAggregates/additivity.d.ts +0 -9
- package/dist/esm/preAggregates/additivity.d.ts.map +0 -1
- package/dist/esm/preAggregates/additivity.js +0 -48
- package/dist/esm/preAggregates/additivity.js.map +0 -1
- package/dist/esm/preAggregates/buildPreAggregateExplore.d.ts +0 -5
- package/dist/esm/preAggregates/buildPreAggregateExplore.d.ts.map +0 -1
- package/dist/esm/preAggregates/buildPreAggregateExplore.js +0 -237
- package/dist/esm/preAggregates/buildPreAggregateExplore.js.map +0 -1
- package/dist/esm/preAggregates/buildPreAggregateExplore.test.d.ts +0 -2
- package/dist/esm/preAggregates/buildPreAggregateExplore.test.d.ts.map +0 -1
- package/dist/esm/preAggregates/buildPreAggregateExplore.test.js +0 -231
- package/dist/esm/preAggregates/buildPreAggregateExplore.test.js.map +0 -1
- package/dist/esm/preAggregates/definition.d.ts +0 -5
- package/dist/esm/preAggregates/definition.d.ts.map +0 -1
- package/dist/esm/preAggregates/definition.js +0 -68
- package/dist/esm/preAggregates/definition.js.map +0 -1
- package/dist/esm/preAggregates/generatePreAggregateExplores.d.ts +0 -7
- package/dist/esm/preAggregates/generatePreAggregateExplores.d.ts.map +0 -1
- package/dist/esm/preAggregates/generatePreAggregateExplores.js +0 -47
- package/dist/esm/preAggregates/generatePreAggregateExplores.js.map +0 -1
- package/dist/esm/preAggregates/index.d.ts +0 -9
- package/dist/esm/preAggregates/index.d.ts.map +0 -1
- package/dist/esm/preAggregates/index.js +0 -9
- package/dist/esm/preAggregates/index.js.map +0 -1
- package/dist/esm/preAggregates/matcher.d.ts +0 -14
- package/dist/esm/preAggregates/matcher.d.ts.map +0 -1
- package/dist/esm/preAggregates/matcher.js +0 -217
- package/dist/esm/preAggregates/matcher.js.map +0 -1
- package/dist/esm/preAggregates/matcher.test.d.ts +0 -2
- package/dist/esm/preAggregates/matcher.test.d.ts.map +0 -1
- package/dist/esm/preAggregates/matcher.test.js +0 -591
- package/dist/esm/preAggregates/matcher.test.js.map +0 -1
- package/dist/esm/preAggregates/metricRepresentation.d.ts +0 -21
- package/dist/esm/preAggregates/metricRepresentation.d.ts.map +0 -1
- package/dist/esm/preAggregates/metricRepresentation.js +0 -62
- package/dist/esm/preAggregates/metricRepresentation.js.map +0 -1
- package/dist/esm/preAggregates/naming.d.ts +0 -8
- package/dist/esm/preAggregates/naming.d.ts.map +0 -1
- package/dist/esm/preAggregates/naming.js +0 -7
- package/dist/esm/preAggregates/naming.js.map +0 -1
- package/dist/esm/preAggregates/references.d.ts +0 -21
- package/dist/esm/preAggregates/references.d.ts.map +0 -1
- package/dist/esm/preAggregates/references.js +0 -33
- package/dist/esm/preAggregates/references.js.map +0 -1
- package/dist/types/preAggregates/additivity.d.ts +0 -9
- package/dist/types/preAggregates/additivity.d.ts.map +0 -1
- package/dist/types/preAggregates/additivity.js +0 -48
- package/dist/types/preAggregates/additivity.js.map +0 -1
- package/dist/types/preAggregates/buildPreAggregateExplore.d.ts +0 -5
- package/dist/types/preAggregates/buildPreAggregateExplore.d.ts.map +0 -1
- package/dist/types/preAggregates/buildPreAggregateExplore.js +0 -237
- package/dist/types/preAggregates/buildPreAggregateExplore.js.map +0 -1
- package/dist/types/preAggregates/buildPreAggregateExplore.test.d.ts +0 -2
- package/dist/types/preAggregates/buildPreAggregateExplore.test.d.ts.map +0 -1
- package/dist/types/preAggregates/buildPreAggregateExplore.test.js +0 -231
- package/dist/types/preAggregates/buildPreAggregateExplore.test.js.map +0 -1
- package/dist/types/preAggregates/definition.d.ts +0 -5
- package/dist/types/preAggregates/definition.d.ts.map +0 -1
- package/dist/types/preAggregates/definition.js +0 -68
- package/dist/types/preAggregates/definition.js.map +0 -1
- package/dist/types/preAggregates/generatePreAggregateExplores.d.ts +0 -7
- package/dist/types/preAggregates/generatePreAggregateExplores.d.ts.map +0 -1
- package/dist/types/preAggregates/generatePreAggregateExplores.js +0 -47
- package/dist/types/preAggregates/generatePreAggregateExplores.js.map +0 -1
- package/dist/types/preAggregates/index.d.ts +0 -9
- package/dist/types/preAggregates/index.d.ts.map +0 -1
- package/dist/types/preAggregates/index.js +0 -9
- package/dist/types/preAggregates/index.js.map +0 -1
- package/dist/types/preAggregates/matcher.d.ts +0 -14
- package/dist/types/preAggregates/matcher.d.ts.map +0 -1
- package/dist/types/preAggregates/matcher.js +0 -217
- package/dist/types/preAggregates/matcher.js.map +0 -1
- package/dist/types/preAggregates/matcher.test.d.ts +0 -2
- package/dist/types/preAggregates/matcher.test.d.ts.map +0 -1
- package/dist/types/preAggregates/matcher.test.js +0 -591
- package/dist/types/preAggregates/matcher.test.js.map +0 -1
- package/dist/types/preAggregates/metricRepresentation.d.ts +0 -21
- package/dist/types/preAggregates/metricRepresentation.d.ts.map +0 -1
- package/dist/types/preAggregates/metricRepresentation.js +0 -62
- package/dist/types/preAggregates/metricRepresentation.js.map +0 -1
- package/dist/types/preAggregates/naming.d.ts +0 -8
- package/dist/types/preAggregates/naming.d.ts.map +0 -1
- package/dist/types/preAggregates/naming.js +0 -7
- package/dist/types/preAggregates/naming.js.map +0 -1
- package/dist/types/preAggregates/references.d.ts +0 -21
- package/dist/types/preAggregates/references.d.ts.map +0 -1
- package/dist/types/preAggregates/references.js +0 -33
- package/dist/types/preAggregates/references.js.map +0 -1
|
@@ -1,217 +0,0 @@
|
|
|
1
|
-
import { MetricType } from '../types/field';
|
|
2
|
-
import { flattenFilterGroup } from '../types/filter';
|
|
3
|
-
import { PreAggregateMissReason, } from '../types/preAggregate';
|
|
4
|
-
import { getMetricsMapFromTables } from '../utils/fields';
|
|
5
|
-
import { getItemId } from '../utils/item';
|
|
6
|
-
import { timeFrameOrder } from '../utils/timeFrames';
|
|
7
|
-
import { isPreAggregateCompatible } from './additivity';
|
|
8
|
-
import { getDimensionReferences, getMetricReferences } from './references';
|
|
9
|
-
const isGranularityCoarserOrEqual = (queryGranularity, preAggregateGranularity) => {
|
|
10
|
-
const queryIndex = timeFrameOrder.indexOf(queryGranularity);
|
|
11
|
-
const preAggregateIndex = timeFrameOrder.indexOf(preAggregateGranularity);
|
|
12
|
-
if (queryIndex === -1 || preAggregateIndex === -1) {
|
|
13
|
-
return false;
|
|
14
|
-
}
|
|
15
|
-
return queryIndex >= preAggregateIndex;
|
|
16
|
-
};
|
|
17
|
-
const getDimensionsByFieldId = (explore) => {
|
|
18
|
-
const dimensionsByFieldId = new Map();
|
|
19
|
-
Object.values(explore.tables).forEach((table) => {
|
|
20
|
-
Object.values(table.dimensions).forEach((dimension) => {
|
|
21
|
-
dimensionsByFieldId.set(getItemId(dimension), dimension);
|
|
22
|
-
});
|
|
23
|
-
});
|
|
24
|
-
return dimensionsByFieldId;
|
|
25
|
-
};
|
|
26
|
-
const dimensionFieldIdMatchesDef = (fieldId, explore, defDimensions, dimensionsByFieldId) => {
|
|
27
|
-
const dimension = dimensionsByFieldId.get(fieldId);
|
|
28
|
-
if (!dimension) {
|
|
29
|
-
return false;
|
|
30
|
-
}
|
|
31
|
-
return getDimensionReferences({
|
|
32
|
-
dimension,
|
|
33
|
-
baseTable: explore.baseTable,
|
|
34
|
-
}).some((reference) => defDimensions.has(reference));
|
|
35
|
-
};
|
|
36
|
-
const extractDimensionFilterFieldIds = (metricQuery) => {
|
|
37
|
-
if (!metricQuery.filters.dimensions) {
|
|
38
|
-
return [];
|
|
39
|
-
}
|
|
40
|
-
return flattenFilterGroup(metricQuery.filters.dimensions)
|
|
41
|
-
.filter((rule) => !rule.disabled)
|
|
42
|
-
.map((rule) => rule.target)
|
|
43
|
-
.filter((target) => !!target &&
|
|
44
|
-
typeof target === 'object' &&
|
|
45
|
-
'fieldId' in target &&
|
|
46
|
-
typeof target.fieldId === 'string')
|
|
47
|
-
.map((target) => target.fieldId);
|
|
48
|
-
};
|
|
49
|
-
const getGranularityMissForDef = (metricQuery, explore, preAggregateDef, dimensionsByFieldId) => {
|
|
50
|
-
if (!preAggregateDef.timeDimension || !preAggregateDef.granularity) {
|
|
51
|
-
return null;
|
|
52
|
-
}
|
|
53
|
-
for (const dimensionFieldId of metricQuery.dimensions) {
|
|
54
|
-
const dimension = dimensionsByFieldId.get(dimensionFieldId);
|
|
55
|
-
const queryGranularity = dimension?.timeInterval;
|
|
56
|
-
const matchesRollupTimeDimension = !!dimension &&
|
|
57
|
-
!!queryGranularity &&
|
|
58
|
-
(dimension.timeIntervalBaseDimensionName ?? dimension.name) ===
|
|
59
|
-
preAggregateDef.timeDimension;
|
|
60
|
-
if (matchesRollupTimeDimension &&
|
|
61
|
-
!isGranularityCoarserOrEqual(queryGranularity, preAggregateDef.granularity)) {
|
|
62
|
-
return {
|
|
63
|
-
reason: PreAggregateMissReason.GRANULARITY_TOO_FINE,
|
|
64
|
-
fieldId: dimensionFieldId,
|
|
65
|
-
queryGranularity,
|
|
66
|
-
preAggregateGranularity: preAggregateDef.granularity,
|
|
67
|
-
preAggregateTimeDimension: preAggregateDef.timeDimension,
|
|
68
|
-
};
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
return null;
|
|
72
|
-
};
|
|
73
|
-
const getMissForDef = ({ metricQuery, explore, preAggregateDef, dimensionsByFieldId, metricsByFieldId, }) => {
|
|
74
|
-
const defMetrics = new Set(preAggregateDef.metrics);
|
|
75
|
-
for (const metricFieldId of metricQuery.metrics) {
|
|
76
|
-
const metric = metricsByFieldId[metricFieldId];
|
|
77
|
-
if (!metric) {
|
|
78
|
-
return {
|
|
79
|
-
reason: PreAggregateMissReason.METRIC_NOT_IN_PRE_AGGREGATE,
|
|
80
|
-
fieldId: metricFieldId,
|
|
81
|
-
};
|
|
82
|
-
}
|
|
83
|
-
const isMetricInDef = getMetricReferences({
|
|
84
|
-
metric,
|
|
85
|
-
baseTable: explore.baseTable,
|
|
86
|
-
}).some((reference) => defMetrics.has(reference));
|
|
87
|
-
if (!isMetricInDef) {
|
|
88
|
-
return {
|
|
89
|
-
reason: PreAggregateMissReason.METRIC_NOT_IN_PRE_AGGREGATE,
|
|
90
|
-
fieldId: metricFieldId,
|
|
91
|
-
};
|
|
92
|
-
}
|
|
93
|
-
if (metric.type === MetricType.NUMBER) {
|
|
94
|
-
return {
|
|
95
|
-
reason: PreAggregateMissReason.CUSTOM_SQL_METRIC,
|
|
96
|
-
fieldId: metricFieldId,
|
|
97
|
-
};
|
|
98
|
-
}
|
|
99
|
-
if (!isPreAggregateCompatible(metric.type)) {
|
|
100
|
-
return {
|
|
101
|
-
reason: PreAggregateMissReason.NON_ADDITIVE_METRIC,
|
|
102
|
-
fieldId: metricFieldId,
|
|
103
|
-
};
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
const defDimensions = new Set(preAggregateDef.dimensions);
|
|
107
|
-
if (preAggregateDef.timeDimension &&
|
|
108
|
-
preAggregateDef.granularity &&
|
|
109
|
-
!defDimensions.has(preAggregateDef.timeDimension)) {
|
|
110
|
-
defDimensions.add(preAggregateDef.timeDimension);
|
|
111
|
-
}
|
|
112
|
-
const missingQueryDimensionFieldId = metricQuery.dimensions.find((dimensionFieldId) => !dimensionFieldIdMatchesDef(dimensionFieldId, explore, defDimensions, dimensionsByFieldId));
|
|
113
|
-
if (missingQueryDimensionFieldId) {
|
|
114
|
-
return {
|
|
115
|
-
reason: PreAggregateMissReason.DIMENSION_NOT_IN_PRE_AGGREGATE,
|
|
116
|
-
fieldId: missingQueryDimensionFieldId,
|
|
117
|
-
};
|
|
118
|
-
}
|
|
119
|
-
const filterDimensionFieldIds = extractDimensionFilterFieldIds(metricQuery);
|
|
120
|
-
const missingFilterDimensionFieldId = filterDimensionFieldIds.find((dimensionFieldId) => !dimensionFieldIdMatchesDef(dimensionFieldId, explore, defDimensions, dimensionsByFieldId));
|
|
121
|
-
if (missingFilterDimensionFieldId) {
|
|
122
|
-
return {
|
|
123
|
-
reason: PreAggregateMissReason.FILTER_DIMENSION_NOT_IN_PRE_AGGREGATE,
|
|
124
|
-
fieldId: missingFilterDimensionFieldId,
|
|
125
|
-
};
|
|
126
|
-
}
|
|
127
|
-
const granularityMiss = getGranularityMissForDef(metricQuery, explore, preAggregateDef, dimensionsByFieldId);
|
|
128
|
-
if (granularityMiss) {
|
|
129
|
-
return granularityMiss;
|
|
130
|
-
}
|
|
131
|
-
return null;
|
|
132
|
-
};
|
|
133
|
-
export const findMatch = (metricQuery, explore) => {
|
|
134
|
-
if (!explore.preAggregates || explore.preAggregates.length === 0) {
|
|
135
|
-
return {
|
|
136
|
-
hit: false,
|
|
137
|
-
preAggregateName: null,
|
|
138
|
-
miss: {
|
|
139
|
-
reason: PreAggregateMissReason.NO_PRE_AGGREGATES_DEFINED,
|
|
140
|
-
},
|
|
141
|
-
};
|
|
142
|
-
}
|
|
143
|
-
if ((metricQuery.customDimensions || []).length > 0) {
|
|
144
|
-
return {
|
|
145
|
-
hit: false,
|
|
146
|
-
preAggregateName: null,
|
|
147
|
-
miss: {
|
|
148
|
-
reason: PreAggregateMissReason.CUSTOM_DIMENSION_PRESENT,
|
|
149
|
-
},
|
|
150
|
-
};
|
|
151
|
-
}
|
|
152
|
-
if ((metricQuery.tableCalculations || []).length > 0) {
|
|
153
|
-
return {
|
|
154
|
-
hit: false,
|
|
155
|
-
preAggregateName: null,
|
|
156
|
-
miss: {
|
|
157
|
-
reason: PreAggregateMissReason.TABLE_CALCULATION_PRESENT,
|
|
158
|
-
},
|
|
159
|
-
};
|
|
160
|
-
}
|
|
161
|
-
if ((metricQuery.additionalMetrics || []).length > 0) {
|
|
162
|
-
return {
|
|
163
|
-
hit: false,
|
|
164
|
-
preAggregateName: null,
|
|
165
|
-
miss: {
|
|
166
|
-
reason: PreAggregateMissReason.CUSTOM_METRIC_PRESENT,
|
|
167
|
-
},
|
|
168
|
-
};
|
|
169
|
-
}
|
|
170
|
-
const dimensionsByFieldId = getDimensionsByFieldId(explore);
|
|
171
|
-
const metricsByFieldId = getMetricsMapFromTables(explore.tables);
|
|
172
|
-
const matchedDefs = [];
|
|
173
|
-
let firstMiss = null;
|
|
174
|
-
explore.preAggregates.forEach((preAggregateDef) => {
|
|
175
|
-
const miss = getMissForDef({
|
|
176
|
-
metricQuery,
|
|
177
|
-
explore,
|
|
178
|
-
preAggregateDef,
|
|
179
|
-
dimensionsByFieldId,
|
|
180
|
-
metricsByFieldId,
|
|
181
|
-
});
|
|
182
|
-
if (!miss) {
|
|
183
|
-
matchedDefs.push(preAggregateDef);
|
|
184
|
-
return;
|
|
185
|
-
}
|
|
186
|
-
if (!firstMiss) {
|
|
187
|
-
firstMiss = miss;
|
|
188
|
-
}
|
|
189
|
-
});
|
|
190
|
-
if (matchedDefs.length === 0) {
|
|
191
|
-
return {
|
|
192
|
-
hit: false,
|
|
193
|
-
preAggregateName: null,
|
|
194
|
-
miss: firstMiss ?? {
|
|
195
|
-
reason: PreAggregateMissReason.DIMENSION_NOT_IN_PRE_AGGREGATE,
|
|
196
|
-
fieldId: metricQuery.dimensions[0] ??
|
|
197
|
-
metricQuery.metrics[0] ??
|
|
198
|
-
'unknown',
|
|
199
|
-
},
|
|
200
|
-
};
|
|
201
|
-
}
|
|
202
|
-
// TODO: Prefer using materialized row count once available.
|
|
203
|
-
const smallestMatchingDef = matchedDefs.reduce((best, current) => {
|
|
204
|
-
if (current.dimensions.length !== best.dimensions.length) {
|
|
205
|
-
return current.dimensions.length < best.dimensions.length
|
|
206
|
-
? current
|
|
207
|
-
: best;
|
|
208
|
-
}
|
|
209
|
-
return current.metrics.length < best.metrics.length ? current : best;
|
|
210
|
-
});
|
|
211
|
-
return {
|
|
212
|
-
hit: true,
|
|
213
|
-
preAggregateName: smallestMatchingDef.name,
|
|
214
|
-
miss: null,
|
|
215
|
-
};
|
|
216
|
-
};
|
|
217
|
-
//# sourceMappingURL=matcher.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"matcher.js","sourceRoot":"","sources":["../../../src/preAggregates/matcher.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"matcher.test.d.ts","sourceRoot":"","sources":["../../../src/preAggregates/matcher.test.ts"],"names":[],"mappings":""}
|