response_parser.ts 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. import _ from 'lodash';
  2. export default class ResponseParser {
  3. parse(query, results) {
  4. if (!results || results.results.length === 0) {
  5. return [];
  6. }
  7. var influxResults = results.results[0];
  8. if (!influxResults.series) {
  9. return [];
  10. }
  11. var res = {};
  12. _.each(influxResults.series, serie => {
  13. _.each(serie.values, value => {
  14. if (_.isArray(value)) {
  15. // In general, there are 2 possible shapes for the returned value.
  16. // The first one is a two-element array,
  17. // where the first element is somewhat a metadata value:
  18. // the tag name for SHOW TAG VALUES queries,
  19. // the time field for SELECT queries, etc.
  20. // The second shape is an one-element array,
  21. // that is containing an immediate value.
  22. // For example, SHOW FIELD KEYS queries return such shape.
  23. // Note, pre-0.11 versions return
  24. // the second shape for SHOW TAG VALUES queries
  25. // (while the newer versions—first).
  26. if (value[1] !== undefined) {
  27. addUnique(res, value[1]);
  28. } else {
  29. addUnique(res, value[0]);
  30. }
  31. } else {
  32. addUnique(res, value);
  33. }
  34. });
  35. });
  36. return _.map(res, value => {
  37. return { text: value };
  38. });
  39. }
  40. }
  41. function addUnique(arr, value) {
  42. arr[value] = value;
  43. }