This commit is contained in:
dute7liang
2024-01-14 17:22:07 +08:00
parent fae8c9b679
commit f035172f00
3 changed files with 25 additions and 9 deletions

View File

@@ -3,7 +3,6 @@ package com.ruoyi.cai.manager;
import com.ruoyi.cai.domain.Account; import com.ruoyi.cai.domain.Account;
import com.ruoyi.cai.domain.User; import com.ruoyi.cai.domain.User;
import com.ruoyi.cai.domain.UserChatRecord; import com.ruoyi.cai.domain.UserChatRecord;
import com.ruoyi.cai.domain.UserMember;
import com.ruoyi.cai.dto.app.dto.ImMessageDTO; import com.ruoyi.cai.dto.app.dto.ImMessageDTO;
import com.ruoyi.cai.dto.app.vo.ImResp; import com.ruoyi.cai.dto.app.vo.ImResp;
import com.ruoyi.cai.enums.GenderEnum; import com.ruoyi.cai.enums.GenderEnum;
@@ -145,14 +144,14 @@ public class ImService {
private UserBlacklistService userBlacklistService; private UserBlacklistService userBlacklistService;
private Long getByImPrice(Long userId){ private Long getByImPrice(Long userId){
UserMember userMember = userMemberService.getNormalMember(userId); UserMemberTypeEnum userMemberType = userMemberService.checkUserMember(userId);
if(userMember == null){ if(userMemberType == null){
return 10L; return 10L;
} }
if(userMember.getMemberType().equals(UserMemberTypeEnum.NORMAL_VIP.getCode())){ if(userMemberType == UserMemberTypeEnum.NORMAL_VIP){
return 5L; return 5L;
} }
if(userMember.getMemberType().equals(UserMemberTypeEnum.SUPER_VIP.getCode())){ if(userMemberType == UserMemberTypeEnum.SUPER_VIP){
return 0L; return 0L;
} }
return 10L; return 10L;

View File

@@ -5,6 +5,7 @@ import com.baomidou.mybatisplus.extension.service.IService;
import com.ruoyi.cai.domain.UserMember; import com.ruoyi.cai.domain.UserMember;
import com.ruoyi.cai.dto.admin.vo.UserMemberAdminVo; import com.ruoyi.cai.dto.admin.vo.UserMemberAdminVo;
import com.ruoyi.cai.dto.app.vo.user.MemberInfoVo; import com.ruoyi.cai.dto.app.vo.user.MemberInfoVo;
import com.ruoyi.cai.enums.UserMemberTypeEnum;
import com.ruoyi.common.core.domain.PageQuery; import com.ruoyi.common.core.domain.PageQuery;
/** /**
@@ -21,7 +22,12 @@ public interface UserMemberService extends IService<UserMember> {
UserMember getByUserIdAndType(Long userId, Integer type); UserMember getByUserIdAndType(Long userId, Integer type);
UserMember getNormalMember(Long userId); /**
* 判断用户是否为会员
* @param userId
* @return
*/
UserMemberTypeEnum checkUserMember(Long userId);
void relieveMember(Long id); void relieveMember(Long id);

View File

@@ -9,6 +9,7 @@ import com.ruoyi.cai.domain.User;
import com.ruoyi.cai.domain.UserMember; import com.ruoyi.cai.domain.UserMember;
import com.ruoyi.cai.dto.admin.vo.UserMemberAdminVo; import com.ruoyi.cai.dto.admin.vo.UserMemberAdminVo;
import com.ruoyi.cai.dto.app.vo.user.MemberInfoVo; import com.ruoyi.cai.dto.app.vo.user.MemberInfoVo;
import com.ruoyi.cai.enums.UserMemberTypeEnum;
import com.ruoyi.cai.mapper.UserMemberMapper; import com.ruoyi.cai.mapper.UserMemberMapper;
import com.ruoyi.cai.pay.MemberStatusEnum; import com.ruoyi.cai.pay.MemberStatusEnum;
import com.ruoyi.cai.service.MemberPriceService; import com.ruoyi.cai.service.MemberPriceService;
@@ -59,10 +60,20 @@ public class UserMemberServiceImpl extends ServiceImpl<UserMemberMapper, UserMem
} }
@Override @Override
public UserMember getNormalMember(Long userId){ public UserMemberTypeEnum checkUserMember(Long userId){
return this.getOne(Wrappers.lambdaQuery(UserMember.class).eq(UserMember::getUserId,userId) List<UserMember> list = this.list(Wrappers.lambdaQuery(UserMember.class)
.eq(UserMember::getUserId, userId)
.eq(UserMember::getMemberStatus, MemberStatusEnum.NORMAL.getCode()) .eq(UserMember::getMemberStatus, MemberStatusEnum.NORMAL.getCode())
.last("limit 1")); .le(UserMember::getExpireDate, LocalDateTime.now())
.orderByDesc(UserMember::getMemberType));
for (UserMember userMember : list) {
if(userMember.getMemberType().equals(UserMemberTypeEnum.SUPER_VIP.getCode())){
return UserMemberTypeEnum.SUPER_VIP;
}else{
return UserMemberTypeEnum.NORMAL_VIP;
}
}
return null;
} }
@Override @Override