Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
M
mall.oytour.com
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
黄奎
mall.oytour.com
Commits
84f2e737
Commit
84f2e737
authored
Jul 01, 2020
by
liudong1993
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'master' of
http://gitlab.oytour.com/Kui2/mall.oytour.com
parents
9e9a8fab
28f4937d
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
251 additions
and
128 deletions
+251
-128
OrderPayReidsCache.cs
Mall.CacheManager/AppletWeChat/OrderPayReidsCache.cs
+66
-0
DataConstant.cs
Mall.CacheManager/DataStatistic/DataConstant.cs
+6
-0
RB_Recharge_Settings.cs
Mall.Model/Entity/MarketingCenter/RB_Recharge_Settings.cs
+6
-0
PayUtil.cs
Mall.WebApi/App_Code/PayUtil.cs
+8
-2
LiveHouseController.cs
Mall.WebApi/Controllers/AppletWeChat/LiveHouseController.cs
+2
-2
WeChatPayController.cs
Mall.WebApi/Controllers/AppletWeChat/WeChatPayController.cs
+20
-0
MallHelper.cs
Mall.WebApi/Controllers/Mall/MallHelper.cs
+32
-19
StatisticsController.cs
...ebApi/Controllers/MarketingCenter/StatisticsController.cs
+2
-2
Mall.WindowsService.csproj
Mall.WindowsService/Mall.WindowsService.csproj
+1
-0
FinanceModule.cs
Mall.WindowsService/Module/FinanceModule.cs
+108
-103
No files found.
Mall.CacheManager/AppletWeChat/OrderPayReidsCache.cs
0 → 100644
View file @
84f2e737
using
Mall.CacheManager.DataStatistic
;
using
Mall.Common.Plugin.Redis
;
using
System
;
using
System.Collections.Generic
;
using
System.Text
;
namespace
Mall.CacheManager.AppletWeChat
{
public
class
OrderPayReidsCache
{
static
RedisHelper
redis
=
new
RedisHelper
(
DataStatistic
.
DataConstant
.
REDIS_DB2
,
DataStatistic
.
DataConstant
.
DATA_OrderPayId
);
/// <summary>
/// 设置缓存
/// </summary>
/// <param name="value"></param>
public
static
void
Set
(
string
cacheKey
,
string
value
,
TimeSpan
ts
)
{
try
{
// TimeSpan ts = DateTime.Now.AddMinutes(10) - DateTime.Now;
redis
.
StringSet
(
cacheKey
,
value
,
ts
);
}
catch
(
Exception
ex
)
{
Common
.
Plugin
.
LogHelper
.
Write
(
ex
,
"DATA_OrderPayId"
);
}
}
/// <summary>
/// 获取缓存
/// </summary>
/// <returns></returns>
public
static
string
Get
(
string
Key
)
{
string
cacheKey
=
DataConstant
.
DATA_OrderPayId
+
Key
;
try
{
Object
obj
=
redis
.
Get
(
cacheKey
);
if
(
obj
!=
null
)
{
return
obj
.
ToString
();
}
}
catch
(
Exception
ex
)
{
//再获取一次缓存
try
{
System
.
Threading
.
Thread
.
Sleep
(
500
);
Object
obj
=
redis
.
Get
(
cacheKey
);
if
(
obj
!=
null
)
{
return
obj
.
ToString
();
}
}
catch
(
Exception
ex2
)
{
Common
.
Plugin
.
LogHelper
.
Write
(
ex2
,
"DATA_OrderPayId2"
);
}
Common
.
Plugin
.
LogHelper
.
Write
(
ex
,
"DATA_OrderPayId"
);
}
return
""
;
}
}
}
Mall.CacheManager/DataStatistic/DataConstant.cs
View file @
84f2e737
...
...
@@ -21,5 +21,11 @@ namespace Mall.CacheManager.DataStatistic
/// 微信小程序token
/// </summary>
public
static
readonly
string
DATA_WeiXinToken
=
"DATA_WeiXinToken_"
;
/// <summary>
///订单支付缓存
/// </summary>
public
static
readonly
string
DATA_OrderPayId
=
"DATA_OrderPayId_"
;
}
}
Mall.Model/Entity/MarketingCenter/RB_Recharge_Settings.cs
View file @
84f2e737
...
...
@@ -30,6 +30,12 @@ namespace Mall.Model.Entity.MarketingCenter
public
DateTime
CreateDate
{
get
;
set
;
}
public
DateTime
UpdateDate
{
get
;
set
;
}
/// <summary>
/// 是否显示充值余额按钮0-否,1-是 2020-07-01 add By:w
/// </summary>
public
int
IsOpenBtn
{
get
;
set
;
}
/// <summary>
/// 开启余额功能0-否,1-是
/// </summary>
...
...
Mall.WebApi/App_Code/PayUtil.cs
View file @
84f2e737
...
...
@@ -48,6 +48,7 @@ namespace Mall.WebApi.App_Code
/// <returns></returns>
public
static
string
GetMinUnifiedOrder
(
string
sOrderNo
,
string
sProductName
,
decimal
dPrice
,
string
CustomerId
,
string
openid
,
string
notify_url
,
RB_MiniProgram_Extend
model
,
IHttpContextAccessor
_accessor
,
string
IPAddress
)
{
DateTime
time_start
=
DateTime
.
Now
;
var
req
=
new
Common
.
Pay
.
WeChatPat
.
RequestHandler
();
req
.
SetKey
(
model
.
WeChatApiSecret
);
req
.
SetParameter
(
"appid"
,
model
.
MiniAppId
);
//微信开放平台审核通过的应用APPID
...
...
@@ -58,8 +59,8 @@ namespace Mall.WebApi.App_Code
req
.
SetParameter
(
"out_trade_no"
,
sOrderNo
);
req
.
SetParameter
(
"total_fee"
,
(
dPrice
*
100
).
ToString
(
"f0"
));
req
.
SetParameter
(
"spbill_create_ip"
,
IPAddress
);
req
.
SetParameter
(
"time_start"
,
DateTime
.
Now
.
ToString
(
"yyyyMMddHHmmss"
));
req
.
SetParameter
(
"time_expire"
,
DateTime
.
Now
.
AddMinutes
(
10
).
ToString
(
"yyyyMMddHHmmss"
));
req
.
SetParameter
(
"time_start"
,
time_start
.
ToString
(
"yyyyMMddHHmmss"
));
req
.
SetParameter
(
"time_expire"
,
time_start
.
AddMinutes
(
10
).
ToString
(
"yyyyMMddHHmmss"
));
req
.
SetParameter
(
"notify_url"
,
notify_url
);
req
.
SetParameter
(
"trade_type"
,
"JSAPI"
);
req
.
SetParameter
(
"openid"
,
openid
);
...
...
@@ -79,6 +80,11 @@ namespace Mall.WebApi.App_Code
LogHelper
.
Write
(
null
,
"订单号【"
+
sOrderNo
+
"】成功回调:"
+
xe
);
try
{
//存入缓存,方便自动取消的时候不被清理
TimeSpan
ts
=
time_start
.
AddMinutes
(
10
)
-
time_start
;
string
orderId
=
sOrderNo
[
17.
.];
System
.
Threading
.
Tasks
.
Task
.
Run
(()
=>
CacheManager
.
AppletWeChat
.
OrderPayReidsCache
.
Set
(
orderId
,
orderId
,
ts
));
var
prepayId
=
xe
.
GetElement
(
"prepay_id"
).
Value
;
var
payReq
=
new
RequestHandler
();
...
...
Mall.WebApi/Controllers/AppletWeChat/LiveHouseController.cs
View file @
84f2e737
...
...
@@ -121,7 +121,7 @@ namespace Mall.WebApi.Controllers.AppletWeChat
item
.
ALLCommission
=
item
.
CostFreight
+
item
.
CostMoney
+
item
.
PackingMoney
+
item
.
GoodsFreight
+
item
.
OneCommission
+
item
.
TwoCommission
+
item
.
OtherPrice
;
item
.
NoPaid
=
item
.
ALLCommission
-
item
.
Paid
;
item
.
GrossProfit
=
item
.
AllPrice
-
item
.
ALLCommission
;
item
.
GrossProfitRate
=
item
.
AllPrice
==
0
?
0
:
item
.
GrossProfit
/
item
.
AllPrice
;
item
.
GrossProfitRate
=
item
.
AllPrice
==
0
?
0
:
Math
.
Round
((
item
.
GrossProfit
/
item
.
AllPrice
),
2
,
MidpointRounding
.
AwayFromZero
);
}
pagelist
.
count
=
Convert
.
ToInt32
(
count
);
pagelist
.
pageData
=
list
;
...
...
@@ -183,7 +183,7 @@ namespace Mall.WebApi.Controllers.AppletWeChat
item
.
ALLCommission
=
item
.
CostFreight
+
item
.
CostMoney
+
item
.
PackingMoney
+
item
.
GoodsFreight
+
item
.
OneCommission
+
item
.
TwoCommission
+
item
.
OtherPrice
;
item
.
NoPaid
=
item
.
ALLCommission
-
item
.
Paid
;
item
.
GrossProfit
=
item
.
AllPrice
-
item
.
ALLCommission
;
item
.
GrossProfitRate
=
item
.
AllPrice
==
0
?
0
:
item
.
GrossProfit
/
item
.
AllPrice
;
item
.
GrossProfitRate
=
item
.
AllPrice
==
0
?
0
:
Math
.
Round
((
item
.
GrossProfit
/
item
.
AllPrice
),
2
,
MidpointRounding
.
AwayFromZero
)
;
}
#
region
组装数据
int
Num
=
0
;
...
...
Mall.WebApi/Controllers/AppletWeChat/WeChatPayController.cs
View file @
84f2e737
...
...
@@ -285,6 +285,8 @@ namespace Mall.WebApi.Controllers.AppletWeChat
#
region
测试接口
public
ApiResult
TestReturn
()
{
RB_MiniProgram_Extend
miniProgram
=
new
RB_MiniProgram_Extend
();
//2020年5月26号新增
...
...
@@ -302,6 +304,24 @@ namespace Mall.WebApi.Controllers.AppletWeChat
}
public
ApiResult
TestWeChatPay
()
{
RB_MiniProgram_Extend
miniProgram
=
new
RB_MiniProgram_Extend
();
//2020年5月26号新增
miniProgram
=
new
RB_MiniProgram_Extend
{
MiniAppId
=
"wxacd9f8cc3480d29e"
,
WeChatApiSecret
=
"936110e2c2214340b9829a3608bde6b0"
,
WeChatPayMerchants
=
"1562277941"
};
// programModule.GetMiniProgramModule(new RB_MiniProgram_Extend { MallBaseId = 1, TenantId =1 });
string
RefundOrderNo
=
"2020052916044326411"
;
var
pram
=
new
Common
.
Pay
.
WeChatPat
.
PayParam
()
{
TotalFee
=
Convert
.
ToInt32
(
0.01
*
100
),
RefundFee
=
Convert
.
ToInt32
(
0.01
*
100
),
OrderNumber
=
"202005291604432641"
,
RefundNumber
=
RefundOrderNo
};
string
sOrderNo
=
(
System
.
DateTime
.
Now
.
ToString
(
"yyyyMMddHHmmssfff"
))
+
"1001"
;
App_Code
.
PayUtil
.
GetMinUnifiedOrder
(
sOrderNo
,
"测试"
,
Convert
.
ToDecimal
(
0.05
),
"1"
,
""
,
Config
.
sTenpayNotify
,
miniProgram
,
_accessor
,
System
.
Net
.
Dns
.
GetHostEntry
(
System
.
Net
.
Dns
.
GetHostName
()).
AddressList
.
FirstOrDefault
(
address
=>
address
.
AddressFamily
==
System
.
Net
.
Sockets
.
AddressFamily
.
InterNetwork
)?.
ToString
());
return
ApiResult
.
Success
(
""
);
}
public
ApiResult
TestTransfersOrder
()
{
RB_MiniProgram_Extend
miniProgram
=
new
RB_MiniProgram_Extend
();
//2020年5月26号新增
...
...
Mall.WebApi/Controllers/Mall/MallHelper.cs
View file @
84f2e737
...
...
@@ -51,6 +51,11 @@ namespace Mall.WebApi.Controllers
/// </summary>
private
static
IntegralModule
integralModule
=
new
IntegralModule
();
/// <summary>
/// 充值设置
/// </summary>
private
static
RechargeModule
rechargeModule
=
new
RechargeModule
();
/// <summary>
/// 用户处理类
/// </summary>
...
...
@@ -171,7 +176,7 @@ namespace Mall.WebApi.Controllers
TenantId
=
TenantId
,
MallBaseId
=
MallBaseId
,
GoodsIds
=
Ids
,
GoodsStatus
=
1
GoodsStatus
=
1
});
List
<
GoodsDetailsItem2
>
newGoodsList
=
new
List
<
GoodsDetailsItem2
>();
...
...
@@ -182,7 +187,7 @@ namespace Mall.WebApi.Controllers
{
lastItem
.
id
=
tempGood
.
Id
;
lastItem
.
name
=
tempGood
.
Name
;
lastItem
.
price
=
Math
.
Round
((
tempGood
?.
SellingPrice
??
0
),
2
);
lastItem
.
price
=
Math
.
Round
((
tempGood
?.
SellingPrice
??
0
),
2
);
lastItem
.
picUrl
=
tempGood
?.
CoverImage
!=
null
?
Common
.
Config
.
GetFileUrl
(
tempGood
.
CoverImage
)
:
""
;
lastItem
.
OriginalPrice
=
Math
.
Round
((
tempGood
?.
OriginalPrice
??
0
),
2
);
newGoodsList
.
Add
(
lastItem
);
...
...
@@ -746,7 +751,7 @@ namespace Mall.WebApi.Controllers
{
TenantId
=
Convert
.
ToInt32
(
miniProgram
.
TenantId
),
MallBaseId
=
miniProgram
.
MallBaseId
,
GoodsStatus
=
1
,
GoodsStatus
=
1
,
});
if
(
goodsList
!=
null
&&
goodsList
.
Count
>
0
)
{
...
...
@@ -865,7 +870,7 @@ namespace Mall.WebApi.Controllers
h
=
1
,
x
=
0
,
y
=
0
,
link
=
new
List
<
rubikLinkItem
>()
link
=
new
List
<
rubikLinkItem
>()
{
new
rubikLinkItem
()
{
...
...
@@ -923,7 +928,7 @@ namespace Mall.WebApi.Controllers
h
=
12
,
x
=
10
,
y
=
0
,
link
=
new
List
<
rubikLinkItem
>()
link
=
new
List
<
rubikLinkItem
>()
{
new
rubikLinkItem
()
{
...
...
@@ -981,7 +986,7 @@ namespace Mall.WebApi.Controllers
h
=
6
,
x
=
10
,
y
=
0
,
link
=
new
List
<
rubikLinkItem
>()
link
=
new
List
<
rubikLinkItem
>()
{
new
rubikLinkItem
()
{
...
...
@@ -1039,7 +1044,7 @@ namespace Mall.WebApi.Controllers
h
=
24
,
x
=
0
,
y
=
0
,
link
=
new
List
<
rubikLinkItem
>()
link
=
new
List
<
rubikLinkItem
>()
{
new
rubikLinkItem
()
{
...
...
@@ -1065,7 +1070,7 @@ namespace Mall.WebApi.Controllers
h
=
12
,
x
=
20
,
y
=
0
,
link
=
new
List
<
rubikLinkItem
>()
link
=
new
List
<
rubikLinkItem
>()
{
new
rubikLinkItem
()
{
...
...
@@ -1091,7 +1096,7 @@ namespace Mall.WebApi.Controllers
h
=
12
,
x
=
20
,
y
=
12
,
link
=
new
List
<
rubikLinkItem
>()
link
=
new
List
<
rubikLinkItem
>()
{
new
rubikLinkItem
()
{
...
...
@@ -1117,7 +1122,7 @@ namespace Mall.WebApi.Controllers
h
=
12
,
x
=
35
,
y
=
12
,
link
=
new
List
<
rubikLinkItem
>()
link
=
new
List
<
rubikLinkItem
>()
{
new
rubikLinkItem
()
{
...
...
@@ -1149,7 +1154,7 @@ namespace Mall.WebApi.Controllers
h
=
16
,
x
=
0
,
y
=
0
,
link
=
new
List
<
rubikLinkItem
>()
link
=
new
List
<
rubikLinkItem
>()
{
new
rubikLinkItem
()
{
...
...
@@ -1207,7 +1212,7 @@ namespace Mall.WebApi.Controllers
h
=
24
,
x
=
0
,
y
=
0
,
link
=
new
List
<
rubikLinkItem
>()
link
=
new
List
<
rubikLinkItem
>()
{
new
rubikLinkItem
()
{
...
...
@@ -1318,7 +1323,7 @@ namespace Mall.WebApi.Controllers
h
=
1
,
x
=
1
,
y
=
0
,
link
=
new
List
<
rubikLinkItem
>()
link
=
new
List
<
rubikLinkItem
>()
{
new
rubikLinkItem
()
{
...
...
@@ -1555,6 +1560,13 @@ namespace Mall.WebApi.Controllers
{
integralModel
=
new
RB_Integral_Settings
();
}
//充值信息
var
rechargeModel
=
rechargeModule
.
GetRechargeSettingsList
(
new
RB_Recharge_Settings
{
TenantId
=
miniProgram
.
TenantId
??
0
,
MallBaseId
=
miniProgram
.
MallBaseId
}).
FirstOrDefault
();
if
(
rechargeModel
==
null
)
{
rechargeModel
=
new
RB_Recharge_Settings
();
}
List
<
string
>
payment_type
=
new
List
<
string
>();
if
(!
string
.
IsNullOrWhiteSpace
(
mallBaseModel
.
PayWay
))
{
...
...
@@ -1620,7 +1632,7 @@ namespace Mall.WebApi.Controllers
}
//商城风格
var
mallStyle
=
new
object
();
ResultMallShopStyle
resultMallShopStyle
=
new
ResultMallShopStyle
();
switch
(
miniProgram
.
MallShopStyle
)
{
...
...
@@ -1660,7 +1672,7 @@ namespace Mall.WebApi.Controllers
resultMallShopStyle
?.
main
,
resultMallShopStyle
?.
secondary
,
};
var
setting
=
new
{
mallStyle
,
...
...
@@ -1710,8 +1722,8 @@ namespace Mall.WebApi.Controllers
is_quick_map
=
mallBaseModel
?.
ShortcutNavigation
,
quick_map_pic
=
mallBaseModel
?.
ShortcutNavigationIco
,
quick_map_address
=
mallBaseModel
?.
Address
,
longitude
=
!
string
.
IsNullOrWhiteSpace
(
mallBaseModel
.
LongAndLat
)?
mallBaseModel
?.
LongAndLat
.
Split
(
","
)[
0
]:
""
,
latitude
=
!
string
.
IsNullOrWhiteSpace
(
mallBaseModel
.
LongAndLat
)
?
mallBaseModel
?.
LongAndLat
.
Split
(
","
)[
1
]
:
""
,
longitude
=
!
string
.
IsNullOrWhiteSpace
(
mallBaseModel
.
LongAndLat
)
?
mallBaseModel
?.
LongAndLat
.
Split
(
","
)[
0
]
:
""
,
latitude
=
!
string
.
IsNullOrWhiteSpace
(
mallBaseModel
.
LongAndLat
)
?
mallBaseModel
?.
LongAndLat
.
Split
(
","
)[
1
]
:
""
,
is_quick_home
=
mallBaseModel
?.
BackTopNavigation
,
quick_home_pic
=
mallBaseModel
?.
BackTopNavigationIco
,
logo
=
""
,
...
...
@@ -1753,7 +1765,8 @@ namespace Mall.WebApi.Controllers
quick_customize_link_url
=
mallBaseModel
?.
TurnLink
,
quick_customize_new_params
=
""
,
theme_color
=
""
,
latitude_longitude
=
mallBaseModel
?.
LongAndLat
latitude_longitude
=
mallBaseModel
?.
LongAndLat
,
IsShowRecharge
=
rechargeModel
.
IsOpenBtn
};
#
endregion
return
setting
;
...
...
@@ -1799,7 +1812,7 @@ namespace Mall.WebApi.Controllers
}
}
var
share_setting
=
new
var
share_setting
=
new
{
level
=
distributorBasics
?.
DistributorTier
,
is_rebate
=
distributorBasics
?.
InPurchasing
,
...
...
Mall.WebApi/Controllers/MarketingCenter/StatisticsController.cs
View file @
84f2e737
...
...
@@ -340,7 +340,7 @@ namespace Mall.WebApi.Controllers.MarketingCenter
item
.
ALLCommission
=
item
.
CostFreight
+
item
.
CostMoney
+
item
.
PackingMoney
+
item
.
GoodsFreight
+
item
.
OneCommission
+
item
.
TwoCommission
+
item
.
OtherPrice
;
item
.
NoPaid
=
item
.
ALLCommission
-
item
.
Paid
;
item
.
GrossProfit
=
item
.
AllPrice
-
item
.
ALLCommission
;
item
.
GrossProfitRate
=
item
.
AllPrice
==
0
?
0
:
item
.
GrossProfit
/
item
.
AllPrice
;
item
.
GrossProfitRate
=
item
.
AllPrice
==
0
?
0
:
Math
.
Round
((
item
.
GrossProfit
/
item
.
AllPrice
),
2
,
MidpointRounding
.
AwayFromZero
)
;
}
pagelist
.
count
=
Convert
.
ToInt32
(
count
);
pagelist
.
pageData
=
list
;
...
...
@@ -402,7 +402,7 @@ namespace Mall.WebApi.Controllers.MarketingCenter
item
.
ALLCommission
=
item
.
CostFreight
+
item
.
CostMoney
+
item
.
PackingMoney
+
item
.
GoodsFreight
+
item
.
OneCommission
+
item
.
TwoCommission
+
item
.
OtherPrice
;
item
.
NoPaid
=
item
.
ALLCommission
-
item
.
Paid
;
item
.
GrossProfit
=
item
.
AllPrice
-
item
.
ALLCommission
;
item
.
GrossProfitRate
=
item
.
AllPrice
==
0
?
0
:
item
.
GrossProfit
/
item
.
AllPrice
;
item
.
GrossProfitRate
=
item
.
AllPrice
==
0
?
0
:
Math
.
Round
((
item
.
GrossProfit
/
item
.
AllPrice
),
2
,
MidpointRounding
.
AwayFromZero
)
;
}
#
region
组装数据
int
Num
=
0
;
...
...
Mall.WindowsService/Mall.WindowsService.csproj
View file @
84f2e737
...
...
@@ -23,6 +23,7 @@
</ItemGroup>
<ItemGroup>
<ProjectReference Include="..\Mall.CacheManager\Mall.CacheManager.csproj" />
<ProjectReference Include="..\Mall.Common\Mall.Common.csproj" />
<ProjectReference Include="..\Mall.DataAccess\Mall.DataAccess.csproj" />
<ProjectReference Include="..\Mall.Model\Mall.Model.csproj" />
...
...
Mall.WindowsService/Module/FinanceModule.cs
View file @
84f2e737
using
DapperExtensions.Lambda
;
using
Mall.CacheManager.AppletWeChat
;
using
Mall.Common
;
using
Mall.Common.Enum.Goods
;
using
Mall.Common.Enum.User
;
...
...
@@ -322,11 +323,14 @@ and DATE_FORMAT(b.PaymentTime,'%y-%m-%d')<DATE_FORMAT('{endDate}','%y-%m-%d') A
{
try
{
Dictionary
<
string
,
object
>
keyValues
=
new
Dictionary
<
string
,
object
>()
{
};
keyValues
.
Add
(
nameof
(
RB_Goods_Order_Extend
.
OrderStatus
),
OrderStatusEnum
.
Cancel
);
keyValues
.
Add
(
nameof
(
RB_Goods_Order_Extend
.
CancelTime
),
DateTime
.
Now
);
string
cacheOrderId
=
OrderPayReidsCache
.
Get
(
qitem
.
OrderId
.
ToString
());
if
(
string
.
IsNullOrWhiteSpace
(
cacheOrderId
))
{
Dictionary
<
string
,
object
>
keyValues
=
new
Dictionary
<
string
,
object
>()
{
};
keyValues
.
Add
(
nameof
(
RB_Goods_Order_Extend
.
OrderStatus
),
OrderStatusEnum
.
Cancel
);
keyValues
.
Add
(
nameof
(
RB_Goods_Order_Extend
.
CancelTime
),
DateTime
.
Now
);
List
<
WhereHelper
>
wheres
=
new
List
<
WhereHelper
>()
{
List
<
WhereHelper
>
wheres
=
new
List
<
WhereHelper
>()
{
new
WhereHelper
(){
FiledName
=
nameof
(
RB_Goods_Order_Extend
.
OrderId
),
FiledValue
=
qitem
.
OrderId
,
...
...
@@ -348,155 +352,156 @@ and DATE_FORMAT(b.PaymentTime,'%y-%m-%d')<DATE_FORMAT('{endDate}','%y-%m-%d') A
OperatorEnum
=
OperatorEnum
.
Equal
}
};
bool
flag
=
goods_OrderRepository
.
Update
(
keyValues
,
wheres
);
if
(
flag
)
{
//回滚商品库存
if
(
true
)
bool
flag
=
goods_OrderRepository
.
Update
(
keyValues
,
wheres
);
if
(
flag
)
{
int
tenantId
=
item
.
TenantId
;
int
mallBaseId
=
item
.
MallBaseId
;
int
TotalIntegralNumber
=
0
;
var
detailList
=
goodsOrderDetailRepository
.
GetOrderDetailList
(
new
RB_Goods_OrderDetail_Extend
()
{
OrderId
=
qitem
.
OrderId
,
TenantId
=
tenantId
,
MallBaseId
=
mallBaseId
});
if
(
detailList
.
Any
())
//回滚商品库存
if
(
true
)
{
string
goodsIds
=
string
.
Join
(
","
,
detailList
.
Select
(
x
=>
x
.
GoodsId
??
0
).
Distinct
())
;
var
goodsList
=
goodsRepository
.
GetList
(
new
RB_Goods_Extend
()
{
GoodsIds
=
goodsIds
,
TenantId
=
tenantId
,
MallBaseId
=
mallBaseId
})
;
var
speciPList
=
goods_SpecificationPriceRepository
.
GetList
(
new
RB_Goods_SpecificationPrice_Extend
()
{
GoodsIds
=
goodsIds
,
TenantId
=
tenantId
,
MallBaseId
=
mallBaseId
})
;
foreach
(
var
ditem
in
detailList
)
int
tenantId
=
item
.
TenantId
;
int
mallBaseId
=
item
.
MallBaseId
;
int
TotalIntegralNumber
=
0
;
var
detailList
=
goodsOrderDetailRepository
.
GetOrderDetailList
(
new
RB_Goods_OrderDetail_Extend
()
{
OrderId
=
qitem
.
OrderId
,
TenantId
=
tenantId
,
MallBaseId
=
mallBaseId
});
if
(
detailList
.
Any
()
)
{
var
gmodel
=
goodsList
.
Where
(
x
=>
x
.
Id
==
ditem
.
GoodsId
).
FirstOrDefault
();
if
(
gmodel
==
null
)
{
continue
;
}
if
(
string
.
IsNullOrEmpty
(
ditem
.
SpecificationSort
))
string
goodsIds
=
string
.
Join
(
","
,
detailList
.
Select
(
x
=>
x
.
GoodsId
??
0
).
Distinct
());
var
goodsList
=
goodsRepository
.
GetList
(
new
RB_Goods_Extend
()
{
GoodsIds
=
goodsIds
,
TenantId
=
tenantId
,
MallBaseId
=
mallBaseId
});
var
speciPList
=
goods_SpecificationPriceRepository
.
GetList
(
new
RB_Goods_SpecificationPrice_Extend
()
{
GoodsIds
=
goodsIds
,
TenantId
=
tenantId
,
MallBaseId
=
mallBaseId
});
foreach
(
var
ditem
in
detailList
)
{
if
(
gmodel
.
IsCustomSpecification
==
1
)
var
gmodel
=
goodsList
.
Where
(
x
=>
x
.
Id
==
ditem
.
GoodsId
).
FirstOrDefault
();
if
(
gmodel
==
null
)
{
continue
;
}
}
else
{
if
(
gmodel
.
IsCustomSpecification
!=
1
)
if
(
string
.
IsNullOrEmpty
(
ditem
.
SpecificationSort
))
{
continue
;
if
(
gmodel
.
IsCustomSpecification
==
1
)
{
continue
;
}
}
var
speciPModel
=
speciPList
.
Where
(
x
=>
x
.
GoodsId
==
ditem
.
GoodsId
&&
x
.
SpecificationSort
==
ditem
.
SpecificationSort
).
FirstOrDefault
();
if
(
speciPModel
==
null
)
else
{
continue
;
}
//更新商品规格表库存 + 商品表总库存
Dictionary
<
string
,
object
>
keyValues2
=
new
Dictionary
<
string
,
object
>()
{
if
(
gmodel
.
IsCustomSpecification
!=
1
)
{
continue
;
}
var
speciPModel
=
speciPList
.
Where
(
x
=>
x
.
GoodsId
==
ditem
.
GoodsId
&&
x
.
SpecificationSort
==
ditem
.
SpecificationSort
).
FirstOrDefault
();
if
(
speciPModel
==
null
)
{
continue
;
}
//更新商品规格表库存 + 商品表总库存
Dictionary
<
string
,
object
>
keyValues2
=
new
Dictionary
<
string
,
object
>()
{
{
nameof
(
RB_Goods_SpecificationPrice_Extend
.
InventoryNum
),
(
speciPModel
.
InventoryNum
??
0
)+(
ditem
.
Number
??
0
)}
};
List
<
WhereHelper
>
wheres2
=
new
List
<
WhereHelper
>()
{
List
<
WhereHelper
>
wheres2
=
new
List
<
WhereHelper
>()
{
new
WhereHelper
(){
FiledName
=
nameof
(
RB_Goods_SpecificationPrice_Extend
.
Id
),
FiledValue
=
speciPModel
.
Id
,
OperatorEnum
=
OperatorEnum
.
Equal
}
};
goods_SpecificationPriceRepository
.
Update
(
keyValues2
,
wheres2
);
}
//更新商品表库存
Dictionary
<
string
,
object
>
keyValues1
=
new
Dictionary
<
string
,
object
>()
{
goods_SpecificationPriceRepository
.
Update
(
keyValues2
,
wheres2
);
}
//更新商品表库存
Dictionary
<
string
,
object
>
keyValues1
=
new
Dictionary
<
string
,
object
>()
{
{
nameof
(
RB_Goods_Extend
.
InventoryNum
),
(
gmodel
.
InventoryNum
??
0
)+(
ditem
.
Number
??
0
)}
};
List
<
WhereHelper
>
wheres1
=
new
List
<
WhereHelper
>()
{
List
<
WhereHelper
>
wheres1
=
new
List
<
WhereHelper
>()
{
new
WhereHelper
(){
FiledName
=
nameof
(
RB_Goods_Extend
.
Id
),
FiledValue
=
gmodel
.
Id
,
OperatorEnum
=
OperatorEnum
.
Equal
}
};
goodsRepository
.
Update
(
keyValues1
,
wheres1
);
goods_LogRepository
.
Insert
(
new
Mall
.
Model
.
Entity
.
Product
.
RB_Goods_Log
()
{
Id
=
0
,
Type
=
2
,
SourceId
=
ditem
.
GoodsId
,
Content
=
$"取消订单
{
qitem
.
OrderId
}
,还原商品库存:"
+
ditem
.
Number
,
CreateDate
=
DateTime
.
Now
,
MallBaseId
=
mallBaseId
,
TenantId
=
tenantId
});
if
(
ditem
.
IntegralNumber
>
0
)
{
TotalIntegralNumber
+=
(
ditem
.
IntegralNumber
??
0
);
goodsRepository
.
Update
(
keyValues1
,
wheres1
);
goods_LogRepository
.
Insert
(
new
Mall
.
Model
.
Entity
.
Product
.
RB_Goods_Log
()
{
Id
=
0
,
Type
=
2
,
SourceId
=
ditem
.
GoodsId
,
Content
=
$"取消订单
{
qitem
.
OrderId
}
,还原商品库存:"
+
ditem
.
Number
,
CreateDate
=
DateTime
.
Now
,
MallBaseId
=
mallBaseId
,
TenantId
=
tenantId
});
if
(
ditem
.
IntegralNumber
>
0
)
{
TotalIntegralNumber
+=
(
ditem
.
IntegralNumber
??
0
);
}
}
}
}
var
umodel
=
member_UserRepository
.
GetEntity
(
qitem
.
UserId
);
//积分抵扣回滚
if
(
TotalIntegralNumber
>
0
)
{
Dictionary
<
string
,
object
>
keyValues1
=
new
Dictionary
<
string
,
object
>()
{
var
umodel
=
member_UserRepository
.
GetEntity
(
qitem
.
UserId
);
//积分抵扣回滚
if
(
TotalIntegralNumber
>
0
)
{
Dictionary
<
string
,
object
>
keyValues1
=
new
Dictionary
<
string
,
object
>()
{
{
nameof
(
RB_Member_User_Extend
.
Integral
),
umodel
.
Integral
+
TotalIntegralNumber
}
};
List
<
WhereHelper
>
wheres1
=
new
List
<
WhereHelper
>()
{
List
<
WhereHelper
>
wheres1
=
new
List
<
WhereHelper
>()
{
new
WhereHelper
(){
FiledName
=
nameof
(
RB_Member_User_Extend
.
Id
),
FiledValue
=
umodel
.
Id
,
OperatorEnum
=
OperatorEnum
.
Equal
}
};
bool
flag2
=
member_UserRepository
.
Update
(
keyValues1
,
wheres1
);
if
(
flag2
)
{
member_IntegralRepository
.
Insert
(
new
Mall
.
Model
.
Entity
.
User
.
RB_Member_Integral
()
bool
flag2
=
member_UserRepository
.
Update
(
keyValues1
,
wheres1
);
if
(
flag2
)
{
Id
=
0
,
CreateDate
=
DateTime
.
Now
,
Description
=
"订单取消返回积分抵扣,订单号:"
+
qitem
.
OrderNo
,
Image
=
0
,
Integral
=
TotalIntegralNumber
,
MallBaseId
=
item
.
MallBaseId
,
PlatformType
=
qitem
.
OrderSource
,
Remarks
=
""
,
TenantId
=
item
.
TenantId
,
Type
=
Common
.
Enum
.
MarketingCenter
.
RecordTypeEnum
.
Income
,
UserId
=
qitem
.
UserId
,
OrderId
=
qitem
.
OrderId
});
member_IntegralRepository
.
Insert
(
new
Mall
.
Model
.
Entity
.
User
.
RB_Member_Integral
()
{
Id
=
0
,
CreateDate
=
DateTime
.
Now
,
Description
=
"订单取消返回积分抵扣,订单号:"
+
qitem
.
OrderNo
,
Image
=
0
,
Integral
=
TotalIntegralNumber
,
MallBaseId
=
item
.
MallBaseId
,
PlatformType
=
qitem
.
OrderSource
,
Remarks
=
""
,
TenantId
=
item
.
TenantId
,
Type
=
Common
.
Enum
.
MarketingCenter
.
RecordTypeEnum
.
Income
,
UserId
=
qitem
.
UserId
,
OrderId
=
qitem
.
OrderId
});
}
}
}
//优惠券回滚
if
(!
string
.
IsNullOrEmpty
(
qitem
.
CouponsIds
))
{
var
cList
=
member_CouponRepository
.
GetList
(
new
RB_Member_DiscountCoupon_Extend
()
{
UseState
=
1
,
Ids
=
qitem
.
CouponsIds
,
UserId
=
qitem
.
UserId
,
TenantId
=
item
.
TenantId
,
MallBaseId
=
item
.
MallBaseId
});
foreach
(
var
citem
in
cList
)
//优惠券回滚
if
(!
string
.
IsNullOrEmpty
(
qitem
.
CouponsIds
))
{
Dictionary
<
string
,
object
>
keyValues1
=
new
Dictionary
<
string
,
object
>()
{
var
cList
=
member_CouponRepository
.
GetList
(
new
RB_Member_DiscountCoupon_Extend
()
{
UseState
=
1
,
Ids
=
qitem
.
CouponsIds
,
UserId
=
qitem
.
UserId
,
TenantId
=
item
.
TenantId
,
MallBaseId
=
item
.
MallBaseId
});
foreach
(
var
citem
in
cList
)
{
Dictionary
<
string
,
object
>
keyValues1
=
new
Dictionary
<
string
,
object
>()
{
{
nameof
(
RB_Member_DiscountCoupon_Extend
.
UseState
),
0
}
};
List
<
WhereHelper
>
wheres1
=
new
List
<
WhereHelper
>()
{
List
<
WhereHelper
>
wheres1
=
new
List
<
WhereHelper
>()
{
new
WhereHelper
(){
FiledName
=
nameof
(
RB_Member_DiscountCoupon_Extend
.
Id
),
FiledValue
=
citem
.
Id
,
OperatorEnum
=
OperatorEnum
.
Equal
}
};
member_CouponRepository
.
Update
(
keyValues1
,
wheres1
);
member_CouponRepository
.
Update
(
keyValues1
,
wheres1
);
}
}
}
//余额支付回滚
//余额支付回滚
}
goods_LogRepository
.
Insert
(
new
Mall
.
Model
.
Entity
.
Product
.
RB_Goods_Log
()
{
Id
=
0
,
Type
=
1
,
SourceId
=
qitem
.
OrderId
,
Content
=
"订单超时,自动取消订单"
,
CreateDate
=
DateTime
.
Now
,
MallBaseId
=
item
.
MallBaseId
,
TenantId
=
item
.
TenantId
});
}
goods_LogRepository
.
Insert
(
new
Mall
.
Model
.
Entity
.
Product
.
RB_Goods_Log
()
{
Id
=
0
,
Type
=
1
,
SourceId
=
qitem
.
OrderId
,
Content
=
"订单超时,自动取消订单"
,
CreateDate
=
DateTime
.
Now
,
MallBaseId
=
item
.
MallBaseId
,
TenantId
=
item
.
TenantId
});
}
}
catch
(
Exception
ex
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment