EasyGBS批量接入设备及导入通道的实现过程分享

EasyGBS是TSINGSEE青犀视频研发的可接入国标GB28181协议的视频平台,经过多年的沉淀和不断的优化,EasyGBS目前已经适应了很多场景下的视频监控可视化搭建,并且能够提供丰富的二次接口进行开发。

为了方便EasyGBS的日常运维和现场部署,需要用户和运维人员能够通过简单的方式,批量的配置EasyGBS后台的接入通道配置。并且能够随时了解通道配置的具体情况,因此在前端提供一个通道信息的一键导入功能。

首先设定一个固定的通道导入信息模板:

设备信息导入模板:

通道信息导入模板。

后端保存文件通道信息内容,选择是更新或者新建通道和设备信息。

 func (h *APIHandler) ImportChannelInfo(c *gin.Context) {
   file, err := c.FormFile("file")
   if err != nil {
      err = fmt.Errorf("获取上传文件错误, %v", err)
      c.AbortWithStatusJSON(http.StatusBadRequest, err.Error())
      return
   }
   ext := filepath.Ext(file.Filename)
   if ext != ".xlsx" {
      err = fmt.Errorf("上传文件格式错误, %v", err)
      c.AbortWithStatusJSON(http.StatusBadRequest, err.Error())
      return
   }

   tmp := "tmp.xlsx"
   f, err := os.Create(tmp)
   if err != nil {
      err = fmt.Errorf("新建文件失败, %v", err)
      c.AbortWithStatusJSON(http.StatusInternalServerError, err.Error())
      return
   }

   err = c.SaveUploadedFile(file, tmp)
   if err != nil {
      err = fmt.Errorf("保存上传文件错误, %v", err)
      c.AbortWithStatusJSON(http.StatusInternalServerError, err.Error())
      return
   }

   xlFile, e := xlsx.OpenFile(tmp)
   if e != nil {
      err = fmt.Errorf("xlsx open error, %v", e)
      c.AbortWithStatusJSON(http.StatusInternalServerError, err.Error())
      return
   }
   defer func() {
      f.Close()
      os.RemoveAll(tmp)
   }()

   err = importInfo(xlFile)
   if err != nil {
      c.AbortWithStatusJSON(http.StatusInternalServerError, err.Error())
      return
   }
   c.AbortWithStatusJSON(http.StatusOK, "ok")
   return
}
posted on 2021-09-26 17:26  EasyGBS  阅读(76)  评论(0)    收藏  举报