edb_monitor.go 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470
  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", "edb_classify_id", "edb_unique_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.EdbClassifyId = edb.ClassifyId
  181. edbMonitorInfo.EdbUniqueCode = edb.UniqueCode
  182. edbMonitorInfo.Source = edb.Source
  183. edbMonitorInfo.SubSource = edb.SubSource
  184. edbMonitorInfo.EdbLatestDate = edb.LatestDate
  185. edbMonitorInfo.EdbLatestValue = edb.LatestValue
  186. }
  187. if edbMonitorInfo.EdbMonitorName != req.EdbMonitorName {
  188. updateCols = append(updateCols, "edb_monitor_name")
  189. edbMonitorInfo.EdbMonitorName = req.EdbMonitorName
  190. }
  191. if edbMonitorInfo.EdbMonitorClassifyId != req.ClassifyId {
  192. updateCols = append(updateCols, "edb_monitor_classify_id")
  193. edbMonitorInfo.EdbMonitorClassifyId = req.ClassifyId
  194. }
  195. if edbMonitorInfo.MonitorType != req.MonitorType {
  196. updateCols = append(updateCols, "monitor_type")
  197. edbMonitorInfo.MonitorType = req.MonitorType
  198. }
  199. monitorData, _ := strconv.ParseFloat(req.MonitorData, 64)
  200. if edbMonitorInfo.MonitorData != monitorData {
  201. updateCols = append(updateCols, "monitor_data")
  202. edbMonitorInfo.MonitorData = monitorData
  203. }
  204. if edbMonitorInfo.MonitorLevel != req.MonitorLevel {
  205. updateCols = append(updateCols, "monitor_level")
  206. edbMonitorInfo.MonitorLevel = req.MonitorLevel
  207. }
  208. if len(updateCols) > 0 {
  209. updateCols = append(updateCols, "modify_time")
  210. edbMonitorInfo.ModifyTime = time.Now()
  211. er := edbMonitorInfo.Update(updateCols)
  212. if er != nil {
  213. msg = "编辑指标预警失败"
  214. err = fmt.Errorf("UpdateEdbMonitorInfoById err:%w", er)
  215. return
  216. }
  217. }
  218. } else {
  219. edbMonitorInfo = new(edbmonitor.EdbMonitorInfo)
  220. edbMonitorInfo.EdbMonitorClassifyId = req.ClassifyId
  221. edbMonitorInfo.EdbMonitorName = req.EdbMonitorName
  222. edbMonitorInfo.EdbInfoId = req.EdbInfoId
  223. edbMonitorInfo.EdbInfoType = edb.EdbInfoType
  224. edbMonitorInfo.EdbUniqueCode = edb.UniqueCode
  225. edbMonitorInfo.EdbClassifyId = edb.ClassifyId
  226. edbMonitorInfo.EdbCode = edb.EdbCode
  227. edbMonitorInfo.Source = edb.Source
  228. edbMonitorInfo.SubSource = edb.SubSource
  229. edbMonitorInfo.EdbLatestDate = edb.LatestDate
  230. edbMonitorInfo.EdbLatestValue = edb.LatestValue
  231. edbMonitorInfo.MonitorType = req.MonitorType
  232. monitorData, _ := strconv.ParseFloat(req.MonitorData, 64)
  233. edbMonitorInfo.MonitorData = monitorData
  234. edbMonitorInfo.MonitorLevel = req.MonitorLevel
  235. edbMonitorInfo.CreateUserId = adminId
  236. edbMonitorInfo.CreateTime = time.Now()
  237. edbMonitorInfo.ModifyTime = time.Now()
  238. insertId, er := edbMonitorInfo.Insert()
  239. if er != nil {
  240. msg = "添加指标预警失败"
  241. err = fmt.Errorf("insert err:%w", er)
  242. return
  243. }
  244. edbMonitorInfo.EdbMonitorId = int(insertId)
  245. }
  246. err = ModifyEdbMonitorState(edbMonitorInfo, edb.EdbCode, edb.Source, edb.SubSource)
  247. if err != nil {
  248. msg = "更新指标预警失败"
  249. err = fmt.Errorf("ModifyEdbMonitorState err:%w", err)
  250. return
  251. }
  252. return
  253. }
  254. func ModifyEdbMonitorState(edbMonitorInfo *edbmonitor.EdbMonitorInfo, edbCode string, source, subSource int) (err error) {
  255. cond := ` AND edb_code = ? `
  256. pars := []interface{}{edbCode}
  257. latestTwoData, er := data_manage.GetEdbDataListByCondition(cond, pars, source, subSource, 2, 0)
  258. if er != nil {
  259. err = fmt.Errorf("GetEdbDataListByCondition err:%w", er)
  260. return
  261. }
  262. var updateCols []string
  263. edbMonitorInfo.EdbLatestDate = latestTwoData[0].DataTime
  264. edbMonitorInfo.EdbLatestValue = latestTwoData[0].Value
  265. updateCols = append(updateCols, []string{"edb_latest_date", "edb_latest_value"}...)
  266. triggerState := cmpEdbMonitorState(latestTwoData, edbMonitorInfo.MonitorType, edbMonitorInfo.MonitorData)
  267. if triggerState == EDB_MONITOR_STATE_TRIGGER_SUCCESS {
  268. tmpTime, _ := time.Parse(utils.FormatDate, latestTwoData[0].DataTime)
  269. edbMonitorInfo.EdbTriggerDate = tmpTime
  270. edbMonitorInfo.MonitorTriggerTime = time.Now()
  271. updateCols = append(updateCols, []string{"edb_trigger_date", "monitor_trigger_time"}...)
  272. }
  273. if edbMonitorInfo.State == EDB_MONITOR_STATE_NO_TRIGGER || edbMonitorInfo.State == EDB_MONITOR_STATE_CLOSE {
  274. edbMonitorInfo.State = triggerState
  275. updateCols = append(updateCols, "state")
  276. }
  277. err = edbMonitorInfo.Update(updateCols)
  278. if err != nil {
  279. return
  280. }
  281. if triggerState == EDB_MONITOR_STATE_TRIGGER_SUCCESS {
  282. triggerTime := edbMonitorInfo.MonitorTriggerTime.Format(utils.FormatDateTime)
  283. err = SendMessages(edbMonitorInfo.CreateUserId, edbMonitorInfo.EdbInfoId, edbMonitorInfo.EdbInfoType, edbMonitorInfo.EdbMonitorClassifyId, edbMonitorInfo.EdbUniqueCode, edbMonitorInfo.EdbMonitorName, triggerTime)
  284. isRead := 1
  285. if err != nil {
  286. isRead = 0
  287. }
  288. err = LogMessage(edbMonitorInfo.EdbMonitorName, edbMonitorInfo.EdbUniqueCode, edbMonitorInfo.MonitorTriggerTime, edbMonitorInfo.EdbInfoId, edbMonitorInfo.EdbInfoType, edbMonitorInfo.CreateUserId, isRead, edbMonitorInfo.EdbClassifyId)
  289. }
  290. return
  291. }
  292. func cmpEdbMonitorState(twoData []*data_manage.EdbData, monitorType int, monitorData float64) int {
  293. if len(twoData) < 2 {
  294. return EDB_MONITOR_STATE_NO_TRIGGER
  295. }
  296. switch monitorType {
  297. case EDB_MONITOR_TYPE_UP:
  298. if twoData[0].Value >= monitorData && twoData[1].Value < monitorData {
  299. return EDB_MONITOR_STATE_TRIGGER_SUCCESS
  300. } else {
  301. return EDB_MONITOR_STATE_NO_TRIGGER
  302. }
  303. case EDB_MONITOR_TYPE_DOWN:
  304. if twoData[0].Value <= monitorData && twoData[1].Value > monitorData {
  305. return EDB_MONITOR_STATE_TRIGGER_SUCCESS
  306. } else {
  307. return EDB_MONITOR_STATE_NO_TRIGGER
  308. }
  309. default:
  310. return EDB_MONITOR_STATE_NO_TRIGGER
  311. }
  312. }
  313. func DeleteEdbMonitorInfo(req request.EdbMonitorInfoDeleteReq) (msg string, err error) {
  314. err = edbmonitor.DeleteEdbMonitorInfoById(req.EdbMonitorId)
  315. if err != nil {
  316. msg = "删除失败"
  317. err = fmt.Errorf("DeleteEdbMonitorInfoById err:%w", err)
  318. }
  319. return
  320. }
  321. func GetEdbMonitorLevelList() (list []string, msg string, err error) {
  322. list, err = edbmonitor.GetEdbMonitorLevelList()
  323. if err != nil {
  324. msg = "获取等级等级列表失败"
  325. err = fmt.Errorf("GetEdbMonitorLevelList err:%w", err)
  326. return
  327. }
  328. return
  329. }
  330. func CloseEdbMonitorInfo(req request.EdbMonitorInfoCloseReq, adminId int) (msg string, err error) {
  331. edbMonitor, er := edbmonitor.GetEdbMonitorInfoById(req.EdbMonitorId)
  332. if er != nil {
  333. if er.Error() == utils.ErrNoRow() {
  334. msg = "指标预警不存在,请刷新重试"
  335. err = er
  336. }
  337. msg = "关闭失败"
  338. err = fmt.Errorf("获取预警详情失败, err:%w", er)
  339. return
  340. }
  341. if edbMonitor.CreateUserId != adminId {
  342. msg = "无权限操作"
  343. err = fmt.Errorf("无权限操作")
  344. return
  345. }
  346. if edbMonitor.State == EDB_MONITOR_STATE_CLOSE {
  347. msg = "预警已关闭"
  348. err = fmt.Errorf("预警已关闭")
  349. return
  350. }
  351. edbMonitor.State = EDB_MONITOR_STATE_CLOSE
  352. edbMonitor.ModifyTime = time.Now()
  353. er = edbMonitor.Update([]string{"state", "modify_time"})
  354. if er != nil {
  355. msg = "关闭失败"
  356. err = fmt.Errorf("修改预警状态失败, err:%w", er)
  357. return
  358. }
  359. return
  360. }
  361. func RestartEdbMonitorInfo(req request.EdbMonitorInfoRestartReq, adminId int) (msg string, err error) {
  362. edbMonitor, er := edbmonitor.GetEdbMonitorInfoById(req.EdbMonitorId)
  363. if er != nil {
  364. if er.Error() == utils.ErrNoRow() {
  365. msg = "指标预警不存在,请刷新重试"
  366. err = er
  367. }
  368. msg = "重启失败"
  369. err = fmt.Errorf("获取预警详情失败, err:%w", er)
  370. return
  371. }
  372. if edbMonitor.CreateUserId != adminId {
  373. msg = "无权限操作"
  374. err = fmt.Errorf("无权限操作")
  375. return
  376. }
  377. if edbMonitor.State != EDB_MONITOR_STATE_CLOSE {
  378. msg = "预警未关闭,无需重启"
  379. err = fmt.Errorf("预警未关闭,无需重启")
  380. return
  381. }
  382. edbMonitor.EdbTriggerDate = time.Time{}
  383. edbMonitor.MonitorTriggerTime = time.Time{}
  384. edbMonitor.ModifyTime = time.Now()
  385. err = ModifyEdbMonitorState(edbMonitor, edbMonitor.EdbCode, edbMonitor.Source, edbMonitor.SubSource)
  386. if err != nil {
  387. msg = "重启失败"
  388. err = fmt.Errorf("修改预警状态失败, err:%w", err)
  389. return
  390. }
  391. return
  392. }
  393. func GetEdbMonitorInfoUserList() (resp response.EdbMonitorInfoCreateUserResp, msg string, err error) {
  394. userIdList, err := edbmonitor.GetEdbMonitorCreateUserId()
  395. if err != nil {
  396. msg = "获取用户列表失败"
  397. return
  398. }
  399. adminList, err := system.GetAdminItemByIdList(userIdList)
  400. if err != nil {
  401. msg = "获取用户列表失败"
  402. return
  403. }
  404. createUserItem := make([]*response.EdbMonitorCreateUserItem, 0)
  405. for _, v := range adminList {
  406. tmp := new(response.EdbMonitorCreateUserItem)
  407. tmp.AdminId = v.AdminId
  408. tmp.RealName = v.RealName
  409. createUserItem = append(createUserItem, tmp)
  410. }
  411. resp.List = createUserItem
  412. return
  413. }
  414. func toEdbMonitorInfoItems(edbmonitor []*edbmonitor.EdbMonitorInfo, userMap, classifyPathMap, infoMap map[int]string) []*response.EdbMonitorInfoItem {
  415. res := make([]*response.EdbMonitorInfoItem, 0, len(edbmonitor))
  416. for _, v := range edbmonitor {
  417. tmp := new(response.EdbMonitorInfoItem)
  418. tmp.EdbMonitorId = v.EdbMonitorId
  419. tmp.EdbMonitorName = v.EdbMonitorName
  420. tmp.EdbMonitorClassifyId = v.EdbMonitorClassifyId
  421. tmp.EdbMonitorClassifyName = classifyPathMap[v.EdbMonitorClassifyId]
  422. tmp.EdbInfoId = v.EdbInfoId
  423. tmp.EdbInfoName = infoMap[v.EdbInfoId]
  424. tmp.EdbUniqueCode = v.EdbUniqueCode
  425. tmp.EdbClassifyId = v.EdbClassifyId
  426. tmp.EdbInfoType = v.EdbInfoType
  427. tmp.EdbCode = v.EdbCode
  428. tmp.Source = v.Source
  429. tmp.SubSource = v.SubSource
  430. tmp.EdbLatestDate = v.EdbLatestDate
  431. tmp.EdbLatestValue = v.EdbLatestValue
  432. tmp.MonitorType = v.MonitorType
  433. tmp.MonitorData = v.MonitorData
  434. tmp.MonitorLevel = v.MonitorLevel
  435. tmp.State = v.State
  436. tmp.EdbTriggerDate = utils.TimeTransferString(utils.FormatDate, v.EdbTriggerDate)
  437. tmp.MonitorTriggerTime = utils.TimeTransferString(utils.FormatDateTime, v.MonitorTriggerTime)
  438. tmp.CreateUserId = v.CreateUserId
  439. tmp.CreateUserName = userMap[v.CreateUserId]
  440. tmp.CreateTime = utils.TimeTransferString(utils.FormatDateTime, v.CreateTime)
  441. tmp.ModifyTime = utils.TimeTransferString(utils.FormatDateTime, v.ModifyTime)
  442. res = append(res, tmp)
  443. }
  444. return res
  445. }