Files
jx-callback/business/partner/delivery/rider.go
邹宗楠 1cef6008b2 1
2022-05-18 18:32:53 +08:00

137 lines
6.3 KiB
Go
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
package delivery
import (
"git.rosy.net.cn/baseapi/platformapi/mtpsapi"
"git.rosy.net.cn/baseapi/utils"
"git.rosy.net.cn/jx-callback/business/model"
"git.rosy.net.cn/jx-callback/business/model/dao"
"git.rosy.net.cn/jx-callback/business/partner"
"git.rosy.net.cn/jx-callback/globals"
"time"
)
// 订单骑手信息推送:将获取到的三方配送订单,且订单状态为配送中的订单,将配送人员的信息返回给订单方
// 该方法为定时任务,没五分钟推送一次订单消息,订单状态发生变化时
//配送状态code如下提供配送状态枚举值
//以及各配送状态对应在C端用户端和B端商家PC端后台展示的配送状态信息。
//未同步配送状态时C端商家已接单B端待发配送
//0-配送单发往配送C端商家已接单B端待骑手接单
//1-已创建配送包裹C端商家已接单B端待骑手接单
//5-已分配骑手C端商家已接单B端已分配骑手
//10-骑手已接单C端骑手正在赶往商家B端待骑手取货
//15-骑手已到店C端骑手到店取货中B端骑手已到店
//20-骑手已取货C端商品配送中/骑手正在送货B端骑手已取货
//40-骑手已送达C端商品已送达B端骑手已送达
//100-配送单已取消C端商家已接单B端配送已取消
//注:若同步配送状态为“配送单已取消”,接口仍支持继续同步配送状态。 说明商家如未上传此信息则平台默认值为20现已要求必传
func GetOrderRiderInfoToPlatform(orderId string) {
globals.SugarLogger.Debug("==========GetOrderRiderInfoToPlatform", time.Now())
params := make(map[string]interface{}, 0)
params["statuss"] = []string{"20"}
params["isDateFinish"] = false
params["isIncludeFake"] = true
params["mustInvoice"] = false
params["adjustCount"] = 0
params["waybillVendorIDs"] = `[101,102,103]`
if orderId != "" { // 订单id会忽略其他参数
params["keyword"] = orderId
}
// 每五分钟查询当前订单信息待配送状态订单1
orders, _, err := dao.GetOrders(dao.GetDB(), nil, false, true, time.Now().Add(-24*time.Hour).Format("2006-01-02"), time.Now().Format("2006-01-02"), false, nil, false, "", params, 0, 10000)
if err != nil {
globals.SugarLogger.Errorf("GetOrder err :%v", err)
return
}
//1.此接口用于同步自配送商家自配订单除在B2C清单中的商家的配送信息包括物流平台、骑手名称、骑手电话且此配送信息会同步展示在用户端订单详情的“配送信息”中。
//(注:美团跑腿订单的配送信息,平台会自动回流,无需商家再同步。自配的配送信息目前只能在用户端查询,不支持在商家端查询
//2.从订单状态为“商家已确认”(status=4)到“订单已完成”(status=8)后的24小时之内均可使用此接口创建和更新配送信息。
//3.当同一个订单已经上传了一次配送信息,如再次同步会更新配送信息,以最新的一次为准。
//4.如订单已完成、已取消等状态发货将失败。
for _, v := range orders {
globals.SugarLogger.Debug("==========orderId,vendorId,waybillId:", v.VendorOrderID, v.VendorID, v.WaybillVendorID, v.Status)
if v.Status < 20 {
continue
}
riderInfo := &mtpsapi.RiderInfo{}
if handlerInfo := partner.GetDeliveryPlatformFromVendorID(v.WaybillVendorID); handlerInfo != nil {
if v.WaybillVendorID == model.VendorIDDada || v.WaybillVendorID == model.VendorIDFengNiao {
riderInfo, err = handlerInfo.Handler.GetRiderInfo(v.VendorOrderID, 0, "")
} else {
globals.SugarLogger.Debug("==========VendorWaybillId2Waybill:", v.VendorWaybillID)
if v.VendorWaybillID == "" {
globals.SugarLogger.Debug("==========VendorWaybillId2Waybill:", v.VendorWaybillID)
continue
}
riderInfo, err = handlerInfo.Handler.GetRiderInfo(v.VendorOrderID, v.ID+1000000, v.VendorWaybillID)
}
if err != nil {
globals.SugarLogger.Debug("Get Order waybill rider info err :%v", err)
continue
}
}
if riderInfo.CourierName == "" {
globals.SugarLogger.Debug("同步外卖骑手位置信息到美团失败,为获取到订单的骑手信息:", "----")
continue
}
if v.WaybillVendorID == model.VendorIDDada {
riderInfo.LogisticsProviderCode = "10002"
riderInfo.OrderId = v.VendorOrderID // 运单id
}
if v.WaybillVendorID == model.VendorIDFengNiao {
riderInfo.LogisticsProviderCode = "10004"
}
if v.WaybillVendorID == model.VendorIDMTPS {
riderInfo.LogisticsProviderCode = "10032"
}
riderInfo.ThirdCarrierOrderId = v.VendorWaybillID
switch v.Status {
case 20: //配送中
riderInfo.LogisticsStatus = 20
case 110: // 完成
riderInfo.LogisticsStatus = 40
case 115: // 取消
riderInfo.LogisticsStatus = 100
}
// 目前只推送美团骑手信息
switch v.VendorID {
case model.VendorIDMTWM: // 美团发单
globals.SugarLogger.Debug("struct 2 map ", riderInfo.Latitude, "---", riderInfo.Longitude, "---", riderInfo.CourierName)
paramsMap := utils.Struct2Map(riderInfo, "", true)
globals.SugarLogger.Debug("GetOrderRiderInfoToPlatform map ", paramsMap)
if handler := partner.GetPurchaseOrderHandlerFromVendorID(v.VendorID); handler != nil {
if err := handler.GetOrderRider(v.VendorOrgCode, v.VendorOrderID, paramsMap); err != nil {
globals.SugarLogger.Errorf("Error pushing meituan rider information :%v", err)
}
}
case model.VendorIDELM: // 饿了么
case model.VendorIDEBAI: // 饿百发单
case model.VendorIDJD: // 京东发单
case model.VendorIDGD: // 美团发单
case model.VendorIDYB: // 银豹发单
case model.VendorIDJDShop: // 京东商城
case model.VendorIDWSC: // 微盟微商城
default:
globals.SugarLogger.Errorf("Order source error, non system order")
return
}
}
return
}
//将以过期订单状态为配送中的订单修改为完成状态
func UpdateOrder2Complete() {
sql := `UPDATE goods_order g SET g.status=110 WHERE g.status=20 AND g.order_created_at < ?`
sqlParams := []interface{}{
time.Now().AddDate(0, 1, 0),
}
if num, err := dao.ExecuteSQL(dao.GetDB(), sql, sqlParams); err != nil {
globals.SugarLogger.Errorf("Update Order Status 20 To 110 Fail")
globals.SugarLogger.Debug("Update Order Status 20 To 110 Time,Count", time.Now(), num)
}
return
}