mirror of
https://github.com/grafana/grafana.git
synced 2025-09-19 20:33:05 +08:00
83 lines
2.1 KiB
TypeScript
83 lines
2.1 KiB
TypeScript
import { Observable, of } from 'rxjs';
|
|
import { catchError, map, share } from 'rxjs/operators';
|
|
|
|
import {
|
|
dataFrameFromJSON,
|
|
DataFrameJSON,
|
|
getDefaultTimeRange,
|
|
LoadingState,
|
|
PanelData,
|
|
withLoadingIndicator,
|
|
} from '@grafana/data';
|
|
import { getBackendSrv, toDataQueryError } from '@grafana/runtime';
|
|
|
|
import {
|
|
isCloudPreviewRequest,
|
|
isGrafanaPreviewRequest,
|
|
PreviewRuleRequest,
|
|
PreviewRuleResponse,
|
|
} from '../types/preview';
|
|
import { RuleFormType } from '../types/rule-form';
|
|
import { GRAFANA_RULES_SOURCE_NAME } from '../utils/datasource';
|
|
|
|
export function previewAlertRule(request: PreviewRuleRequest): Observable<PreviewRuleResponse> {
|
|
if (isCloudPreviewRequest(request)) {
|
|
return fetchAlertRulePreview(request, request.dataSourceUid, RuleFormType.cloudAlerting);
|
|
}
|
|
|
|
if (isGrafanaPreviewRequest(request)) {
|
|
return fetchAlertRulePreview(request, GRAFANA_RULES_SOURCE_NAME, RuleFormType.grafana);
|
|
}
|
|
|
|
throw new Error('unsupported preview rule request');
|
|
}
|
|
|
|
type AlertRulePreviewResponse = {
|
|
instances: DataFrameJSON[];
|
|
};
|
|
|
|
function fetchAlertRulePreview(
|
|
request: PreviewRuleRequest,
|
|
dataSourceUid: string,
|
|
ruleType: RuleFormType
|
|
): Observable<PreviewRuleResponse> {
|
|
return withLoadingIndicator({
|
|
whileLoading: createResponse(ruleType),
|
|
source: getBackendSrv()
|
|
.fetch<AlertRulePreviewResponse>({
|
|
method: 'POST',
|
|
url: `/api/v1/rule/test/${dataSourceUid}`,
|
|
data: request,
|
|
})
|
|
.pipe(
|
|
map(({ data }) => {
|
|
return createResponse(ruleType, {
|
|
state: LoadingState.Done,
|
|
series: data.instances.map(dataFrameFromJSON),
|
|
});
|
|
}),
|
|
catchError((error: Error) => {
|
|
return of(
|
|
createResponse(ruleType, {
|
|
state: LoadingState.Error,
|
|
error: toDataQueryError(error),
|
|
})
|
|
);
|
|
}),
|
|
share()
|
|
),
|
|
});
|
|
}
|
|
|
|
function createResponse(ruleType: RuleFormType, data: Partial<PanelData> = {}): PreviewRuleResponse {
|
|
return {
|
|
ruleType,
|
|
data: {
|
|
state: LoadingState.Loading,
|
|
series: [],
|
|
timeRange: getDefaultTimeRange(),
|
|
...data,
|
|
},
|
|
};
|
|
}
|