chest.go 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  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. "sync"
  9. "time"
  10. )
  11. func DeviceChest(ctx context.Context, task *job.Task, technologyName string) error {
  12. // 1. 查询所有的设备
  13. devices, err := findDeviceChest(task.Job.SvcCtx, int64(task.Id))
  14. if err != nil {
  15. return err
  16. }
  17. // 2. 获得点位信息
  18. var wg sync.WaitGroup
  19. wg.Add(len(devices))
  20. for _, device := range devices {
  21. device := device
  22. go func() {
  23. defer wg.Done()
  24. if err := device.Items.FillCurrentValue(); err != nil {
  25. logx.Errorf("DeviceChest device.Items.FillCurrentValue error: %s", err.Error())
  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. }