alarmService.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. package service
  2. import (
  3. "fmt"
  4. "iot_manager_service/app/device/dao"
  5. "iot_manager_service/app/device/model"
  6. "iot_manager_service/app/system/service"
  7. "iot_manager_service/util/cache"
  8. "iot_manager_service/util/common"
  9. "time"
  10. )
  11. // 中间件管理服务
  12. var AlarmService = new(alarmService)
  13. type alarmService struct{}
  14. func (s *alarmService) Get(id int) (*dao.Alarm, *common.Errors) {
  15. // 创建查询实例
  16. device := &dao.Alarm{
  17. ID: id,
  18. }
  19. err := device.GetDevice()
  20. if err != nil {
  21. return nil, common.FailResponse(err.Error(), nil)
  22. }
  23. return device, nil
  24. }
  25. func (s *alarmService) CreateOrUpdate(userId int64, tenantId int, req dao.Alarm) *common.Errors {
  26. device := req
  27. device.TenantId = tenantId
  28. device.UpdateUser = userId
  29. device.UpdateTime = time.Now()
  30. if req.ID == 0 {
  31. device.CreateTime = time.Now()
  32. device.CreateUser = userId
  33. if device.IsExistedBySN() {
  34. fmt.Printf("Create IsExistedBySN \n")
  35. return common.ParamsInvalidResponse(model.RepeatedName, nil)
  36. }
  37. if err := device.Create(); err != nil {
  38. fmt.Printf("Create err = %s \n", err.Error())
  39. return common.FailResponse(err.Error(), nil)
  40. }
  41. service.OperationHisService.Save(userId, tenantId, common.OperationCreate, common.ModuleTypeDevice,
  42. common.DeviceTypeAlarmServer, common.GetDeviceObject(device.ID, device.ServeName), common.OperationSuccess)
  43. return common.SuccessResponse(common.Succeeded, nil)
  44. }
  45. if device.IsExistedByNameAndCode() {
  46. fmt.Printf("Update IsExistedByNameAndCode \n")
  47. return common.ParamsInvalidResponse(model.RepeatedName, nil)
  48. }
  49. if err := device.Update(); err != nil {
  50. fmt.Printf("Update err = %s \n", err.Error())
  51. return common.FailResponse(err.Error(), nil)
  52. }
  53. service.OperationHisService.Save(userId, tenantId, common.OperationUpdate, common.ModuleTypeDevice,
  54. common.DeviceTypeAlarmServer, common.GetDeviceObject(device.ID, device.ServeName), common.OperationSuccess)
  55. return common.SuccessResponse(common.Succeeded, nil)
  56. }
  57. func (s *alarmService) List(poleGroupName string, current, size int) ([]dao.Alarm, *common.Errors) {
  58. // 创建查询实例
  59. device := &dao.Alarm{}
  60. offset := (current - 1) * size
  61. limit := size
  62. devices, err := device.GetDevices(offset, limit)
  63. if err != nil {
  64. return nil, common.FailResponse(err.Error(), nil)
  65. }
  66. return devices, nil
  67. }
  68. func (s *alarmService) Remove(userId int64, tenantId int, id int) *common.Errors {
  69. // 创建查询实例
  70. device := &dao.Alarm{
  71. ID: id,
  72. IsDeleted: 1,
  73. UpdateUser: userId,
  74. UpdateTime: time.Now(),
  75. }
  76. err := device.Delete()
  77. if err != nil {
  78. return common.FailResponse(err.Error(), nil)
  79. }
  80. service.OperationHisService.Save(userId, tenantId, common.OperationRemove, common.ModuleTypeDevice,
  81. common.DeviceTypeAlarmServer, common.GetDeviceObject(device.ID, device.ServeName), common.OperationSuccess)
  82. return nil
  83. }
  84. func (s *alarmService) GetList(tenantId int) ([]*dao.Alarm, *common.Errors) {
  85. var devices []*dao.Alarm
  86. err := cache.Redis.Get(getAlarmListRedisKey(tenantId)).Scan(&devices)
  87. if err == nil {
  88. return devices, nil
  89. }
  90. device := &dao.Alarm{
  91. TenantId: tenantId,
  92. IsDeleted: 0,
  93. }
  94. devices, err = device.GetAllDevices()
  95. if err != nil {
  96. return nil, common.FailResponse(err.Error(), nil)
  97. }
  98. _ = cache.Redis.Set(getAlarmListRedisKey(tenantId), devices, 0).Err()
  99. return devices, nil
  100. }
  101. func getAlarmListRedisKey(tenantId int) string {
  102. return fmt.Sprintf(model.AlarmList, tenantId)
  103. }