Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
C
cloud-platform
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
youjj
cloud-platform
Commits
58010773
Commit
58010773
authored
Jul 18, 2019
by
hezhen
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'base-modify' of
http://113.105.137.151:22280/youjj/cloud-platform
into base-modify
parents
8d701871
855ca91c
Changes
22
Hide whitespace changes
Inline
Side-by-side
Showing
22 changed files
with
412 additions
and
147 deletions
+412
-147
RabbitConstant.java
...wxiaoqi/security/common/config/rabbit/RabbitConstant.java
+1
-1
PersonalConsumptionDTO.java
...ub/wxiaoqi/security/admin/dto/PersonalConsumptionDTO.java
+17
-0
RegisterParamDTO.java
...m/github/wxiaoqi/security/admin/dto/RegisterParamDTO.java
+2
-0
RegisterQueueDTO.java
...m/github/wxiaoqi/security/admin/dto/RegisterQueueDTO.java
+3
-0
WalletCathFindDTO.java
.../github/wxiaoqi/security/admin/dto/WalletCathFindDTO.java
+1
-1
WalletDetailFindDTO.java
...ithub/wxiaoqi/security/admin/dto/WalletDetailFindDTO.java
+20
-0
WalletDetailListDTO.java
...ithub/wxiaoqi/security/admin/dto/WalletDetailListDTO.java
+13
-15
WalletDetailAdminVo.java
...github/wxiaoqi/security/admin/vo/WalletDetailAdminVo.java
+52
-0
WalletPageVo.java
...va/com/github/wxiaoqi/security/admin/vo/WalletPageVo.java
+4
-1
MyWalletBiz.java
...va/com/github/wxiaoqi/security/admin/biz/MyWalletBiz.java
+14
-3
MyWalletCathBiz.java
...om/github/wxiaoqi/security/admin/biz/MyWalletCathBiz.java
+2
-1
MyWalletDetailBiz.java
.../github/wxiaoqi/security/admin/biz/MyWalletDetailBiz.java
+41
-0
MyWalletCathMapper.java
...hub/wxiaoqi/security/admin/mapper/MyWalletCathMapper.java
+1
-0
MyWalletDetailMapper.java
...b/wxiaoqi/security/admin/mapper/MyWalletDetailMapper.java
+9
-1
WalletDetailAdminController.java
...ecurity/admin/rest/admin/WalletDetailAdminController.java
+31
-0
AppPermissionService.java
...aoqi/security/admin/rpc/service/AppPermissionService.java
+27
-5
MyWalletCathMapper.xml
...ce-admin/src/main/resources/mapper/MyWalletCathMapper.xml
+3
-3
MyWalletDetailMapper.xml
...-admin/src/main/resources/mapper/MyWalletDetailMapper.xml
+42
-0
RabbitActivityConfig.java
...m/xxfc/platform/activity/config/RabbitActivityConfig.java
+65
-0
RabbitUserConfig.java
...a/com/xxfc/platform/activity/config/RabbitUserConfig.java
+0
-52
IntegralMQHandler.java
...com/xxfc/platform/activity/handler/IntegralMQHandler.java
+63
-63
OrderRentVehicleService.java
.../xxfc/platform/order/service/OrderRentVehicleService.java
+1
-1
No files found.
ace-common/src/main/java/com/github/wxiaoqi/security/common/config/rabbit/RabbitConstant.java
View file @
58010773
...
...
@@ -15,7 +15,7 @@ public class RabbitConstant {
public
static
final
String
ORDER_TOPIC
=
ORDER
+
TOPIC_EXC
;
/**************************key*********************************/
// public static final String
public
static
final
String
KEY_REGISTER_SUCCESS
=
"register.success"
;
static
{
exchangeTopicSet
=
new
HashSet
<
String
>()
{{
...
...
ace-modules/ace-admin-api/src/main/java/com/github/wxiaoqi/security/admin/dto/PersonalConsumptionDTO.java
0 → 100644
View file @
58010773
package
com
.
github
.
wxiaoqi
.
security
.
admin
.
dto
;
import
lombok.Data
;
import
java.math.BigDecimal
;
/**
* @author libin
* @version 1.0
* @description
* @data 2019/7/18 15:59
*/
@Data
public
class
PersonalConsumptionDTO
{
private
Integer
userId
;
private
BigDecimal
totalConsumption
;
}
ace-modules/ace-admin-api/src/main/java/com/github/wxiaoqi/security/admin/dto/RegisterParamDTO.java
View file @
58010773
package
com
.
github
.
wxiaoqi
.
security
.
admin
.
dto
;
import
lombok.AllArgsConstructor
;
import
lombok.Data
;
@Data
@AllArgsConstructor
public
class
RegisterParamDTO
{
String
username
;
String
password
;
...
...
ace-modules/ace-admin-api/src/main/java/com/github/wxiaoqi/security/admin/dto/RegisterQueueDTO.java
View file @
58010773
package
com
.
github
.
wxiaoqi
.
security
.
admin
.
dto
;
import
com.alibaba.fastjson.JSONObject
;
import
lombok.Data
;
@Data
public
class
RegisterQueueDTO
{
RegisterParamDTO
registerParamDTO
;
Integer
appUserId
;
JSONObject
data
;
}
ace-modules/ace-admin-api/src/main/java/com/github/wxiaoqi/security/admin/dto/WalletCathFindDTO.java
View file @
58010773
...
...
@@ -12,7 +12,7 @@ import lombok.Data;
@Data
public
class
WalletCathFindDTO
extends
PageParam
{
private
String
user
N
ame
;
private
String
user
n
ame
;
private
String
phone
;
...
...
ace-modules/ace-admin-api/src/main/java/com/github/wxiaoqi/security/admin/dto/WalletDetailFindDTO.java
0 → 100644
View file @
58010773
package
com
.
github
.
wxiaoqi
.
security
.
admin
.
dto
;
import
com.github.wxiaoqi.security.common.vo.PageParam
;
import
lombok.Data
;
/**
* @author libin
* @version 1.0
* @description
* @data 2019/7/18 11:12
*/
@Data
public
class
WalletDetailFindDTO
extends
PageParam
{
private
String
username
;
private
String
phone
;
private
Integer
source
;
}
ace-modules/ace-admin-api/src/main/java/com/github/wxiaoqi/security/admin/dto/WalletDetailListDTO.java
View file @
58010773
...
...
@@ -25,25 +25,28 @@ public class WalletDetailListDTO {
private
String
phone
;
@ApiModelProperty
(
value
=
"来源:0-活动,1-佣金,2-会员充值,10-提现,11-转账,12-购买"
)
private
Integer
source
Type
;
private
Integer
source
;
@ApiModelProperty
(
"
活动名称或
佣金商品名称"
)
private
String
sourc
e
;
@ApiModelProperty
(
"佣金商品名称"
)
private
String
titl
e
;
@ApiModelProperty
(
value
=
"收入/支出:0-收入,1-支出
"
)
private
Integer
ityp
e
;
@ApiModelProperty
(
"商品价格
"
)
private
BigDecimal
pric
e
;
@ApiModelProperty
(
value
=
"收入/支出的金额(分)
"
)
private
BigDecimal
amoun
t
;
@ApiModelProperty
(
"提成比例
"
)
private
Integer
extrac
t
;
@ApiModelProperty
(
"入帐状态"
)
private
Integer
waiting
;
@ApiModelProperty
(
value
=
"活动类型"
)
private
Integer
type
;
@ApiModelProperty
(
value
=
"收入/支出的金额(分)"
)
private
BigDecimal
amount
;
@ApiModelProperty
(
value
=
"活动id"
)
private
Integer
activityId
;
@ApiModelProperty
(
value
=
"0 收入 1 支出"
)
private
Integer
itype
;
@ApiModelProperty
(
"活动名称"
)
private
String
activityName
;
...
...
@@ -52,11 +55,6 @@ public class WalletDetailListDTO {
@ApiModelProperty
(
value
=
"单号"
)
private
Integer
cono
;
@ApiModelProperty
(
value
=
"加上当时的收入的余额"
)
private
BigDecimal
balance
;
@ApiModelProperty
(
value
=
"操作时间"
,
hidden
=
true
)
private
Long
crtTime
;
...
...
ace-modules/ace-admin-api/src/main/java/com/github/wxiaoqi/security/admin/vo/WalletDetailAdminVo.java
0 → 100644
View file @
58010773
package
com
.
github
.
wxiaoqi
.
security
.
admin
.
vo
;
import
io.swagger.annotations.ApiModelProperty
;
import
lombok.Data
;
import
java.math.BigDecimal
;
/**
* @author libin
* @version 1.0
* @description
* @data 2019/7/18 10:50
*/
@Data
public
class
WalletDetailAdminVo
{
private
Integer
id
;
private
String
username
;
private
String
phone
;
@ApiModelProperty
(
value
=
"来源:0-活动,1-佣金,2-会员充值,10-提现,11-转账,12-购买"
)
private
Integer
source
;
@ApiModelProperty
(
"佣金商品名称"
)
private
String
title
;
@ApiModelProperty
(
"商品价格"
)
private
BigDecimal
price
;
@ApiModelProperty
(
"提成比例"
)
private
Integer
extract
;
@ApiModelProperty
(
"入帐状态"
)
private
Integer
waiting
;
@ApiModelProperty
(
value
=
"收入/支出的金额(分)"
)
private
BigDecimal
amount
;
@ApiModelProperty
(
value
=
"0收入 1支出"
)
private
Integer
itype
;
@ApiModelProperty
(
"活动名称"
)
private
String
activityName
;
@ApiModelProperty
(
value
=
"单号"
)
private
Integer
cono
;
@ApiModelProperty
(
value
=
"操作时间"
,
hidden
=
true
)
private
Long
crtTime
;
}
ace-modules/ace-admin-api/src/main/java/com/github/wxiaoqi/security/admin/vo/WalletPageVo.java
View file @
58010773
...
...
@@ -30,12 +30,15 @@ public class WalletPageVo {
@ApiModelProperty
(
value
=
"已提现金额"
)
private
BigDecimal
withdrawals
;
@ApiModelProperty
(
value
=
"总消费"
)
private
BigDecimal
totalConsumption
;
@ApiModelProperty
(
value
=
"进账总额(元)"
)
private
BigDecimal
totalAmount
;
@ApiModelProperty
(
value
=
"
进账
总额(元)"
)
@ApiModelProperty
(
value
=
"
日收益
总额(元)"
)
private
BigDecimal
todayAmount
;
...
...
ace-modules/ace-admin/src/main/java/com/github/wxiaoqi/security/admin/biz/MyWalletBiz.java
View file @
58010773
...
...
@@ -10,14 +10,15 @@ import com.github.wxiaoqi.security.common.biz.BaseBiz;
import
com.github.wxiaoqi.security.common.vo.PageDataVO
;
import
org.apache.commons.collections.CollectionUtils
;
import
org.springframework.beans.BeanUtils
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
import
org.springframework.transaction.annotation.Transactional
;
import
org.springframework.util.StringUtils
;
import
tk.mybatis.mapper.entity.Example
;
import
java.
util.ArrayList
;
import
java.util.
Comparator
;
import
java.util.
List
;
import
java.
math.BigDecimal
;
import
java.util.
*
;
import
java.util.
stream.Collectors
;
/**
* @author libin
...
...
@@ -29,6 +30,8 @@ import java.util.List;
@Service
public
class
MyWalletBiz
extends
BaseBiz
<
MyWalletMapper
,
MyWallet
>
{
@Autowired
private
MyWalletDetailBiz
myWalletDetailBiz
;
public
AppletWalletVo
findMyWallet
(
Integer
userId
)
{
...
...
@@ -62,6 +65,14 @@ public class MyWalletBiz extends BaseBiz<MyWalletMapper, MyWallet> {
walletpg
.
setPhone
(
wallet
.
getUsername
());
walletPageVos
.
add
(
walletpg
);
}
List
<
Integer
>
userIds
=
wallets
.
stream
().
map
(
WalletListDTO:
:
getUserId
).
collect
(
Collectors
.
toList
());
Map
<
Integer
,
BigDecimal
>
userIdAndTotalConsumptionMap
=
myWalletDetailBiz
.
finduserIdAndPersonalTotalConsumptionMapByUserIds
(
userIds
);
Optional
.
ofNullable
(
userIdAndTotalConsumptionMap
).
ifPresent
(
x
->{
for
(
WalletPageVo
wtpg
:
walletPageVos
)
{
wtpg
.
setTotalConsumption
(
x
.
get
(
wtpg
.
getUserId
()));
}
});
walletPageVos
.
sort
(
Comparator
.
comparing
(
WalletPageVo:
:
getTotalAmount
).
reversed
());
walletPageVo
.
setPageNum
(
walletFindDTO
.
getPage
());
walletPageVo
.
setPageSize
(
walletFindDTO
.
getLimit
());
...
...
ace-modules/ace-admin/src/main/java/com/github/wxiaoqi/security/admin/biz/MyWalletCathBiz.java
View file @
58010773
...
...
@@ -87,7 +87,7 @@ public class MyWalletCathBiz extends BaseBiz<MyWalletCathMapper, MyWalletCath> {
// List<WalletCathListDTO> walletCathListDTOS = mapper.selectByUserNameOrPhoneOrWithDrawSate(walletCathFindDTO.getUserName(), walletCathFindDTO.getPhone(), walletCathFindDTO.getState());
PageDataVO
<
WalletCathListDTO
>
walletCathListDTOPage
=
PageDataVO
.
pageInfo
(
walletCathFindDTO
.
getPage
(),
walletCathFindDTO
.
getLimit
(),
()
->
mapper
.
selectByUserNameOrPhoneOrWithDrawSate
(
walletCathFindDTO
.
getUser
N
ame
(),
walletCathFindDTO
.
getPhone
(),
walletCathFindDTO
.
getState
()));
()
->
mapper
.
selectByUserNameOrPhoneOrWithDrawSate
(
walletCathFindDTO
.
getUser
n
ame
(),
walletCathFindDTO
.
getPhone
(),
walletCathFindDTO
.
getState
()));
List
<
WalletCathListDTO
>
walletCathListDTOList
=
walletCathListDTOPage
.
getData
();
if
(
CollectionUtils
.
isEmpty
(
walletCathListDTOList
)){
...
...
@@ -111,4 +111,5 @@ public class MyWalletCathBiz extends BaseBiz<MyWalletCathMapper, MyWalletCath> {
return
walletCathAdminVoPage
;
}
}
ace-modules/ace-admin/src/main/java/com/github/wxiaoqi/security/admin/biz/MyWalletDetailBiz.java
View file @
58010773
package
com
.
github
.
wxiaoqi
.
security
.
admin
.
biz
;
import
com.github.wxiaoqi.security.admin.dto.PersonalConsumptionDTO
;
import
com.github.wxiaoqi.security.admin.dto.WalletDetailFindDTO
;
import
com.github.wxiaoqi.security.admin.dto.WalletDetailListDTO
;
import
com.github.wxiaoqi.security.admin.entity.MyWalletDetail
;
import
com.github.wxiaoqi.security.admin.mapper.MyWalletDetailMapper
;
import
com.github.wxiaoqi.security.admin.vo.WalletDetailAdminVo
;
import
com.github.wxiaoqi.security.admin.vo.WalletDetailPageVo
;
import
com.github.wxiaoqi.security.common.biz.BaseBiz
;
import
com.github.wxiaoqi.security.common.vo.PageDataVO
;
import
lombok.Data
;
import
org.apache.commons.collections.CollectionUtils
;
import
org.springframework.beans.BeanUtils
;
import
org.springframework.stereotype.Service
;
import
org.springframework.transaction.annotation.Transactional
;
import
tk.mybatis.mapper.entity.Example
;
import
java.math.BigDecimal
;
import
java.util.ArrayList
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.stream.Collectors
;
/**
...
...
@@ -23,6 +31,7 @@ import java.util.List;
*/
@Transactional
@Service
@Data
public
class
MyWalletDetailBiz
extends
BaseBiz
<
MyWalletDetailMapper
,
MyWalletDetail
>
{
...
...
@@ -53,4 +62,36 @@ public class MyWalletDetailBiz extends BaseBiz<MyWalletDetailMapper, MyWalletDet
return
walletDetailPageVo
;
}
public
PageDataVO
<
WalletDetailAdminVo
>
findWalletDetailPage
(
WalletDetailFindDTO
walletDetailFindDTO
){
PageDataVO
<
WalletDetailAdminVo
>
pageDataVO
=
new
PageDataVO
<>();
PageDataVO
<
WalletDetailListDTO
>
walletDetailPage
=
PageDataVO
.
pageInfo
(
walletDetailFindDTO
.
getPage
(),
walletDetailFindDTO
.
getLimit
(),
()->
mapper
.
findWalletDetailsByUserNameOrPhoneOrsourceType
(
walletDetailFindDTO
.
getUsername
(),
walletDetailFindDTO
.
getPhone
(),
walletDetailFindDTO
.
getSource
()));
List
<
WalletDetailListDTO
>
detailListDTOS
=
walletDetailPage
.
getData
();
if
(
CollectionUtils
.
isEmpty
(
detailListDTOS
)){
return
pageDataVO
;
}
List
<
WalletDetailAdminVo
>
walletDetailAdminVos
=
new
ArrayList
<>();
WalletDetailAdminVo
walletDetailAdminVo
;
for
(
WalletDetailListDTO
detailListDTO
:
detailListDTOS
)
{
walletDetailAdminVo
=
new
WalletDetailAdminVo
();
BeanUtils
.
copyProperties
(
detailListDTO
,
walletDetailAdminVo
);
walletDetailAdminVos
.
add
(
walletDetailAdminVo
);
}
pageDataVO
.
setPageNum
(
walletDetailFindDTO
.
getPage
());
pageDataVO
.
setPageSize
(
walletDetailFindDTO
.
getLimit
());
pageDataVO
.
setTotalCount
(
walletDetailPage
.
getTotalCount
());
pageDataVO
.
setTotalPage
(
walletDetailPage
.
getTotalPage
());
pageDataVO
.
setData
(
walletDetailAdminVos
);
return
pageDataVO
;
}
public
Map
<
Integer
,
BigDecimal
>
finduserIdAndPersonalTotalConsumptionMapByUserIds
(
List
<
Integer
>
userIds
)
{
List
<
PersonalConsumptionDTO
>
personalConsumptions
=
mapper
.
findpersonalConsumptionsByUserIds
(
userIds
);
Map
<
Integer
,
BigDecimal
>
userIdAndPersonalConsumptionMap
=
personalConsumptions
.
stream
().
collect
(
Collectors
.
toMap
(
PersonalConsumptionDTO:
:
getUserId
,
PersonalConsumptionDTO:
:
getTotalConsumption
));
return
userIdAndPersonalConsumptionMap
;
}
}
ace-modules/ace-admin/src/main/java/com/github/wxiaoqi/security/admin/mapper/MyWalletCathMapper.java
View file @
58010773
...
...
@@ -19,4 +19,5 @@ public interface MyWalletCathMapper extends Mapper<MyWalletCath> {
List
<
WalletCathListDTO
>
selectByUserNameOrPhoneOrWithDrawSate
(
@Param
(
"userName"
)
String
userName
,
@Param
(
"phone"
)
String
phone
,
@Param
(
"state"
)
Integer
state
);
}
ace-modules/ace-admin/src/main/java/com/github/wxiaoqi/security/admin/mapper/MyWalletDetailMapper.java
View file @
58010773
package
com
.
github
.
wxiaoqi
.
security
.
admin
.
mapper
;
import
com.github.wxiaoqi.security.admin.dto.PersonalConsumptionDTO
;
import
com.github.wxiaoqi.security.admin.dto.WalletDetailListDTO
;
import
com.github.wxiaoqi.security.admin.entity.MyWalletDetail
;
import
org.apache.ibatis.annotations.Param
;
import
tk.mybatis.mapper.common.Mapper
;
import
java.util.List
;
/**
* 收入/支持明细表,每笔的进账,出账的详细记录
*
...
...
@@ -11,5 +16,8 @@ import tk.mybatis.mapper.common.Mapper;
* @date 2019-07-11 14:14:54
*/
public
interface
MyWalletDetailMapper
extends
Mapper
<
MyWalletDetail
>
{
List
<
WalletDetailListDTO
>
findWalletDetailsByUserNameOrPhoneOrsourceType
(
@Param
(
"userName"
)
String
userName
,
@Param
(
"phone"
)
String
phone
,
@Param
(
"sourceType"
)
Integer
sourceType
);
List
<
PersonalConsumptionDTO
>
findpersonalConsumptionsByUserIds
(
@Param
(
"userIds"
)
List
<
Integer
>
userIds
);
}
ace-modules/ace-admin/src/main/java/com/github/wxiaoqi/security/admin/rest/admin/WalletDetailAdminController.java
0 → 100644
View file @
58010773
package
com
.
github
.
wxiaoqi
.
security
.
admin
.
rest
.
admin
;
import
com.github.wxiaoqi.security.admin.biz.MyWalletDetailBiz
;
import
com.github.wxiaoqi.security.admin.dto.WalletDetailFindDTO
;
import
com.github.wxiaoqi.security.admin.vo.WalletDetailAdminVo
;
import
com.github.wxiaoqi.security.common.msg.ObjectRestResponse
;
import
com.github.wxiaoqi.security.common.vo.PageDataVO
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.web.bind.annotation.GetMapping
;
import
org.springframework.web.bind.annotation.RequestMapping
;
import
org.springframework.web.bind.annotation.RestController
;
/**
* @author libin
* @version 1.0
* @description
* @data 2019/7/18 13:30
*/
@RestController
@RequestMapping
(
"/walletdetail/admin"
)
public
class
WalletDetailAdminController
{
@Autowired
private
MyWalletDetailBiz
myWalletDetailBiz
;
@GetMapping
(
"/page"
)
public
ObjectRestResponse
<
PageDataVO
<
WalletDetailAdminVo
>>
findWalletDetailPage
(
WalletDetailFindDTO
walletDetailFindDTO
){
PageDataVO
<
WalletDetailAdminVo
>
walletDetailPage
=
myWalletDetailBiz
.
findWalletDetailPage
(
walletDetailFindDTO
);
return
ObjectRestResponse
.
succ
(
walletDetailPage
);
}
}
ace-modules/ace-admin/src/main/java/com/github/wxiaoqi/security/admin/rpc/service/AppPermissionService.java
View file @
58010773
package
com
.
github
.
wxiaoqi
.
security
.
admin
.
rpc
.
service
;
import
cn.hutool.core.bean.BeanUtil
;
import
cn.hutool.json.JSONUtil
;
import
com.alibaba.fastjson.JSONObject
;
import
com.github.wxiaoqi.security.admin.biz.*
;
import
com.github.wxiaoqi.security.admin.biz.AppUserBiz
;
...
...
@@ -9,6 +11,8 @@ import com.github.wxiaoqi.security.admin.biz.ElementBiz;
import
com.github.wxiaoqi.security.admin.constant.RedisKey
;
import
com.github.wxiaoqi.security.admin.constant.enumerate.UserSourceEnum
;
import
com.github.wxiaoqi.security.admin.dto.BaseUserMemberExportDTO
;
import
com.github.wxiaoqi.security.admin.dto.RegisterParamDTO
;
import
com.github.wxiaoqi.security.admin.dto.RegisterQueueDTO
;
import
com.github.wxiaoqi.security.admin.dto.UserMemberDTO
;
import
com.github.wxiaoqi.security.admin.entity.*
;
import
com.github.wxiaoqi.security.admin.vo.AppUserVo
;
...
...
@@ -40,7 +44,6 @@ import org.springframework.stereotype.Service;
import
org.springframework.transaction.annotation.Propagation
;
import
org.springframework.transaction.annotation.Transactional
;
import
org.springframework.web.client.RestTemplate
;
import
org.springframework.web.context.request.RequestAttributes
;
import
org.springframework.web.context.request.RequestContextHolder
;
import
org.springframework.web.context.request.ServletRequestAttributes
;
...
...
@@ -48,6 +51,8 @@ import javax.annotation.Resource;
import
java.util.*
;
import
java.util.concurrent.TimeUnit
;
import
static
com
.
github
.
wxiaoqi
.
security
.
common
.
config
.
rabbit
.
RabbitConstant
.
KEY_REGISTER_SUCCESS
;
/**
* @author keliii
*/
...
...
@@ -211,6 +216,8 @@ public class AppPermissionService {
@Transactional
(
rollbackFor
=
Exception
.
class
,
propagation
=
Propagation
.
REQUIRED
)
public
JSONObject
register
(
String
username
,
String
password
,
String
headimgurl
,
String
nickname
,
String
mobilecode
,
String
openId
,
String
unionid
,
Integer
type
,
String
code
)
{
String
activityCode
;
// 判断参数和验证码
if
(
StringUtils
.
isBlank
(
username
)
||
StringUtils
.
isBlank
(
password
)
||
StringUtils
.
isBlank
(
mobilecode
))
{
return
JsonResultUtil
.
createFailedResult
(
ResultCode
.
NULL_CODE
,
"参数为空"
);
...
...
@@ -266,7 +273,13 @@ public class AppPermissionService {
//邀请人id关系绑定
Integer
parentId
=
0
;
if
(
StringUtils
.
isNotBlank
(
code
)){
parentId
=
appUserDetailBiz
.
getUserByCode
(
code
);
//判断处理活动关键字
String
[]
codes
=
code
.
split
(
"_"
);
if
(
codes
.
length
>
1
)
{
code
=
codes
[
0
];
activityCode
=
codes
[
1
];
}
parentId
=
appUserDetailBiz
.
getUserByCode
(
code
);
}
if
(
parentId
!=
null
&&
parentId
>
0
){
rsUserDetail
.
setInviterAccount
(
parentId
);
...
...
@@ -306,10 +319,19 @@ public class AppPermissionService {
data
.
put
(
"imUserId"
,
imUserId
);
}
if
(
data
!=
null
)
{
// try {
try
{
//入参
RegisterQueueDTO
registerQueueDTO
=
new
RegisterQueueDTO
(){{
setData
(
data
);
setAppUserId
(
userid
);
setRegisterParamDTO
(
new
RegisterParamDTO
(
username
,
password
,
headimgurl
,
nickname
,
mobilecode
,
openId
,
unionid
,
type
,
null
));
}};
// //注册成功,发送队列
// mqSerderFeign.sendMessage(RabbitConstant.ADMIN_TOPIC, )
// }
mqSerderFeign
.
sendMessage
(
RabbitConstant
.
ADMIN_TOPIC
,
KEY_REGISTER_SUCCESS
,
JSONUtil
.
toJsonStr
(
registerQueueDTO
));
}
catch
(
Exception
e
){
log
.
error
(
e
.
getMessage
(),
e
);
}
return
JsonResultUtil
.
createSuccessResultWithObj
(
data
);
}
else
{
return
JsonResultUtil
.
createDefaultFail
();
...
...
ace-modules/ace-admin/src/main/resources/mapper/MyWalletCathMapper.xml
View file @
58010773
...
...
@@ -3,7 +3,7 @@
<mapper
namespace=
"com.github.wxiaoqi.security.admin.mapper.MyWalletCathMapper"
>
<select
id=
"selectByUserNameOrPhoneOrWithDrawSate"
resultType=
"com.github.wxiaoqi.security.admin.dto.WalletListDTO"
>
<select
id=
"selectByUserNameOrPhoneOrWithDrawSate"
resultType=
"com.github.wxiaoqi.security.admin.dto.Wallet
Cath
ListDTO"
>
SELECT
wc.id,
aud.nickname,
...
...
@@ -20,10 +20,10 @@
</if>
) AS `wc`
INNER JOIN ( SELECT `id`, `username` FROM `app_user_login`
<if
test=
"phone != null and phone != ''"
>
WHERE `username`=#{phone}
</if>
) AS `aul` ON aul.id = w.user_id
</if>
) AS `aul` ON aul.id = w
c
.user_id
INNER JOIN ( SELECT `userid`, `nickname`, `realname` FROM `app_user_detail`
<if
test=
"userName != null and userName != ''"
>
WHERE nickname =#{user
n
ame} OR realname =#{userName}
WHERE nickname =#{user
N
ame} OR realname =#{userName}
</if>
) AS `aud` ON aud.userid = aul.id
</select>
</mapper>
\ No newline at end of file
ace-modules/ace-admin/src/main/resources/mapper/MyWalletDetailMapper.xml
0 → 100644
View file @
58010773
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper
namespace=
"com.github.wxiaoqi.security.admin.mapper.MyWalletDetailMapper"
>
<select
id=
"findWalletDetailsByUserNameOrPhoneOrsourceType"
resultType=
"com.github.wxiaoqi.security.admin.dto.WalletDetailListDTO"
>
SELECT
wd.id,
wd.source,
wd.amount,
wd.cono,
wd.itype,
wd.activity_id AS `activityId`,
wd.activity_name AS `activityName`,
aul.username,
aud.nickname,
aud.realname,
ausw.price,
ausw.extract,
ausw.waiting,
ausw.title
FROM
(select id,user_id,source,amount,cono,itype,activity_id,activity_name FROM `my_wallet_detail`
<if
test=
"sourceType != null"
>
WHERE `source`=#{sourceType}
</if>
) AS `wd`
LEFT JOIN (SELECT id,username FROM `app_user_login`
<if
test=
"phone != null and phone != ''"
>
WHERE `username`=#{phone}
</if>
) AS `aul` ON aul.id = wd.user_id
LEFT JOIN (SELECT userid,nickname,realname FROM `app_user_detail`
<if
test=
"userName != null and userName != ''"
>
WHERE `nickname`=#{userName} OR `realname`=#{userName}
</if>
) AS `aud` ON aud.userid = aul.id
LEFT JOIN (SELECT DISTINCT order_id,id,price,extract,waiting,title FROM `app_user_selling_water`) AS `ausw` ON ausw.order_id = wd.cono
</select>
<select
id=
"findpersonalConsumptionsByUserIds"
resultType=
"com.github.wxiaoqi.security.admin.dto.PersonalConsumptionDTO"
>
select `user_id` AS `userId`,SUM(amount) AS `totalConsumption` FROM my_wallet_cath
<if
test=
"userIds != null and userIds.size() != 0"
>
WHERE `user_id` IN
<foreach
collection=
"userIds"
item=
"userId"
open=
"("
close=
")"
separator=
","
>
#{userId}
</foreach>
</if>
GROUP BY user_id;
</select>
</mapper>
\ No newline at end of file
xx-activity/xx-activity-server/src/main/java/com/xxfc/platform/activity/config/RabbitActivityConfig.java
0 → 100644
View file @
58010773
package
com
.
xxfc
.
platform
.
activity
.
config
;
import
com.github.wxiaoqi.security.common.config.RabbitCommonConfig
;
import
com.github.wxiaoqi.security.common.config.rabbit.BindDTO
;
import
com.github.wxiaoqi.security.common.config.rabbit.RabbitConstant
;
import
org.springframework.amqp.core.Binding
;
import
org.springframework.amqp.core.BindingBuilder
;
import
org.springframework.amqp.core.DirectExchange
;
import
org.springframework.amqp.core.Queue
;
import
org.springframework.context.annotation.Bean
;
import
org.springframework.context.annotation.Configuration
;
import
java.util.ArrayList
;
/**
* rabbitmq配置类
* 包含: 不知道什么orderWater队列
* @author zhoujw
* @date 2019/7/15
*/
@Configuration
public
class
RabbitActivityConfig
extends
RabbitCommonConfig
{
public
static
final
String
INTEGRAL_QUEUE
=
"integral_queue"
;
static
{
myQueue
=
new
ArrayList
<
BindDTO
>(){{
add
(
new
BindDTO
(
INTEGRAL_QUEUE
,
RabbitConstant
.
ADMIN_TOPIC
,
"order.#"
));
}};
}
// public static final String BASE_EXC = "hz_exchange";
// public static final String INTEGRAL_QUEUE = "integral_queue";
// public static final String ORDER_WATER_KEY = "order";
// /**
// * 队列交换机
// * 注意这里的交换机类型:CustomExchange
// * @return
// */
// @Bean
// public DirectExchange directExchange(){
// return new DirectExchange(BASE_EXC, true, false);
// }
//
// /**
// * 队列
// * @return
// */
// @Bean
// public Queue orderWaterQueue(){
// return new Queue(INTEGRAL_QUEUE,true);
// }
//
// /**
// * 队列绑定交换机
// * @return
// */
// @Bean
// public Binding orderWaterBinding(Queue orderWaterQueue, DirectExchange directExchange){
// return BindingBuilder.bind(orderWaterQueue).to(directExchange).with(ORDER_WATER_KEY);
// }
}
xx-activity/xx-activity-server/src/main/java/com/xxfc/platform/activity/config/RabbitUserConfig.java
deleted
100644 → 0
View file @
8d701871
package
com
.
xxfc
.
platform
.
activity
.
config
;
import
org.springframework.amqp.core.Binding
;
import
org.springframework.amqp.core.BindingBuilder
;
import
org.springframework.amqp.core.DirectExchange
;
import
org.springframework.amqp.core.Queue
;
import
org.springframework.context.annotation.Bean
;
import
org.springframework.context.annotation.Configuration
;
/**
* rabbitmq配置类
* 包含: 不知道什么orderWater队列
* @author zhoujw
* @date 2019/7/15
*/
@Configuration
public
class
RabbitUserConfig
{
public
static
final
String
BASE_EXC
=
"hz_exchange"
;
public
static
final
String
INTEGRAL_QUEUE
=
"integral_queue"
;
public
static
final
String
ORDER_WATER_KEY
=
"order"
;
/**
* 队列交换机
* 注意这里的交换机类型:CustomExchange
* @return
*/
@Bean
public
DirectExchange
directExchange
(){
return
new
DirectExchange
(
BASE_EXC
,
true
,
false
);
}
/**
* 队列
* @return
*/
@Bean
public
Queue
orderWaterQueue
(){
return
new
Queue
(
INTEGRAL_QUEUE
,
true
);
}
/**
* 队列绑定交换机
* @return
*/
@Bean
public
Binding
orderWaterBinding
(
Queue
orderWaterQueue
,
DirectExchange
directExchange
){
return
BindingBuilder
.
bind
(
orderWaterQueue
).
to
(
directExchange
).
with
(
ORDER_WATER_KEY
);
}
}
xx-activity/xx-activity-server/src/main/java/com/xxfc/platform/activity/handler/IntegralMQHandler.java
View file @
58010773
//
package com.xxfc.platform.activity.handler;
//
//
//
import com.alibaba.fastjson.JSONObject;
//
import com.rabbitmq.client.Channel;
//
import com.xxfc.platform.activity.biz.IntegralUserRecordBiz;
//
import com.xxfc.platform.activity.vo.IntegralUserRecordDto;
//
import lombok.extern.slf4j.Slf4j;
//
import org.apache.commons.lang3.StringUtils;
//
import org.springframework.amqp.core.Message;
//
import org.springframework.amqp.rabbit.annotation.RabbitListener;
//
import org.springframework.amqp.support.AmqpHeaders;
//
import org.springframework.beans.factory.annotation.Autowired;
//
import org.springframework.messaging.handler.annotation.Headers;
//
import org.springframework.stereotype.Component;
//
//
import java.io.IOException;
//
import java.util.Map;
//
import java.util.concurrent.ExecutorService;
//
import java.util.concurrent.Executors;
//
//
@Component
//
@Slf4j
//
public class IntegralMQHandler {
//
//
@Autowired
//
IntegralUserRecordBiz integralUserRecordBiz;
//
//
@RabbitListener(queues = "integral_queue")
//
public void integralHandler(Message message, @Headers Map<String, Object> headers, Channel channel) {
//
ExecutorService executorService = Executors.newCachedThreadPool();
//
executorService.execute(new Runnable() {
//
@Override
//
public void run() {
//
try {
//
String messageId = message.getMessageProperties().getMessageId();
//
String msg = new String(message.getBody(), "UTF-8");
//
log.info("接收到的消息:msg = {}, 消息ID是:messageId = {} ", msg, messageId);
//
//
if (StringUtils.isNotBlank(msg)) {
//
IntegralUserRecordDto integralUserRecordDto = JSONObject.parseObject(msg, IntegralUserRecordDto.class);
//
integralUserRecordBiz.add(integralUserRecordDto);
//
}
//
//
executorService.shutdown();
//
Long deliveryTag = (Long) headers.get(AmqpHeaders.DELIVERY_TAG);
//
// 手动签收
//
channel.basicAck(deliveryTag, false);
//
} catch (Exception e) {
//
log.info("接收到的消息失败");
//
try {
//
channel.basicNack(message.getMessageProperties().getDeliveryTag(), false, false);
//
} catch (IOException i) {
//
i.printStackTrace();
//
}
//
e.printStackTrace();
//
}
//
}
//
});
//
}
//
//
//
}
package
com
.
xxfc
.
platform
.
activity
.
handler
;
import
com.alibaba.fastjson.JSONObject
;
import
com.rabbitmq.client.Channel
;
import
com.xxfc.platform.activity.biz.IntegralUserRecordBiz
;
import
com.xxfc.platform.activity.vo.IntegralUserRecordDto
;
import
lombok.extern.slf4j.Slf4j
;
import
org.apache.commons.lang3.StringUtils
;
import
org.springframework.amqp.core.Message
;
import
org.springframework.amqp.rabbit.annotation.RabbitListener
;
import
org.springframework.amqp.support.AmqpHeaders
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.messaging.handler.annotation.Headers
;
import
org.springframework.stereotype.Component
;
import
java.io.IOException
;
import
java.util.Map
;
import
java.util.concurrent.ExecutorService
;
import
java.util.concurrent.Executors
;
@Component
@Slf4j
public
class
IntegralMQHandler
{
@Autowired
IntegralUserRecordBiz
integralUserRecordBiz
;
@RabbitListener
(
queues
=
"integral_queue"
)
public
void
integralHandler
(
Message
message
,
@Headers
Map
<
String
,
Object
>
headers
,
Channel
channel
)
{
ExecutorService
executorService
=
Executors
.
newCachedThreadPool
();
executorService
.
execute
(
new
Runnable
()
{
@Override
public
void
run
()
{
try
{
String
messageId
=
message
.
getMessageProperties
().
getMessageId
();
String
msg
=
new
String
(
message
.
getBody
(),
"UTF-8"
);
log
.
info
(
"接收到的消息:msg = {}, 消息ID是:messageId = {} "
,
msg
,
messageId
);
if
(
StringUtils
.
isNotBlank
(
msg
))
{
IntegralUserRecordDto
integralUserRecordDto
=
JSONObject
.
parseObject
(
msg
,
IntegralUserRecordDto
.
class
);
integralUserRecordBiz
.
add
(
integralUserRecordDto
);
}
executorService
.
shutdown
();
Long
deliveryTag
=
(
Long
)
headers
.
get
(
AmqpHeaders
.
DELIVERY_TAG
);
// 手动签收
channel
.
basicAck
(
deliveryTag
,
false
);
}
catch
(
Exception
e
)
{
log
.
info
(
"接收到的消息失败"
);
try
{
channel
.
basicNack
(
message
.
getMessageProperties
().
getDeliveryTag
(),
false
,
false
);
}
catch
(
IOException
i
)
{
i
.
printStackTrace
();
}
e
.
printStackTrace
();
}
}
});
}
}
xx-order/xx-order-server/src/main/java/com/xxfc/platform/order/service/OrderRentVehicleService.java
View file @
58010773
...
...
@@ -216,7 +216,7 @@ public class OrderRentVehicleService extends AbstractOrderHandle<OrderRentVehicl
//优惠券处理
//待完成
// activityFeign.use(dto.getUserid(),
);
// activityFeign.use(dto.getUserid()
);
//如果有使用会员权益或者优惠券,则设置订单已优惠
if
(
SYS_TRUE
.
equals
(
detail
.
getOrder
().
getHasMemberRight
()))
{
...
...
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