task.go 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284
  1. package bo
  2. import (
  3. "errors"
  4. "fmt"
  5. "scd_check_tools/logger"
  6. "scd_check_tools/models/enum"
  7. "scd_check_tools/tools"
  8. "strconv"
  9. "strings"
  10. "github.com/astaxie/beego/orm"
  11. )
  12. //检测任务模型
  13. type T_data_task struct {
  14. Id int `orm:"pk"`
  15. Name string // '任务名称' ,
  16. Code string // '任务编号' ,
  17. StationId int // '所属变电站' ,
  18. ScdId int64 // 'SCD文件编号' ,
  19. ReportId int // '报告模板ID' ,
  20. Memo string // '任务说明' ,
  21. State int // '检测状态;0 未检查 1 检测中 2检测结束 3 异常中断' ,
  22. StartTime string // '开始检测时间' ,
  23. EndTime string // '检测结束时间' ,
  24. Cr int // '创建人' ,
  25. Ct string `orm:"-"` // '创建时间' ,
  26. Ur int // '更新人' ,
  27. Ut string `orm:"-"` // '更新时间'
  28. }
  29. //检测任务管理对象
  30. type TaskMgr struct {
  31. Model T_data_task
  32. DeviceBaseModel
  33. }
  34. var modelDesc = "检测任务"
  35. func init() {
  36. orm.RegisterModel(new(T_data_task))
  37. }
  38. //设置指定任务的状态 flag:0 未检查 1 检测中 2检测结束 3 异常中断
  39. func (c *TaskMgr) SetActive(flag int) (err error) {
  40. dblog := new(SystemLog)
  41. dblog.SetUserInfo(c.GetUserInfo())
  42. dblog.Audittype = enum.AuditType_check_task
  43. dblog.Logtype = enum.LogType_Execute
  44. dblog.Eventtype = enum.OptEventType_Bus
  45. dblog.Eventlevel = enum.OptEventLevel_Hight
  46. db := orm.NewOrm()
  47. err = db.Read(&c.Model)
  48. if err != nil {
  49. logger.Logger.Error(err)
  50. return err
  51. }
  52. c.Model.State = flag
  53. if flag == 0 {
  54. c.Model.StartTime = "1970-01-01 00:00:00"
  55. c.Model.EndTime = "1970-01-01 00:00:00"
  56. }
  57. if flag == 1 {
  58. if c.Model.State == 1 {
  59. return errors.New("当前任务正在检测中")
  60. }
  61. c.Model.StartTime = tools.NowTime()
  62. c.Model.EndTime = "1970-01-01 00:00:00"
  63. }
  64. if flag == 2 {
  65. c.Model.EndTime = tools.NowTime()
  66. }
  67. _, err = db.Update(&c.Model)
  68. if err != nil {
  69. logger.Logger.Error(err)
  70. dblog.Description = fmt.Sprintf("更新%s%s状态失败:%s,操作数据:%+v", modelDesc, c.Model.Name, err.Error(), c.Model)
  71. dblog.Fail2()
  72. } else {
  73. dblog.Description = fmt.Sprintf("更新%s%s状态,操作数据:%+v", modelDesc, c.Model.Name, c.Model)
  74. dblog.Success2()
  75. if flag == 1 {
  76. return c.start(c.Model)
  77. }
  78. if flag == 2 {
  79. return c.finish(c.Model)
  80. }
  81. if flag == 3 {
  82. return c.stop(c.Model)
  83. }
  84. }
  85. return err
  86. }
  87. //开始检测
  88. func (c *TaskMgr) start(task T_data_task) error {
  89. scdParse := new(ScdParse)
  90. scdParse.SetUserInfo(c.GetUserInfo())
  91. scdMgr := new(ScdMgr)
  92. scdMgr.SetUserInfo(c.GetUserInfo())
  93. scdInfo, err := scdMgr.One(fmt.Sprintf("%d", task.ScdId))
  94. if err != nil {
  95. return err
  96. }
  97. go func() {
  98. _, err = scdParse.XmlIEDParse(tools.IsEmpty(scdInfo["station_id"]), tools.IsEmpty(scdInfo["scd_name"]), tools.IsEmpty(scdInfo["path"]))
  99. if err == nil {
  100. scdParse.XmlCheckParse(task.ScdId)
  101. }
  102. }()
  103. return err
  104. }
  105. //取消/终止检测
  106. func (c *TaskMgr) stop(task T_data_task) error {
  107. return nil
  108. }
  109. //完成检测
  110. func (c *TaskMgr) finish(task T_data_task) error {
  111. return nil
  112. }
  113. //保存任务信息
  114. func (c *TaskMgr) Save() (id int, err error) {
  115. dblog := new(SystemLog)
  116. dblog.SetUserInfo(c.GetUserInfo())
  117. dblog.Audittype = enum.AuditType_check_task
  118. dblog.Logtype = enum.LogType_Insert
  119. dblog.Eventtype = enum.OptEventType_Bus
  120. dblog.Eventlevel = enum.OptEventLevel_Hight
  121. db := orm.NewOrm()
  122. if c.Model.Id == 0 {
  123. c.Model.StartTime = "1970-01-01 00:00:00"
  124. c.Model.EndTime = "1970-01-01 00:00:00"
  125. c.Model.State = 0
  126. c.Model.Cr, _ = strconv.Atoi(c.GetUserId())
  127. id64 := int64(0)
  128. id64, err = db.Insert(&c.Model)
  129. id = int(id64)
  130. } else {
  131. id = c.Model.Id
  132. oldinfo, _ := c.One()
  133. if oldinfo.State == 1 {
  134. return 0, errors.New("任务正在检测中,不允许编辑")
  135. }
  136. if oldinfo.State == 2 {
  137. return 0, errors.New("任务已检测完成,不允许编辑")
  138. }
  139. c.Model.StartTime = oldinfo.StartTime
  140. c.Model.EndTime = oldinfo.EndTime
  141. c.Model.State = oldinfo.State
  142. c.Model.Ur, _ = strconv.Atoi(c.GetUserId())
  143. _, err = db.Update(&c.Model)
  144. }
  145. if err != nil {
  146. logger.Logger.Error(err)
  147. dblog.Description = fmt.Sprintf("保存%s信息失败:%s,操作数据:%+v", modelDesc, err.Error(), c.Model)
  148. dblog.Fail2()
  149. } else {
  150. dblog.Description = fmt.Sprintf("保存%s信息成功,操作数据:%+v", modelDesc, c.Model)
  151. dblog.Success2()
  152. }
  153. return id, err
  154. }
  155. func (c *TaskMgr) One() (T_data_task, error) {
  156. if c.Model.Id == 0 {
  157. return c.Model, errors.New("未指定id")
  158. }
  159. o := orm.NewOrm()
  160. err := o.Read(&c.Model)
  161. if err != nil {
  162. logger.Logger.Error(err)
  163. }
  164. return c.Model, err
  165. }
  166. //根据model中指定的id删除检测任务
  167. func (c *TaskMgr) Delete() (err error) {
  168. dblog := new(SystemLog)
  169. u := c.GetUserInfo()
  170. dblog.SetUserInfo(u)
  171. dblog.Audittype = enum.AuditType_check_task
  172. dblog.Logtype = enum.LogType_Delete
  173. dblog.Eventtype = enum.OptEventType_Bus
  174. dblog.Eventlevel = enum.OptEventLevel_Hight
  175. db := orm.NewOrm()
  176. if c.Model.Id == 0 {
  177. return errors.New("无效的ID")
  178. } else {
  179. db.Read(&c.Model)
  180. if c.Model.State == 1 {
  181. return errors.New("任务正在检测中,不允许删除")
  182. }
  183. _, err = db.Delete(&c.Model)
  184. }
  185. if err != nil {
  186. logger.Logger.Error(err)
  187. dblog.Description = fmt.Sprintf("删除%s%s失败:%s", modelDesc, c.Model.Name, err.Error())
  188. dblog.Fail2()
  189. } else {
  190. dblog.Description = fmt.Sprintf("删除%s%s成功", modelDesc, c.Model.Name)
  191. dblog.Success2()
  192. //同步删除关联数据
  193. scdmgr := new(ScdMgr)
  194. scdmgr.SetUserInfo(u)
  195. scdmgr.DeleteScd(strconv.FormatInt(c.Model.ScdId, 10), true)
  196. //删除关联模型
  197. m1 := new(TaskModelMgr)
  198. m1.SetUserInfo(u)
  199. m1.Model = T_data_task_model{TaskId: c.Model.Id}
  200. m1.Delete()
  201. //删除报告关联数据
  202. r1 := new(TaskReportMgr)
  203. r1.SetUserInfo(u)
  204. r1.Model = T_data_task_report{TaskId: c.Model.Id}
  205. r1.Delete()
  206. }
  207. return err
  208. }
  209. //根据model中的指定过滤属性条件查询任务列表
  210. func (c *TaskMgr) List(pageno, pagesize int) ([]orm.Params, int, error) {
  211. dblog := new(SystemLog)
  212. dblog.SetUserInfo(c.GetUserInfo())
  213. dblog.Audittype = enum.AuditType_check_task
  214. dblog.Logtype = enum.LogType_Query
  215. dblog.Eventtype = enum.OptEventType_Bus
  216. dblog.Eventlevel = enum.OptEventLevel_Low
  217. o := orm.NewOrm()
  218. sqlParamters := []interface{}{}
  219. sql := "select t.*,u.name username,s.scd_name,ts.area_name station_name,c1.id voltage_level,c1.name voltage_name from t_data_task t left join t_scd_scl s on t.scd_id=s.id left join t_data_user u on t.cr=u.id left join t_data_area ts on t.station_id=ts.ID left join global_const_code c1 on ts.AREA_LEVEL=c1.id and c1.parentcode='voltage_level' where 1=1 "
  220. if c.Model.Id > 0 {
  221. sql += " and t.id=?"
  222. sqlParamters = append(sqlParamters, c.Model.Id)
  223. }
  224. if c.Model.StationId > 0 {
  225. sql += " and t.station_id=?"
  226. sqlParamters = append(sqlParamters, c.Model.StationId)
  227. }
  228. if c.Model.Name != "" {
  229. sql += " and t.name like ?"
  230. sqlParamters = append(sqlParamters, "%"+c.Model.Name+"%")
  231. }
  232. if c.Model.ScdId > 0 {
  233. sql += " and t.scd_id=?"
  234. sqlParamters = append(sqlParamters, c.Model.ScdId)
  235. }
  236. if c.Model.State >= 0 {
  237. sql += " and t.state=?"
  238. sqlParamters = append(sqlParamters, c.Model.State)
  239. }
  240. if c.Model.StartTime != "" {
  241. sql += " and t.start_time>=?"
  242. sqlParamters = append(sqlParamters, c.Model.StartTime+" 00:00:00")
  243. }
  244. if c.Model.EndTime != "" {
  245. sql += " and t.end_time<=?"
  246. sqlParamters = append(sqlParamters, c.Model.EndTime+" 23:59:59")
  247. }
  248. limit := fmt.Sprintf(" order by t.ct desc limit %d,%d", (pageno-1)*pagesize, pagesize)
  249. r := []orm.Params{}
  250. _, err := o.Raw(sql+limit, sqlParamters).Values(&r)
  251. dblog.Description = fmt.Sprintf("SQL:%s 参数:%+v", sql+limit, sqlParamters)
  252. if err != nil {
  253. logger.Logger.Error(err, dblog.Description)
  254. dblog.Fail2()
  255. return nil, 0, err
  256. }
  257. dblog.Success2()
  258. total := []orm.Params{}
  259. _, err = o.Raw(strings.Replace(sql, "t.*,u.name username,s.scd_name,ts.area_name station_name", "count(1) cnt", 1), sqlParamters).Values(&total)
  260. if err != nil {
  261. logger.Logger.Error(err)
  262. return nil, 0, err
  263. }
  264. totalCnt := 0
  265. if len(total) > 0 {
  266. totalCnt, _ = strconv.Atoi(tools.IsEmpty(total[0]["cnt"]))
  267. }
  268. return r, totalCnt, err
  269. }