212 lines
7.4 KiB
Go
212 lines
7.4 KiB
Go
package elm
|
||
|
||
import (
|
||
"fmt"
|
||
|
||
"git.rosy.net.cn/jx-callback/globals"
|
||
|
||
"git.rosy.net.cn/baseapi/platformapi/elmapi"
|
||
"git.rosy.net.cn/baseapi/utils"
|
||
"git.rosy.net.cn/jx-callback/business/controller"
|
||
"git.rosy.net.cn/jx-callback/business/model"
|
||
)
|
||
|
||
type OrderController struct {
|
||
controller.OrderController
|
||
}
|
||
|
||
var (
|
||
api *elmapi.API
|
||
)
|
||
|
||
func (c *OrderController) OnOrderStatusMsg(msg *elmapi.CallbackOrderStatusMsg) (retVal *elmapi.CallbackResponse) {
|
||
controller.RoutinePool.CallFun(func() {
|
||
retVal = c.onOrderStatusMsg(msg)
|
||
}, msg.OrderID)
|
||
return retVal
|
||
}
|
||
|
||
func (c *OrderController) OnOrderNewMsg(msg map[string]interface{}) (retVal *elmapi.CallbackResponse) {
|
||
controller.RoutinePool.CallFun(func() {
|
||
retVal = c.onOrderNew(msg)
|
||
}, msg["orderId"].(string))
|
||
return retVal
|
||
}
|
||
|
||
func (c *OrderController) OnOrderCancelRefundMsg(msg *elmapi.CallbackOrderCancelRefundMsg) (retVal *elmapi.CallbackResponse) {
|
||
controller.RoutinePool.CallFun(func() {
|
||
retVal = c.onOrderCancelRefundMsg(msg)
|
||
}, msg.OrderID)
|
||
return retVal
|
||
}
|
||
|
||
func (c *OrderController) orderStatusMsg2Status(msg *elmapi.CallbackOrderStatusMsg) *model.OrderStatus {
|
||
orderStatus := &model.OrderStatus{
|
||
VendorOrderID: msg.OrderID,
|
||
VendorID: controller.VendorIDELM,
|
||
OrderType: controller.OrderTypeOrder,
|
||
VendorStatus: fmt.Sprintf("%s-%d", msg.State, msg.MsgType),
|
||
StatusTime: utils.Timestamp2Time(msg.UpdateTime),
|
||
}
|
||
return orderStatus
|
||
}
|
||
|
||
func (c *OrderController) cancelRefundMsg2Status(msg *elmapi.CallbackOrderCancelRefundMsg) *model.OrderStatus {
|
||
orderStatus := &model.OrderStatus{
|
||
VendorOrderID: msg.OrderID,
|
||
VendorID: controller.VendorIDELM,
|
||
OrderType: controller.OrderTypeOrder,
|
||
Status: controller.OrderStatusEvent,
|
||
VendorStatus: utils.Int2Str(msg.MsgType),
|
||
StatusTime: utils.Timestamp2Time(msg.UpdateTime),
|
||
}
|
||
return orderStatus
|
||
}
|
||
|
||
func (c *OrderController) onOrderStatusMsg(msg *elmapi.CallbackOrderStatusMsg) (retVal *elmapi.CallbackResponse) {
|
||
switch msg.MsgType {
|
||
case elmapi.MsgTypeOrderAccepted:
|
||
retVal = c.onOrderAccepted(msg)
|
||
case elmapi.MsgTypeOrderCanceled:
|
||
retVal = c.onOrderCanceled(msg)
|
||
case elmapi.MsgTypeOrderInvalid:
|
||
retVal = c.onOrderInvalid(msg)
|
||
case elmapi.MsgTypeOrderForceInvalid:
|
||
retVal = c.onOrderForceInvalid(msg)
|
||
case elmapi.MsgTypeOrderFinished:
|
||
retVal = c.onOrderFinished(msg)
|
||
default:
|
||
globals.SugarLogger.Warnf("elm msg:%d not handled", msg.MsgType)
|
||
retVal = elmapi.SuccessResponse
|
||
}
|
||
return retVal
|
||
}
|
||
|
||
func (c *OrderController) onOrderCancelRefundMsg(msg *elmapi.CallbackOrderCancelRefundMsg) (retVal *elmapi.CallbackResponse) {
|
||
switch msg.MsgType {
|
||
case elmapi.MsgTypeUserApplyCancel:
|
||
retVal = c.onOrderUserApplyCancel(msg)
|
||
case elmapi.MsgTypeUserApplyRefund:
|
||
retVal = c.onOrderUserApplyRefund(msg)
|
||
default:
|
||
retVal = c.onOrderOtherCancelRefundStatus(msg)
|
||
}
|
||
return retVal
|
||
}
|
||
|
||
func (c *OrderController) getOrderInfo(msg *elmapi.CallbackOrderStatusMsg) (order *model.Order, orderSkus []*model.OrderSku, err error) {
|
||
result, err := api.GetOrder(msg.OrderID)
|
||
if err == nil {
|
||
phoneList := result["phoneList"].([]interface{})
|
||
consigneeMobile := ""
|
||
if len(phoneList) > 0 {
|
||
consigneeMobile = phoneList[0].(string)
|
||
}
|
||
order = &model.Order{
|
||
VendorOrderID: msg.OrderID,
|
||
VendorID: controller.VendorIDELM,
|
||
VendorStoreID: result["shopId"].(string),
|
||
StoreID: int(utils.Str2Int64(result["openId"].(string))),
|
||
StoreName: result["shopName"].(string),
|
||
ConsigneeName: result["consignee"].(string),
|
||
ConsigneeMobile: consigneeMobile,
|
||
VendorStatus: msg.State,
|
||
OrderCreatedAt: utils.Str2Time(result["createdAt"].(string)),
|
||
}
|
||
|
||
orderSkus = []*model.OrderSku{}
|
||
for _, group := range result["groups"].([]map[string]interface{}) {
|
||
for _, product := range group["items"].([]map[string]interface{}) {
|
||
sku := &model.OrderSku{
|
||
VendorOrderID: msg.OrderID,
|
||
VendorID: controller.VendorIDJD,
|
||
Count: int(utils.MustInterface2Int64(product["quantity"])),
|
||
SkuID: int(utils.Str2Int64(product["extendCode"].(string))),
|
||
VendorSkuID: product["skuId"].(string),
|
||
SkuName: product["name"].(string),
|
||
SalePrice: utils.MustInterface2Int64(product["userPrice"]),
|
||
OrderCreatedAt: order.OrderCreatedAt,
|
||
}
|
||
orderSkus = append(orderSkus, sku)
|
||
order.SkuCount++
|
||
order.SalePrice += sku.SalePrice
|
||
}
|
||
}
|
||
}
|
||
|
||
return order, orderSkus, err
|
||
}
|
||
|
||
//
|
||
func (c *OrderController) onOrderNew(msg map[string]interface{}) (response *elmapi.CallbackResponse) {
|
||
// todo 这里应该可以直接用msg里的内容,而不用再次去查
|
||
fakeOrderMsg := &elmapi.CallbackOrderStatusMsg{
|
||
OrderID: msg["orderId"].(string),
|
||
State: elmapi.OrderStatusFake,
|
||
}
|
||
order, orderSkus, err := c.getOrderInfo(fakeOrderMsg)
|
||
if err == nil {
|
||
err = c.OnOrderNew(c, order, orderSkus)
|
||
}
|
||
return elmapi.Err2CallbackResponse(err, "elm onOrderNew")
|
||
}
|
||
|
||
func (c *OrderController) onOrderAccepted(msg *elmapi.CallbackOrderStatusMsg) *elmapi.CallbackResponse {
|
||
status := c.orderStatusMsg2Status(msg)
|
||
err := c.OnOrderAccepted(c, status)
|
||
if err == nil {
|
||
status.VendorStatus = "fakeautopickup"
|
||
err = c.OnOrderFinishedPickup(c, c.orderStatusMsg2Status(msg))
|
||
}
|
||
return elmapi.Err2CallbackResponse(err, "elm onOrderAccepted")
|
||
}
|
||
|
||
func (c *OrderController) onOrderCanceled(msg *elmapi.CallbackOrderStatusMsg) *elmapi.CallbackResponse {
|
||
return elmapi.Err2CallbackResponse(c.OnOrderCanceled(c, c.orderStatusMsg2Status(msg)), "elm onOrderCanceled")
|
||
}
|
||
|
||
func (c *OrderController) onOrderInvalid(msg *elmapi.CallbackOrderStatusMsg) *elmapi.CallbackResponse {
|
||
return c.onOrderCanceled(msg)
|
||
}
|
||
|
||
func (c *OrderController) onOrderForceInvalid(msg *elmapi.CallbackOrderStatusMsg) *elmapi.CallbackResponse {
|
||
return c.onOrderCanceled(msg)
|
||
}
|
||
|
||
func (c *OrderController) onOrderFinished(msg *elmapi.CallbackOrderStatusMsg) *elmapi.CallbackResponse {
|
||
return elmapi.Err2CallbackResponse(c.OnOrderDelivered(c, c.orderStatusMsg2Status(msg)), "elm onOrderFinished")
|
||
}
|
||
|
||
func (c *OrderController) onOrderUserUrgeOrder(msg *elmapi.CallbackOrderUrgeMsg) *elmapi.CallbackResponse {
|
||
orderStatus := &model.OrderStatus{
|
||
VendorOrderID: msg.OrderID,
|
||
VendorID: controller.VendorIDELM,
|
||
OrderType: controller.OrderTypeOrder,
|
||
Status: controller.OrderStatusEvent,
|
||
VendorStatus: utils.Int2Str(msg.MsgType),
|
||
StatusTime: utils.Timestamp2Time(msg.UpdateTime),
|
||
}
|
||
return elmapi.Err2CallbackResponse(c.OnOrderUserUrgeOrder(c, orderStatus), "elm onOrderUserUrgeOrder")
|
||
}
|
||
|
||
func (c *OrderController) onOrderUserApplyCancel(msg *elmapi.CallbackOrderCancelRefundMsg) *elmapi.CallbackResponse {
|
||
return elmapi.Err2CallbackResponse(c.OnOrderUserApplyCancel(c, c.cancelRefundMsg2Status(msg)), "elm onOrderUserApplyCancel")
|
||
}
|
||
|
||
func (c *OrderController) onOrderUserApplyRefund(msg *elmapi.CallbackOrderCancelRefundMsg) *elmapi.CallbackResponse {
|
||
return elmapi.Err2CallbackResponse(c.OnOrderUserApplyRefund(c, c.cancelRefundMsg2Status(msg)), "elm onOrderUserApplyRefund")
|
||
}
|
||
|
||
func (c *OrderController) onOrderOtherCancelRefundStatus(msg *elmapi.CallbackOrderCancelRefundMsg) *elmapi.CallbackResponse {
|
||
return elmapi.Err2CallbackResponse(c.OnOrderOtherStatus(c, c.cancelRefundMsg2Status(msg)), "elm onOrderOtherCancelRefundStatus")
|
||
}
|
||
|
||
// PurchasePlatformHandler
|
||
func (c *OrderController) AcceptOrRefuseOrder(order *model.Order, isAcceptIt bool) {
|
||
if isAcceptIt {
|
||
api.ConfirmOrder(order.VendorOrderID)
|
||
} else {
|
||
api.CancelOrder(order.VendorOrderID, elmapi.CancelOrderTypeOthers, "")
|
||
}
|
||
}
|