Influxdb: Handle legacy Influxdb influxql annotations with target in migration (#63225)

* handle legacy influxdb annotations with target in migration

* add types

* don't check tags that are empty strings and give annotation a type
This commit is contained in:
Brendan O'Handley
2023-04-28 08:39:11 -04:00
committed by GitHub
parent 50fb1497e5
commit 7a3f7e26ce
3 changed files with 36 additions and 3 deletions

View File

@@ -1,3 +1,5 @@
import { InfluxQuery, InfluxQueryTag } from './types';
type LegacyAnnotation = {
query?: string;
queryType?: string;
@@ -7,11 +9,19 @@ type LegacyAnnotation = {
timeEndColumn?: string;
titleColumn?: string;
name?: string;
target?: {
limit?: string | number | undefined;
matchAny?: boolean;
tags?: InfluxQueryTag[];
type?: string;
};
};
// this becomes the target in the migrated annotations
const migrateLegacyAnnotation = (json: LegacyAnnotation) => {
return {
// eslint-ignore-next-line
const target: InfluxQuery = {
refId: '',
query: json.query ?? '',
queryType: 'tags',
fromAnnotations: true,
@@ -21,11 +31,31 @@ const migrateLegacyAnnotation = (json: LegacyAnnotation) => {
titleColumn: json.titleColumn ?? '',
name: json.name ?? '',
};
// handle json target fields
if (json.target && json.target.limit) {
target.limit = json.target.limit;
}
if (json.target && json.target.matchAny) {
target.matchAny = json.target.matchAny;
}
if (json.target && json.target.tags) {
target.tags = json.target.tags;
}
if (json.target && json.target.type) {
target.type = json.target.type;
}
return target;
};
// eslint-ignore-next-line
export const prepareAnnotation = (json: any) => {
json.target = json.target ?? migrateLegacyAnnotation(json);
// make sure that any additional target fields are migrated
json.target = json.target && !json.target?.query ? migrateLegacyAnnotation(json) : json.target;
return json;
};

View File

@@ -171,7 +171,7 @@ export default class ResponseParser {
function colContainsTag(colText: string, tagsColumn: string): boolean {
const tags = (tagsColumn || '').replace(' ', '').split(',');
for (const tag of tags) {
if (colText.includes(tag)) {
if (tag !== '' && colText.includes(tag)) {
return true;
}
}

View File

@@ -71,6 +71,9 @@ export interface InfluxQuery extends DataQuery {
timeEndColumn?: string;
titleColumn?: string;
name?: string;
matchAny?: boolean;
type?: string;
textEditor?: boolean;
adhocFilters?: AdHocVariableFilter[];
}