liuxiaolong
2019-11-13 f26a0cab5bca17b7eab57f6330e576271e17a17f
controllers/camera.go
@@ -12,6 +12,7 @@
   "webserver/extend/code"
   "webserver/extend/util"
    "webserver/service"
   "webserver/cache"
)
type CameraController struct{}
@@ -19,6 +20,7 @@
type CameraVo struct {
   Id        string  `json:"id"`
   Name      string  `json:"name"`
   Alias     string  `json:"alias"` //摄像机的别名
   Type      int     `json:"type" `
   Addr      string  `json:"addr"`
   Areaid    string  `json:"areaid"`
@@ -40,6 +42,7 @@
// @Summary 添加摄像机
// @Description  "传入区域的id(areaid)和摄像机名字(name) 必须, 其他参数可以在摄像机配置点击保存进行添加"
// @Security ApiKeyAuth
// @Accept json
// @Produce json
// @Tags camera
@@ -56,10 +59,10 @@
      util.ResponseFormat(c, code.RequestParamError, "参数错误")
      return
   }
   cam.Id = util.PseudoUuid()
   paramBody := util.Struct2Map(cam)
   if api.CameraAdd(paramBody) {
      util.ResponseFormat(c, code.Success, cam)
   b, data := api.CameraAdd(paramBody)
   if b {
      util.ResponseFormat(c, code.Success, data)
      return
   }
   util.ResponseFormat(c, code.ComError, err)
@@ -68,6 +71,7 @@
// @Summary 更新摄像机
// @Description "用于更新摄像机操作"
// @Security ApiKeyAuth
// @Accept json
// @Produce json
// @Tags camera
@@ -95,6 +99,7 @@
// @Summary "删除摄像机"
// @Description "根据摄像机id删除摄像机"
// @Security ApiKeyAuth
// @Produce json
// @Tags camera
// @Param cid path string true "摄像机id example: cid0"
@@ -114,11 +119,12 @@
// @Summary 显示摄像机
// @Description "显示摄像机"
// @Security ApiKeyAuth
// @Produce json
// @Tags camera
// @Param cid path string true "摄像机id"
// @Success 200 {string} json "{"code":200, success:true,  msg:"请求处理成功", data:"摄像机信息"}"
// @Failure 500 {string} json "{"code":500, success:false   msg:"",data:"错误信息内容"}"
// @Success 200 {string} json "{"code":200, success:true, msg:"", data:""}"
// @Failure 500 {string} json "{"code":500, success:false, msg:"",data:""}"
// @Router /data/api-v/camera/show/{cid} [get]
func (ac CameraController) CameraSel(c *gin.Context) {
   var api dbapi.CameraApi
@@ -128,8 +134,35 @@
      util.ResponseFormat(c, code.ComError, "查询失败")
      return
   }
   util.ResponseFormat(c, code.Success, camera)
   //2019-11-02新增需求,显示每个摄像机的处理服务器信息,归属的节点服务器名称
   m := util.Struct2Map(camera)
   m["runServerName"] = ""
   if camera.RunServerId !="" {
      localConf, e := cache.GetServerInfo()
      if e ==nil {
         if camera.RunServerId == localConf.ServerId {//归属本台服务器
            m["runServerName"] = localConf.ServerName
         } else {//属于其他服务器
            var clusterApi dbapi.ClusterApi
            b, data := clusterApi.FindCluster()
            if b && data !=nil {
               cb, _ := json.Marshal(data)
               var clu ClusterDb
               if err := json.Unmarshal(cb, &clu);err ==nil {
                  if len(clu.Nodes) >0 {
                     for _,n :=range clu.Nodes {
                        if camera.RunServerId == n.NodeId {
                           m["runServerName"] = n.NodeName
                           break
                        }
                     }
                  }
               }
            }
         }
      }
   }
   util.ResponseFormat(c, code.Success, m)
}
@@ -178,6 +211,22 @@
   fmt.Println(areaId)
}
func (cc CameraController) GetAllCamerasByServer(c *gin.Context) {
   localConf, err2 := cache.GetServerInfo()
   if err2 !=nil || localConf.ServerId == "" {
      logger.Debug("localConfig is wrong!!!")
      util.ResponseFormat(c,code.ComError,"服务器本机未配置serverId")
      return
   }
   var api dbapi.CameraApi
   cameraName := c.Query("cameraName")
   b,d := api.GetAllCamerasByServer(localConf.ServerId, cameraName)
   if b {
      util.ResponseFormat(c,code.Success, d)
   } else {
      util.ResponseFormat(c,code.ComError, "")
   }
}
func (cc CameraController) GetCamerasByRunType(c *gin.Context) {
@@ -254,4 +303,13 @@
   }
}
func (cc CameraController) StatisticRunInfo(c *gin.Context) {
   var api dbapi.CameraApi
   b, d := api.StatisticRunInfo()
   if b {
      util.ResponseFormat(c,code.Success,d)
   } else {
      util.ResponseFormat(c,code.ComError,"")
   }
}