Browse Source

数据告警信息获取 92%

dev
巴林闲侠 2 years ago
parent
commit
af7605dcfc
  1. 70
      api/app/lib/controllers/alarm/data.js
  2. 80
      api/app/lib/utils/dataRange.js

70
api/app/lib/controllers/alarm/data.js

@ -34,15 +34,16 @@ async function list (ctx) {
const { utils: { judgeSuper, anxinStrucIdRange } } = ctx.app.fs const { utils: { judgeSuper, anxinStrucIdRange } } = ctx.app.fs
const { database: anxinyun } = clickHouse.anxinyun.opts.config const { database: anxinyun } = clickHouse.anxinyun.opts.config
const { pepProjectId, keyword, groupId, groupUnitId, sustainTimeStart, sustainTimeEnd, limit, page, projectOrStructKeyword } = ctx.query const { pepProjectId, keywordTarget, keyword, groupId, groupUnitId, sustainTimeStart, sustainTimeEnd, limit, page, projectOrStructKeyword } = ctx.query
const isSuper = judgeSuper(ctx) let anxinStruc = await anxinStrucIdRange({
let anxinStrucIds = await anxinStrucIdRange({ ctx, pepProjectId, keywordTarget, keyword
ctx, pepProjectId, projectOrStructKeyword,
}) })
let whereOption = [] let whereOption = []
if (anxinStrucIds.length ||1) { if (anxinStruc.length || 1) {
whereOption.push(`alarms.StructureId IN (${anxinStrucIds.join(",")})`) const anxinStrucIds = anxinStruc.map(a => a.strucId)
// TODO: 开发临时注释
// whereOption.push(`alarms.StructureId IN (${anxinStrucIds.join(",")})`)
if (groupId) { if (groupId) {
whereOption.push(`alarms.AlarmGroup IN (${groupId})`) whereOption.push(`alarms.AlarmGroup IN (${groupId})`)
@ -67,6 +68,9 @@ async function list (ctx) {
) )
`) `)
} }
if (keywordTarget == 'source' && keyword) {
whereOption.push(`SourceName LIKE '%${keyword}%'`)
}
const alarmRes = await clickHouse.dataAlarm.query(` const alarmRes = await clickHouse.dataAlarm.query(`
SELECT SELECT
@ -76,31 +80,61 @@ async function list (ctx) {
alarms.CurrentLevel AS CurrentLevel, alarms.CurrentLevel AS CurrentLevel,
SourceTypeId, SourceTypeId,
AlarmAdviceProblem, AlarmGroup, AlarmGroupUnit, AlarmAdviceProblem, AlarmAdviceProblem, AlarmGroup, AlarmGroupUnit, AlarmAdviceProblem,
alarms.StructureId AS StructureId,
${anxinyun}.t_structure.name AS StructureName, ${anxinyun}.t_structure.name AS StructureName,
StructureId,
${anxinyun}.t_alarm_code.name AS AlarmCodeName ${anxinyun}.t_alarm_code.name AS AlarmCodeName
FROM FROM
alarms alarms
LEFT JOIN ${anxinyun}.t_structure LEFT JOIN ${anxinyun}.t_structure
ON ${anxinyun}.t_structure.id = alarms.StructureId ON ${anxinyun}.t_structure.id = alarms.StructureId
LEFT JOIN ${anxinyun}.t_alarm_code LEFT JOIN ${anxinyun}.t_alarm_code
ON ${anxinyun}.t_alarm_code.code = alarms.AlarmTypeCode ON ${anxinyun}.t_alarm_code.code = alarms.AlarmTypeCode
${whereOption.length ? 'WHERE ' + whereOption.join(' AND ') : ''}
ORDER BY alarms.StartTime DESC
${limit ? 'LIMIT ' + limit : ''}
${limit && page ? 'OFFSET ' + parseInt(limit) * parseInt(page) : ''}
`).toPromise(); `).toPromise();
// alarm_details.Time, alarm_details.Content const confirmedAlarm = alarmRes
// TODO: 开发临时注释
// LEFT JOIN alarm_details // .filter(ar => ar.State && ar.State > 2)
// ON alarms.AlarmId = alarm_details.AlarmId .map(ar => "'" + ar.AlarmId + "'")
// AND alarm_details.Time = ( const confirmedAlarmDetailMax = confirmedAlarm.length ?
// SELECT MAX(alarm_details.Time) from alarm_details WHERE AlarmId = alarms.AlarmId await clickHouse.dataAlarm.query(`
// ) SELECT
max(Time) AS Time,AlarmId
FROM
alarm_details
WHERE
AlarmId IN (${confirmedAlarm.join(',')})
GROUP BY AlarmId
`).toPromise() :
[];
// State = 3 是 自动恢复 / 4 是 人工恢复 / 其他数字 是 需要恢复 // State = 3 是 自动恢复 / 4 是 人工恢复 / 其他数字 是 需要恢复
// const SourceType = { 0: 'DTU', 1: '传感器', 2: '测点' }; // state = 2 是 等级提升 / 1 是持续产生 / 0 是首次产生
// SourceType 0: 'DTU' / 1: '传感器' / 2: '测点'
alarmRes.forEach(ar => {
ar.pepProject = (anxinStruc.find(as => as.strucId == ar.StructureId) ||
{
// TODO: 开发临时添加
pepProject: [{
id: 999,
name: '这是假的开发の数据,看到请拨打110',
isdelete: 0,
}]
}).pepProject
let corConfirmedData = (confirmedAlarmDetailMax.find(cdm => cdm.AlarmId == ar.AlarmId) || {});
if (corConfirmedData.AlarmState && corConfirmedData.AlarmState > 2) {
} else {
corConfirmedData = {}
}
ar.confirmedContent = 'corConfirmedData.Content'
ar.confirmedTime = 'corConfirmedData.Time'
})
ctx.body = alarmRes ctx.body = alarmRes
} else { } else {
ctx.body = [] ctx.body = []

80
api/app/lib/utils/dataRange.js

@ -8,14 +8,13 @@ module.exports = function (app, opts) {
try { try {
const { userInfo = {} } = ctx.fs.api || {}; const { userInfo = {} } = ctx.fs.api || {};
const { role = [] } = userInfo const { role = [] } = userInfo
return role.includes('SuperAdmin') return role.some(r => r == 'SuperAdmin' || r == 'admin')
} catch (error) { } catch (error) {
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
} }
} }
async function anxinStrucIdRange ({ ctx, pepProjectId, projectOrStructKeyword }) { async function anxinStrucIdRange ({ ctx, pepProjectId, keywordTarget, keyword }) {
try {
const { models } = ctx.fs.dc; const { models } = ctx.fs.dc;
const { userInfo = {} } = ctx.fs.api || {}; const { userInfo = {} } = ctx.fs.api || {};
const { clickHouse } = ctx.app.fs const { clickHouse } = ctx.app.fs
@ -28,46 +27,71 @@ module.exports = function (app, opts) {
} }
} }
if (pepProjectId) { if (pepProjectId) {
// 有 特定的项目id 就按此查询
findOption.where.pepProjectId = pepProjectId findOption.where.pepProjectId = pepProjectId
} else if (!isSuper) { } else if (!isSuper) {
// 还不是超管或管理员就按关联的项目id的数据范围查
findOption.where.id = { $in: correlationProject } findOption.where.id = { $in: correlationProject }
} }
// TODO 这儿也许需要判断传进来的 pepProjectId 在不在当前用户的关注范围内 // TODO 这儿也许需要判断传进来的 pepProjectId 在不在当前用户的关注范围内
// 根据 poms 的项目绑定关系查相关联的项企项目、安心云项目id信息
const bindRes = await models.ProjectCorrelation.findAll(findOption) const bindRes = await models.ProjectCorrelation.findAll(findOption)
let pepProjectIds = [] // 获取不重复的 安心云项目id
let pepProjectIds = bindRes.map(b => b.pepProjectId)
const anxinProjectIds = [ // 查询项企项目的信息
...bindRes.reduce( let pepProjectWhereOptions = []
(arr, b) => { if (keywordTarget == 'pepProject' && keyword) {
pepProjectIds.push(b.pepProjectId) pepProjectWhereOptions.push(`name LIKE '%${keyword}%')`)
for (let sid of b.anxinProjectId) {
arr.add(sid);
} }
return arr;
},
new Set()
)
]
const pepProjectRes = pepProjectIds.length ? const pepProjectRes = pepProjectIds.length ?
await clickHouse.projectManage.query( await clickHouse.projectManage.query(
` `
SELECT SELECT
id, project_name, isdelete id, project_name AS name, isdelete
FROM FROM
t_pim_project t_pim_project
WHERE WHERE
id IN (${pepProjectIds.join(',')}) id IN (${pepProjectIds.join(',')})
${pepProjectWhereOptions.length ? `AND ${pepProjectWhereOptions.join(' AND ')}`
: ''}
` `
).toPromise() : ).toPromise() :
[] []
const anxinProjectIds = [
...(
bindRes.filter(b => pepProjectRes.some(pp => pp.id == b.pepProjectId))
).reduce(
(arr, b) => {
for (let sid of b.anxinProjectId) {
arr.add(sid);
}
return arr;
},
new Set()
)
]
// 查询安心云项目及结构物信息
let undelStrucWhereOptions = []
if (keywordTarget && keyword) {
if (keywordTarget == 'struc') {
undelStrucWhereOptions.push(`t_structure.name LIKE '%${keyword}%'`)
}
}
const undelStrucRes = anxinProjectIds.length ? const undelStrucRes = anxinProjectIds.length ?
await clickHouse.anxinyun.query( await clickHouse.anxinyun.query(
` `
SELECT SELECT
t_project.id, t_structure.id AS strucId, project_state t_project.id AS projectId,
t_structure.id AS strucId,
t_structure.name AS strucName,
project_state
FROM FROM
t_project t_project
LEFT JOIN LEFT JOIN
@ -80,16 +104,28 @@ module.exports = function (app, opts) {
project_state != -1 project_state != -1
AND AND
t_project.id IN (${anxinProjectIds.join(',')}) t_project.id IN (${anxinProjectIds.join(',')})
${projectOrStructKeyword ? `AND (t_project.name LIKE '%${projectOrStructKeyword}%' OR t_structure.name LIKE '%${projectOrStructKeyword}%')` : ''} ${undelStrucWhereOptions.length ? `AND ${undelStrucWhereOptions.join(' AND ')}` : ''}
` `
).toPromise() : ).toPromise() :
[] []
const undelStrucIds = [...new Set(...undelStrucRes.map(s => s.strucId))] // 构建安心云结构物和项企项目的关系
return {} // 并保存信息至数据
} catch (error) { let undelStruc = []
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); for (let s of undelStrucRes) {
if (!undelStruc.some(us => us.strucId == s.strucId)) {
undelStruc.push({
strucId: s.strucId,
strucName: s.strucName,
pepProject: pepProjectRes.filter(pp => {
return bindRes.find(br => {
return br.pepProjectId == pp.id && br.anxinProjectId.some(braId => braId == s.strucId)
})
})
})
}
} }
return undelStruc
} }
return { return {

Loading…
Cancel
Save