notice.go 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. package bo
  2. import (
  3. "scd_check_tools/logger"
  4. "scd_check_tools/models/enum"
  5. "scd_check_tools/mqtt"
  6. "scd_check_tools/tools"
  7. "encoding/json"
  8. "errors"
  9. "fmt"
  10. "log"
  11. "strconv"
  12. "strings"
  13. "github.com/astaxie/beego/orm"
  14. )
  15. //通知提醒模型
  16. type T_base_notice struct {
  17. Id int `orm:"pk"`
  18. StationId int //INT NOT NULL COMMENT '所属站' ,
  19. Caption string
  20. NoticeType int //INT NOT NULL DEFAULT 0 COMMENT '通知分类' ,
  21. SenderName string //VARCHAR(20) COMMENT '发送者名称' ,
  22. SenderTime string //DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '发送时间' ,
  23. Content string //text(255) NOT NULL COMMENT '正文内容' ,
  24. RevId int //INT NOT NULL COMMENT '通知对象ID' ,
  25. ReadFlag int //INT NOT NULL COMMENT '已读标记' ,
  26. ReadTime string //DATETIME COMMENT '读取时间' ,
  27. Cr string
  28. Ct string
  29. }
  30. //提醒类型:消息提醒
  31. var NoticeType_Message = 200
  32. //提醒类型:通知提醒
  33. var NoticeType_Notice = 100
  34. //通知提醒管理对象
  35. type NoticeMgr struct {
  36. Model T_base_notice
  37. DeviceBaseModel
  38. }
  39. func init() {
  40. orm.RegisterModel(new(T_base_notice))
  41. }
  42. //发送流程流转通知
  43. func SendFlowNotice(curuser map[string]interface{}, station_id int, nextFlowNodeId int32, desc ...string) error {
  44. //获取当前节点的处理人员
  45. db := orm.NewOrm()
  46. lst := []orm.Params{}
  47. _, err := db.Raw("select t.node_name,t.node_type,t1.staff_id,t2.flow_name from t_sys_flow_node t, t_sys_flow_node_staff_ref t1,t_sys_flow t2 where t.id=t1.node_id and t.flow_id=t2.id and t1.station_id=? and t1.node_id=?", station_id, nextFlowNodeId).Values(&lst)
  48. if err != nil {
  49. log.Println(err)
  50. }
  51. for _, row := range lst {
  52. uid, _ := strconv.Atoi(tools.IsEmpty(row["staff_id"]))
  53. if SendNotice(curuser, int(station_id), NoticeType_Notice, fmt.Sprintf("有新的SCD文件任务【%s】需要您%s。", row["flow_name"], row["node_name"]), "", int32(uid)) != nil {
  54. return err
  55. }
  56. }
  57. return err
  58. }
  59. func SendNotice(curuser map[string]interface{}, station_id, noticetype int, caption, txt string, touser int32) error {
  60. dblog := new(SystemLog)
  61. dblog.SetUserInfo(map[string]interface{}{"name": "", "ip": "127.0.0.1"})
  62. dblog.Audittype = enum.AuditType_Notice
  63. dblog.Logtype = enum.LogType_Insert
  64. dblog.Eventtype = enum.OptEventType_System
  65. dblog.Eventlevel = enum.OptEventLevel_Mid
  66. obj := new(NoticeMgr)
  67. obj.Model = T_base_notice{}
  68. obj.Model.Caption = caption
  69. obj.Model.Content = txt
  70. obj.Model.RevId = int(touser)
  71. obj.Model.SenderTime = tools.NowTime()
  72. obj.Model.SenderName = tools.IsEmpty(curuser["name"])
  73. obj.Model.StationId = int(station_id)
  74. obj.Model.NoticeType = noticetype
  75. obj.Model.ReadTime = "1970-01-01 00:00:00"
  76. obj.Model.ReadFlag = 0
  77. obj.Model.Cr = tools.IsEmpty(curuser["userid"])
  78. obj.Model.Ct = tools.NowTime()
  79. db := orm.NewOrm()
  80. _, err := db.Insert(&obj.Model)
  81. if err != nil {
  82. logger.Logger.Error(err)
  83. dblog.Description = fmt.Sprintf("发送新的通知/公告失败:%s,操作数据:%+v", err.Error(), obj.Model)
  84. dblog.Fail2()
  85. } else {
  86. dblog.Description = fmt.Sprintf("发送新的通知/公告成功,操作数据:%+v", obj.Model)
  87. dblog.Success2()
  88. }
  89. msg, _ := json.Marshal(obj.Model)
  90. mqtt.PublishMessage(fmt.Sprintf("/jujutong/scd_check_tools/notice/%d", touser), string(msg))
  91. return err
  92. }
  93. func (c *NoticeMgr) SetRead() (err error) {
  94. dblog := new(SystemLog)
  95. dblog.SetUserInfo(c.GetUserInfo())
  96. dblog.Audittype = enum.AuditType_Notice
  97. dblog.Logtype = enum.LogType_Execute
  98. dblog.Eventtype = enum.OptEventType_Bus
  99. dblog.Eventlevel = enum.OptEventLevel_Mid
  100. db := orm.NewOrm()
  101. err = db.Read(&c.Model)
  102. if err != nil {
  103. logger.Logger.Error(err)
  104. return err
  105. }
  106. c.Model.ReadFlag = 1
  107. c.Model.ReadTime = tools.NowTime()
  108. _, err = db.Update(&c.Model)
  109. if err != nil {
  110. logger.Logger.Error(err)
  111. dblog.Description = fmt.Sprintf("设置通知/公告为已读失败:%s,操作数据:%+v", err.Error(), c.Model)
  112. dblog.Fail2()
  113. } else {
  114. dblog.Description = fmt.Sprintf("设置通知/公告为已读,操作数据:%+v", c.Model)
  115. dblog.Success2()
  116. }
  117. return err
  118. }
  119. func (c *NoticeMgr) Save() (err error) {
  120. dblog := new(SystemLog)
  121. dblog.SetUserInfo(map[string]interface{}{"name": "", "ip": "127.0.0.1"})
  122. dblog.Audittype = enum.AuditType_Notice
  123. dblog.Logtype = enum.LogType_Insert
  124. dblog.Eventtype = enum.OptEventType_System
  125. dblog.Eventlevel = enum.OptEventLevel_Mid
  126. db := orm.NewOrm()
  127. c.Model.Cr = c.GetUserId()
  128. c.Model.Ct = tools.NowTime()
  129. c.Model.ReadFlag = 0
  130. if c.Model.Id == 0 {
  131. _, err = db.Insert(&c.Model)
  132. } else {
  133. _, err = db.Update(&c.Model)
  134. }
  135. if err != nil {
  136. logger.Logger.Error(err)
  137. dblog.Description = fmt.Sprintf("创建新的通知/公告失败:%s,操作数据:%+v", err.Error(), c.Model)
  138. dblog.Fail2()
  139. } else {
  140. dblog.Description = fmt.Sprintf("创建新的通知/公告成功,操作数据:%+v", c.Model)
  141. dblog.Success2()
  142. }
  143. return err
  144. }
  145. func (c *NoticeMgr) One() (T_base_notice, error) {
  146. o := orm.NewOrm()
  147. err := o.Read(&c.Model)
  148. if err != nil {
  149. log.Println(err)
  150. }
  151. return c.Model, err
  152. }
  153. func (c *NoticeMgr) Delete() (err error) {
  154. dblog := new(SystemLog)
  155. dblog.SetUserInfo(c.GetUserInfo())
  156. dblog.Audittype = enum.AuditType_Notice
  157. dblog.Logtype = enum.LogType_Delete
  158. dblog.Eventtype = enum.OptEventType_Bus
  159. dblog.Eventlevel = enum.OptEventLevel_Hight
  160. db := orm.NewOrm()
  161. if c.Model.Id == 0 {
  162. return errors.New("无效的ID")
  163. } else {
  164. db.Read(&c.Model)
  165. _, err = db.Delete(&c.Model)
  166. }
  167. if err != nil {
  168. logger.Logger.Error(err)
  169. dblog.Description = fmt.Sprintf("删除通知提醒%s失败:%s", c.Model.Caption, err.Error())
  170. dblog.Fail2()
  171. } else {
  172. dblog.Description = fmt.Sprintf("删除通知提醒%s成功", c.Model.Caption)
  173. dblog.Success2()
  174. }
  175. return err
  176. }
  177. func (c *NoticeMgr) List(rev_id, station_id, isread int32, caption, noticetype string, pageno, pagesize int32) ([]orm.Params, int, error) {
  178. dblog := new(SystemLog)
  179. dblog.SetUserInfo(c.GetUserInfo())
  180. dblog.Audittype = enum.AuditType_Notice
  181. dblog.Logtype = enum.LogType_Query
  182. dblog.Eventtype = enum.OptEventType_Bus
  183. dblog.Eventlevel = enum.OptEventLevel_Hight
  184. o := orm.NewOrm()
  185. sqlParamters := []interface{}{}
  186. sql := "select t.*,u.name username,c.name type_name,ts.area_name station_name from t_base_notice t left join t_data_user u on t.cr=u.id left join global_const_code c on t.notice_type=c.id and c.parentcode='notice_types' left join t_data_area ts on t.station_id=ts.ID where 1=1 "
  187. if rev_id > 0 {
  188. sql += " and t.rev_id=?"
  189. sqlParamters = append(sqlParamters, rev_id)
  190. }
  191. if station_id > 0 {
  192. sql += " and t.station_id=?"
  193. sqlParamters = append(sqlParamters, station_id)
  194. }
  195. if caption != "" {
  196. sql += " and t.caption like ?"
  197. sqlParamters = append(sqlParamters, "%"+caption+"%")
  198. }
  199. if noticetype != "" {
  200. sql += " and t.notice_type=?"
  201. sqlParamters = append(sqlParamters, noticetype)
  202. }
  203. if isread != -1 {
  204. sql += " and t.read_flag=?"
  205. sqlParamters = append(sqlParamters, isread)
  206. }
  207. limit := fmt.Sprintf(" order by t.ct desc limit %d,%d", (pageno-1)*pagesize, pagesize)
  208. r := []orm.Params{}
  209. _, err := o.Raw(sql+limit, sqlParamters).Values(&r)
  210. dblog.Description = fmt.Sprintf("SQL:%s 参数:%+v", sql+limit, sqlParamters)
  211. if err != nil {
  212. logger.Logger.Error(err, dblog.Description)
  213. dblog.Fail2()
  214. return nil, 0, err
  215. }
  216. dblog.Success2()
  217. total := []orm.Params{}
  218. _, err = o.Raw(strings.Replace(sql, "t.*,u.name username,c.name type_name", "count(1) cnt", 1), sqlParamters).Values(&total)
  219. if err != nil {
  220. log.Println(err)
  221. return nil, 0, err
  222. }
  223. totalCnt := 0
  224. if len(total) > 0 {
  225. totalCnt, _ = strconv.Atoi(tools.IsEmpty(total[0]["cnt"]))
  226. }
  227. return r, totalCnt, err
  228. }
  229. func (c *NoticeMgr) Clear(stationid int) {
  230. o := orm.NewOrm()
  231. sql := "delete from t_base_notice where station_id=?"
  232. o.Raw(sql, stationid).Exec()
  233. }