code review:分销
This commit is contained in:
		
							parent
							
								
									d874346d42
								
							
						
					
					
						commit
						df4716d5a1
					
				| @ -83,7 +83,6 @@ public interface ErrorCodeConstants { | ||||
|     ErrorCode BROKERAGE_BIND_LOOP = new ErrorCode(1_011_007_007, "下级不能绑定自己的上级"); | ||||
|     ErrorCode BROKERAGE_USER_LEVEL_NOT_SUPPORT = new ErrorCode(1_011_007_008, "目前只支持 level 小于等于 2"); | ||||
| 
 | ||||
| 
 | ||||
|     // ========== 分销提现 模块 1-011-008-000 ========== | ||||
|     ErrorCode BROKERAGE_WITHDRAW_NOT_EXISTS = new ErrorCode(1_011_008_000, "佣金提现记录不存在"); | ||||
|     ErrorCode BROKERAGE_WITHDRAW_STATUS_NOT_AUDITING = new ErrorCode(1_011_008_001, "佣金提现记录状态不是审核中"); | ||||
|  | ||||
| @ -151,10 +151,16 @@ public interface BrokerageUserMapper extends BaseMapperX<BrokerageUserDO> { | ||||
|                                                                         @Param("ids") Collection<Long> ids, | ||||
|                                                                         @Param("sortingField") SortingField sortingField); | ||||
| 
 | ||||
|     /** | ||||
|      * 获得被 bindUserIds 推广的用户编号数组 | ||||
|      * | ||||
|      * @param bindUserIds 推广员编号数组 | ||||
|      * @return 用户编号数组 | ||||
|      */ | ||||
|     default List<Long> selectIdListByBindUserIdIn(Collection<Long> bindUserIds) { | ||||
|         return Convert.toList(Long.class, | ||||
|                 selectObjs(new LambdaQueryWrapperX<BrokerageUserDO>() | ||||
|                         .select(Collections.singletonList(BrokerageUserDO::getId)) | ||||
|                         .select(Collections.singletonList(BrokerageUserDO::getId)) // 只查询 id 字段,加速返回速度 | ||||
|                         .in(BrokerageUserDO::getBindUserId, bindUserIds))); | ||||
|     } | ||||
| 
 | ||||
|  | ||||
| @ -231,7 +231,6 @@ public class BrokerageUserServiceImpl implements BrokerageUserService { | ||||
|         if (CollUtil.isEmpty(childIds)) { | ||||
|             return PageResult.empty(); | ||||
|         } | ||||
| 
 | ||||
|         // 1.2 根据昵称过滤下级用户 | ||||
|         Map<Long, MemberUserRespDTO> userMap = convertMapByFilter(memberUserApi.getUserList(childIds), | ||||
|                 user -> StrUtil.contains(user.getNickname(), pageReqVO.getNickname()), | ||||
| @ -240,13 +239,13 @@ public class BrokerageUserServiceImpl implements BrokerageUserService { | ||||
|             return PageResult.empty(); | ||||
|         } | ||||
| 
 | ||||
|         // 2 分页查询 | ||||
|         // 2. 分页查询 | ||||
|         IPage<AppBrokerageUserChildSummaryRespVO> pageResult = brokerageUserMapper.selectSummaryPageByUserId( | ||||
|                 MyBatisUtils.buildPage(pageReqVO), BrokerageRecordBizTypeEnum.ORDER.getType(), | ||||
|                 BrokerageRecordStatusEnum.SETTLEMENT.getStatus(), userMap.keySet(), pageReqVO.getSortingField() | ||||
|         ); | ||||
| 
 | ||||
|         // 3 拼接数据并返回 | ||||
|         // 3. 拼接数据并返回 | ||||
|         BrokerageUserConvert.INSTANCE.copyTo(pageResult.getRecords(), userMap); | ||||
|         return new PageResult<>(pageResult.getRecords(), pageResult.getTotal()); | ||||
|     } | ||||
|  | ||||
| @ -2,7 +2,6 @@ package cn.iocoder.yudao.module.member.service.user; | ||||
| 
 | ||||
| import cn.hutool.core.collection.CollUtil; | ||||
| import cn.hutool.core.collection.ListUtil; | ||||
| import cn.hutool.core.util.BooleanUtil; | ||||
| import cn.hutool.core.util.IdUtil; | ||||
| import cn.hutool.core.util.ObjectUtil; | ||||
| import cn.hutool.core.util.StrUtil; | ||||
| @ -28,6 +27,8 @@ import lombok.extern.slf4j.Slf4j; | ||||
| import org.springframework.security.crypto.password.PasswordEncoder; | ||||
| import org.springframework.stereotype.Service; | ||||
| import org.springframework.transaction.annotation.Transactional; | ||||
| import org.springframework.transaction.support.TransactionSynchronization; | ||||
| import org.springframework.transaction.support.TransactionSynchronizationManager; | ||||
| import org.springframework.transaction.support.TransactionTemplate; | ||||
| 
 | ||||
| import javax.annotation.Resource; | ||||
| @ -78,6 +79,7 @@ public class MemberUserServiceImpl implements MemberUserService { | ||||
|     } | ||||
| 
 | ||||
|     @Override | ||||
|     @Transactional(rollbackFor = Exception.class) | ||||
|     public MemberUserDO createUserIfAbsent(String mobile, String registerIp) { | ||||
|         // 用户已经存在 | ||||
|         MemberUserDO user = memberUserMapper.selectByMobile(mobile); | ||||
| @ -85,7 +87,7 @@ public class MemberUserServiceImpl implements MemberUserService { | ||||
|             return user; | ||||
|         } | ||||
|         // 用户不存在,则进行创建 | ||||
|         return this.createUser(mobile, registerIp); | ||||
|         return createUser(mobile, registerIp); | ||||
|     } | ||||
| 
 | ||||
|     private MemberUserDO createUser(String mobile, String registerIp) { | ||||
| @ -97,13 +99,17 @@ public class MemberUserServiceImpl implements MemberUserService { | ||||
|         user.setStatus(CommonStatusEnum.ENABLE.getStatus()); // 默认开启 | ||||
|         user.setPassword(encodePassword(password)); // 加密密码 | ||||
|         user.setRegisterIp(registerIp); | ||||
|         memberUserMapper.insert(user); | ||||
| 
 | ||||
|         Boolean success = transactionTemplate.execute(status -> memberUserMapper.insert(user) > 0); | ||||
|         if (BooleanUtil.isTrue(success)) { | ||||
|             // 发送 MQ 消息:用户创建 | ||||
|             registerCouponProducer.sendUserCreateMessage(user.getId()); | ||||
|         } | ||||
|         // 发送 MQ 消息:用户创建 | ||||
|         TransactionSynchronizationManager.registerSynchronization(new TransactionSynchronization() { | ||||
| 
 | ||||
|             @Override | ||||
|             public void afterCommit() { | ||||
|                 registerCouponProducer.sendUserCreateMessage(user.getId()); | ||||
|             } | ||||
| 
 | ||||
|         }); | ||||
|         return user; | ||||
|     } | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 YunaiV
						YunaiV