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