chest.go 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  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 devices, err := svcCtx.DeviceBind.FindByProjectIdDeviceType(context.Background(), projectId, DEVICE_CHEST); err != nil {
  43. logx.Infof("findDeviceChest not found devices")
  44. return nil, err
  45. } else {
  46. return devices, nil
  47. }
  48. }
  49. func transDeviceChestData(datas []model.DcDeviceBind) ([]model.DcWorkingChest, error) {
  50. ts := make([]model.DcWorkingChest, len(datas))
  51. for i, data := range datas {
  52. ts[i] = model.DcWorkingChest{
  53. Id: 0,
  54. ProjectId: data.ProjectId,
  55. DeviceCode: data.DeviceCode,
  56. Switch: data.Items.GetItemInt64Value("switch"),
  57. Level: data.Items.GetItemFloat64Value("level"),
  58. AgitatorStatus: data.Items.GetItemInt64Value("agitator_status"),
  59. AgitatorDuration: data.Items.GetItemInt64Value("agitator_duration"),
  60. AgitatorFaultStatus: data.Items.GetItemInt64Value("agitator_fault_status"),
  61. CTime: time.Now(),
  62. }
  63. }
  64. return ts, nil
  65. }