| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169 |
- define([
- 'lodash'
- ],
- function (_) {
- 'use strict';
- function InfluxQueryBuilder(target) {
- this.target = target;
- if (target.groupByTags) {
- target.groupBy = [{type: 'time', interval: 'auto'}];
- for (var i in target.groupByTags) {
- target.groupBy.push({type: 'tag', key: target.groupByTags[i]});
- }
- delete target.groupByTags;
- }
- }
- function renderTagCondition (tag, index) {
- var str = "";
- var operator = tag.operator;
- var value = tag.value;
- if (index > 0) {
- str = (tag.condition || 'AND') + ' ';
- }
- if (!operator) {
- if (/^\/.*\/$/.test(tag.value)) {
- operator = '=~';
- } else {
- operator = '=';
- }
- }
- // quote value unless regex
- if (operator !== '=~' && operator !== '!~') {
- value = "'" + value + "'";
- }
- return str + '"' + tag.key + '" ' + operator + ' ' + value;
- }
- var p = InfluxQueryBuilder.prototype;
- p.build = function() {
- return this.target.rawQuery ? this._modifyRawQuery() : this._buildQuery();
- };
- p.buildExploreQuery = function(type, withKey) {
- var query;
- var measurement;
- if (type === 'TAG_KEYS') {
- query = 'SHOW TAG KEYS';
- measurement = this.target.measurement;
- } else if (type === 'TAG_VALUES') {
- query = 'SHOW TAG VALUES';
- measurement = this.target.measurement;
- } else if (type === 'MEASUREMENTS') {
- query = 'SHOW MEASUREMENTS';
- } else if (type === 'FIELDS') {
- query = 'SHOW FIELD KEYS FROM "' + this.target.measurement + '"';
- return query;
- }
- if (measurement) {
- if (!measurement.match('^/.*/') && !measurement.match(/^merge\(.*\)/)) {
- measurement = '"' + measurement+ '"';
- }
- query += ' FROM ' + measurement;
- }
- if (withKey) {
- query += ' WITH KEY = "' + withKey + '"';
- }
- if (this.target.tags && this.target.tags.length > 0) {
- var whereConditions = _.reduce(this.target.tags, function(memo, tag) {
- // do not add a condition for the key we want to explore for
- if (tag.key === withKey) {
- return memo;
- }
- memo.push(renderTagCondition(tag, memo.length));
- return memo;
- }, []);
- if (whereConditions.length > 0) {
- query += ' WHERE ' + whereConditions.join(' ');
- }
- }
- return query;
- };
- p._getGroupByTimeInterval = function(interval) {
- if (interval === 'auto') {
- return '$interval';
- }
- return interval;
- };
- p._buildQuery = function() {
- var target = this.target;
- if (!target.measurement) {
- throw "Metric measurement is missing";
- }
- if (!target.fields) {
- target.fields = [{name: 'value', func: target.function || 'mean'}];
- }
- var query = 'SELECT ';
- var i;
- for (i = 0; i < target.fields.length; i++) {
- var field = target.fields[i];
- if (i > 0) {
- query += ', ';
- }
- query += field.func + '("' + field.name + '")';
- if (field.mathExpr) {
- query += field.mathExpr;
- }
- if (field.asExpr) {
- query += ' AS "' + field.asExpr + '"';
- } else {
- query += ' AS "' + field.name + '"';
- }
- }
- var measurement = target.measurement;
- if (!measurement.match('^/.*/') && !measurement.match(/^merge\(.*\)/)) {
- measurement = '"' + measurement+ '"';
- }
- query += ' FROM ' + measurement + ' WHERE ';
- var conditions = _.map(target.tags, function(tag, index) {
- return renderTagCondition(tag, index);
- });
- query += conditions.join(' ');
- query += (conditions.length > 0 ? ' AND ' : '') + '$timeFilter';
- query += ' GROUP BY';
- for (i = 0; i < target.groupBy.length; i++) {
- var group = target.groupBy[i];
- if (group.type === 'time') {
- query += ' time(' + this._getGroupByTimeInterval(group.interval) + ')';
- } else {
- query += ', "' + group.key + '"';
- }
- }
- if (target.fill) {
- query += ' fill(' + target.fill + ')';
- }
- target.query = query;
- return query;
- };
- p._modifyRawQuery = function () {
- var query = this.target.query.replace(";", "");
- return query;
- };
- return InfluxQueryBuilder;
- });
|