|
|
|
|
@@ -310,20 +310,25 @@ func (p *PurchaseHandler) FullSyncStoreSkus(ctx *jxcontext.Context, parentTask t
|
|
|
|
|
rootTask := tasksch.NewSeqTask("美团外卖FullSyncStoreSkus", userName, func(rootTask *tasksch.SeqTask, step int, params ...interface{}) (result interface{}, err error) {
|
|
|
|
|
switch step {
|
|
|
|
|
case 0:
|
|
|
|
|
if err = p.DeleteRemoteSkus(ctx, rootTask, storeID, nil); err == nil {
|
|
|
|
|
_, err = dao.SetStoreCategorySyncStatus(db, model.VendorIDMTWM, storeID, nil, model.SyncFlagNewMask)
|
|
|
|
|
err = p.DeleteRemoteSkus(ctx, rootTask, storeID, nil)
|
|
|
|
|
if isContinueWhenError {
|
|
|
|
|
err = nil
|
|
|
|
|
}
|
|
|
|
|
case 1:
|
|
|
|
|
_, err = dao.SetStoreSkuSyncStatus(db, model.VendorIDMTWM, storeID, nil, model.SyncFlagNewMask)
|
|
|
|
|
case 2:
|
|
|
|
|
_, err = p.SyncLocalStoreCategory(ctx, db, storeID, true)
|
|
|
|
|
if err = p.DeleteRemoteCategories(ctx, rootTask, storeID, nil); err == nil {
|
|
|
|
|
_, err = dao.SetStoreCategorySyncStatus(db, model.VendorIDMTWM, storeID, nil, model.SyncFlagNewMask)
|
|
|
|
|
}
|
|
|
|
|
case 3:
|
|
|
|
|
_, err = p.SyncStoreCategory(ctx, rootTask, storeID, false)
|
|
|
|
|
_, err = p.SyncLocalStoreCategory(ctx, db, storeID, true)
|
|
|
|
|
case 4:
|
|
|
|
|
_, err = p.SyncStoreCategory(ctx, rootTask, storeID, false)
|
|
|
|
|
case 5:
|
|
|
|
|
_, err = p.SyncStoreSkus(ctx, rootTask, storeID, nil, false, isContinueWhenError)
|
|
|
|
|
}
|
|
|
|
|
return nil, err
|
|
|
|
|
}, 5)
|
|
|
|
|
}, 6)
|
|
|
|
|
tasksch.AddChild(parentTask, rootTask).Run()
|
|
|
|
|
if !isAsync {
|
|
|
|
|
_, err = rootTask.GetResult(0)
|
|
|
|
|
@@ -377,7 +382,7 @@ func (p *PurchaseHandler) GetAllRemoteSkus(storeID int) (skus []map[string]inter
|
|
|
|
|
return skus, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (p *PurchaseHandler) DeleteRemoteCategories(storeID int, vendorCatIDs []string) (err error) {
|
|
|
|
|
func (p *PurchaseHandler) DeleteRemoteCategories(ctx *jxcontext.Context, parentTask tasksch.ITask, storeID int, vendorCatIDs []string) (err error) {
|
|
|
|
|
storeDetail, err := dao.GetStoreDetail(dao.GetDB(), storeID, model.VendorIDMTWM)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
@@ -416,11 +421,41 @@ func (p *PurchaseHandler) DeleteRemoteCategories(storeID int, vendorCatIDs []str
|
|
|
|
|
}
|
|
|
|
|
return nil, err
|
|
|
|
|
}, 2)
|
|
|
|
|
rootTask.Run()
|
|
|
|
|
tasksch.AddChild(parentTask, rootTask).Run()
|
|
|
|
|
_, err = rootTask.GetResult(0)
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (p *PurchaseHandler) DeleteRemoteStoreSkus(ctx *jxcontext.Context, parentTask tasksch.ITask, storeID int, isAsync, isContinueWhenError bool) (hint string, err error) {
|
|
|
|
|
return hint, err
|
|
|
|
|
userName := ctx.GetUserName()
|
|
|
|
|
globals.SugarLogger.Debugf("mtwm DeleteRemoteStoreSkus storeID:%d, isContinueWhenError:%t, userName:%s", storeID, isContinueWhenError, userName)
|
|
|
|
|
|
|
|
|
|
db := dao.GetDB()
|
|
|
|
|
var errDeleteSku error
|
|
|
|
|
rootTask := tasksch.NewSeqTask("mtwm DeleteRemoteStoreSkus", userName, func(rootTask *tasksch.SeqTask, step int, params ...interface{}) (result interface{}, err error) {
|
|
|
|
|
switch step {
|
|
|
|
|
case 0:
|
|
|
|
|
err = p.DeleteRemoteSkus(ctx, rootTask, storeID, nil)
|
|
|
|
|
errDeleteSku = err
|
|
|
|
|
// 强制忽略删除SKU错误
|
|
|
|
|
if isContinueWhenError {
|
|
|
|
|
err = nil
|
|
|
|
|
}
|
|
|
|
|
case 1:
|
|
|
|
|
_, err = dao.SetStoreSkuSyncStatus(db, model.VendorIDMTWM, storeID, nil, model.SyncFlagNewMask)
|
|
|
|
|
case 2:
|
|
|
|
|
if err = p.DeleteRemoteCategories(ctx, rootTask, storeID, nil); err == nil {
|
|
|
|
|
_, err = dao.SetStoreCategorySyncStatus(db, model.VendorIDMTWM, storeID, nil, model.SyncFlagNewMask)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return nil, err
|
|
|
|
|
}, 3)
|
|
|
|
|
tasksch.AddChild(parentTask, rootTask).Run()
|
|
|
|
|
if !isAsync {
|
|
|
|
|
_, err = rootTask.GetResult(0)
|
|
|
|
|
}
|
|
|
|
|
if err == nil {
|
|
|
|
|
err = errDeleteSku
|
|
|
|
|
}
|
|
|
|
|
return rootTask.ID, err
|
|
|
|
|
}
|
|
|
|
|
|