zhangqian
2023-08-15 550bd8a218224e6c73201f444387d66a299f438b
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
package nsq
 
import (
    "apsClient/model"
    "apsClient/pkg/logx"
    "encoding/json"
    "fmt"
)
 
type MsgHandler interface {
    HandleMessage(data []byte) (err error)
}
 
type ScheduleTask struct {
}
 
func (slf *ScheduleTask) HandleMessage(data []byte) (err error) {
    fmt.Println(string(data))
 
    var tasks = make([]*DeliverScheduleTask, 0)
 
    err = json.Unmarshal(data, &tasks)
    if err != nil {
        logx.Errorf("ScheduleTask HandleMessage Unmarshal json err: %v", err.Error())
        return err
    }
    for _, task := range tasks {
        taskRecord := model.ScheduleTask{
            Id:          0,
            OrderId:     task.Order.OrderID,
            ProductId:   task.Order.ProductID,
            ProductName: task.Order.ProductName,
            Amount:      task.Order.Amount,
            Unit:        task.Order.Unit,
            StartTime:   task.Order.StartTime,
            EndTime:     task.Order.EndTime,
        }
        jsonStr, err := json.Marshal(task)
        if err != nil {
            logx.Errorf("ScheduleTask HandleMessage Marshal err: %v, old: %#v", err.Error(), task)
            return err
        }
        taskRecord.Data = string(jsonStr)
        err = model.NewScheduleTaskSearch(nil).Create(&taskRecord)
        if err != nil {
            logx.Errorf("ScheduleTask HandleMessage Create taskRecord err: %v,  record: %#v", err.Error(), taskRecord)
            return err
        }
    }
    return nil
}