mirror of
https://github.com/grafana/grafana.git
synced 2025-02-11 16:15:42 -06:00
68 lines
1.5 KiB
JavaScript
68 lines
1.5 KiB
JavaScript
define([
|
|
],
|
|
function () {
|
|
'use strict';
|
|
|
|
function InfluxQueryBuilder(target) {
|
|
this.target = target;
|
|
}
|
|
|
|
var p = InfluxQueryBuilder.prototype;
|
|
|
|
p.build = function() {
|
|
return this.target.rawQuery ? this._modifyRawQuery() : this._buildQuery();
|
|
};
|
|
|
|
p._buildQuery = function() {
|
|
var target = this.target;
|
|
var query = 'select ';
|
|
var seriesName = target.series;
|
|
|
|
if(!seriesName.match('^/.*/') && !seriesName.match(/^merge\(.*\)/)) {
|
|
seriesName = '"' + seriesName+ '"';
|
|
}
|
|
|
|
if (target.groupby_field) {
|
|
query += target.groupby_field + ', ';
|
|
}
|
|
|
|
query += target.function + '(' + target.column + ')';
|
|
query += ' from ' + seriesName + ' where $timeFilter';
|
|
|
|
if (target.condition) {
|
|
query += ' and ' + target.condition;
|
|
}
|
|
|
|
query += ' group by time($interval)';
|
|
|
|
if (target.groupby_field) {
|
|
query += ', ' + target.groupby_field;
|
|
this.groupByField = target.groupby_field;
|
|
}
|
|
|
|
if (target.fill) {
|
|
query += ' fill(' + target.fill + ')';
|
|
}
|
|
|
|
query += " order asc";
|
|
target.query = query;
|
|
|
|
return query;
|
|
};
|
|
|
|
p._modifyRawQuery = function () {
|
|
var query = this.target.query.replace(";", "");
|
|
|
|
var queryElements = query.split(" ");
|
|
var lowerCaseQueryElements = query.toLowerCase().split(" ");
|
|
|
|
if (lowerCaseQueryElements[1].indexOf(',') !== -1) {
|
|
this.groupByField = lowerCaseQueryElements[1].replace(',', '');
|
|
}
|
|
|
|
return queryElements.join(" ");
|
|
};
|
|
|
|
return InfluxQueryBuilder;
|
|
});
|