task_model.go 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. package bo
  2. import (
  3. "errors"
  4. "fmt"
  5. "scd_check_tools/arrayex"
  6. "scd_check_tools/logger"
  7. "scd_check_tools/models/enum"
  8. "scd_check_tools/tools"
  9. "strconv"
  10. "strings"
  11. "github.com/astaxie/beego/orm"
  12. )
  13. //检测任务模型
  14. type T_data_task_model struct {
  15. Id int `orm:"pk"`
  16. TaskId int // '任务ID' ,
  17. AreaId int // 间隔ID
  18. ModelId int // '模型ID' ,
  19. Cr int // '创建人' ,
  20. Ct string `orm:"-"` // '创建时间' ,
  21. Ur int // '更新人' ,
  22. Ut string `orm:"-"` // '更新时间'
  23. }
  24. //检测任务管理对象
  25. type TaskModelMgr struct {
  26. Model T_data_task_model
  27. DeviceBaseModel
  28. }
  29. var modelDesc2 = "检测任务关联模型"
  30. func init() {
  31. orm.RegisterModel(new(T_data_task_model))
  32. }
  33. //保存任务模型信息
  34. func (c *TaskModelMgr) Save(modelids []string) (err error) {
  35. dblog := new(SystemLog)
  36. dblog.SetUserInfo(c.GetUserInfo())
  37. dblog.Audittype = enum.AuditType_check_task
  38. dblog.Logtype = enum.LogType_Insert
  39. dblog.Eventtype = enum.OptEventType_Bus
  40. dblog.Eventlevel = enum.OptEventLevel_Hight
  41. //获取检测任务原来的模型
  42. oldModels := []string{}
  43. rowset := []orm.Params{}
  44. db := orm.NewOrm()
  45. db.Raw("select model_id from t_data_task_model where task_id=?", c.Model.TaskId).Values(&rowset)
  46. for _, row := range rowset {
  47. oldModels = append(oldModels, tools.IsEmpty(row["model_id"]))
  48. }
  49. c.Model.Cr, _ = strconv.Atoi(c.GetUserId())
  50. m1 := new(SysCheckModelMgr)
  51. m1.SetUserInfo(c.GetUserInfo())
  52. for _, item := range oldModels {
  53. //判断模型有没有删减,如果有删除模型则同步删除对应的模型配置数据
  54. if arrayex.IndexOf(modelids, item) == -1 {
  55. c.Model.ModelId, _ = strconv.Atoi(item)
  56. c.Delete()
  57. }
  58. }
  59. for _, ids := range modelids {
  60. if ids == "" {
  61. continue
  62. }
  63. //判断是否新增了模型
  64. if arrayex.IndexOf(oldModels, ids) == -1 {
  65. logger.Logger.Debug(fmt.Sprintf("正在从模型%s复制新模型", ids))
  66. //将选择的系统模型复制为检测模型
  67. m1.Model.ModelName = fmt.Sprintf("[%d]", c.Model.TaskId) //生成不唯一的模型名称,规则:检测任务id作为复制源模型的名称前缀
  68. tmpid, _ := strconv.Atoi(ids)
  69. m1.Model.IsSys = 2
  70. err, newid := m1.Copy(tmpid)
  71. if err != nil {
  72. logger.Logger.Error(err)
  73. break
  74. }
  75. if newid == 0 {
  76. continue
  77. }
  78. c.Model.ModelId = newid
  79. _, err = db.Insert(&c.Model)
  80. if err != nil {
  81. break
  82. }
  83. }
  84. }
  85. if err != nil {
  86. logger.Logger.Error(err)
  87. dblog.Description = fmt.Sprintf("保存%s信息失败:%s,操作数据:%+v", modelDesc2, err.Error(), c.Model)
  88. dblog.Fail2()
  89. } else {
  90. dblog.Description = fmt.Sprintf("保存%s信息成功,操作数据:%+v", modelDesc2, c.Model)
  91. dblog.Success2()
  92. }
  93. return err
  94. }
  95. func (c *TaskModelMgr) One() (T_data_task_model, error) {
  96. if c.Model.Id == 0 {
  97. return c.Model, errors.New("未指定id")
  98. }
  99. o := orm.NewOrm()
  100. err := o.Read(&c.Model)
  101. if err != nil {
  102. logger.Logger.Error(err)
  103. }
  104. return c.Model, err
  105. }
  106. //根据model中指定的id删除检测任务模型对应关系
  107. func (c *TaskModelMgr) Delete() (err error) {
  108. dblog := new(SystemLog)
  109. dblog.SetUserInfo(c.GetUserInfo())
  110. dblog.Audittype = enum.AuditType_check_task
  111. dblog.Logtype = enum.LogType_Delete
  112. dblog.Eventtype = enum.OptEventType_Bus
  113. dblog.Eventlevel = enum.OptEventLevel_Hight
  114. db := orm.NewOrm()
  115. if c.Model.Id > 0 {
  116. db.Read(&c.Model)
  117. _, err = db.Delete(&c.Model)
  118. }
  119. models := []orm.Params{}
  120. if c.Model.TaskId > 0 {
  121. if c.Model.ModelId > 0 {
  122. _, err = db.Raw("delete from t_data_task_model where task_id=? and model_id=?", c.Model.TaskId, c.Model.ModelId).Exec()
  123. } else {
  124. _, err = db.Raw("select model_id from t_data_task_model where task_id=?", c.Model.TaskId).Values(&models)
  125. _, err = db.Raw("delete from t_data_task_model where task_id=?", c.Model.TaskId).Exec()
  126. }
  127. } else {
  128. if c.Model.ModelId > 0 {
  129. _, err = db.Raw("delete from t_data_task_model where model_id=?", c.Model.ModelId).Exec()
  130. }
  131. }
  132. if err != nil {
  133. logger.Logger.Error(err)
  134. dblog.Description = fmt.Sprintf("删除%s%d失败:%s", modelDesc2, c.Model.TaskId, err.Error())
  135. dblog.Fail2()
  136. } else {
  137. if c.Model.TaskId > 0 && c.Model.ModelId == 0 {
  138. for _, r := range models {
  139. id, _ := strconv.Atoi(tools.IsEmpty(r["model_id"]))
  140. m1 := new(SysCheckModelMgr)
  141. m1.SetUserInfo(c.GetUserInfo())
  142. m1.Model = T_data_model_defualt{Id: id, IsSys: 2}
  143. m1.Delete()
  144. }
  145. } else {
  146. m1 := new(SysCheckModelMgr)
  147. m1.SetUserInfo(c.GetUserInfo())
  148. m1.Model = T_data_model_defualt{Id: c.Model.ModelId, IsSys: 2}
  149. m1.Delete()
  150. }
  151. dblog.Description = fmt.Sprintf("删除%s%d成功", modelDesc2, c.Model.TaskId)
  152. dblog.Success2()
  153. }
  154. return err
  155. }
  156. //根据model中的指定过滤属性条件查询任务列表
  157. func (c *TaskModelMgr) List(pageno, pagesize int) ([]orm.Params, int, error) {
  158. dblog := new(SystemLog)
  159. dblog.SetUserInfo(c.GetUserInfo())
  160. dblog.Audittype = enum.AuditType_check_task
  161. dblog.Logtype = enum.LogType_Query
  162. dblog.Eventtype = enum.OptEventType_Bus
  163. dblog.Eventlevel = enum.OptEventLevel_Low
  164. o := orm.NewOrm()
  165. sqlParamters := []interface{}{}
  166. sql := "select t.*,t1.model_name from t_data_task_model t,t_data_model_defualt t1 where t.model_id=t1.id "
  167. if c.Model.Id > 0 {
  168. sql += " and t.id=?"
  169. sqlParamters = append(sqlParamters, c.Model.Id)
  170. }
  171. if c.Model.TaskId > 0 {
  172. sql += " and t.task_id=?"
  173. sqlParamters = append(sqlParamters, c.Model.TaskId)
  174. }
  175. limit := fmt.Sprintf(" order by t.ct desc limit %d,%d", (pageno-1)*pagesize, pagesize)
  176. r := []orm.Params{}
  177. _, err := o.Raw(sql+limit, sqlParamters).Values(&r)
  178. dblog.Description = fmt.Sprintf("SQL:%s 参数:%+v", sql+limit, sqlParamters)
  179. if err != nil {
  180. logger.Logger.Error(err, dblog.Description)
  181. dblog.Fail2()
  182. return nil, 0, err
  183. }
  184. dblog.Success2()
  185. total := []orm.Params{}
  186. _, err = o.Raw(strings.Replace(sql, "t.*,t1.model_name", "count(1) cnt", 1), sqlParamters).Values(&total)
  187. if err != nil {
  188. logger.Logger.Error(err)
  189. return nil, 0, err
  190. }
  191. totalCnt := 0
  192. if len(total) > 0 {
  193. totalCnt, _ = strconv.Atoi(tools.IsEmpty(total[0]["cnt"]))
  194. }
  195. return r, totalCnt, err
  196. }