| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- define([
- 'lodash'
- ],
- 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;
- console.log('Build Query: target = ', target);
- if (!target.measurement) {
- throw "Metric measurement is missing";
- }
- var query = 'SELECT ';
- var measurement = target.measurement;
- var aggregationFunc = target.function || 'mean';
- if(!measurement.match('^/.*/') && !measurement.match(/^merge\(.*\)/)) {
- measurement = '"' + measurement+ '"';
- }
- query += aggregationFunc + '(value)';
- query += ' FROM ' + measurement + ' WHERE $timeFilter';
- query += _.map(target.tags, function(value, key) {
- return ' AND ' + key + '=' + "'" + value + "'";
- }).join('');
- query += ' GROUP BY time($interval)';
- if (target.fill) {
- query += ' fill(' + target.fill + ')';
- }
- query += " ORDER BY asc";
- target.query = query;
- return query;
- };
- p._modifyRawQuery = function () {
- var query = this.target.query.replace(";", "");
- return query;
- };
- return InfluxQueryBuilder;
- });
|