chest.go 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. package handler
  2. import (
  3. "GtDataStore/app/cmd/organization/internal/logic/job"
  4. "GtDataStore/app/cmd/organization/internal/svc"
  5. "GtDataStore/app/model"
  6. "context"
  7. "github.com/zeromicro/go-zero/core/logx"
  8. "time"
  9. )
  10. func DeviceChest(ctx context.Context, task *job.Task, technologyName string) error {
  11. // 1. 查询所有的设备
  12. devices, err := findDeviceChest(task.Job.SvcCtx, int64(task.Id))
  13. if err != nil {
  14. return err
  15. }
  16. // 2. 获得点位信息
  17. //var wg sync.WaitGroup
  18. //wg.Add(len(devices))
  19. //for _, device := range devices {
  20. // device := device
  21. // go func() {
  22. // defer wg.Done()
  23. // if err := device.Items.FillCurrentValue(); err != nil {
  24. // logx.Errorf("DeviceChest device.Items.FillCurrentValue error: %s", err.Error())
  25. // }
  26. // }()
  27. //}
  28. //
  29. //wg.Wait()
  30. // 3. 转换为存储对象
  31. workings, err := transDeviceChestData(devices)
  32. if err != nil {
  33. return err
  34. }
  35. // 4. 批量入库
  36. if _, err := task.Job.SvcCtx.WorkingChest.MultiInsert(context.Background(), workings); err != nil {
  37. logx.Errorf("DeviceChest task.Job.SvcCtx.WorkingChest.MultiInsert error: %s", err.Error())
  38. }
  39. return nil
  40. }
  41. func findDeviceChest(svcCtx *svc.ServiceContext, projectId int64) ([]model.DcDeviceBind, error) {
  42. if data := deviceBindCacheTable.GetCache(DEVICE_CHEST); data != nil {
  43. return data, nil
  44. }
  45. if devices, err := svcCtx.DeviceBind.FindByProjectIdDeviceType(context.Background(), projectId, DEVICE_CHEST); err != nil {
  46. logx.Infof("findDeviceChest not found devices")
  47. return nil, err
  48. } else {
  49. deviceBindCacheTable.SetCache(DEVICE_CHEST, devices, time.Now().Add(300*time.Second))
  50. return devices, nil
  51. }
  52. }
  53. func transDeviceChestData(datas []model.DcDeviceBind) ([]model.DcWorkingChest, error) {
  54. ts := make([]model.DcWorkingChest, len(datas))
  55. for i, data := range datas {
  56. ts[i] = model.DcWorkingChest{
  57. Id: 0,
  58. ProjectId: data.ProjectId,
  59. DeviceCode: data.DeviceCode,
  60. Switch: data.Items.GetItemInt64Value("switch"),
  61. Level: data.Items.GetItemFloat64Value("level"),
  62. AgitatorStatus: data.Items.GetItemInt64Value("agitator_status"),
  63. AgitatorDuration: data.Items.GetItemInt64Value("agitator_duration"),
  64. AgitatorFaultStatus: data.Items.GetItemInt64Value("agitator_fault_status"),
  65. CTime: time.Now(),
  66. }
  67. }
  68. return ts, nil
  69. }