fix
liuxiaolong
2019-11-13 263c7b18ce7f18f1222318f6e0e499e907895a52
controllers/sdk.go
@@ -2,9 +2,13 @@
import (
   "basic.com/dbapi.git"
   uuid "github.com/satori/go.uuid"
   "webserver/extend/code"
   "webserver/extend/config"
   "basic.com/valib/logger.git"
   "webserver/extend/util"
   "github.com/gin-gonic/gin"
   "webserver/service"
)
type SdkController struct {
@@ -14,14 +18,14 @@
   Id       string `json:"id"`
   SdkType string `json:"sdk_type"`//人脸检测:FaceDetect,人脸提取:FaceExtract,人脸比对:FaceCompare,行为:Yolo
   SdkName string `json:"sdk_name"`    //算法名称
   Args    []SdkArgVo `json:"args,omitempty"` //算法参数
   Icon    string `json:"icon,omitempty"`       //算法图标
   Url     string `json:"url,omitempty"`                       //算法下载地址
   Args    []SdkArgVo `json:"args"` //算法参数
   Icon    string `json:"icon"`       //算法图标
   Url     string `json:"url"`                       //算法下载地址
   CreateTime string `json:"create_time"`
   CreateBy string `json:"create_by"`
   UpdateTime string `json:"update_time"`
   Enabled int `json:"enabled"`//是否启用
   DelFlag int `json:"del_flag"`//逻辑删除
   Enable bool `json:"enable"`//是否启用
   DelFlag bool `json:"del_flag"`//逻辑删除
}
//算法参数定义
@@ -30,18 +34,24 @@
   Name  string `json:"name"`  //参数名称
   Type  string `json:"type"`  //参数类型(整数,字符串或数组)
   Must  bool   `json:"must"`  //是否必填
   Unit  string `json:"unit"`
   Range string `json:"range"` //值的范围,eg:0,100表示从0到100
   DefaultValue string `json:"default_value"`
   Sort  int    `json:"sort"`  //参数顺序
}
/*
// @Security ApiKeyAuth
// @Summary 算法保存
// @Description 算法保存
// @Accept json
// @Produce json
// @Tags sdk
// @Param reqMap body controllers.SdkVo true "人脸检测"
// @Success 200 {string} json "{"code":200, msg:"请求处理成功",data:"",success:true}"
// @Failure 500 {string} json "{"code":500, msg:"请求失败",data:"",success:false}"
// @Router /data/api-v/sdk/save [POST]
*/
func (sc SdkController) Save(c *gin.Context) {
   var sdk SdkVo
   var api dbapi.SdkApi
@@ -59,6 +69,8 @@
   }
}
/*
// @Security ApiKeyAuth
// @Summary 查找所有算法
// @Description 查找所有算法
// @Produce json
@@ -67,6 +79,7 @@
// @Success 200 {string} json "{"code":200, msg:"请求处理成功",data:"算法列表",success:true}"
// @Failure 500 {string} json "{"code":500, msg:"请求失败",data:"[]",success:false}"
// @Router /data/api-v/sdk/findAllSdk [GET]
*/
func (sc SdkController) FindAllSdk(c *gin.Context) {
   var api dbapi.SdkApi
@@ -75,6 +88,8 @@
   util.ResponseFormat(c, code.Success, sdks)
}
/*
// @Security ApiKeyAuth
// @Summary 根据id获取算法信息
// @Description 根据id获取算法信息
// @Produce json
@@ -83,6 +98,7 @@
// @Success 200 {string} json "{"code":200, msg:"请求处理成功",data:"算法信息",success:true}"
// @Failure 500 {string} json "{"code":500, msg:"请求失败",data:"",success:false}"
// @Router /data/api-v/sdk/getById [GET]
*/
func (sc SdkController) GetById(c *gin.Context) {
   var api dbapi.SdkApi
   sdkId := c.Query("id")
@@ -92,6 +108,7 @@
   }
   flag, sdk := api.GetById(sdkId)
   if flag {
      util.ResponseFormat(c,code.Success,sdk)
   } else {
@@ -99,6 +116,27 @@
   }
}
/*
// @Router /data/api-v/sdkArg/getSdkArgs [get]
*/
func (sc SdkController) GetSdkArgs(c *gin.Context) {
   sdkId := c.Query("sdkId")
   scope := c.Query("scope")
   if sdkId== "" || scope == ""{
      util.ResponseFormat(c,code.RequestParamError,"参数有误")
      return
   }
   var api dbapi.SdkApi
   b,d := api.GetSdkArgs(sdkId, scope)
   if b{
      util.ResponseFormat(c,code.Success,d)
   } else {
      util.ResponseFormat(c,code.ComError,"查询失败")
   }
}
/*
// @Security ApiKeyAuth
// @Summary 根据taskId获取算法信息
// @Description 根据taskId获取算法信息
// @Produce json
@@ -107,6 +145,7 @@
// @Success 200 {string} json "{"code":200, msg:"请求处理成功",data:"算法信息",success:true}"
// @Failure 500 {string} json "{"code":500, msg:"请求失败",data:"",success:false}"
// @Router /data/api-v/sdk/findByTaskId [GET]
*/
func (sc SdkController) FindByTaskId(c *gin.Context) {
   var api dbapi.SdkApi
   taskId := c.Query("taskId")
@@ -120,4 +159,44 @@
   } else {
      util.ResponseFormat(c,code.ComError,sdks)
   }
}
func (sc SdkController) SdkDownLoad(c *gin.Context) {
   path,exist := c.GetQuery("path")
   if !exist {
      util.ResponseFormat(c,code.ComError,"下载的算法参数有误")
   }
   logger.Info(path)
   flag := c.Query("needUpdateMiddle")
   // 下载算法(有时候也需要把中间件一起下载下来)
   if flag == "true" {
      // 下载并更新中间件,带上MD5校验
      flag1,err := service.DownSo("http://"+config.SoPath.Ip+":"+config.SoPath.Port+"/"+"middleware.so")
      logger.Debug("中间件路径:","http://"+config.SoPath.Ip+":"+config.SoPath.Port+"/"+"middleware.so")
      if err != nil {
         logger.Info(err)
      }
      if !flag1 {
         util.ResponseFormat(c,code.ComError,"请重新下载算法")
      }
   }
   // 下载算法,校验,并写入到目标目录下
   flag2,err2 := service.DownSo(path)
   if err2 != nil {
      logger.Info(err2)
   }
   if !flag2 {
      util.ResponseFormat(c,code.ComError,"请重新下载算法")
   }
   // 将算法和so名称存到规则私有的注册表
   var soApi dbapi.SoApi
   param := make(map[string]interface{})
   param["id"] = uuid.NewV4().String()
   sdkId := uuid.NewV4().String()
   param["sdkId"] = sdkId
   param["soName"] = service.GetFileNameFromUrl(path,true)
   flag3,_ := soApi.Add(param)
   if flag3 {
      util.ResponseFormat(c,code.Success,"下载算法成功!")
   }
}