123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284 |
- package bo
- import (
- "errors"
- "fmt"
- "scd_check_tools/logger"
- "scd_check_tools/models/enum"
- "scd_check_tools/tools"
- "strconv"
- "strings"
- "github.com/astaxie/beego/orm"
- )
- //检测任务模型
- type T_data_task struct {
- Id int `orm:"pk"`
- Name string // '任务名称' ,
- Code string // '任务编号' ,
- StationId int // '所属变电站' ,
- ScdId int64 // 'SCD文件编号' ,
- ReportId int // '报告模板ID' ,
- Memo string // '任务说明' ,
- State int // '检测状态;0 未检查 1 检测中 2检测结束 3 异常中断' ,
- StartTime string // '开始检测时间' ,
- EndTime string // '检测结束时间' ,
- Cr int // '创建人' ,
- Ct string `orm:"-"` // '创建时间' ,
- Ur int // '更新人' ,
- Ut string `orm:"-"` // '更新时间'
- }
- //检测任务管理对象
- type TaskMgr struct {
- Model T_data_task
- DeviceBaseModel
- }
- var modelDesc = "检测任务"
- func init() {
- orm.RegisterModel(new(T_data_task))
- }
- //设置指定任务的状态 flag:0 未检查 1 检测中 2检测结束 3 异常中断
- func (c *TaskMgr) SetActive(flag int) (err error) {
- dblog := new(SystemLog)
- dblog.SetUserInfo(c.GetUserInfo())
- dblog.Audittype = enum.AuditType_check_task
- dblog.Logtype = enum.LogType_Execute
- dblog.Eventtype = enum.OptEventType_Bus
- dblog.Eventlevel = enum.OptEventLevel_Hight
- db := orm.NewOrm()
- err = db.Read(&c.Model)
- if err != nil {
- logger.Logger.Error(err)
- return err
- }
- c.Model.State = flag
- if flag == 0 {
- c.Model.StartTime = "1970-01-01 00:00:00"
- c.Model.EndTime = "1970-01-01 00:00:00"
- }
- if flag == 1 {
- if c.Model.State == 1 {
- return errors.New("当前任务正在检测中")
- }
- c.Model.StartTime = tools.NowTime()
- c.Model.EndTime = "1970-01-01 00:00:00"
- }
- if flag == 2 {
- c.Model.EndTime = tools.NowTime()
- }
- _, err = db.Update(&c.Model)
- if err != nil {
- logger.Logger.Error(err)
- dblog.Description = fmt.Sprintf("更新%s%s状态失败:%s,操作数据:%+v", modelDesc, c.Model.Name, err.Error(), c.Model)
- dblog.Fail2()
- } else {
- dblog.Description = fmt.Sprintf("更新%s%s状态,操作数据:%+v", modelDesc, c.Model.Name, c.Model)
- dblog.Success2()
- if flag == 1 {
- return c.start(c.Model)
- }
- if flag == 2 {
- return c.finish(c.Model)
- }
- if flag == 3 {
- return c.stop(c.Model)
- }
- }
- return err
- }
- //开始检测
- func (c *TaskMgr) start(task T_data_task) error {
- scdParse := new(ScdParse)
- scdParse.SetUserInfo(c.GetUserInfo())
- scdMgr := new(ScdMgr)
- scdMgr.SetUserInfo(c.GetUserInfo())
- scdInfo, err := scdMgr.One(fmt.Sprintf("%d", task.ScdId))
- if err != nil {
- return err
- }
- go func() {
- _, err = scdParse.XmlIEDParse(tools.IsEmpty(scdInfo["station_id"]), tools.IsEmpty(scdInfo["scd_name"]), tools.IsEmpty(scdInfo["path"]))
- if err == nil {
- scdParse.XmlCheckParse(task.ScdId)
- }
- }()
- return err
- }
- //取消/终止检测
- func (c *TaskMgr) stop(task T_data_task) error {
- return nil
- }
- //完成检测
- func (c *TaskMgr) finish(task T_data_task) error {
- return nil
- }
- //保存任务信息
- func (c *TaskMgr) Save() (id int, err error) {
- dblog := new(SystemLog)
- dblog.SetUserInfo(c.GetUserInfo())
- dblog.Audittype = enum.AuditType_check_task
- dblog.Logtype = enum.LogType_Insert
- dblog.Eventtype = enum.OptEventType_Bus
- dblog.Eventlevel = enum.OptEventLevel_Hight
- db := orm.NewOrm()
- if c.Model.Id == 0 {
- c.Model.StartTime = "1970-01-01 00:00:00"
- c.Model.EndTime = "1970-01-01 00:00:00"
- c.Model.State = 0
- c.Model.Cr, _ = strconv.Atoi(c.GetUserId())
- id64 := int64(0)
- id64, err = db.Insert(&c.Model)
- id = int(id64)
- } else {
- id = c.Model.Id
- oldinfo, _ := c.One()
- if oldinfo.State == 1 {
- return 0, errors.New("任务正在检测中,不允许编辑")
- }
- if oldinfo.State == 2 {
- return 0, errors.New("任务已检测完成,不允许编辑")
- }
- c.Model.StartTime = oldinfo.StartTime
- c.Model.EndTime = oldinfo.EndTime
- c.Model.State = oldinfo.State
- c.Model.Ur, _ = strconv.Atoi(c.GetUserId())
- _, err = db.Update(&c.Model)
- }
- if err != nil {
- logger.Logger.Error(err)
- dblog.Description = fmt.Sprintf("保存%s信息失败:%s,操作数据:%+v", modelDesc, err.Error(), c.Model)
- dblog.Fail2()
- } else {
- dblog.Description = fmt.Sprintf("保存%s信息成功,操作数据:%+v", modelDesc, c.Model)
- dblog.Success2()
- }
- return id, err
- }
- func (c *TaskMgr) One() (T_data_task, error) {
- if c.Model.Id == 0 {
- return c.Model, errors.New("未指定id")
- }
- o := orm.NewOrm()
- err := o.Read(&c.Model)
- if err != nil {
- logger.Logger.Error(err)
- }
- return c.Model, err
- }
- //根据model中指定的id删除检测任务
- func (c *TaskMgr) Delete() (err error) {
- dblog := new(SystemLog)
- u := c.GetUserInfo()
- dblog.SetUserInfo(u)
- dblog.Audittype = enum.AuditType_check_task
- dblog.Logtype = enum.LogType_Delete
- dblog.Eventtype = enum.OptEventType_Bus
- dblog.Eventlevel = enum.OptEventLevel_Hight
- db := orm.NewOrm()
- if c.Model.Id == 0 {
- return errors.New("无效的ID")
- } else {
- db.Read(&c.Model)
- if c.Model.State == 1 {
- return errors.New("任务正在检测中,不允许删除")
- }
- _, err = db.Delete(&c.Model)
- }
- if err != nil {
- logger.Logger.Error(err)
- dblog.Description = fmt.Sprintf("删除%s%s失败:%s", modelDesc, c.Model.Name, err.Error())
- dblog.Fail2()
- } else {
- dblog.Description = fmt.Sprintf("删除%s%s成功", modelDesc, c.Model.Name)
- dblog.Success2()
- //同步删除关联数据
- scdmgr := new(ScdMgr)
- scdmgr.SetUserInfo(u)
- scdmgr.DeleteScd(strconv.FormatInt(c.Model.ScdId, 10), true)
- //删除关联模型
- m1 := new(TaskModelMgr)
- m1.SetUserInfo(u)
- m1.Model = T_data_task_model{TaskId: c.Model.Id}
- m1.Delete()
- //删除报告关联数据
- r1 := new(TaskReportMgr)
- r1.SetUserInfo(u)
- r1.Model = T_data_task_report{TaskId: c.Model.Id}
- r1.Delete()
- }
- return err
- }
- //根据model中的指定过滤属性条件查询任务列表
- func (c *TaskMgr) List(pageno, pagesize int) ([]orm.Params, int, error) {
- dblog := new(SystemLog)
- dblog.SetUserInfo(c.GetUserInfo())
- dblog.Audittype = enum.AuditType_check_task
- dblog.Logtype = enum.LogType_Query
- dblog.Eventtype = enum.OptEventType_Bus
- dblog.Eventlevel = enum.OptEventLevel_Low
- o := orm.NewOrm()
- sqlParamters := []interface{}{}
- 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 "
- if c.Model.Id > 0 {
- sql += " and t.id=?"
- sqlParamters = append(sqlParamters, c.Model.Id)
- }
- if c.Model.StationId > 0 {
- sql += " and t.station_id=?"
- sqlParamters = append(sqlParamters, c.Model.StationId)
- }
- if c.Model.Name != "" {
- sql += " and t.name like ?"
- sqlParamters = append(sqlParamters, "%"+c.Model.Name+"%")
- }
- if c.Model.ScdId > 0 {
- sql += " and t.scd_id=?"
- sqlParamters = append(sqlParamters, c.Model.ScdId)
- }
- if c.Model.State >= 0 {
- sql += " and t.state=?"
- sqlParamters = append(sqlParamters, c.Model.State)
- }
- if c.Model.StartTime != "" {
- sql += " and t.start_time>=?"
- sqlParamters = append(sqlParamters, c.Model.StartTime+" 00:00:00")
- }
- if c.Model.EndTime != "" {
- sql += " and t.end_time<=?"
- sqlParamters = append(sqlParamters, c.Model.EndTime+" 23:59:59")
- }
- limit := fmt.Sprintf(" order by t.ct desc limit %d,%d", (pageno-1)*pagesize, pagesize)
- r := []orm.Params{}
- _, err := o.Raw(sql+limit, sqlParamters).Values(&r)
- dblog.Description = fmt.Sprintf("SQL:%s 参数:%+v", sql+limit, sqlParamters)
- if err != nil {
- logger.Logger.Error(err, dblog.Description)
- dblog.Fail2()
- return nil, 0, err
- }
- dblog.Success2()
- total := []orm.Params{}
- _, 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)
- if err != nil {
- logger.Logger.Error(err)
- return nil, 0, err
- }
- totalCnt := 0
- if len(total) > 0 {
- totalCnt, _ = strconv.Atoi(tools.IsEmpty(total[0]["cnt"]))
- }
- return r, totalCnt, err
- }
|