From d2542a6123fa6834e01ed3af23c7ba0a02696bc6 Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期五, 29 十一月 2024 16:37:02 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/AppUserServiceImpl.java |  156 +++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 135 insertions(+), 21 deletions(-)

diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/AppUserServiceImpl.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/AppUserServiceImpl.java
index de64b48..953d74d 100644
--- a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/AppUserServiceImpl.java
+++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/AppUserServiceImpl.java
@@ -7,14 +7,18 @@
 import com.ruoyi.account.service.AppUserService;
 import com.ruoyi.account.util.weChat.WeChatUtil;
 import com.ruoyi.account.vo.*;
+import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.core.web.domain.AjaxResult;
 import com.ruoyi.common.redis.service.RedisService;
 import com.ruoyi.common.security.service.TokenService;
-import com.ruoyi.system.api.vo.LoginUser;
+import com.ruoyi.system.api.model.LoginUser;
 import org.springframework.stereotype.Service;
 
 import javax.annotation.Resource;
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
 import java.util.HashMap;
+import java.util.List;
 import java.util.Map;
 
 /**
@@ -44,12 +48,12 @@
 	 * @return
 	 */
 	@Override
-	public AjaxResult appletLogin(AppletLogin appletLogin) {
+	public R appletLogin(AppletLogin appletLogin) {
 		//使用jscode获取微信openid
 		Map<String, Object> map = weChatUtil.code2Session(appletLogin.getJscode());
 		Integer errcode = Integer.valueOf(map.get("errcode").toString());
 		if(0 != errcode){
-			return AjaxResult.error(map.get("msg").toString());
+			return R.fail(map.get("msg").toString());
 		}
 		String openid = map.get("openid").toString();
 		//查询用户是否注册,没有注册则跳转到注册页面
@@ -57,11 +61,11 @@
 		if(null == appUser){
 			LoginVo loginVo = new LoginVo();
 			loginVo.setSkipPage(2);
-			return AjaxResult.success(loginVo);
+			return R.ok(loginVo);
 		}
 		//账户被冻结,给出提示
 		if(2 == appUser.getStatus()){
-			return AjaxResult.error("账户已被冻结,请联系管理员!");
+			return R.fail("账户已被冻结,请联系管理员!");
 		}
 		LoginVo loginVo = new LoginVo();
 		loginVo.setSkipPage(1);
@@ -69,12 +73,12 @@
 		loginVo.setPhone(appUser.getPhone());
 		//构建token
 		LoginUser loginUser = new LoginUser();
-		loginUser.setUserId(appUser.getId());
-		loginUser.setName(appUser.getName());
+		loginUser.setUserid(appUser.getId());
+		loginUser.setUsername(appUser.getName());
 		Map<String, Object> tokenApplet = tokenService.createTokenApplet(loginUser);
 		loginVo.setToken(tokenApplet.get("access_token").toString());
 		loginVo.setFailureTime(Long.valueOf(tokenApplet.get("expires_in").toString()));
-		return AjaxResult.success(loginVo);
+		return R.ok(loginVo);
 	}
 	
 	
@@ -84,11 +88,11 @@
 	 * @return
 	 */
 	@Override
-	public AjaxResult<LoginVo> mobileLogin(MobileLogin mobileLogin) {
+	public R<LoginVo> mobileLogin(MobileLogin mobileLogin) {
 		//校验验证码
 		String code = redisService.getCacheObject(mobileLogin.getPhone());
 		if(null == code || !code.equals(mobileLogin.getCode())){
-			return AjaxResult.error("验证码错误");
+			return R.fail("验证码错误");
 		}
 		
 		//查询用户是否注册,没有注册则跳转到注册页面
@@ -96,11 +100,11 @@
 		if(null == appUser){
 			LoginVo loginVo = new LoginVo();
 			loginVo.setSkipPage(2);
-			return AjaxResult.success(loginVo);
+			return R.ok(loginVo);
 		}
 		//账户被冻结,给出提示
 		if(2 == appUser.getStatus()){
-			return AjaxResult.error("账户已被冻结,请联系管理员!");
+			return R.fail("账户已被冻结,请联系管理员!");
 		}
 		LoginVo loginVo = new LoginVo();
 		loginVo.setSkipPage(1);
@@ -108,12 +112,12 @@
 		loginVo.setPhone(appUser.getPhone());
 		//构建token
 		LoginUser loginUser = new LoginUser();
-		loginUser.setUserId(appUser.getId());
-		loginUser.setName(appUser.getName());
+		loginUser.setUserid(appUser.getId());
+		loginUser.setUsername(appUser.getName());
 		Map<String, Object> tokenApplet = tokenService.createTokenApplet(loginUser);
 		loginVo.setToken(tokenApplet.get("access_token").toString());
-		loginVo.setFailureTime(Long.valueOf(tokenApplet.get("expires_in").toString()));
-		return AjaxResult.success(loginVo);
+			loginVo.setFailureTime(Long.valueOf(tokenApplet.get("expires_in").toString()));
+		return R.ok(loginVo);
 	}
 	
 	
@@ -123,7 +127,7 @@
 	 * @return
 	 */
 	@Override
-	public AjaxResult getSMSCode(SMSCode smsCode) {
+	public R getSMSCode(SMSCode smsCode) {
 		//校验验证码获取评率(1分钟5次)
 		String key = smsCode.getType() + "&" + smsCode.getPhone();
 		Map<String, Object> cacheMap = redisService.getCacheMap(key);
@@ -131,7 +135,7 @@
 			Integer number = Integer.valueOf(cacheMap.get("number").toString()) + 1;
 			Long startTime = Long.valueOf(cacheMap.get("startTime").toString());
 			if(number > 5 && (System.currentTimeMillis() - startTime) < 60000){
-				return AjaxResult.error("获取验证码太频繁,请稍后重试!");
+				return R.fail("获取验证码太频繁,请稍后重试!");
 			}
 			if(number <= 5){
 				cacheMap.put("number", number);
@@ -153,7 +157,7 @@
 			code += Double.valueOf(Math.random() * 10).intValue();
 		}
 		//发送短信 todo 待对接短信
-		return AjaxResult.success();
+		return R.ok();
 	}
 	
 	
@@ -163,7 +167,117 @@
 	 * @return
 	 */
 	@Override
-	public AjaxResult<LoginVo> registerAccount(RegisterAccount registerAccount) {
-		return null;
+	public R<LoginVo> registerAccount(RegisterAccount registerAccount) {
+		//校验验证码
+		String code = redisService.getCacheObject(registerAccount.getPhone());
+		if(null == code || !code.equals(registerAccount.getCode())){
+			return R.fail("验证码错误");
+		}
+		//使用jscode获取微信openid
+		Map<String, Object> map = weChatUtil.code2Session(registerAccount.getJscode());
+		Integer errcode = Integer.valueOf(map.get("errcode").toString());
+		if(0 != errcode){
+			return R.fail(map.get("msg").toString());
+		}
+		String openid = map.get("openid").toString();
+		//查询用户是否注册
+		AppUser appUser = this.getOne(new LambdaQueryWrapper<AppUser>().eq(AppUser::getWxOpenid, openid).ne(AppUser::getStatus, 3).eq(AppUser::getDelFlag, 0));
+		if(null != appUser){
+			return R.fail("此微信号已注册,请直接登录!");
+		}
+		AppUser appUser1 = this.getOne(new LambdaQueryWrapper<AppUser>().eq(AppUser::getPhone, registerAccount.getPhone()).ne(AppUser::getStatus, 3).eq(AppUser::getDelFlag, 0));
+		if(null != appUser1){
+			return R.fail("手机号已注册,请直接登录!");
+		}
+		if(null == appUser){
+			appUser = new AppUser();
+			appUser.setName(registerAccount.getName());
+			appUser.setPhone(registerAccount.getPhone());
+			appUser.setWxOpenid(openid);
+			//注册默认为普通会员
+			appUser.setVipId(1);
+			appUser.setStatus(1);
+			appUser.setCreateTime(LocalDateTime.now());
+			appUser.setDelFlag(false);
+			appUser.setFirstAdd(1);
+			appUser.setLastLoginTime(LocalDateTime.now());
+			//顶级推广人
+			AppUser topAppUser = getTopAppUser(registerAccount.getPromoter());
+			appUser.setTopInviteId(topAppUser.getId());
+			//绑定门店为推荐人绑定的门店
+			AppUser appUser2 = this.getById(registerAccount.getPromoter());
+			appUser.setInviteUserId(registerAccount.getPromoter());
+			appUser.setShopId(appUser2.getShopId());
+			appUser.setPartPoint(BigDecimal.ZERO);
+			appUser.setPartGrowPoint(BigDecimal.ZERO);
+			appUser.setShopPoint(BigDecimal.ZERO);
+			appUser.setSharePoint(BigDecimal.ZERO);
+			appUser.setShopAmount(BigDecimal.ZERO);
+			appUser.setWithdrawableAmount(BigDecimal.ZERO);
+			appUser.setWithdrawnAmount(BigDecimal.ZERO);
+			appUser.setTotalRechargeAmount(BigDecimal.ZERO);
+			appUser.setTotalRedPacketAmount(BigDecimal.ZERO);
+			appUser.setTotalDistributionAmount(BigDecimal.ZERO);
+			appUser.setLavePoint(BigDecimal.ZERO);
+			//根据平台的配置未达标,则标注为可修改推广人
+			appUser.setChangePromoter(0);
+			appUser.setLongitude(registerAccount.getLongitude());
+			appUser.setLatitude(registerAccount.getLatitude());
+			//调用地图获取省市区数据
+//			appUser.setProvince();
+//			appUser.setProvinceCode();
+//			appUser.setCity();
+//			appUser.setCityCode();
+//			appUser.setDistrict();
+//			appUser.setDistrictCode();
+			this.save(appUser);
+		}
+		LoginVo loginVo = new LoginVo();
+		loginVo.setSkipPage(1);
+		loginVo.setFirstTime(false);
+		loginVo.setPhone(appUser.getPhone());
+		//构建token
+		LoginUser loginUser = new LoginUser();
+		loginUser.setUserid(appUser.getId());
+		loginUser.setUsername(appUser.getName());
+		Map<String, Object> tokenApplet = tokenService.createTokenApplet(loginUser);
+		loginVo.setToken(tokenApplet.get("access_token").toString());
+		loginVo.setFailureTime(Long.valueOf(tokenApplet.get("expires_in").toString()));
+		return R.ok(loginVo);
+	}
+	
+	
+	/**
+	 * 递归查询顶级推广人
+	 * @param id
+	 * @return
+	 */
+	public AppUser getTopAppUser(Long id){
+		List<AppUser> list = this.list(new LambdaQueryWrapper<AppUser>().eq(AppUser::getDelFlag, 0));
+		return getTopAppUser(list, id);
+	}
+	
+	public AppUser getTopAppUser(List<AppUser> list, Long id){
+		AppUser appUser = list.stream().filter(s -> s.getInviteUserId().equals(id)).findFirst().get();
+		if(null == appUser.getInviteUserId()){
+			return appUser;
+		}
+		return getTopAppUser(list, appUser.getId());
+	}
+	
+	
+	/**
+	 * 获取附近推广人
+	 * @param nearbyReferrer
+	 * @return
+	 */
+	@Override
+	public List<NearbyReferrerVo> getNearbyReferrer(NearbyReferrer nearbyReferrer) {
+		//使用地图获取省市区数据
+		String longitude = nearbyReferrer.getLongitude();
+		String latitude = nearbyReferrer.getLatitude();
+		String cityCode = "";
+		List<NearbyReferrerVo> list = this.baseMapper.getNearbyReferrer(cityCode, nearbyReferrer);
+		return list;
 	}
 }

--
Gitblit v1.7.1