task.go 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356
  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. "sync"
  11. "github.com/astaxie/beego/orm"
  12. )
  13. //检测任务模型
  14. type T_data_task struct {
  15. Id int `orm:"pk"`
  16. Name string // '任务名称' ,
  17. Code string // '任务编号' ,
  18. StationId int // '所属变电站' ,
  19. ScdId int64 // 'SCD文件编号' ,
  20. ReportId int // '报告模板ID' ,
  21. Memo string // '任务说明' ,
  22. State int // '检测状态;0 未检查 1 检测中 2检测结束 3 异常中断' ,
  23. StartTime string // '开始检测时间' ,
  24. EndTime string // '检测结束时间' ,
  25. Cr int // '创建人' ,
  26. Ct string `orm:"-"` // '创建时间' ,
  27. Ur int // '更新人' ,
  28. Ut string `orm:"-"` // '更新时间'
  29. }
  30. //检测任务管理对象
  31. type TaskMgr struct {
  32. Model T_data_task
  33. DeviceBaseModel
  34. }
  35. var TaskSCD = sync.Map{}
  36. var modelDesc = "检测任务"
  37. func init() {
  38. orm.RegisterModel(new(T_data_task))
  39. }
  40. //设置指定任务的状态 flag:0 未检查 1 检测中 2检测结束 3 异常中断
  41. func (c *TaskMgr) SetActive(flag int) (err error) {
  42. dblog := new(SystemLog)
  43. dblog.SetUserInfo(c.GetUserInfo())
  44. dblog.Audittype = enum.AuditType_check_task
  45. dblog.Logtype = enum.LogType_Execute
  46. dblog.Eventtype = enum.OptEventType_Bus
  47. dblog.Eventlevel = enum.OptEventLevel_Hight
  48. db := orm.NewOrm()
  49. err = db.Read(&c.Model)
  50. if err != nil {
  51. logger.Logger.Error(err)
  52. return err
  53. }
  54. c.Model.State = flag
  55. if flag == 0 {
  56. c.Model.StartTime = "1970-01-01 00:00:00"
  57. c.Model.EndTime = "1970-01-01 00:00:00"
  58. }
  59. if flag == 1 {
  60. if c.Model.State == 1 {
  61. return errors.New("当前任务正在检测中")
  62. }
  63. c.Model.StartTime = tools.NowTime()
  64. c.Model.EndTime = "1970-01-01 00:00:00"
  65. }
  66. if flag == 2 {
  67. c.Model.EndTime = tools.NowTime()
  68. }
  69. _, err = db.Update(&c.Model)
  70. if err != nil {
  71. logger.Logger.Error(err)
  72. dblog.Description = fmt.Sprintf("更新%s%s状态失败:%s,操作数据:%+v", modelDesc, c.Model.Name, err.Error(), c.Model)
  73. dblog.Fail2()
  74. } else {
  75. dblog.Description = fmt.Sprintf("更新%s%s状态,操作数据:%+v", modelDesc, c.Model.Name, c.Model)
  76. dblog.Success2()
  77. if flag == 1 {
  78. return c.start(c.Model)
  79. }
  80. if flag == 2 {
  81. return c.finish(c.Model)
  82. }
  83. if flag == 3 {
  84. return c.stop(c.Model)
  85. }
  86. }
  87. return err
  88. }
  89. //开始检测
  90. func (c *TaskMgr) start(task T_data_task) error {
  91. scdParse := new(ScdParse)
  92. scdParse.SetUserInfo(c.GetUserInfo())
  93. scdMgr := new(ScdMgr)
  94. scdMgr.SetUserInfo(c.GetUserInfo())
  95. scdInfo, err := scdMgr.One(fmt.Sprintf("%d", task.ScdId))
  96. if err != nil {
  97. return err
  98. }
  99. c.Model.Id = task.Id
  100. _, cnt, _ := c.GetModels()
  101. if cnt == 0 {
  102. return errors.New("该检测任务还未配置检测模型")
  103. }
  104. TaskSCD.Store(task.ScdId, task)
  105. db := orm.NewOrm()
  106. //清除原步骤及状态
  107. db.Raw("delete from t_data_task_check_step where task_id=?", task.Id).Exec()
  108. //生成新的步骤
  109. db.Raw("insert into t_data_task_check_step(task_id,task_step_id,state) select ?,id,0 from global_const_code where parentcode='CHECK_STEP' order by id", task.Id).Exec()
  110. go func() {
  111. _, err = scdParse.XmlIEDParse(tools.IsEmpty(scdInfo["station_id"]), tools.IsEmpty(scdInfo["scd_name"]), tools.IsEmpty(scdInfo["path"]))
  112. if err == nil {
  113. scdParse.XmlCheckParse(task.ScdId)
  114. //模型分析
  115. c.SetStep(tools.IsEmpty(task.ScdId), enum.TaskStep_SCD_model_parse.Code(), 1)
  116. checkAreaMgr := new(CheckAreaMgr)
  117. checkAreaMgr.ScdId = task.ScdId
  118. //checkAreaMgr.ParseModelArea()
  119. c.SetStep(tools.IsEmpty(task.ScdId), enum.TaskStep_SCD_model_parse.Code(), 2)
  120. }
  121. }()
  122. return err
  123. }
  124. //取消/终止检测
  125. func (c *TaskMgr) stop(task T_data_task) error {
  126. TaskSCD.Delete(task.ScdId)
  127. return nil
  128. }
  129. //完成检测
  130. func (c *TaskMgr) finish(task T_data_task) error {
  131. TaskSCD.Delete(task.ScdId)
  132. return nil
  133. }
  134. //更新检测步骤状态
  135. func (c *TaskMgr) SetStep(scdid string, stepcode string, state int, msg ...string) {
  136. db := orm.NewOrm()
  137. scdidint64, _ := strconv.ParseInt(scdid, 10, 64)
  138. taskid, has := TaskSCD.Load(scdidint64)
  139. if !has {
  140. return
  141. }
  142. errormsg := ""
  143. if len(msg) > 0 {
  144. errormsg = msg[0]
  145. }
  146. t1 := "ct" //步骤开始时间字段
  147. if state > 1 {
  148. t1 = "ut" //步骤结束时间字段
  149. }
  150. db.Raw("update t_data_task_check_step set state=?,state_msg=?,"+t1+"=now() where task_id=? and task_step_id=(select id from global_const_code where parentcode='CHECK_STEP' and code=?)", state, errormsg, taskid, stepcode).Exec()
  151. }
  152. //保存任务信息
  153. func (c *TaskMgr) Save() (id int, err error) {
  154. dblog := new(SystemLog)
  155. dblog.SetUserInfo(c.GetUserInfo())
  156. dblog.Audittype = enum.AuditType_check_task
  157. dblog.Logtype = enum.LogType_Insert
  158. dblog.Eventtype = enum.OptEventType_Bus
  159. dblog.Eventlevel = enum.OptEventLevel_Hight
  160. db := orm.NewOrm()
  161. if c.Model.Id == 0 {
  162. c.Model.StartTime = "1970-01-01 00:00:00"
  163. c.Model.EndTime = "1970-01-01 00:00:00"
  164. c.Model.State = 0
  165. c.Model.Cr, _ = strconv.Atoi(c.GetUserId())
  166. id64 := int64(0)
  167. id64, err = db.Insert(&c.Model)
  168. id = int(id64)
  169. } else {
  170. id = c.Model.Id
  171. oldinfo, _ := c.One()
  172. if oldinfo.State == 1 {
  173. return 0, errors.New("任务正在检测中,不允许编辑")
  174. }
  175. if oldinfo.State == 2 {
  176. return 0, errors.New("任务已检测完成,不允许编辑")
  177. }
  178. c.Model.StartTime = oldinfo.StartTime
  179. c.Model.EndTime = oldinfo.EndTime
  180. c.Model.State = oldinfo.State
  181. c.Model.Ur, _ = strconv.Atoi(c.GetUserId())
  182. _, err = db.Update(&c.Model)
  183. }
  184. if err != nil {
  185. logger.Logger.Error(err)
  186. dblog.Description = fmt.Sprintf("保存%s信息失败:%s,操作数据:%+v", modelDesc, err.Error(), c.Model)
  187. dblog.Fail2()
  188. } else {
  189. dblog.Description = fmt.Sprintf("保存%s信息成功,操作数据:%+v", modelDesc, c.Model)
  190. dblog.Success2()
  191. }
  192. return id, err
  193. }
  194. func (c *TaskMgr) One() (T_data_task, error) {
  195. if c.Model.Id == 0 {
  196. return c.Model, errors.New("未指定id")
  197. }
  198. o := orm.NewOrm()
  199. tmp := T_data_task{Id: c.Model.Id}
  200. err := o.Read(&tmp)
  201. if err != nil {
  202. logger.Logger.Error(err)
  203. }
  204. return tmp, err
  205. }
  206. //根据model中指定的id删除检测任务
  207. func (c *TaskMgr) Delete() (err error) {
  208. dblog := new(SystemLog)
  209. u := c.GetUserInfo()
  210. dblog.SetUserInfo(u)
  211. dblog.Audittype = enum.AuditType_check_task
  212. dblog.Logtype = enum.LogType_Delete
  213. dblog.Eventtype = enum.OptEventType_Bus
  214. dblog.Eventlevel = enum.OptEventLevel_Hight
  215. db := orm.NewOrm()
  216. if c.Model.Id == 0 {
  217. return errors.New("无效的ID")
  218. } else {
  219. db.Read(&c.Model)
  220. if c.Model.State == 1 {
  221. return errors.New("任务正在检测中,不允许删除")
  222. }
  223. _, err = db.Delete(&c.Model)
  224. }
  225. if err != nil {
  226. logger.Logger.Error(err)
  227. dblog.Description = fmt.Sprintf("删除%s%s失败:%s", modelDesc, c.Model.Name, err.Error())
  228. dblog.Fail2()
  229. } else {
  230. TaskSCD.Delete(c.Model.ScdId)
  231. dblog.Description = fmt.Sprintf("删除%s%s成功", modelDesc, c.Model.Name)
  232. dblog.Success2()
  233. //同步删除关联数据
  234. db.Raw("delete from t_data_task_check_step where task_id=?", c.Model.Id).Exec()
  235. scdmgr := new(ScdMgr)
  236. scdmgr.SetUserInfo(u)
  237. scdmgr.DeleteScd(strconv.FormatInt(c.Model.ScdId, 10), true)
  238. //删除关联模型
  239. m1 := new(TaskModelMgr)
  240. m1.SetUserInfo(u)
  241. m1.Model = T_data_task_model{TaskId: c.Model.Id}
  242. m1.Delete()
  243. //删除报告关联数据
  244. r1 := new(TaskReportMgr)
  245. r1.SetUserInfo(u)
  246. r1.Model = T_data_task_report{TaskId: c.Model.Id}
  247. r1.Delete()
  248. }
  249. return err
  250. }
  251. //根据model中的指定过滤属性条件查询任务列表
  252. func (c *TaskMgr) List(pageno, pagesize int) ([]orm.Params, int, error) {
  253. dblog := new(SystemLog)
  254. dblog.SetUserInfo(c.GetUserInfo())
  255. dblog.Audittype = enum.AuditType_check_task
  256. dblog.Logtype = enum.LogType_Query
  257. dblog.Eventtype = enum.OptEventType_Bus
  258. dblog.Eventlevel = enum.OptEventLevel_Low
  259. o := orm.NewOrm()
  260. sqlParamters := []interface{}{}
  261. 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 "
  262. if c.Model.Id > 0 {
  263. sql += " and t.id=?"
  264. sqlParamters = append(sqlParamters, c.Model.Id)
  265. }
  266. if c.Model.StationId > 0 {
  267. sql += " and t.station_id=?"
  268. sqlParamters = append(sqlParamters, c.Model.StationId)
  269. }
  270. if c.Model.Name != "" {
  271. sql += " and t.name like ?"
  272. sqlParamters = append(sqlParamters, "%"+c.Model.Name+"%")
  273. }
  274. if c.Model.ScdId > 0 {
  275. sql += " and t.scd_id=?"
  276. sqlParamters = append(sqlParamters, c.Model.ScdId)
  277. }
  278. if c.Model.State >= 0 {
  279. sql += " and t.state=?"
  280. sqlParamters = append(sqlParamters, c.Model.State)
  281. }
  282. if c.Model.StartTime != "" {
  283. sql += " and t.start_time>=?"
  284. sqlParamters = append(sqlParamters, c.Model.StartTime+" 00:00:00")
  285. }
  286. if c.Model.EndTime != "" {
  287. sql += " and t.end_time<=?"
  288. sqlParamters = append(sqlParamters, c.Model.EndTime+" 23:59:59")
  289. }
  290. limit := fmt.Sprintf(" order by t.ct desc limit %d,%d", (pageno-1)*pagesize, pagesize)
  291. r := []orm.Params{}
  292. _, err := o.Raw(sql+limit, sqlParamters).Values(&r)
  293. dblog.Description = fmt.Sprintf("SQL:%s 参数:%+v", sql+limit, sqlParamters)
  294. if err != nil {
  295. logger.Logger.Error(err, dblog.Description)
  296. dblog.Fail2()
  297. return nil, 0, err
  298. }
  299. dblog.Success2()
  300. total := []orm.Params{}
  301. _, 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)
  302. if err != nil {
  303. logger.Logger.Error(err)
  304. return nil, 0, err
  305. }
  306. totalCnt := 0
  307. if len(total) > 0 {
  308. totalCnt, _ = strconv.Atoi(tools.IsEmpty(total[0]["cnt"]))
  309. }
  310. return r, totalCnt, err
  311. }
  312. //获取指定任务的已选择模型
  313. func (c *TaskMgr) GetModels() ([]orm.Params, int, error) {
  314. if c.Model.Id == 0 {
  315. return nil, 0, errors.New("任务ID不能为空")
  316. }
  317. db := orm.NewOrm()
  318. rowset := []orm.Params{}
  319. _, err := db.Raw("select t.*,t1.model_name,t1.vol_id,t1.line_link_style from t_data_task_model t,t_data_model_defualt t1 where t.model_id=t1.id and t.task_id=?", c.Model.Id).Values(&rowset)
  320. if err != nil {
  321. return rowset, 0, err
  322. }
  323. return rowset, len(rowset), nil
  324. }
  325. //根据SCD ID获取指定任务的已选择模型
  326. func (c *TaskMgr) GetModelsByScdID(scdid int64) ([]orm.Params, int, error) {
  327. if scdid == 0 {
  328. return nil, 0, errors.New("SCD ID不能为空")
  329. }
  330. db := orm.NewOrm()
  331. rowset := []orm.Params{}
  332. _, err := db.Raw("select t.*,t1.model_name,t1.vol_id,t1.line_link_style from t_data_task a, t_data_task_model t,t_data_model_defualt t1 where a.id=t.task_id and t.model_id=t1.id and a.scd_id=?", scdid).Values(&rowset)
  333. if err != nil {
  334. return rowset, 0, err
  335. }
  336. return rowset, len(rowset), nil
  337. }