report_tpl.go 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  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_report_tpl struct {
  14. Id int `orm:"pk"`
  15. Name string //'模板名称' ,
  16. Memo string //'模板描述' ,
  17. DocId int //'模板文件id' ,
  18. State int // '启用状态;1 启用 2 停用' ,
  19. Cr int // '创建人' ,
  20. Ct string `orm:"-"` // '创建时间' ,
  21. Ur int // '更新人' ,
  22. Ut string `orm:"-"` // '更新时间'
  23. }
  24. //接线方式管理对象
  25. type ReportTplMgr struct {
  26. Model T_data_report_tpl
  27. DeviceBaseModel
  28. }
  29. var reporttpl_modelDesc = "报告模板"
  30. func init() {
  31. orm.RegisterModel(new(T_data_report_tpl))
  32. }
  33. //保存信息
  34. func (c *ReportTplMgr) Save() (err error) {
  35. dblog := new(SystemLog)
  36. dblog.SetUserInfo(c.GetUserInfo())
  37. dblog.Audittype = enum.AuditType_check_report
  38. dblog.Logtype = enum.LogType_Insert
  39. dblog.Eventtype = enum.OptEventType_Bus
  40. dblog.Eventlevel = enum.OptEventLevel_Hight
  41. db := orm.NewOrm()
  42. c.Model.Cr, _ = strconv.Atoi(c.GetUserId())
  43. if c.Model.Id == 0 {
  44. _, err = db.Insert(&c.Model)
  45. } else {
  46. _, err = db.Update(&c.Model)
  47. }
  48. if err != nil {
  49. logger.Logger.Error(err)
  50. dblog.Description = fmt.Sprintf("保存%s信息失败:%s,操作数据:%+v", reporttpl_modelDesc, err.Error(), c.Model)
  51. dblog.Fail2()
  52. } else {
  53. dblog.Description = fmt.Sprintf("保存%s信息成功,操作数据:%+v", reporttpl_modelDesc, c.Model)
  54. dblog.Success2()
  55. }
  56. return err
  57. }
  58. func (c *ReportTplMgr) One() (T_data_report_tpl, error) {
  59. if c.Model.Id == 0 {
  60. return c.Model, errors.New("未指定id")
  61. }
  62. o := orm.NewOrm()
  63. err := o.Read(&c.Model)
  64. if err != nil {
  65. logger.Logger.Error(err)
  66. }
  67. return c.Model, err
  68. }
  69. //根据接线方式中指定的id删除检测任务
  70. func (c *ReportTplMgr) Delete() (err error) {
  71. dblog := new(SystemLog)
  72. dblog.SetUserInfo(c.GetUserInfo())
  73. dblog.Audittype = enum.AuditType_check_report
  74. dblog.Logtype = enum.LogType_Delete
  75. dblog.Eventtype = enum.OptEventType_Bus
  76. dblog.Eventlevel = enum.OptEventLevel_Hight
  77. db := orm.NewOrm()
  78. if c.Model.Id > 0 {
  79. db.Read(&c.Model)
  80. _, err = db.Delete(&c.Model)
  81. }
  82. if err != nil {
  83. logger.Logger.Error(err)
  84. dblog.Description = fmt.Sprintf("删除%s%s失败:%s", reporttpl_modelDesc, c.Model.Name, err.Error())
  85. dblog.Fail2()
  86. } else {
  87. //同步清除关联的模型
  88. lsm := new(LinkStyleModelMgr)
  89. lsm.Model.LinkstyleId = c.Model.Id
  90. lsm.Delete()
  91. dblog.Description = fmt.Sprintf("删除%s%s成功", reporttpl_modelDesc, c.Model.Name)
  92. dblog.Success2()
  93. }
  94. return err
  95. }
  96. //根据接线方式中的指定过滤属性条件查询列表
  97. func (c *ReportTplMgr) List(pageno, pagesize int) ([]orm.Params, int, error) {
  98. dblog := new(SystemLog)
  99. dblog.SetUserInfo(c.GetUserInfo())
  100. dblog.Audittype = enum.AuditType_check_report
  101. dblog.Logtype = enum.LogType_Query
  102. dblog.Eventtype = enum.OptEventType_Bus
  103. dblog.Eventlevel = enum.OptEventLevel_Low
  104. o := orm.NewOrm()
  105. sqlParamters := []interface{}{}
  106. sql := "select t.* from t_data_report_tpl t where 1=1 "
  107. if c.Model.Id > 0 {
  108. sql += " and t.id=?"
  109. sqlParamters = append(sqlParamters, c.Model.Id)
  110. }
  111. if c.Model.State > 0 {
  112. sql += " and t.state=?"
  113. sqlParamters = append(sqlParamters, c.Model.State)
  114. }
  115. if c.Model.Name != "" {
  116. sql += " and t.name like ? "
  117. sqlParamters = append(sqlParamters, "%"+c.Model.Name+"%")
  118. }
  119. limit := fmt.Sprintf(" order by t.id desc limit %d,%d", (pageno-1)*pagesize, pagesize)
  120. r := []orm.Params{}
  121. _, err := o.Raw(sql+limit, sqlParamters).Values(&r)
  122. dblog.Description = fmt.Sprintf("SQL:%s 参数:%+v", sql+limit, sqlParamters)
  123. if err != nil {
  124. logger.Logger.Error(err, dblog.Description)
  125. dblog.Fail2()
  126. return nil, 0, err
  127. }
  128. dblog.Success2()
  129. total := []orm.Params{}
  130. _, err = o.Raw(strings.Replace(sql, "t.*", "count(1) cnt", 1), sqlParamters).Values(&total)
  131. if err != nil {
  132. logger.Logger.Error(err)
  133. return nil, 0, err
  134. }
  135. totalCnt := 0
  136. if len(total) > 0 {
  137. totalCnt, _ = strconv.Atoi(tools.IsEmpty(total[0]["cnt"]))
  138. }
  139. return r, totalCnt, err
  140. }