queryBuilder.js 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. define([
  2. 'lodash'
  3. ],
  4. function (_) {
  5. 'use strict';
  6. function InfluxQueryBuilder(target) {
  7. this.target = target;
  8. }
  9. var p = InfluxQueryBuilder.prototype;
  10. p.build = function() {
  11. return this.target.rawQuery ? this._modifyRawQuery() : this._buildQuery();
  12. };
  13. p.showTagsQuery = function() {
  14. var query = 'SHOW TAG KEYS';
  15. if (this.target.measurement) {
  16. query += ' FROM "' + this.target.measurement + '"';
  17. }
  18. return query;
  19. };
  20. p._buildQuery = function() {
  21. var target = this.target;
  22. console.log('Build Query: target = ', target);
  23. if (!target.measurement) {
  24. throw "Metric measurement is missing";
  25. }
  26. var query = 'SELECT ';
  27. var measurement = target.measurement;
  28. var aggregationFunc = target.function || 'mean';
  29. if (!measurement.match('^/.*/') && !measurement.match(/^merge\(.*\)/)) {
  30. measurement = '"' + measurement+ '"';
  31. }
  32. query += aggregationFunc + '(value)';
  33. query += ' FROM ' + measurement + ' WHERE ';
  34. var conditions = _.map(target.tags, function(tag) {
  35. return tag.key + '=' + "'" + tag.value + "' ";
  36. });
  37. conditions.push('$timeFilter');
  38. query += conditions.join('AND ');
  39. query += ' GROUP BY time($interval)';
  40. if (target.groupByTags && target.groupByTags.length > 0) {
  41. query += ', ' + target.groupByTags.join();
  42. }
  43. if (target.fill) {
  44. query += ' fill(' + target.fill + ')';
  45. }
  46. query += " ORDER BY asc";
  47. target.query = query;
  48. return query;
  49. };
  50. p._modifyRawQuery = function () {
  51. var query = this.target.query.replace(";", "");
  52. return query;
  53. };
  54. return InfluxQueryBuilder;
  55. });