From 3e9a1a28b1283e40bc7edb94e2370c74e7fd68e0 Mon Sep 17 00:00:00 2001 From: zhangzengfei <zhangzengfei@smartai.com> Date: 星期五, 17 五月 2024 15:54:29 +0800 Subject: [PATCH] 添加订阅查询接口 --- controller/captureCtl.go | 72 +++++++++++++++++++++++++++++++++++- 1 files changed, 70 insertions(+), 2 deletions(-) diff --git a/controller/captureCtl.go b/controller/captureCtl.go index 6dd58f8..223dec0 100644 --- a/controller/captureCtl.go +++ b/controller/captureCtl.go @@ -1,6 +1,8 @@ package controller import ( + "gat1400Exchange/config" + "gat1400Exchange/service" "net/http" "time" @@ -37,10 +39,21 @@ } face := req.FaceListObject.FaceObject[0] + logger.Debug("Receive new message, Id:%s Ip:%s faceId:%s, LeftTopX:%d, appearTime:%s", c.RemoteIP(), face.DeviceID, face.FaceID, face.LeftTopX, face.FaceAppearTime) - logger.Debug("鎺ユ敹鍒颁汉鑴告暟鎹�, ip:%s dev:%s faceId:%s, LeftTopX:%d", c.RemoteIP(), face.DeviceID, face.FaceID, face.LeftTopX) + // 濡傛灉寮�鍚簡涓嬬骇, 韬唤搴旇鏄秷鎭唬鐞�, 涓嶅啀杞彂鍒版湇鍔″櫒 + if config.ClientConf.Enable && config.ServeConf.Role == "agent" { + go a.Repository.VIIDMsgForward(&req) + } else if config.ServeConf.Role == "cascade" { + go service.AddFaceNotification(&face) + } - a.Repository.FaceForward(req.FaceListObject.FaceObject) + if config.ForwardConf.SyncServer != "" { + go a.Repository.FaceForward(req.FaceListObject.FaceObject) + } + + // 璁惧淇濇椿 + service.KeepDeviceAlive(face.DeviceID) rspMsg := vo.ResponseStatus{ RequestURL: c.FullPath(), @@ -52,3 +65,58 @@ c.JSON(http.StatusOK, gin.H{"ResponseStatusObject": rspMsg}) } +func (a CaptureController) VideoLabels(c *gin.Context) { + var req vo.RequestVideoLabelList + if err := c.BindJSON(&req); err != nil { + c.AbortWithStatus(http.StatusBadRequest) + return + } + + if len(req.VideoLabelListObject.VideoLabelObject) == 0 { + c.AbortWithStatus(http.StatusBadRequest) + return + } + + videoLabel := req.VideoLabelListObject.VideoLabelObject[0] + logger.Debug("Receive new message, Id:%s Ip:%s faceId:%s, LeftTopX:%d, appearTime:%s", c.RemoteIP(), videoLabel.VideoLabelID) + + // 杞汉鑴告秷鎭� + var face vo.FaceObject + face.FaceID = videoLabel.VideoLabelID + face.InfoKind = 1 + face.SourceID = videoLabel.VideoImageID + face.SourceID = videoLabel.VideoImageID + face.LocationMarkTime = videoLabel.CreateTimeAbs + face.FaceAppearTime = videoLabel.BehaviorAnalysisObject.BehaviorBeginTime + face.FaceDisAppearTime = videoLabel.BehaviorAnalysisObject.BehaviorEndTime + + for idx, _ := range videoLabel.SubImageList.SubImageInfoObject { + videoLabel.SubImageList.SubImageInfoObject[idx].EventSort = 10 + } + + face.SubImageList.SubImageInfoObject = videoLabel.SubImageList.SubImageInfoObject + + // 濡傛灉寮�鍚簡涓嬬骇, 韬唤搴旇鏄秷鎭唬鐞�, 涓嶅啀杞彂鍒版湇鍔″櫒 + if config.ClientConf.Enable && config.ServeConf.Role == "agent" { + //go a.Repository.VIIDMsgForward(&req) + } else if config.ServeConf.Role == "cascade" { + go service.AddFaceNotification(&face) + } + + if config.ForwardConf.SyncServer != "" { + go a.Repository.FaceForward([]vo.FaceObject{face}) + } + + // 璁惧淇濇椿 + service.KeepDeviceAlive(videoLabel.IVADeviceID) + + rspMsg := vo.ResponseStatus{ + RequestURL: c.FullPath(), + StatusCode: vo.StatusSuccess, + StatusString: vo.StatusString[vo.StatusSuccess], + Id: videoLabel.VideoLabelID, + LocalTime: time.Now().Format("20060102150405"), + } + + c.JSON(http.StatusOK, gin.H{"ResponseStatusObject": rspMsg}) +} -- Gitblit v1.8.0