2017-12-21 08:39:31 +01:00
|
|
|
import angular from 'angular';
|
|
|
|
|
import _ from 'lodash';
|
|
|
|
|
import { QueryCtrl } from 'app/plugins/sdk';
|
|
|
|
|
import { PromCompleter } from './completer';
|
|
|
|
|
import './mode-prometheus';
|
|
|
|
|
import './snippets/prometheus';
|
2019-06-18 11:01:12 +02:00
|
|
|
import { TemplateSrv } from 'app/features/templating/template_srv';
|
2016-02-01 23:24:08 +01:00
|
|
|
|
2016-02-02 12:52:43 +01:00
|
|
|
class PrometheusQueryCtrl extends QueryCtrl {
|
2017-12-21 08:39:31 +01:00
|
|
|
static templateUrl = 'partials/query.editor.html';
|
2016-02-05 10:37:14 +01:00
|
|
|
|
2016-02-02 09:12:58 +01:00
|
|
|
metric: any;
|
|
|
|
|
resolutions: any;
|
2017-04-25 12:57:23 +02:00
|
|
|
formats: any;
|
2017-09-07 18:34:46 +09:00
|
|
|
instant: any;
|
2016-02-02 09:12:58 +01:00
|
|
|
oldTarget: any;
|
2016-02-02 10:19:15 +01:00
|
|
|
suggestMetrics: any;
|
2017-08-09 10:58:00 +03:00
|
|
|
getMetricsAutocomplete: any;
|
2016-02-02 10:19:15 +01:00
|
|
|
linkToPrometheus: any;
|
2016-02-01 23:24:08 +01:00
|
|
|
|
2016-02-02 12:52:43 +01:00
|
|
|
/** @ngInject */
|
2019-06-18 11:01:12 +02:00
|
|
|
constructor($scope: any, $injector: angular.auto.IInjectorService, private templateSrv: TemplateSrv) {
|
2016-02-02 09:12:58 +01:00
|
|
|
super($scope, $injector);
|
2016-02-01 23:24:08 +01:00
|
|
|
|
2018-08-29 14:27:29 +02:00
|
|
|
const target = this.target;
|
2017-12-21 08:39:31 +01:00
|
|
|
target.expr = target.expr || '';
|
2017-12-15 14:21:29 +01:00
|
|
|
target.intervalFactor = target.intervalFactor || 1;
|
2017-04-25 12:57:23 +02:00
|
|
|
target.format = target.format || this.getDefaultFormat();
|
2016-02-01 23:24:08 +01:00
|
|
|
|
2017-12-21 08:39:31 +01:00
|
|
|
this.metric = '';
|
2018-09-04 14:27:03 +02:00
|
|
|
this.resolutions = _.map([1, 2, 3, 4, 5, 10], f => {
|
2017-12-21 08:39:31 +01:00
|
|
|
return { factor: f, label: '1/' + f };
|
2016-02-01 23:24:08 +01:00
|
|
|
});
|
|
|
|
|
|
2018-02-21 15:26:45 +03:00
|
|
|
this.formats = [
|
|
|
|
|
{ text: 'Time series', value: 'time_series' },
|
|
|
|
|
{ text: 'Table', value: 'table' },
|
|
|
|
|
{ text: 'Heatmap', value: 'heatmap' },
|
|
|
|
|
];
|
2016-02-01 23:24:08 +01:00
|
|
|
|
2017-09-07 18:34:46 +09:00
|
|
|
this.instant = false;
|
|
|
|
|
|
2017-08-09 11:43:02 +02:00
|
|
|
this.updateLink();
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-18 11:01:12 +02:00
|
|
|
getCompleter(query: string) {
|
2018-03-16 02:17:51 +09:00
|
|
|
return new PromCompleter(this.datasource, this.templateSrv);
|
2016-02-02 09:12:58 +01:00
|
|
|
}
|
2016-02-01 23:24:08 +01:00
|
|
|
|
2017-04-25 12:57:23 +02:00
|
|
|
getDefaultFormat() {
|
2017-12-21 08:39:31 +01:00
|
|
|
if (this.panelCtrl.panel.type === 'table') {
|
|
|
|
|
return 'table';
|
2018-02-21 15:26:45 +03:00
|
|
|
} else if (this.panelCtrl.panel.type === 'heatmap') {
|
|
|
|
|
return 'heatmap';
|
2017-04-25 12:57:23 +02:00
|
|
|
}
|
2018-02-21 15:26:45 +03:00
|
|
|
|
2017-12-21 08:39:31 +01:00
|
|
|
return 'time_series';
|
2017-04-25 12:57:23 +02:00
|
|
|
}
|
|
|
|
|
|
2016-02-02 09:12:58 +01:00
|
|
|
refreshMetricData() {
|
|
|
|
|
if (!_.isEqual(this.oldTarget, this.target)) {
|
|
|
|
|
this.oldTarget = angular.copy(this.target);
|
|
|
|
|
this.panelCtrl.refresh();
|
2016-02-02 10:19:15 +01:00
|
|
|
this.updateLink();
|
2016-02-01 23:24:08 +01:00
|
|
|
}
|
2016-02-02 09:12:58 +01:00
|
|
|
}
|
2016-02-01 23:24:08 +01:00
|
|
|
|
2016-02-02 10:19:15 +01:00
|
|
|
updateLink() {
|
2018-08-29 14:27:29 +02:00
|
|
|
const range = this.panelCtrl.range;
|
2016-05-20 09:03:52 +02:00
|
|
|
if (!range) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2018-08-29 14:27:29 +02:00
|
|
|
const rangeDiff = Math.ceil((range.to.valueOf() - range.from.valueOf()) / 1000);
|
|
|
|
|
const endTime = range.to.utc().format('YYYY-MM-DD HH:mm');
|
|
|
|
|
const expr = {
|
2017-12-21 08:39:31 +01:00
|
|
|
'g0.expr': this.templateSrv.replace(
|
2017-12-19 16:06:54 +01:00
|
|
|
this.target.expr,
|
|
|
|
|
this.panelCtrl.panel.scopedVars,
|
|
|
|
|
this.datasource.interpolateQueryExpr
|
|
|
|
|
),
|
2017-12-21 08:39:31 +01:00
|
|
|
'g0.range_input': rangeDiff + 's',
|
|
|
|
|
'g0.end_input': endTime,
|
|
|
|
|
'g0.step_input': this.target.step,
|
|
|
|
|
'g0.stacked': this.panelCtrl.panel.stack ? 1 : 0,
|
|
|
|
|
'g0.tab': 0,
|
2016-02-01 23:24:08 +01:00
|
|
|
};
|
2018-08-29 14:27:29 +02:00
|
|
|
const args = _.map(expr, (v, k) => {
|
2017-12-21 08:39:31 +01:00
|
|
|
return k + '=' + encodeURIComponent(v);
|
|
|
|
|
}).join('&');
|
|
|
|
|
this.linkToPrometheus = this.datasource.directUrl + '/graph?' + args;
|
2016-02-02 10:19:15 +01:00
|
|
|
}
|
2016-02-01 23:24:08 +01:00
|
|
|
}
|
|
|
|
|
|
2017-12-19 16:06:54 +01:00
|
|
|
export { PrometheusQueryCtrl };
|