|
|
@ -34,9 +34,94 @@ namespace BBWY.Server.Business.Sync |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
private void SyncServiceOrder(ShopResponse shop, JArray jArray) |
|
|
|
private void SyncServiceOrder(ShopResponse shop, long shopId, IList<JToken> jtokenList, string relayAPIHost, string appKey, string appSecret, string token) |
|
|
|
{ |
|
|
|
var serviceIdList = jtokenList.Select(j => j.Value<string>("serviceId")).ToList(); |
|
|
|
var dbServiceOrderList = fsql.Select<ServiceOrder>().Where(s => s.ShopId == shop.ShopId && serviceIdList.Contains(s.ServiceId)).ToList(); |
|
|
|
var dbServiceIdList = dbServiceOrderList.Select(s => s.ServiceId).ToList(); |
|
|
|
var exceptServiceIdList = serviceIdList.Except(dbServiceIdList); |
|
|
|
|
|
|
|
var apiOrderIdList = jtokenList.Where(j => exceptServiceIdList.Contains(j.Value<string>("serviceId"))).Select(j => j.Value<string>("orderId")).ToList(); |
|
|
|
var dbOrderSkuList = fsql.Select<OrderSku, Order>().InnerJoin((osku, o) => osku.OrderId == o.Id) |
|
|
|
.Where((osku, o) => osku.ShopId == shopId && apiOrderIdList.Contains(osku.OrderId)) |
|
|
|
.ToList((osku, o) => new |
|
|
|
{ |
|
|
|
Id = osku.Id, |
|
|
|
ProductId = osku.ProductId, |
|
|
|
SkuId = osku.SkuId, |
|
|
|
OrderId = osku.OrderId, |
|
|
|
ItemTotal = osku.ItemTotal, |
|
|
|
StorageType = o.StorageType |
|
|
|
}); |
|
|
|
|
|
|
|
foreach (var serviceOrderJToken in jtokenList) |
|
|
|
{ |
|
|
|
var serviceId = serviceOrderJToken.Value<string>("serviceId"); |
|
|
|
var status = serviceOrderJToken.Value<int>("sserviceOrderJToken"); |
|
|
|
var dbServiceOrder = dbServiceOrderList.FirstOrDefault(s => s.ServiceId == serviceId); |
|
|
|
if (dbServiceOrder == null) |
|
|
|
{ |
|
|
|
var serviceOrderId = serviceOrderJToken.Value<string>("orderId"); |
|
|
|
var skuId = serviceOrderJToken.Value<string>("skuId"); |
|
|
|
var dbOsku = dbOrderSkuList.FirstOrDefault(osku => osku.OrderId == serviceOrderId && osku.SkuId == skuId); |
|
|
|
if (dbOsku == null) |
|
|
|
continue; |
|
|
|
var isNeedSubscribeKuaiDi100 = false; |
|
|
|
|
|
|
|
#region 待收货服务单,检查是否需要订阅快递100
|
|
|
|
if (status == 10005) |
|
|
|
{ |
|
|
|
if (dbOsku.StorageType == Enums.StorageType.代发) |
|
|
|
isNeedSubscribeKuaiDi100 = true; |
|
|
|
else |
|
|
|
{ |
|
|
|
try |
|
|
|
{ |
|
|
|
var serviceOrderDetailResult = restApiService.SendRequest(relayAPIHost, "api/PlatformSDK/GetServiceOrderDetail", new QueryServiceOrderDetailRequest() |
|
|
|
{ |
|
|
|
AppKey = appKey, |
|
|
|
AppSecret = appSecret, |
|
|
|
AppToken = token, |
|
|
|
OrderId = serviceOrderId, |
|
|
|
ServiceId = serviceId, |
|
|
|
Platform = Enums.Platform.京东, |
|
|
|
VenderId = shop.VenderId |
|
|
|
}, GetYunDingRequestHeader(), HttpMethod.Post); |
|
|
|
|
|
|
|
if (serviceOrderDetailResult.StatusCode != System.Net.HttpStatusCode.OK) |
|
|
|
throw new Exception($"获取服务单详情失败 {serviceOrderDetailResult.Content}"); |
|
|
|
var serviceOrderDetailResponse = JsonConvert.DeserializeObject<ApiResponse<JToken>>(serviceOrderDetailResult.Content); |
|
|
|
if (!serviceOrderDetailResponse.Success) |
|
|
|
throw new Exception($"获取服务单详情失败 {serviceOrderDetailResponse.Msg}"); |
|
|
|
|
|
|
|
//检查退货城市是否为泉州
|
|
|
|
isNeedSubscribeKuaiDi100 = serviceOrderDetailResponse.Data["returnWareAddress"].Value<int>("cityCode") == 2812; |
|
|
|
} |
|
|
|
catch { } |
|
|
|
} |
|
|
|
} |
|
|
|
#endregion
|
|
|
|
|
|
|
|
dbServiceOrder = new ServiceOrder() |
|
|
|
{ |
|
|
|
Id = idGenerator.NewLong(), |
|
|
|
ServiceId = serviceId, |
|
|
|
OrderId = serviceOrderId, |
|
|
|
ShopId = shop.ShopId, |
|
|
|
ProductId = dbOsku.ProductId, |
|
|
|
SkuItemCount = dbOsku.ItemTotal, |
|
|
|
Status = status, |
|
|
|
CreateTime = DateTime.Now, |
|
|
|
SkuId = skuId, |
|
|
|
StatusUpdateTime = serviceOrderJToken.Value<DateTime>("updateTime"), |
|
|
|
IsSubscribeKuaiDi100 = false, |
|
|
|
IsNeedSubscribeKuaiDi100 = isNeedSubscribeKuaiDi100, |
|
|
|
WaybillNo = string.Empty, |
|
|
|
ExpressName = string.Empty, |
|
|
|
ApplyTime = serviceOrderJToken.Value<DateTime>("applyTime") |
|
|
|
}; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
private void SyncServiceOrder(ShopResponse shop, string orderId, DateTime? startTime = null, DateTime? endTime = null, bool isAuto = false) |
|
|
@ -63,7 +148,7 @@ namespace BBWY.Server.Business.Sync |
|
|
|
var shopId = long.Parse(shop.ShopId); |
|
|
|
var relayAPIHost = GetPlatformRelayAPIHost(shop.PlatformId); |
|
|
|
var serviceStatusList = new List<int>() { 10005, 10011, 10010 }; |
|
|
|
#region
|
|
|
|
|
|
|
|
var request = new QueryServiceOrderRequest() |
|
|
|
{ |
|
|
|
UpdateTimeBegin = startTime ?? DateTime.Now.Date.AddHours(-1), |
|
|
@ -91,69 +176,8 @@ namespace BBWY.Server.Business.Sync |
|
|
|
throw new Exception($"获取服务单失败 {serviceOrderListResponse.Msg}"); |
|
|
|
jtokenList.AddRange(serviceOrderListResponse.Data); |
|
|
|
} |
|
|
|
#endregion
|
|
|
|
|
|
|
|
var serviceIdList = jtokenList.Select(j => j.Value<string>("serviceId")).ToList(); |
|
|
|
var dbServiceOrderList = fsql.Select<ServiceOrder>().Where(s => s.ShopId == shop.ShopId && serviceIdList.Contains(s.ServiceId)).ToList(); |
|
|
|
var dbServiceIdList = dbServiceOrderList.Select(s => s.ServiceId).ToList(); |
|
|
|
var exceptServiceIdList = serviceIdList.Except(dbServiceIdList); |
|
|
|
|
|
|
|
var apiOrderIdList = jtokenList.Where(j => exceptServiceIdList.Contains(j.Value<string>("serviceId"))).Select(j => j.Value<string>("orderId")).ToList(); |
|
|
|
var dbOrderSkuList = fsql.Select<OrderSku, Order>().InnerJoin((osku, o) => osku.OrderId == o.Id) |
|
|
|
.Where((osku, o) => osku.ShopId == shopId && apiOrderIdList.Contains(osku.OrderId)) |
|
|
|
.ToList((osku, o) => new |
|
|
|
{ |
|
|
|
Id = osku.Id, |
|
|
|
ProductId = osku.ProductId, |
|
|
|
SkuId = osku.SkuId, |
|
|
|
OrderId = osku.OrderId, |
|
|
|
ItemTotal = osku.ItemTotal, |
|
|
|
StorageType = o.StorageType |
|
|
|
}); |
|
|
|
|
|
|
|
foreach (var serviceOrderJToken in jtokenList) |
|
|
|
{ |
|
|
|
var serviceId = serviceOrderJToken.Value<string>("serviceId"); |
|
|
|
var dbServiceOrder = dbServiceOrderList.FirstOrDefault(s => s.ServiceId == serviceId); |
|
|
|
if (dbServiceOrder == null) |
|
|
|
{ |
|
|
|
var serviceOrderId = serviceOrderJToken.Value<string>("orderId"); |
|
|
|
var skuId = serviceOrderJToken.Value<string>("skuId"); |
|
|
|
var dbOsku = dbOrderSkuList.FirstOrDefault(osku => osku.OrderId == serviceOrderId && osku.SkuId == skuId); |
|
|
|
if (dbOsku == null) |
|
|
|
continue; |
|
|
|
var isNeedSubscribeKuaiDi100 = false; |
|
|
|
|
|
|
|
if (dbOsku.StorageType == Enums.StorageType.代发) |
|
|
|
isNeedSubscribeKuaiDi100 = true; |
|
|
|
else |
|
|
|
{ |
|
|
|
//检查退货城市是否为泉州
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
dbServiceOrder = new ServiceOrder() |
|
|
|
{ |
|
|
|
Id = idGenerator.NewLong(), |
|
|
|
ServiceId = serviceId, |
|
|
|
OrderId = serviceOrderId, |
|
|
|
ShopId = shop.ShopId, |
|
|
|
ProductId = dbOsku.ProductId, |
|
|
|
SkuItemCount = dbOsku.ItemTotal, |
|
|
|
Status = serviceOrderJToken.Value<int>("sserviceOrderJToken"), |
|
|
|
CreateTime = DateTime.Now, |
|
|
|
SkuId = skuId, |
|
|
|
StatusUpdateTime = serviceOrderJToken.Value<DateTime>("updateTime"), |
|
|
|
IsSubscribeKuaiDi100 = false, |
|
|
|
IsNeedSubscribeKuaiDi100 = isNeedSubscribeKuaiDi100, |
|
|
|
WaybillNo = string.Empty, |
|
|
|
ExpressName = string.Empty, |
|
|
|
ApplyTime = serviceOrderJToken.Value<DateTime>("applyTime") |
|
|
|
}; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
//SyncServiceOrder(shop, serviceOrderListResponse.Data);
|
|
|
|
SyncServiceOrder(shop, shopId, jtokenList, relayAPIHost, request.AppKey, request.AppSecret, request.AppToken); |
|
|
|
} |
|
|
|
catch (Exception ex) |
|
|
|
{ |
|
|
|