forked from ixre/go2o
-
Notifications
You must be signed in to change notification settings - Fork 0
/
order.go
78 lines (70 loc) · 1.81 KB
/
order.go
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/**
* Copyright 2014 @ z3q.net.
* name :
* author : jarryliu
* date : 2014-01-08 21:35
* description :
* history :
*/
package daemon
import (
"fmt"
"github.com/jsix/gof"
"go2o/src/core/domain/interface/enum"
"go2o/src/core/service/dps"
"go2o/src/core/variable"
"time"
)
func orderDaemon(app gof.App) {
defer recoverDaemon()
for {
ids := getPartners()
for _, v := range ids {
autoSetOrder(v)
}
time.Sleep(time.Minute * CRON_ORDER_SETUP_MINUTE)
}
}
func autoSetOrder(partnerId int) {
f := func(err error) {
appCtx.Log().PrintErr(err)
}
dps.ShoppingService.OrderAutoSetup(partnerId, f)
}
func confirmNewOrder(app gof.App, dfs []DaemonFunc) {
if i, _ := appCtx.Storage().GetInt(variable.KvHaveNewCreatedOrder); i == enum.TRUE {
appCtx.Log().Printf("[ DAEMON][ ORDER][ CONFIRM] - begin invoke confirm handler.")
if dfs == nil || len(dfs) == 0 {
confirmOrderQueue(app)
} else {
for _, v := range dfs {
v(app)
}
}
appCtx.Storage().Set(variable.KvHaveNewCreatedOrder, enum.FALSE)
}
}
func completedOrderObs(app gof.App, dfs []DaemonFunc) {
if i, _ := appCtx.Storage().GetInt(variable.KvHaveNewCompletedOrder); i == enum.TRUE {
appCtx.Log().Printf("[ DAEMON][ ORDER][ FINISHED] - begin invoke finish handler.\n")
for _, v := range dfs {
v(app)
}
appCtx.Storage().Set(variable.KvHaveNewCompletedOrder, enum.FALSE)
}
}
type orderInfo struct {
PartnerId int
OrderNo string
}
func confirmOrderQueue(app gof.App) {
var list []*orderInfo = []*orderInfo{}
appCtx.Db().GetOrm().SelectByQuery(&list, fmt.Sprintf("SELECT partner_id,order_no FROM pt_order WHERE status=%d",
enum.ORDER_WAIT_CONFIRM))
for _, v := range list {
err := dps.ShoppingService.ConfirmOrder(v.PartnerId, v.OrderNo)
if err != nil {
appCtx.Log().Printf("[ DAEMON][ ORDER][ ERROR] - %s\n", err.Error())
}
}
}