|
|
@ -2223,123 +2223,157 @@ namespace djy.Paas.Service
|
|
|
|
var cfgAutoCompId = DjyTools.GetConfigKey("baoguanAutoBindCompanyFeeCompId");
|
|
|
|
var cfgAutoCompId = DjyTools.GetConfigKey("baoguanAutoBindCompanyFeeCompId");
|
|
|
|
var cfgDingtalk = DjyTools.GetConfigKey("baoguanDingtalkNotify");
|
|
|
|
var cfgDingtalk = DjyTools.GetConfigKey("baoguanDingtalkNotify");
|
|
|
|
|
|
|
|
|
|
|
|
_LogsAdd($"报关自动扣费,公司参数:{cfgAutoCompId}", "胜云航通客服消息", null);
|
|
|
|
_LogsAdd($"报关自动扣费,公司参数:{cfgAutoCompId}", "胜云航通自动扣费", null);
|
|
|
|
_LogsAdd($"报关自动扣费,钉钉:{cfgDingtalk}", "胜云航通客服消息", null);
|
|
|
|
_LogsAdd($"报关自动扣费,钉钉:{cfgDingtalk}", "胜云航通自动扣费", null);
|
|
|
|
|
|
|
|
|
|
|
|
if (!string.IsNullOrEmpty(cfgAutoCompId))
|
|
|
|
if (!string.IsNullOrEmpty(cfgAutoCompId))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
try
|
|
|
|
var arr = cfgAutoCompId.Split(",".ToCharArray(), StringSplitOptions.RemoveEmptyEntries);
|
|
|
|
|
|
|
|
_LogsAdd($"报关自动扣费,待处理公司:{arr.Length}", "胜云航通自动扣费", null);
|
|
|
|
|
|
|
|
foreach (var compid in arr)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var arr = cfgAutoCompId.Split(",".ToCharArray(), StringSplitOptions.RemoveEmptyEntries);
|
|
|
|
var guidComp = Guid.Parse(compid);
|
|
|
|
_LogsAdd($"报关自动扣费,待处理公司:{arr.Length}", "胜云航通客服消息", null);
|
|
|
|
var orderList = DbBus.Get(DbList.djypublicedb)
|
|
|
|
foreach (var compid in arr)
|
|
|
|
.Select<tb_BaoGuanOrderList>()
|
|
|
|
|
|
|
|
.Where(x => x.CompId == guidComp
|
|
|
|
|
|
|
|
&& (x.StaCustFee == null || x.StaCustFee == "") //未扣费
|
|
|
|
|
|
|
|
&& x.ClientName != null && x.ClientName != "" //已绑定客户
|
|
|
|
|
|
|
|
&& (x.stateCode == "14" || x.stateCode == "15" || x.stateCode == "18"))//14海关放行,15已结关,18准予入港
|
|
|
|
|
|
|
|
.ToList();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_LogsAdd($"处理{guidComp}的报关自动扣费,共发现{orderList.Count}票", "胜云航通自动扣费", null);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
foreach (var ord in orderList)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var guidComp = Guid.Parse(compid);
|
|
|
|
var customerComp = DbBus.Get(DbList.djyolddb)
|
|
|
|
var orderList = DbBus.Get(DbList.djypublicedb)
|
|
|
|
.Select<CompanyNew>()
|
|
|
|
.Select<tb_BaoGuanOrderList>()
|
|
|
|
.Where(x => x.CompName == ord.ClientName)
|
|
|
|
.Where(x => x.CompId == guidComp
|
|
|
|
.ToOne();
|
|
|
|
&& (x.StaCustFee == null || x.StaCustFee == "") //未扣费
|
|
|
|
|
|
|
|
&& x.ClientName != null && x.ClientName != "" //已绑定客户
|
|
|
|
if (customerComp == null)
|
|
|
|
&& (x.stateCode == "14" || x.stateCode == "15" || x.stateCode == "18"))//14海关放行,15已结关,18准予入港
|
|
|
|
|
|
|
|
.ToList();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_LogsAdd($"处理{compid}的报关自动扣费,共发现{orderList.Count}票", "胜云航通客服消息", null);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
foreach (var ord in orderList)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var customerComp = DbBus.Get(DbList.djyolddb)
|
|
|
|
//推送钉钉消息给客服
|
|
|
|
.Select<CompanyNew>()
|
|
|
|
var content = $"公司{ord.ClientName}未找到";
|
|
|
|
.Where(x => x.CompName == ord.ClientName)
|
|
|
|
_LogsAdd(content, "胜云航通自动扣费", null);
|
|
|
|
.ToOne();
|
|
|
|
var gethtml = DjyTools.PostOnLogs(new { text = new { content = $"【未扣费提醒】\r\n{content}\r\n----报关消息通知" }, msgtype = "text" }, cfgDingtalk, "胜云航通自动扣费", YsPsotType.Json).Result;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//设置状态
|
|
|
|
|
|
|
|
DbBus.Get(DbList.djypublicedb).Update<tb_BaoGuanOrderList>()
|
|
|
|
|
|
|
|
.Where(x => x.Gid == ord.Gid)
|
|
|
|
|
|
|
|
.Set(x => x.StaCustFee, "FAIL")
|
|
|
|
|
|
|
|
.Set(x => x.TimeCustFee, DateTime.Now)
|
|
|
|
|
|
|
|
.ExecuteAffrows();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (customerComp == null)
|
|
|
|
var balance = DbBus.Get(DbList.djyolddb)
|
|
|
|
{
|
|
|
|
.Select<CustBalance>()
|
|
|
|
//推送钉钉消息给客服
|
|
|
|
.Where(x => x.COMNAME == customerComp.CompName)
|
|
|
|
var content = $"公司{ord.ClientName}未找到";
|
|
|
|
.ToOne();
|
|
|
|
_LogsAdd(content, "胜云航通客服消息", null);
|
|
|
|
|
|
|
|
var gethtml = DjyTools.PostOnLogs(new { text = new { content = $"【未扣费提醒】\r\n{content}\r\n----报关消息通知" }, msgtype = "text" }, cfgDingtalk, "胜云航通客服消息", YsPsotType.Json).Result;
|
|
|
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var balance = DbBus.Get(DbList.djyolddb)
|
|
|
|
//没有钱包
|
|
|
|
.Select<CustBalance>()
|
|
|
|
if (balance == null)
|
|
|
|
.Where(x => x.COMNAME == customerComp.CompName)
|
|
|
|
{
|
|
|
|
.ToOne();
|
|
|
|
//推送钉钉消息给客服
|
|
|
|
|
|
|
|
var content = $"公司{ord.ClientName}没有钱包";
|
|
|
|
|
|
|
|
_LogsAdd(content, "胜云航通自动扣费", null);
|
|
|
|
|
|
|
|
var gethtml = DjyTools.PostOnLogs(new { text = new { content = $"【未扣费提醒】\r\n{content}\r\n----报关消息通知" }, msgtype = "text" }, cfgDingtalk, "胜云航通自动扣费", YsPsotType.Json).Result;
|
|
|
|
|
|
|
|
|
|
|
|
//没有钱包
|
|
|
|
|
|
|
|
if (balance == null)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
//推送钉钉消息给客服
|
|
|
|
|
|
|
|
var content = $"公司{ord.ClientName}没有钱包";
|
|
|
|
|
|
|
|
_LogsAdd(content, "胜云航通客服消息", null);
|
|
|
|
|
|
|
|
var gethtml = DjyTools.PostOnLogs(new { text = new { content = $"【未扣费提醒】\r\n{content}\r\n----报关消息通知" }, msgtype = "text" }, cfgDingtalk, "胜云航通客服消息", YsPsotType.Json).Result;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
continue;
|
|
|
|
//设置状态
|
|
|
|
}
|
|
|
|
DbBus.Get(DbList.djypublicedb).Update<tb_BaoGuanOrderList>()
|
|
|
|
|
|
|
|
.Where(x => x.Gid == ord.Gid)
|
|
|
|
|
|
|
|
.Set(x => x.StaCustFee, "FAIL")
|
|
|
|
|
|
|
|
.Set(x => x.TimeCustFee, DateTime.Now)
|
|
|
|
|
|
|
|
.ExecuteAffrows();
|
|
|
|
|
|
|
|
|
|
|
|
var price = DbBus.Get(DbList.djyolddb)
|
|
|
|
continue;
|
|
|
|
.Select<CustPrice>()
|
|
|
|
}
|
|
|
|
.Where(x => x.COMNAME == customerComp.CompName && x.SENDTYPE == 0 && x.BSTYPE == 13)
|
|
|
|
|
|
|
|
.ToOne();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//未设置单价
|
|
|
|
var price = DbBus.Get(DbList.djyolddb)
|
|
|
|
if (price == null)
|
|
|
|
.Select<CustPrice>()
|
|
|
|
{
|
|
|
|
.Where(x => x.COMNAME == customerComp.CompName && x.SENDTYPE == 0 && x.BSTYPE == 13)
|
|
|
|
//推送钉钉消息给客服
|
|
|
|
.ToOne();
|
|
|
|
var content = $"公司{ord.ClientName}的报关单价未设置";
|
|
|
|
|
|
|
|
var gethtml = DjyTools.PostOnLogs(new { text = new { content = $"【未扣费提醒】\r\n{content}\r\n----报关消息通知" }, msgtype = "text" }, cfgDingtalk, "胜云航通客服消息", YsPsotType.Json).Result;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
continue;
|
|
|
|
//未设置单价
|
|
|
|
}
|
|
|
|
if (price == null)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
//推送钉钉消息给客服
|
|
|
|
|
|
|
|
var content = $"公司{ord.ClientName}的报关单价未设置";
|
|
|
|
|
|
|
|
var gethtml = DjyTools.PostOnLogs(new { text = new { content = $"【未扣费提醒】\r\n{content}\r\n----报关消息通知" }, msgtype = "text" }, cfgDingtalk, "胜云航通自动扣费", YsPsotType.Json).Result;
|
|
|
|
|
|
|
|
|
|
|
|
//余额不足
|
|
|
|
|
|
|
|
if (price.PRICE > balance.Balance)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
//推送钉钉消息给客服
|
|
|
|
|
|
|
|
var content = $"公司{ord.ClientName}的余额不足";
|
|
|
|
|
|
|
|
var gethtml = DjyTools.PostOnLogs(new { text = new { content = $"【未扣费提醒】\r\n{content}\r\n----报关消息通知" }, msgtype = "text" }, cfgDingtalk, "胜云航通客服消息", YsPsotType.Json).Result;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
continue;
|
|
|
|
//设置状态
|
|
|
|
}
|
|
|
|
DbBus.Get(DbList.djypublicedb).Update<tb_BaoGuanOrderList>()
|
|
|
|
|
|
|
|
.Where(x => x.Gid == ord.Gid)
|
|
|
|
|
|
|
|
.Set(x => x.StaCustFee, "FAIL")
|
|
|
|
|
|
|
|
.Set(x => x.TimeCustFee, DateTime.Now)
|
|
|
|
|
|
|
|
.ExecuteAffrows();
|
|
|
|
|
|
|
|
|
|
|
|
//执行扣费
|
|
|
|
continue;
|
|
|
|
var fin = new FinanceService();
|
|
|
|
}
|
|
|
|
var getfinrs = fin.Expend(new djy.Model.CustFee
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
SENDUSERID = customerComp.AdminUser,
|
|
|
|
|
|
|
|
LURURENID = customerComp.AdminUser,
|
|
|
|
|
|
|
|
CtnrCount = 1,
|
|
|
|
|
|
|
|
CtnrInfo = string.Empty,
|
|
|
|
|
|
|
|
BSTYPE = 13,
|
|
|
|
|
|
|
|
SENDTYPE = 0,
|
|
|
|
|
|
|
|
BSNO = ord.Gid.ToString(),
|
|
|
|
|
|
|
|
MBLNO = ord.ShipOrderNo
|
|
|
|
|
|
|
|
}, 1);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (getfinrs.Status)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
//设置状态
|
|
|
|
|
|
|
|
DbBus.Get(DbList.djypublicedb).Update<tb_BaoGuanOrderList>()
|
|
|
|
|
|
|
|
.Where(x => x.Gid == ord.Gid)
|
|
|
|
|
|
|
|
.Set(x => x.StaCustFee, "OK")
|
|
|
|
|
|
|
|
.Set(x => x.TimeCustFee, DateTime.Now)
|
|
|
|
|
|
|
|
.ExecuteAffrows();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
//推送钉钉消息给客服
|
|
|
|
|
|
|
|
var content = $"公司{ord.ClientName}报关扣费失败:{getfinrs.Message}";
|
|
|
|
|
|
|
|
var gethtml = DjyTools.PostOnLogs(new { text = new { content = $"【未扣费提醒】\r\n{content}\r\n----报关消息通知" }, msgtype = "text" }, cfgDingtalk, "胜云航通客服消息", YsPsotType.Json).Result;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
//余额不足
|
|
|
|
|
|
|
|
if (price.PRICE > balance.Balance)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
//推送钉钉消息给客服
|
|
|
|
|
|
|
|
var content = $"公司{ord.ClientName}的余额不足";
|
|
|
|
|
|
|
|
var gethtml = DjyTools.PostOnLogs(new { text = new { content = $"【未扣费提醒】\r\n{content}\r\n----报关消息通知" }, msgtype = "text" }, cfgDingtalk, "胜云航通自动扣费", YsPsotType.Json).Result;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//设置状态
|
|
|
|
|
|
|
|
DbBus.Get(DbList.djypublicedb).Update<tb_BaoGuanOrderList>()
|
|
|
|
|
|
|
|
.Where(x => x.Gid == ord.Gid)
|
|
|
|
|
|
|
|
.Set(x => x.StaCustFee, "FAIL")
|
|
|
|
|
|
|
|
.Set(x => x.TimeCustFee, DateTime.Now)
|
|
|
|
|
|
|
|
.ExecuteAffrows();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//执行扣费
|
|
|
|
|
|
|
|
var fin = new FinanceService();
|
|
|
|
|
|
|
|
var getfinrs = fin.Expend(new djy.Model.CustFee
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
SENDUSERID = customerComp.AdminUser,
|
|
|
|
|
|
|
|
LURURENID = customerComp.AdminUser,
|
|
|
|
|
|
|
|
CtnrCount = 1,
|
|
|
|
|
|
|
|
CtnrInfo = string.Empty,
|
|
|
|
|
|
|
|
BSTYPE = 13,
|
|
|
|
|
|
|
|
SENDTYPE = 0,
|
|
|
|
|
|
|
|
BSNO = ord.Gid.ToString(),
|
|
|
|
|
|
|
|
MBLNO = ord.ShipOrderNo
|
|
|
|
|
|
|
|
}, 1);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (getfinrs.Status)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
//设置状态
|
|
|
|
|
|
|
|
DbBus.Get(DbList.djypublicedb).Update<tb_BaoGuanOrderList>()
|
|
|
|
|
|
|
|
.Where(x => x.Gid == ord.Gid)
|
|
|
|
|
|
|
|
.Set(x => x.StaCustFee, "OK")
|
|
|
|
|
|
|
|
.Set(x => x.TimeCustFee, DateTime.Now)
|
|
|
|
|
|
|
|
.ExecuteAffrows();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
//设置状态
|
|
|
|
|
|
|
|
DbBus.Get(DbList.djypublicedb).Update<tb_BaoGuanOrderList>()
|
|
|
|
|
|
|
|
.Where(x => x.Gid == ord.Gid)
|
|
|
|
|
|
|
|
.Set(x => x.StaCustFee, "FAIL")
|
|
|
|
|
|
|
|
.Set(x => x.TimeCustFee, DateTime.Now)
|
|
|
|
|
|
|
|
.ExecuteAffrows();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//推送钉钉消息给客服
|
|
|
|
|
|
|
|
var content = $"公司{ord.ClientName}报关扣费失败:{getfinrs.Message}";
|
|
|
|
|
|
|
|
var gethtml = DjyTools.PostOnLogs(new { text = new { content = $"【未扣费提醒】\r\n{content}\r\n----报关消息通知" }, msgtype = "text" }, cfgDingtalk, "胜云航通自动扣费", YsPsotType.Json).Result;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Exception ex)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
_LogsAdd(ex.Message, "胜云航通自动扣费", new { ex.StackTrace });
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endregion
|
|
|
|
#endregion
|
|
|
|