Browse Source

(*)数据告警, 应用告警, 视频告警确认日志记录

dev
wuqun 2 years ago
parent
commit
75ce97f64a
  1. 49
      api/app/lib/controllers/alarm/alarmConfirmLog.js
  2. 27
      api/app/lib/controllers/alarm/app.js
  3. 6
      api/app/lib/controllers/alarm/data.js
  4. 29
      api/app/lib/controllers/alarm/video.js
  5. 25
      web/client/src/sections/problem/containers/dataAlarm.jsx

49
api/app/lib/controllers/alarm/alarmConfirmLog.js

@ -0,0 +1,49 @@
'use strict';
const moment = require('moment')
async function alarmConfirmLog(ctx, confirmPost, content) {
try {
const { models } = ctx.fs.dc;
//存日志
let logDatas = [];
confirmPost.map(cp => {
let { pepUserId, projectCorrelationIds, alarmInfo } = cp;
projectCorrelationIds.map(id => {
logDatas.push({
pepUserId,
projectCorrelationId: id,
alarmInfo,//包含告警id,type,source
confirmTime: moment().format(),
confirmContent: content
})
})
})
let rslt = await models.AlarmConfirmLog.bulkCreate(logDatas, { returning: true });
//存最新动态
let dynamics = rslt.map(r => {
return {
time: r.confirmTime,
alarmConfirmId: r.id,
projectCorrelationId: r.projectCorrelationId,
type: 4//告警确认
}
})
await models.LatestDynamicList.bulkCreate(dynamics);
//TODO 消息推送到前端
} catch (error) {
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
ctx.status = 400;
ctx.body = {
message: typeof error == 'string' ? error : undefined
}
}
}
module.exports = {
alarmConfirmLog
};

27
api/app/lib/controllers/alarm/app.js

@ -1,7 +1,7 @@
'use strict'; 'use strict';
const moment = require('moment') const moment = require('moment')
const { alarmConfirmLog } = require('./alarmConfirmLog');
async function inspection(ctx) { async function inspection(ctx) {
// 巡查 // 巡查
try { try {
@ -328,7 +328,6 @@ async function confirmApiError(ctx) {
try { try {
const models = ctx.fs.dc.models; const models = ctx.fs.dc.models;
const { confirm, appAlarmId = [], confirmPost } = ctx.request.body const { confirm, appAlarmId = [], confirmPost } = ctx.request.body
const { pepUserId, projectCorrelationIds, alarmInfo } = confirmPost
await models.AppAlarm.update({ await models.AppAlarm.update({
confirm, confirm,
confirmTime: moment().format() confirmTime: moment().format()
@ -338,29 +337,7 @@ async function confirmApiError(ctx) {
} }
}) })
//存日志 await alarmConfirmLog(ctx, confirmPost, confirm);//告警确认日志
let logDatas = projectCorrelationIds.map(id => {
return {
pepUserId,
projectCorrelationId: id,
alarmInfo,//包含告警id,type,source
confirmTime: moment().format(),
confirmContent: confirm
}
})
let rslt = await models.AlarmConfirmLog.bulkCreate(logDatas, { returning: true });
//存最新动态
let dynamics = rslt.map(r => {
return {
time: r.confirmTime,
alarmConfirmId: r.id,
projectCorrelationId: r.projectCorrelationId,
type: 4//告警确认
}
})
await models.LatestDynamicList.bulkCreate(dynamics);
ctx.status = 204; ctx.status = 204;
} catch (error) { } catch (error) {

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

@ -1,6 +1,6 @@
'use strict'; 'use strict';
const moment = require('moment'); const moment = require('moment');
const { alarmConfirmLog } = require('./alarmConfirmLog');
async function groupList (ctx) { async function groupList (ctx) {
try { try {
const { models } = ctx.fs.dc; const { models } = ctx.fs.dc;
@ -248,7 +248,6 @@ function confirm (opts) {
const { utils: { kfkSendAsync } } = ctx.app.fs const { utils: { kfkSendAsync } } = ctx.app.fs
const { clickHouse } = ctx.app.fs const { clickHouse } = ctx.app.fs
const { content = '', alarmId, confirmPost } = ctx.request.body; const { content = '', alarmId, confirmPost } = ctx.request.body;
const { pepUserId, projectCorrelationIds, alarmInfo } = confirmPost;
// 发送告警恢复通知 // 发送告警恢复通知
// Topic: alarm // Topic: alarm
/* /*
@ -295,6 +294,9 @@ function confirm (opts) {
await kfkSendAsync(payloads) await kfkSendAsync(payloads)
} }
await alarmConfirmLog(ctx, confirmPost, content);//告警确认日志
ctx.status = 204; ctx.status = 204;
} catch (error) { } catch (error) {
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);

29
api/app/lib/controllers/alarm/video.js

@ -1,6 +1,6 @@
'use strict'; 'use strict';
const moment = require('moment') const moment = require('moment')
const { alarmConfirmLog } = require('./alarmConfirmLog');
async function deviceType (ctx) { async function deviceType (ctx) {
try { try {
const { models } = ctx.fs.dc; const { models } = ctx.fs.dc;
@ -129,7 +129,7 @@ async function alarmList (ctx, agg) {
SELECT camera_status_alarm.id AS alarmId SELECT camera_status_alarm.id AS alarmId
FROM camera_status_alarm FROM camera_status_alarm
RIGHT JOIN ${anxinyun}.t_video_ipc RIGHT JOIN ${anxinyun}.t_video_ipc
ON toString(${anxinyun}.t_video_ipc.channel_no) = camera_status_alarm.channel_no总书记任期 ON toString(${anxinyun}.t_video_ipc.channel_no) = camera_status_alarm.channel_no
AND ${anxinyun}.t_video_ipc.serial_no = camera_status_alarm.serial_no AND ${anxinyun}.t_video_ipc.serial_no = camera_status_alarm.serial_no
${`WHERE ${anxinyun}.t_video_ipc.structure IN (${anxinStrucIds.join(',')})`} ${`WHERE ${anxinyun}.t_video_ipc.structure IN (${anxinStrucIds.join(',')})`}
) )
@ -268,9 +268,7 @@ async function alarmList (ctx, agg) {
async function confirm (ctx) { async function confirm (ctx) {
try { try {
const { models } = ctx.fs.dc;
const { alarmId, content, confirmPost } = ctx.request.body; const { alarmId, content, confirmPost } = ctx.request.body;
const { pepUserId, projectCorrelationIds, alarmInfo } = confirmPost;
// TODO: 以视频·应用的秘钥进行鉴权 // TODO: 以视频·应用的秘钥进行鉴权
await ctx.app.fs.vcmpRequest.put('status/alarm/confirm', { await ctx.app.fs.vcmpRequest.put('status/alarm/confirm', {
data: { data: {
@ -278,28 +276,7 @@ async function confirm (ctx) {
} }
}) })
//存日志 await alarmConfirmLog(ctx, confirmPost, content);//告警确认日志
let logDatas = projectCorrelationIds.map(id => {
return {
pepUserId,
projectCorrelationId: id,
alarmInfo,//包含告警id,type,source
confirmTime: moment().format(),
confirmContent: content
}
})
let rslt = await models.AlarmConfirmLog.bulkCreate(logDatas, { returning: true });
//存最新动态
let dynamics = rslt.map(r => {
return {
time: r.confirmTime,
alarmConfirmId: r.id,
projectCorrelationId: r.projectCorrelationId,
type: 4//告警确认
}
})
await models.LatestDynamicList.bulkCreate(dynamics);
ctx.status = 204; ctx.status = 204;
} catch (error) { } catch (error) {

25
web/client/src/sections/problem/containers/dataAlarm.jsx

@ -37,8 +37,6 @@ const DataAlarm = ({ match, dispatch, actions, user, loading, socket, iotVcmpWeb
const [videoModal, setVideoModal] = useState(false) // const [videoModal, setVideoModal] = useState(false) //
const [videoData, setVideoData] = useState({}) // const [videoData, setVideoData] = useState({}) //
const [videoToken, setVideoToken] = useState() //token const [videoToken, setVideoToken] = useState() //token
const [alarmToConfirm, setAlarmToConfirm] = useState(null) //
const TextAreaApi = useRef('') const TextAreaApi = useRef('')
@ -309,7 +307,6 @@ const DataAlarm = ({ match, dispatch, actions, user, loading, socket, iotVcmpWeb
<Button theme='borderless' style={{ width: 65 }} onClick={() => { <Button theme='borderless' style={{ width: 65 }} onClick={() => {
setConfirm(true) setConfirm(true)
setSelected([r.key]) setSelected([r.key])
setAlarmToConfirm(r)
}}>确认</Button> }}>确认</Button>
: r.State == 3 || r.autoRestore || r.confirmAuto ? : r.State == 3 || r.autoRestore || r.confirmAuto ?
<Button theme='borderless' style={{ width: 65 }} disabled>自动恢复</Button> : <Button theme='borderless' style={{ width: 65 }} disabled>自动恢复</Button> :
@ -384,18 +381,24 @@ const DataAlarm = ({ match, dispatch, actions, user, loading, socket, iotVcmpWeb
// console.log(selected); // console.log(selected);
const getAlarmConfirmItem = () => { const getAlarmConfirmItems = () => {
let source = route == 'useAbnormal' ? alarmToConfirm.appName : alarmToConfirm.SourceName; let confirmItems = [];
let type = route == 'useAbnormal' ? alarmToConfirm.type : route == 'videoAbnormal' ? alarmToConfirm.AlarmContent : alarmToConfirm.AlarmGroupUnit; selected.map(s => {
return { let alarmInfo = tableData.find(td => td.key == s);
let source = route == 'useAbnormal' ? alarmInfo.appName : alarmInfo.SourceName;
let type = route == 'useAbnormal' ? alarmInfo.type : route == 'videoAbnormal' ? alarmInfo.AlarmContent : alarmInfo.AlarmGroupUnit;
let item = {
pepUserId: user.pomsUserInfo.pepUserId, pepUserId: user.pomsUserInfo.pepUserId,
projectCorrelationIds: alarmToConfirm?.projectName?.map(p => p.id), projectCorrelationIds: alarmInfo?.projectName?.map(p => p.id),
alarmInfo: { alarmInfo: {
id: alarmToConfirm.key, id: alarmInfo.key,
source: source,// source: source,//
type: type,// type: type,//
} }
}; }
confirmItems.push(item);
})
return confirmItems;
} }
return ( return (
@ -457,7 +460,7 @@ const DataAlarm = ({ match, dispatch, actions, user, loading, socket, iotVcmpWeb
width={600} width={600}
onCancel={() => setConfirm(false)} onCancel={() => setConfirm(false)}
onOk={() => { onOk={() => {
let confirmPost = getAlarmConfirmItem(); let confirmPost = getAlarmConfirmItems();
if (route == 'useAbnormal') { if (route == 'useAbnormal') {
TextAreaApi.current.validate().then((v) => { TextAreaApi.current.validate().then((v) => {
dispatch(problem.postApiConfirm({ appAlarmId: selected, confirm: content, confirmPost })).then(res => { dispatch(problem.postApiConfirm({ appAlarmId: selected, confirm: content, confirmPost })).then(res => {

Loading…
Cancel
Save