This commit is contained in:
邹宗楠
2022-11-22 16:17:38 +08:00
parent b834cad438
commit 86efceb44c
6 changed files with 35 additions and 50 deletions

View File

@@ -4,11 +4,11 @@ import (
"crypto/md5"
"errors"
"fmt"
order_getSettleBillDetailV3_request "git.rosy.net.cn/baseapi/platformapi/tiktok_shop/sdk-golang/api/order_getSettleBillDetailV3/request"
"git.rosy.net.cn/jx-callback/business/authz/autils"
"git.rosy.net.cn/jx-callback/business/jxutils/excel"
"git.rosy.net.cn/jx-callback/business/jxutils/netprinter"
"git.rosy.net.cn/jx-callback/business/jxutils/weixinmsg"
"git.rosy.net.cn/jx-callback/business/partner/purchase/tiktok_store"
"git.rosy.net.cn/jx-callback/globals/api2"
beego "github.com/astaxie/beego/server/web"
"math"
@@ -2477,53 +2477,40 @@ func ExportOrderWithSku(ctx *jxcontext.Context, orders []*model.GoodsOrderExt) (
// UpdateTiktokShopTotalMoney 定时任务更新抖店订单的平台结算
func UpdateTiktokShopTotalMoney() {
db := dao.GetDB()
var goodsOrders []*model.GoodsOrder
sql := `SELECT g.* FROM goods_order g WHERE g.order_created_at >= ? AND g.status = ? AND g.vendor_id = ? AND total_shop_money = ? ORDER BY g.order_created_at desc`
orderCreateTime := time.Now().AddDate(0, 0, -15)
param := []interface{}{orderCreateTime, model.OrderStatusFinished, model.VendorIDDD, model.NO}
if err := dao.GetRows(dao.GetDB(), &goodsOrders, sql, param...); err != nil {
if err := dao.GetRows(db, &goodsOrders, sql, param...); err != nil {
globals.SugarLogger.Debugf("Update GoodsOrder Total shop money err %s", err)
return
}
orderList := make([]string, 0, 0)
goodsOrdersMap := make(map[string]*model.GoodsOrder, len(goodsOrders))
for _, v := range goodsOrders {
orderList = append(orderList, v.VendorOrderID)
goodsOrdersMap[v.VendorOrderID] = v
}
db := dao.GetDB()
randNum := 0
nextStartIndex := ""
if len(orderList) <= 50 {
randNum = 1
} else {
randNum = len(orderList) / 50
if len(orderList)%50 != 0 {
randNum++
for _, v := range goodsOrders {
orderDetail, err := tiktok_store.GetOrderDetail(v.VendorOrgCode, v.VendorOrderID)
if err != nil {
globals.SugarLogger.Errorf("定时任务:查询订单详情错误,更新订单结算信息,[%s]", err)
continue
}
}
for i := 0; i < randNum; i++ {
orderString := strings.Join(orderList[0:i*50], ",")
orderMap, next, err := api.TiktokStore.GetSettleBillDetailV3(&order_getSettleBillDetailV3_request.OrderGetSettleBillDetailV3Param{
Size: 50,
OrderId: orderString,
StartIndex: nextStartIndex,
})
childrenOrderList := make([]string, 0, 0)
for _, v := range orderDetail.SkuOrderList {
childrenOrderList = append(childrenOrderList, v.OrderId)
}
totalShopMoney, next, err := tiktok_store.GetOrderTotalShopMoney(v.VendorOrgCode, strings.Join(childrenOrderList, ","), nextStartIndex)
if err != nil {
globals.SugarLogger.Errorf("获取平台订单异常 : %s", err)
continue
}
for k, v := range orderMap {
goodsOrdersMap[k].TotalShopMoney = v
if _, err := dao.UpdateEntity(db, goodsOrdersMap[k], "TotalShopMoney"); err != nil {
globals.SugarLogger.Errorf("更新本地订单结算信息错误 : %s", err)
continue
}
}
nextStartIndex = next
v.TotalShopMoney = totalShopMoney
if _, err := dao.UpdateEntity(db, v, "TotalShopMoney"); err != nil {
globals.SugarLogger.Errorf("更新本地订单结算信息错误 : %s", err)
continue
}
}
}