edb_monitor.go 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456
  1. package edbmonitor
  2. import (
  3. "eta/eta_api/models/data_manage"
  4. edbmonitor "eta/eta_api/models/edb_monitor"
  5. "eta/eta_api/models/edb_monitor/request"
  6. "eta/eta_api/models/edb_monitor/response"
  7. "eta/eta_api/models/system"
  8. "eta/eta_api/utils"
  9. "fmt"
  10. "strconv"
  11. "strings"
  12. "time"
  13. "github.com/rdlucklib/rdluck_tools/paging"
  14. )
  15. // 预警触发状态
  16. const (
  17. EDB_MONITOR_STATE_CLOSE = iota
  18. EDB_MONITOR_STATE_NO_TRIGGER
  19. EDB_MONITOR_STATE_TRIGGER_SUCCESS
  20. )
  21. // 预警突破方式
  22. const (
  23. EDB_MONITOR_TYPE_UP = iota
  24. EDB_MONITOR_TYPE_DOWN
  25. )
  26. func GetMonitorList(classifyId, level, state, userId string, pageSize, currentIndex int) (resp response.EdbMonitorInfoListResp, msg string, err error) {
  27. if pageSize <= 0 {
  28. pageSize = utils.PageSize20
  29. }
  30. if currentIndex <= 0 {
  31. currentIndex = 1
  32. }
  33. startSize := utils.StartIndex(currentIndex, pageSize)
  34. var classifyIdList []int
  35. if classifyId != "" {
  36. tmp := strings.Split(classifyId, ",")
  37. for _, v := range tmp {
  38. cv, _ := strconv.Atoi(v)
  39. classifyIdList = append(classifyIdList, cv)
  40. }
  41. }
  42. var levelList []string
  43. if level != "" {
  44. levelList = strings.Split(level, ",")
  45. }
  46. var stateList []int
  47. if state != "" {
  48. tmp := strings.Split(state, ",")
  49. for _, v := range tmp {
  50. st, _ := strconv.Atoi(v)
  51. stateList = append(stateList, st)
  52. }
  53. }
  54. var userIdList []int
  55. if userId != "" {
  56. tmp := strings.Split(userId, ",")
  57. for _, v := range tmp {
  58. ui, _ := strconv.Atoi(v)
  59. userIdList = append(userIdList, ui)
  60. }
  61. }
  62. var conditon string
  63. var pars []interface{}
  64. if len(classifyIdList) != 0 {
  65. conditon += ` AND edb_monitor_classify_id IN (` + utils.GetOrmInReplace(len(classifyIdList)) + ` )`
  66. pars = append(pars, classifyIdList)
  67. }
  68. if len(levelList) != 0 {
  69. conditon += ` AND monitor_level IN (` + utils.GetOrmInReplace(len(levelList)) + ` )`
  70. pars = append(pars, levelList)
  71. }
  72. if len(stateList) != 0 {
  73. conditon += ` AND state IN (` + utils.GetOrmInReplace(len(stateList)) + ` )`
  74. pars = append(pars, stateList)
  75. }
  76. if len(userIdList) != 0 {
  77. conditon += ` AND create_user_id IN (` + utils.GetOrmInReplace(len(userIdList)) + ` )`
  78. pars = append(pars, userIdList)
  79. }
  80. total, err := edbmonitor.GetEdbMonitorInfoCountByCondition(conditon, pars)
  81. if err != nil {
  82. msg = "获取监控列表失败"
  83. err = fmt.Errorf("GetEdbMonitorInfoCountByCondition err:%w", err)
  84. return
  85. }
  86. edbMonitorList, err := edbmonitor.GetEdbMonitorInfoPageByCondition(conditon, pars, startSize, pageSize)
  87. if err != nil {
  88. msg = "获取监控列表失败"
  89. err = fmt.Errorf("GetEdbMonitorInfoPageByCondition err:%w", err)
  90. return
  91. }
  92. var edbInfoId, edbUserId []int
  93. for _, v := range edbMonitorList {
  94. edbUserId = append(edbUserId, v.CreateUserId)
  95. edbInfoId = append(edbInfoId, v.EdbInfoId)
  96. }
  97. edbInfoList, err := data_manage.GetEdbInfoByIdList(edbInfoId)
  98. if err != nil {
  99. msg = "获取监控列表失败"
  100. err = fmt.Errorf("GetEdbInfoByIdList err:%w", err)
  101. return
  102. }
  103. infoMap := make(map[int]string)
  104. for _, v := range edbInfoList {
  105. infoMap[v.EdbInfoId] = v.EdbName
  106. }
  107. userInfoList, err := system.GetSysAdminByIdList(edbUserId)
  108. if err != nil {
  109. msg = "获取监控列表失败"
  110. err = fmt.Errorf("GetSysAdminByIdList err:%w", err)
  111. return
  112. }
  113. userMap := make(map[int]string)
  114. for _, v := range userInfoList {
  115. userMap[v.AdminId] = v.RealName
  116. }
  117. classifyList, err := edbmonitor.GetEdbMonitorClassifyList()
  118. if err != nil {
  119. msg = "获取监控列表失败"
  120. err = fmt.Errorf("GetEdbMonitorClassifyList err:%w", err)
  121. return
  122. }
  123. classifyMap := make(map[int]string)
  124. for _, v := range classifyList {
  125. classifyMap[v.ClassifyId] = v.ClassifyName
  126. }
  127. classifyPathMap := make(map[int]string)
  128. for _, v := range classifyList {
  129. var path []string
  130. if v.ParentId != 0 {
  131. parentName := classifyMap[v.ParentId]
  132. if v.RootId != 0 && v.RootId != v.ParentId {
  133. rootName := classifyMap[v.RootId]
  134. path = append(path, rootName)
  135. }
  136. curName := v.ClassifyName
  137. path = append(path, parentName, curName)
  138. } else {
  139. path = append(path, v.ClassifyName)
  140. }
  141. classifyPathMap[v.ClassifyId] = strings.Join(path, "/")
  142. }
  143. edbMonitorItems := toEdbMonitorInfoItems(edbMonitorList, userMap, classifyPathMap, infoMap)
  144. page := paging.GetPaging(currentIndex, pageSize, total)
  145. resp.List = edbMonitorItems
  146. resp.Paging = page
  147. return
  148. }
  149. func SaveEdbMonitorInfo(req request.EdbMonitorInfoSaveReq, adminId int) (msg string, err error) {
  150. edb, er := data_manage.GetEdbInfoById(req.EdbInfoId)
  151. if er != nil {
  152. if er.Error() == utils.ErrNoRow() {
  153. msg = "指标不存在,请刷新重试"
  154. err = er
  155. return
  156. }
  157. msg = "添加指标预警失败"
  158. err = er
  159. return
  160. }
  161. var edbMonitorInfo *edbmonitor.EdbMonitorInfo
  162. if req.EdbMonitorId > 0 {
  163. edbMonitorInfo, er = edbmonitor.GetEdbMonitorInfoById(req.EdbMonitorId)
  164. if er != nil {
  165. if er.Error() == utils.ErrNoRow() {
  166. msg = "指标预警不存在,请刷新重试"
  167. err = er
  168. return
  169. }
  170. msg = "编辑指标预警失败"
  171. err = fmt.Errorf("GetEdbMonitorInfoById err:%w", er)
  172. return
  173. }
  174. var updateCols []string
  175. if edbMonitorInfo.EdbInfoId != req.EdbInfoId {
  176. updateCols = append(updateCols, []string{"edb_info_id", "edb_info_type", "edb_code", "source", "sub_source", "edb_latest_date", "edb_latest_value"}...)
  177. edbMonitorInfo.EdbInfoId = req.EdbInfoId
  178. edbMonitorInfo.EdbInfoType = edb.EdbInfoType
  179. edbMonitorInfo.EdbCode = edb.EdbCode
  180. edbMonitorInfo.Source = edb.Source
  181. edbMonitorInfo.SubSource = edb.SubSource
  182. edbMonitorInfo.EdbLatestDate = edb.LatestDate
  183. edbMonitorInfo.EdbLatestValue = edb.LatestValue
  184. }
  185. if edbMonitorInfo.EdbMonitorName != req.EdbMonitorName {
  186. updateCols = append(updateCols, "edb_monitor_name")
  187. edbMonitorInfo.EdbMonitorName = req.EdbMonitorName
  188. }
  189. if edbMonitorInfo.EdbMonitorClassifyId != req.ClassifyId {
  190. updateCols = append(updateCols, "edb_monitor_classify_id")
  191. edbMonitorInfo.EdbMonitorClassifyId = req.ClassifyId
  192. }
  193. if edbMonitorInfo.MonitorType != req.MonitorType {
  194. updateCols = append(updateCols, "monitor_type")
  195. edbMonitorInfo.MonitorType = req.MonitorType
  196. }
  197. monitorData, _ := strconv.ParseFloat(req.MonitorData, 64)
  198. if edbMonitorInfo.MonitorData != monitorData {
  199. updateCols = append(updateCols, "monitor_data")
  200. edbMonitorInfo.MonitorData = monitorData
  201. }
  202. if edbMonitorInfo.MonitorLevel != req.MonitorLevel {
  203. updateCols = append(updateCols, "monitor_level")
  204. edbMonitorInfo.MonitorLevel = req.MonitorLevel
  205. }
  206. if len(updateCols) > 0 {
  207. updateCols = append(updateCols, "modify_time")
  208. edbMonitorInfo.ModifyTime = time.Now()
  209. er := edbMonitorInfo.Update(updateCols)
  210. if er != nil {
  211. msg = "编辑指标预警失败"
  212. err = fmt.Errorf("UpdateEdbMonitorInfoById err:%w", er)
  213. return
  214. }
  215. }
  216. } else {
  217. edbMonitorInfo = new(edbmonitor.EdbMonitorInfo)
  218. edbMonitorInfo.EdbMonitorClassifyId = req.ClassifyId
  219. edbMonitorInfo.EdbMonitorName = req.EdbMonitorName
  220. edbMonitorInfo.EdbInfoId = req.EdbInfoId
  221. edbMonitorInfo.EdbInfoType = edb.EdbInfoType
  222. edbMonitorInfo.EdbCode = edb.EdbCode
  223. edbMonitorInfo.Source = edb.Source
  224. edbMonitorInfo.SubSource = edb.SubSource
  225. edbMonitorInfo.EdbLatestDate = edb.LatestDate
  226. edbMonitorInfo.EdbLatestValue = edb.LatestValue
  227. edbMonitorInfo.MonitorType = req.MonitorType
  228. monitorData, _ := strconv.ParseFloat(req.MonitorData, 64)
  229. edbMonitorInfo.MonitorData = monitorData
  230. edbMonitorInfo.MonitorLevel = req.MonitorLevel
  231. edbMonitorInfo.CreateUserId = adminId
  232. edbMonitorInfo.CreateTime = time.Now()
  233. edbMonitorInfo.ModifyTime = time.Now()
  234. insertId, er := edbMonitorInfo.Insert()
  235. if er != nil {
  236. msg = "添加指标预警失败"
  237. err = fmt.Errorf("insert err:%w", er)
  238. return
  239. }
  240. edbMonitorInfo.EdbMonitorId = int(insertId)
  241. }
  242. err = ModifyEdbMonitorState(edbMonitorInfo, edb.EdbCode, edb.Source, edb.SubSource)
  243. if err != nil {
  244. msg = "更新指标预警失败"
  245. err = fmt.Errorf("ModifyEdbMonitorState err:%w", err)
  246. return
  247. }
  248. return
  249. }
  250. func ModifyEdbMonitorState(edbMonitorInfo *edbmonitor.EdbMonitorInfo, edbCode string, source, subSource int) (err error) {
  251. cond := ` AND edb_code = ? `
  252. pars := []interface{}{edbCode}
  253. latestTwoData, er := data_manage.GetEdbDataListByCondition(cond, pars, source, subSource, 0, 2)
  254. if er != nil {
  255. err = fmt.Errorf("GetEdbDataListByCondition err:%w", er)
  256. return
  257. }
  258. triggerState := cmpEdbMonitorState(latestTwoData, edbMonitorInfo.MonitorType, edbMonitorInfo.MonitorData)
  259. var updateCols []string
  260. if edbMonitorInfo.State != EDB_MONITOR_STATE_TRIGGER_SUCCESS {
  261. edbMonitorInfo.State = triggerState
  262. updateCols = append(updateCols, "state")
  263. } else {
  264. tmpTime, _ := time.Parse(utils.FormatDate, latestTwoData[0].DataTime)
  265. edbMonitorInfo.EdbTriggerDate = tmpTime
  266. edbMonitorInfo.MonitorTriggerTime = time.Now()
  267. updateCols = append(updateCols, []string{"edb_trigger_date", "monitor_trigger_time"}...)
  268. }
  269. err = edbMonitorInfo.Update(updateCols)
  270. if err != nil {
  271. return
  272. }
  273. if triggerState == EDB_MONITOR_STATE_TRIGGER_SUCCESS {
  274. triggerTime := edbMonitorInfo.MonitorTriggerTime.Format(utils.FormatDateTime)
  275. err = SendMessages(edbMonitorInfo.CreateUserId, edbMonitorInfo.EdbInfoId, edbMonitorInfo.EdbInfoType, edbMonitorInfo.EdbMonitorName, triggerTime)
  276. isRead := 1
  277. if err != nil {
  278. isRead = 0
  279. }
  280. err = LogMessage(edbMonitorInfo.EdbMonitorName, edbMonitorInfo.MonitorTriggerTime, edbMonitorInfo.EdbInfoId, edbMonitorInfo.EdbInfoType, edbMonitorInfo.CreateUserId, isRead)
  281. }
  282. return
  283. }
  284. func cmpEdbMonitorState(twoData []*data_manage.EdbData, monitorType int, monitorData float64) int {
  285. if len(twoData) < 2 {
  286. return EDB_MONITOR_STATE_NO_TRIGGER
  287. }
  288. switch monitorType {
  289. case EDB_MONITOR_TYPE_UP:
  290. if twoData[0].Value >= monitorData && twoData[1].Value < monitorData {
  291. return EDB_MONITOR_STATE_TRIGGER_SUCCESS
  292. } else {
  293. return EDB_MONITOR_STATE_NO_TRIGGER
  294. }
  295. case EDB_MONITOR_TYPE_DOWN:
  296. if twoData[0].Value <= monitorData && twoData[1].Value > monitorData {
  297. return EDB_MONITOR_STATE_TRIGGER_SUCCESS
  298. } else {
  299. return EDB_MONITOR_STATE_NO_TRIGGER
  300. }
  301. default:
  302. return EDB_MONITOR_STATE_NO_TRIGGER
  303. }
  304. }
  305. func DeleteEdbMonitorInfo(req request.EdbMonitorInfoDeleteReq) (msg string, err error) {
  306. err = edbmonitor.DeleteEdbMonitorInfoById(req.EdbMonitorId)
  307. if err != nil {
  308. msg = "删除失败"
  309. err = fmt.Errorf("DeleteEdbMonitorInfoById err:%w", err)
  310. }
  311. return
  312. }
  313. func GetEdbMonitorLevelList() (list []string, msg string, err error) {
  314. list, err = edbmonitor.GetEdbMonitorLevelList()
  315. if err != nil {
  316. msg = "获取等级等级列表失败"
  317. err = fmt.Errorf("GetEdbMonitorLevelList err:%w", err)
  318. return
  319. }
  320. return
  321. }
  322. func CloseEdbMonitorInfo(req request.EdbMonitorInfoCloseReq, adminId int) (msg string, err error) {
  323. edbMonitor, er := edbmonitor.GetEdbMonitorInfoById(req.EdbMonitorId)
  324. if er != nil {
  325. if er.Error() == utils.ErrNoRow() {
  326. msg = "指标预警不存在,请刷新重试"
  327. err = er
  328. }
  329. msg = "关闭失败"
  330. err = fmt.Errorf("获取预警详情失败, err:%w", er)
  331. return
  332. }
  333. if edbMonitor.CreateUserId != adminId {
  334. msg = "无权限操作"
  335. err = fmt.Errorf("无权限操作")
  336. return
  337. }
  338. if edbMonitor.State == EDB_MONITOR_STATE_CLOSE {
  339. msg = "预警已关闭"
  340. err = fmt.Errorf("预警已关闭")
  341. return
  342. }
  343. edbMonitor.State = EDB_MONITOR_STATE_CLOSE
  344. edbMonitor.ModifyTime = time.Now()
  345. er = edbMonitor.Update([]string{"state", "modify_time"})
  346. if er != nil {
  347. msg = "关闭失败"
  348. err = fmt.Errorf("修改预警状态失败, err:%w", er)
  349. return
  350. }
  351. return
  352. }
  353. func RestartEdbMonitorInfo(req request.EdbMonitorInfoRestartReq, adminId int) (msg string, err error) {
  354. edbMonitor, er := edbmonitor.GetEdbMonitorInfoById(req.EdbMonitorId)
  355. if er != nil {
  356. if er.Error() == utils.ErrNoRow() {
  357. msg = "指标预警不存在,请刷新重试"
  358. err = er
  359. }
  360. msg = "重启失败"
  361. err = fmt.Errorf("获取预警详情失败, err:%w", er)
  362. return
  363. }
  364. if edbMonitor.CreateUserId != adminId {
  365. msg = "无权限操作"
  366. err = fmt.Errorf("无权限操作")
  367. return
  368. }
  369. if edbMonitor.State != EDB_MONITOR_STATE_CLOSE {
  370. msg = "预警未关闭,无需重启"
  371. err = fmt.Errorf("预警未关闭,无需重启")
  372. return
  373. }
  374. err = ModifyEdbMonitorState(edbMonitor, edbMonitor.EdbCode, edbMonitor.Source, edbMonitor.SubSource)
  375. if err != nil {
  376. msg = "重启失败"
  377. err = fmt.Errorf("修改预警状态失败, err:%w", err)
  378. return
  379. }
  380. return
  381. }
  382. func GetEdbMonitorInfoUserList() (resp response.EdbMonitorInfoCreateUserResp, msg string, err error) {
  383. userIdList, err := edbmonitor.GetEdbMonitorCreateUserId()
  384. if err != nil {
  385. msg = "获取用户列表失败"
  386. return
  387. }
  388. adminList, err := system.GetAdminItemByIdList(userIdList)
  389. if err != nil {
  390. msg = "获取用户列表失败"
  391. return
  392. }
  393. createUserItem := make([]*response.EdbMonitorCreateUserItem, 0)
  394. for _, v := range adminList {
  395. tmp := new(response.EdbMonitorCreateUserItem)
  396. tmp.AdminId = v.AdminId
  397. tmp.RealName = v.RealName
  398. createUserItem = append(createUserItem, tmp)
  399. }
  400. resp.List = createUserItem
  401. return
  402. }
  403. func toEdbMonitorInfoItems(edbmonitor []*edbmonitor.EdbMonitorInfo, userMap, classifyPathMap, infoMap map[int]string) []*response.EdbMonitorInfoItem {
  404. res := make([]*response.EdbMonitorInfoItem, 0, len(edbmonitor))
  405. for _, v := range edbmonitor {
  406. tmp := new(response.EdbMonitorInfoItem)
  407. tmp.EdbMonitorId = v.EdbMonitorId
  408. tmp.EdbMonitorName = v.EdbMonitorName
  409. tmp.EdbMonitorClassifyId = v.EdbMonitorClassifyId
  410. tmp.EdbMonitorClassifyName = classifyPathMap[v.EdbMonitorClassifyId]
  411. tmp.EdbInfoId = v.EdbInfoId
  412. tmp.EdbInfoName = infoMap[v.EdbInfoId]
  413. tmp.EdbInfoType = v.EdbInfoType
  414. tmp.EdbCode = v.EdbCode
  415. tmp.Source = v.Source
  416. tmp.SubSource = v.SubSource
  417. tmp.EdbLatestDate = v.EdbLatestDate
  418. tmp.EdbLatestValue = v.EdbLatestValue
  419. tmp.MonitorType = v.MonitorType
  420. tmp.MonitorData = v.MonitorData
  421. tmp.MonitorLevel = v.MonitorLevel
  422. tmp.State = v.State
  423. tmp.EdbTriggerDate = utils.TimeTransferString(utils.FormatDate, v.EdbTriggerDate)
  424. tmp.MonitorTriggerTime = utils.TimeTransferString(utils.FormatDateTime, v.MonitorTriggerTime)
  425. tmp.CreateUserId = v.CreateUserId
  426. tmp.CreateUserName = userMap[v.CreateUserId]
  427. tmp.CreateTime = utils.TimeTransferString(utils.FormatDateTime, v.CreateTime)
  428. tmp.ModifyTime = utils.TimeTransferString(utils.FormatDateTime, v.ModifyTime)
  429. res = append(res, tmp)
  430. }
  431. return res
  432. }