mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
feat(elasticsearch): work on supporting filters aggregate, #2785
This commit is contained in:
@@ -35,6 +35,20 @@ function (angular, _, queryDef) {
|
||||
$scope.agg.settings = {};
|
||||
$scope.showOptions = false;
|
||||
|
||||
switch($scope.agg.type) {
|
||||
case 'date_histogram':
|
||||
case 'terms': {
|
||||
delete $scope.agg.query;
|
||||
$scope.agg.type = 'select field';
|
||||
break;
|
||||
}
|
||||
case 'filters': {
|
||||
delete $scope.agg.field;
|
||||
$scope.agg.query = '*';
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
$scope.validateModel();
|
||||
$scope.onChange();
|
||||
};
|
||||
@@ -65,6 +79,9 @@ function (angular, _, queryDef) {
|
||||
|
||||
break;
|
||||
}
|
||||
case 'filters': {
|
||||
break;
|
||||
}
|
||||
case 'date_histogram': {
|
||||
settings.interval = settings.interval || 'auto';
|
||||
$scope.agg.field = $scope.target.timeField;
|
||||
|
||||
@@ -10,23 +10,8 @@ function (_, queryDef) {
|
||||
this.response = response;
|
||||
}
|
||||
|
||||
// This is quite complex
|
||||
// neeed to recurise down the nested buckets to build series
|
||||
ElasticResponse.prototype.processBuckets = function(aggs, target, seriesList, level, props) {
|
||||
var value, metric, i, y, bucket, aggDef, esAgg, newSeries;
|
||||
|
||||
aggDef = target.bucketAggs[level];
|
||||
esAgg = aggs[aggDef.id];
|
||||
|
||||
if (level < target.bucketAggs.length - 1) {
|
||||
for (i = 0; i < esAgg.buckets.length; i++) {
|
||||
bucket = esAgg.buckets[i];
|
||||
props = _.clone(props);
|
||||
props[aggDef.field] = bucket.key;
|
||||
this.processBuckets(bucket, target, seriesList, level+1, props);
|
||||
}
|
||||
return;
|
||||
}
|
||||
ElasticResponse.prototype.processMetrics = function(esAgg, target, seriesList, props) {
|
||||
var metric, y, i, newSeries, bucket, value;
|
||||
|
||||
for (y = 0; y < target.metrics.length; y++) {
|
||||
metric = target.metrics[y];
|
||||
@@ -101,6 +86,35 @@ function (_, queryDef) {
|
||||
}
|
||||
};
|
||||
|
||||
// This is quite complex
|
||||
// neeed to recurise down the nested buckets to build series
|
||||
ElasticResponse.prototype.processBuckets = function(aggs, target, seriesList, props) {
|
||||
var bucket, aggDef, esAgg, aggId;
|
||||
|
||||
for (aggId in aggs) {
|
||||
aggDef = _.findWhere(target.bucketAggs, {id: aggId});
|
||||
esAgg = aggs[aggId];
|
||||
if (!aggDef) {
|
||||
continue;
|
||||
}
|
||||
|
||||
if (aggDef.type === 'date_histogram') {
|
||||
this.processMetrics(esAgg, target, seriesList, props);
|
||||
} else {
|
||||
for (var nameIndex in esAgg.buckets) {
|
||||
bucket = esAgg.buckets[nameIndex];
|
||||
props = _.clone(props);
|
||||
if (bucket.key) {
|
||||
props[aggDef.field] = bucket.key;
|
||||
} else {
|
||||
props["filter"] = nameIndex;
|
||||
}
|
||||
this.processBuckets(bucket, target, seriesList, props);
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
ElasticResponse.prototype._getMetricName = function(metric) {
|
||||
var metricDef = _.findWhere(queryDef.metricAggTypes, {value: metric});
|
||||
if (!metricDef) {
|
||||
@@ -172,7 +186,7 @@ function (_, queryDef) {
|
||||
var target = this.targets[i];
|
||||
var tmpSeriesList = [];
|
||||
|
||||
this.processBuckets(aggregations, target, tmpSeriesList, 0, {});
|
||||
this.processBuckets(aggregations, target, tmpSeriesList, {});
|
||||
this.nameSeries(tmpSeriesList, target);
|
||||
|
||||
for (var y = 0; y < tmpSeriesList.length; y++) {
|
||||
|
||||
@@ -7,9 +7,12 @@
|
||||
<li>
|
||||
<metric-segment-model property="agg.type" options="bucketAggTypes" on-change="onTypeChanged()" custom="false" css-class="tight-form-item-large"></metric-segment-model>
|
||||
</li>
|
||||
<li>
|
||||
<li ng-if="agg.type !== 'filters'">
|
||||
<metric-segment-model property="agg.field" get-options="getFields()" on-change="onChange()" css-class="tight-form-item-xxlarge"></metric-segment>
|
||||
</li>
|
||||
<li ng-if="agg.type === 'filters'">
|
||||
<input type="text" class="tight-form-input tight-form-item-xxlarge" ng-model="agg.query" spellcheck='false' placeholder="Lucence query" ng-blur="onChange()">
|
||||
</li>
|
||||
<li class="tight-form-item last" ng-if="settingsLinkText">
|
||||
<a ng-click="toggleOptions()">{{settingsLinkText}}</a>
|
||||
</li>
|
||||
|
||||
@@ -54,12 +54,34 @@ function (angular) {
|
||||
}
|
||||
};
|
||||
|
||||
ElasticQueryBuilder.prototype.getFiltersAgg = function(target) {
|
||||
var filterObj = {};
|
||||
|
||||
for (var i = 0; i < target.bucketAggs.length; i++) {
|
||||
var aggDef = target.bucketAggs[i];
|
||||
if (aggDef.type !== 'filters') {
|
||||
continue;
|
||||
}
|
||||
|
||||
filterObj[aggDef.query] = {
|
||||
query: {
|
||||
query_string: {
|
||||
query: aggDef.query,
|
||||
analyze_wildcard: true
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
return filterObj;
|
||||
};
|
||||
|
||||
ElasticQueryBuilder.prototype.build = function(target) {
|
||||
if (target.rawQuery) {
|
||||
return angular.fromJson(target.rawQuery);
|
||||
}
|
||||
|
||||
var i, nestedAggs, metric;
|
||||
var i, nestedAggs, metric, filtersHandled;
|
||||
var query = {
|
||||
"size": 0,
|
||||
"query": {
|
||||
@@ -95,6 +117,15 @@ function (angular) {
|
||||
};
|
||||
break;
|
||||
}
|
||||
case 'filters': {
|
||||
// skip filters if we already processed them
|
||||
if (filtersHandled) {
|
||||
continue;
|
||||
}
|
||||
esAgg["filters"] = {filters: this.getFiltersAgg(target)};
|
||||
filtersHandled = true;
|
||||
break;
|
||||
}
|
||||
case 'terms': {
|
||||
this.buildTermsAgg(aggDef, esAgg, target);
|
||||
break;
|
||||
|
||||
@@ -18,6 +18,7 @@ function (_) {
|
||||
|
||||
bucketAggTypes: [
|
||||
{text: "Terms", value: 'terms' },
|
||||
{text: "Filters", value: 'filters' },
|
||||
{text: "Date Histogram", value: 'date_histogram' },
|
||||
],
|
||||
|
||||
|
||||
Reference in New Issue
Block a user