mirror of
https://github.com/grafana/grafana.git
synced 2025-02-14 17:43:35 -06:00
* fix sql annotation parsing for empty responses * fix backend when no data returned * add back frontend changes Co-authored-by: Ying WANG <ying.wang@grafana.com>
79 lines
2.7 KiB
TypeScript
79 lines
2.7 KiB
TypeScript
import { AnnotationEvent, DataFrame, MetricFindValue } from '@grafana/data';
|
|
import { BackendDataSourceResponse, FetchResponse, toDataQueryResponse } from '@grafana/runtime';
|
|
|
|
export default class ResponseParser {
|
|
transformMetricFindResponse(raw: FetchResponse<BackendDataSourceResponse>): MetricFindValue[] {
|
|
const frames = toDataQueryResponse(raw).data as DataFrame[];
|
|
|
|
if (!frames || !frames.length) {
|
|
return [];
|
|
}
|
|
|
|
const frame = frames[0];
|
|
|
|
const values: MetricFindValue[] = [];
|
|
const textField = frame.fields.find((f) => f.name === '__text');
|
|
const valueField = frame.fields.find((f) => f.name === '__value');
|
|
|
|
if (textField && valueField) {
|
|
for (let i = 0; i < textField.values.length; i++) {
|
|
values.push({ text: '' + textField.values.get(i), value: '' + valueField.values.get(i) });
|
|
}
|
|
} else {
|
|
values.push(
|
|
...frame.fields
|
|
.flatMap((f) => f.values.toArray())
|
|
.map((v) => ({
|
|
text: v,
|
|
}))
|
|
);
|
|
}
|
|
|
|
return Array.from(new Set(values.map((v) => v.text))).map((text) => ({
|
|
text,
|
|
value: values.find((v) => v.text === text)?.value,
|
|
}));
|
|
}
|
|
|
|
async transformAnnotationResponse(options: any, data: BackendDataSourceResponse): Promise<AnnotationEvent[]> {
|
|
const frames = toDataQueryResponse({ data: data }).data as DataFrame[];
|
|
if (!frames || !frames.length) {
|
|
return [];
|
|
}
|
|
const frame = frames[0];
|
|
const timeField = frame.fields.find((f) => f.name === 'time' || f.name === 'time_sec');
|
|
|
|
if (!timeField) {
|
|
throw new Error('Missing mandatory time column (with time column alias) in annotation query');
|
|
}
|
|
|
|
if (frame.fields.find((f) => f.name === 'title')) {
|
|
throw new Error('The title column for annotations is deprecated, now only a column named text is returned');
|
|
}
|
|
|
|
const timeEndField = frame.fields.find((f) => f.name === 'timeend');
|
|
const textField = frame.fields.find((f) => f.name === 'text');
|
|
const tagsField = frame.fields.find((f) => f.name === 'tags');
|
|
|
|
const list: AnnotationEvent[] = [];
|
|
for (let i = 0; i < frame.length; i++) {
|
|
const timeEnd = timeEndField && timeEndField.values.get(i) ? Math.floor(timeEndField.values.get(i)) : undefined;
|
|
list.push({
|
|
annotation: options.annotation,
|
|
time: Math.floor(timeField.values.get(i)),
|
|
timeEnd,
|
|
text: textField && textField.values.get(i) ? textField.values.get(i) : '',
|
|
tags:
|
|
tagsField && tagsField.values.get(i)
|
|
? tagsField.values
|
|
.get(i)
|
|
.trim()
|
|
.split(/\s*,\s*/)
|
|
: [],
|
|
});
|
|
}
|
|
|
|
return list;
|
|
}
|
|
}
|