新增黄金指标,性能任务管理,修正历史活动告警

This commit is contained in:
lai
2023-10-20 19:21:34 +08:00
parent b9d0bed03f
commit 9092d1d051
9 changed files with 725 additions and 590 deletions

View File

@@ -0,0 +1,69 @@
import { RESULT_CODE_SUCCESS } from '@/constants/result-constants';
import { request } from '@/plugins/http-fetch';
import { parseObjLineToHump } from '@/utils/parse-utils';
/**
* 查询日志列表
* @param query 查询参数
* @returns object
*/
export async function listgoldData(query: Record<string, any>) {
let totalSQL = 'select count(*) as total from gold_kpi where 1=1 ';
let rowsSQL = 'select * from gold_kpi where 1=1 ';
// 查询
let querySQL = '';
if (query.neType) {
querySQL += ` and ne_type like '%${query.neType}%' `;
}
if (query.beginTime) {
querySQL += ` and start_time >= '${query.beginTime}' `;
}
if (query.endTime) {
querySQL += ` and start_time <= '${query.endTime}' `;
}
// 排序
let sortSql = ' order by start_time ';
if (query.sortOrder === 'asc') {
sortSql += ' asc ';
} else {
sortSql += ' desc ';
}
// 分页
const pageNum = (query.pageNum - 1) * query.pageSize;
const limtSql = ` limit ${pageNum},${query.pageSize} `;
// 发起请求
const result = await request({
url: `/api/rest/databaseManagement/v1/select/omc_db/gold_kpi`,
method: 'get',
params: {
totalSQL: totalSQL + querySQL,
rowsSQL: rowsSQL + querySQL + sortSql + limtSql,
},
});
// 解析数据
if (result.code === RESULT_CODE_SUCCESS) {
const data: DataList = {
total: 0,
rows: [],
code: result.code,
msg: result.msg,
};
result.data.data.forEach((item: any) => {
const itemData = item['gold_kpi'];
if (Array.isArray(itemData)) {
if (itemData.length === 1 && itemData[0]['total'] >= 0) {
data.total = itemData[0]['total'];
} else {
data.rows = itemData.map(v => parseObjLineToHump(v));
}
}
});
return data;
}
return result;
}

View File

@@ -37,7 +37,7 @@ export async function listperfData(query: Record<string, any>) {
// 发起请求
const result = await request({
url: `/databaseManagement/v1/select/omc_db/measure_data`,
url: `/api/rest/databaseManagement/v1/select/omc_db/measure_data`,
method: 'get',
params: {
totalSQL: totalSQL + querySQL,

View File

@@ -1,6 +1,7 @@
import { RESULT_CODE_SUCCESS } from '@/constants/result-constants';
import { request } from '@/plugins/http-fetch';
import { parseObjLineToHump } from '@/utils/parse-utils';
import { parseDateToStr } from '@/utils/date-utils';
/**
* 查询任务列表
@@ -23,7 +24,7 @@ export async function listPerfTask(query: Record<string, any>) {
// 发起请求
const result = await request({
url: `/databaseManagement/v1/select/omc_db/measure_task`,
url: `/api/rest/databaseManagement/v1/select/omc_db/measure_task`,
method: 'get',
params: {
totalSQL: totalSQL + querySQL,
@@ -59,48 +60,99 @@ export async function listPerfTask(query: Record<string, any>) {
* @param id 网元ID
* @returns object
*/
export async function getTraceTask(id: string | number) {
export async function getPerfTask(id: string | number) {
// 发起请求
const result = await request({
url: `/databaseManagement/v1/select/omc_db/trace_task`,
url: `/api/rest/databaseManagement/v1/select/omc_db/measure_task`,
method: 'get',
params: {
SQL: `select * from trace_task where id = ${id}`,
SQL: `select * from measure_task where id = ${id}`,
},
});
// 解析数据
if (result.code === RESULT_CODE_SUCCESS && Array.isArray(result.data.data)) {
let data = result.data.data[0];
return Object.assign(result, {
data: parseObjLineToHump(data['trace_task'][0]),
data: parseObjLineToHump(data['measure_task'][0]),
});
}
return result;
}
/**
* 新增任务
* 新增性能测量任务
* @param data 网元对象
* @returns object
*/
export function addTraceTask(data: Record<string, any>) {
export function addPerfTask(data: Record<string, any>) {
var time = new Date();
var periods: any = [];
var scheduule: any = [];
//如果没选测量计划 则选择了测量时段也要置为空。因为二者是绑定关系
if (data.smPlan.length && data.bigPlan.length) {
data.periods.forEach((item: any) => {
periods.push({ Start: item.split(',')[0], End: item.split(',')[1] });
});
scheduule.push({ Type: data.bigPlan, Days: data.smPlan });
}
let obj: any = {
ne_type: data.neType,
ne_ids: JSON.stringify([data.neId]),
kpi_set: data.kpiSet,
schedule: JSON.stringify(scheduule),
start_time: data.startTime,
end_time: data.endTime,
granul_option: data.granulOption,
status: 'Inactive',
account_id: data.accountId,
create_time: parseDateToStr(time),
periods: JSON.stringify(periods),
comment: data.comment,
};
return request({
url: `/traceManagement/v1/subscriptions`,
url: `/api/rest/databaseManagement/v1/omc_db/measure_task`,
method: 'post',
data: data,
data: { measure_task: [obj] },
});
}
/**
* 修改任务
* 修改性能测量任务
* @param data 网元对象
* @returns object
*/
export function updateTraceTask(data: Record<string, any>) {
export function updatePerfTask(data: Record<string, any>) {
var time = new Date();
var periods: any = [];
var scheduule: any = [];
//如果没选测量计划 则选择了测量时段也要置为空。因为二者是绑定关系
if (data.smPlan.length && data.bigPlan.length) {
data.periods.forEach((item: any) => {
periods.push({ Start: item.split(',')[0], End: item.split(',')[1] });
});
scheduule.push({ Type: data.bigPlan, Days: data.smPlan });
}
let obj: any = {
ne_type: data.neType,
ne_ids: JSON.stringify([data.neId]),
kpi_set: data.kpiSet,
schedule: JSON.stringify(scheduule),
start_time: data.startTime,
end_time: data.endTime,
granul_option: data.granulOption,
status: 'Inactive',
account_id: data.accountId,
create_time: parseDateToStr(time),
periods: JSON.stringify(periods),
comment: data.comment,
};
return request({
url: `/traceManagement/v1/subscriptions`,
url: `/api/rest/databaseManagement/v1/omc_db/measure_task?WHERE=id=${data.id}`,
method: 'put',
data: data,
data: { measure_task: obj },
});
}
@@ -109,9 +161,11 @@ export function updateTraceTask(data: Record<string, any>) {
* @param noticeId 网元ID
* @returns object
*/
export async function delTraceTask(id: string) {
export async function delPerfTask(data: Record<string, any>) {
return request({
url: `/traceManagement/v1/subscriptions?id=${id}`,
url: `/api/rest/performanceManagement/v1/elementType/${data.neType.toLowerCase()}/objectType/measureTask?id=${
data.id
}`,
method: 'delete',
});
}
@@ -123,7 +177,7 @@ export async function delTraceTask(id: string) {
export async function getNePerformanceList() {
// 发起请求
const result = await request({
url: `/databaseManagement/v1/elementType/omc_db/objectType/measure_title`,
url: `/api/rest/databaseManagement/v1/elementType/omc_db/objectType/measure_title`,
method: 'get',
params: {
SQL: `SELECT * FROM measure_title`,
@@ -138,3 +192,28 @@ export async function getNePerformanceList() {
}
return result;
}
/**
* 激活任务
* @param
* @returns bolb
*/
export function taskRun(data: Record<string, any>) {
return request({
url: `/api/rest/performanceManagement/v1/elementType/${data.neType.toLowerCase()}/objectType/measureTask?ne_id=${JSON.parse(data.neIds)[0]}`,
method: 'post',
});
}
/**
* 挂起任务
* @param
* @returns bolb
*/
export function taskStop(data: Record<string, any>) {
return request({
url: `/api/rest/performanceManagement/v1/elementType/${data.neType.toLowerCase()}/objectType/measureTask?ne_id=${JSON.parse(data.neIds)[0]}`,
method: 'PATCH',
});
}