155 lines
3.7 KiB
TypeScript
155 lines
3.7 KiB
TypeScript
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 listTraceTask(query: Record<string, any>) {
|
|
let totalSQL = 'select count(*) as total from trace_task where 1=1 ';
|
|
let rowsSQL = 'select * from trace_task where 1=1 ';
|
|
|
|
// 查询
|
|
let querySQL = '';
|
|
if (query.imsi) {
|
|
querySQL += ` and imsi like '%${query.imsi}%' `;
|
|
}
|
|
if (query.beginTime) {
|
|
querySQL += ` and start_time >= '${query.beginTime}' `;
|
|
}
|
|
if (query.endTime) {
|
|
querySQL += ` and end_time <= '${query.endTime}' `;
|
|
}
|
|
|
|
// 分页
|
|
const pageNum = (query.pageNum - 1) * query.pageSize;
|
|
const limtSql = ` limit ${pageNum},${query.pageSize} `;
|
|
|
|
// 排序
|
|
let sortSql = ' order by start_time ';
|
|
if (query.sortOrder === 'asc') {
|
|
sortSql += ' asc ';
|
|
} else {
|
|
sortSql += ' desc ';
|
|
}
|
|
|
|
// 发起请求
|
|
const result = await request({
|
|
url: `/api/rest/databaseManagement/v1/select/omc_db/trace_task`,
|
|
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['trace_task'];
|
|
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;
|
|
}
|
|
|
|
/**
|
|
* 查询任务详细
|
|
* @param id 网元ID
|
|
* @returns object
|
|
*/
|
|
export async function getTraceTask(id: string | number) {
|
|
// 发起请求
|
|
const result = await request({
|
|
url: `/api/rest/databaseManagement/v1/select/omc_db/trace_task`,
|
|
method: 'get',
|
|
params: {
|
|
SQL: `select * from trace_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]),
|
|
});
|
|
}
|
|
return result;
|
|
}
|
|
|
|
/**
|
|
* 新增任务
|
|
* @param data 网元对象
|
|
* @returns object
|
|
*/
|
|
export function addTraceTask(data: Record<string, any>) {
|
|
return request({
|
|
url: `/api/rest/traceManagement/v1/subscriptions`,
|
|
method: 'post',
|
|
data: data,
|
|
});
|
|
}
|
|
|
|
/**
|
|
* 修改任务
|
|
* @param data 网元对象
|
|
* @returns object
|
|
*/
|
|
export function updateTraceTask(data: Record<string, any>) {
|
|
return request({
|
|
url: `/api/rest/traceManagement/v1/subscriptions`,
|
|
method: 'put',
|
|
data: data,
|
|
});
|
|
}
|
|
|
|
/**
|
|
* 删除任务
|
|
* @param noticeId 网元ID
|
|
* @returns object
|
|
*/
|
|
export async function delTraceTask(id: string) {
|
|
return request({
|
|
url: `/api/rest/traceManagement/v1/subscriptions?id=${id}`,
|
|
method: 'delete',
|
|
});
|
|
}
|
|
|
|
/**
|
|
* 获取网元跟踪接口列表
|
|
* @returns object
|
|
*/
|
|
export async function getNeTraceInterfaceAll() {
|
|
// 发起请求
|
|
const result = await request({
|
|
url: `/api/rest/databaseManagement/v1/elementType/omc_db/objectType/ne_info`,
|
|
method: 'get',
|
|
params: {
|
|
SQL: `SELECT ne_type,interface FROM trace_info GROUP BY ne_type,interface`,
|
|
},
|
|
});
|
|
// 解析数据
|
|
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_info']),
|
|
});
|
|
}
|
|
return result;
|
|
}
|