From 26b5b1a6bbbb5ff64dc2ec73cf8b11f1aa61c1c5 Mon Sep 17 00:00:00 2001 From: yujian <yujian> Date: 星期二, 14 五月 2019 11:03:25 +0800 Subject: [PATCH] Merge branch 'div_8' --- fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserInfoExtraServiceImpl.java | 88 +++++++++++++++++++++++++++++++++----------- 1 files changed, 66 insertions(+), 22 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserInfoExtraServiceImpl.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserInfoExtraServiceImpl.java index 41f50f2..96de5ca 100644 --- a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserInfoExtraServiceImpl.java +++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserInfoExtraServiceImpl.java @@ -1,5 +1,6 @@ package com.yeshi.fanli.service.impl.user; +import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Calendar; @@ -11,6 +12,7 @@ import javax.annotation.Resource; import org.springframework.stereotype.Service; +import org.yeshi.utils.DateUtil; import com.yeshi.fanli.dao.mybatis.user.UserInfoExtraMapper; import com.yeshi.fanli.dao.mybatis.user.UserRankRecordMapper; @@ -173,6 +175,21 @@ } return userInfoExtra; + } + + @Override + public void createUserInfoExtra (Long uid) throws UserInfoExtraException{ + UserInfoExtra userInfoExtra = userInfoExtraMapper.getInfoExtraByUid(uid); + if (userInfoExtra != null) { + return; + } + + userInfoExtra = new UserInfoExtra(); + userInfoExtra.setUserInfo(new UserInfo(uid)); + userInfoExtra.setFirstLoginTime(new Date()); + userInfoExtra.setCreateTime(new Date()); + userInfoExtra.setUpdateTime(new Date()); + userInfoExtraMapper.insertSelective(userInfoExtra); } @@ -368,7 +385,7 @@ @Override public void activationInviteWX(Long uid, String code) throws UserInfoExtraException{ if (uid == null || code == null) { - throw new UserInfoExtraException(1, "鐢ㄦ埛id銆侀個璇风爜涓嶈兘涓虹┖"); + throw new UserInfoExtraException(1, "婵�娲讳俊鎭笉瀹屾暣"); } // 鐢ㄦ埛淇℃伅 @@ -386,9 +403,8 @@ } } - // 鑾峰彇寰俊淇℃伅 - WeiXinUser weiXinUser = WXLoginUtil.getWeiXinWYUser(code); + WeiXinUser weiXinUser = WXLoginUtil.getWeiXinUser(code); if (weiXinUser == null) { throw new UserInfoExtraException(1, "寰俊鎺堟潈澶辫触"); } @@ -397,24 +413,31 @@ throw new UserInfoExtraException(1, "寰俊鎺堟潈澶辫触"); } - - // 鑷姩缁戝畾寰俊 - UserInfo updateUserInfo = new UserInfo(uid); - updateUserInfo.setWxName(weiXinUser.getNickname()); - updateUserInfo.setWxOpenId(weiXinUser.getOpenid()); - updateUserInfo.setWxPic(weiXinUser.getHeadimgurl()); - updateUserInfo.setWxUnionId(weiXinUser.getUnionid()); - updateUserInfo.setNickName(weiXinUser.getNickname()); - updateUserInfo.setPortrait(weiXinUser.getHeadimgurl()); - if (StringUtil.isNullOrEmpty(weiXinUser.getNickname())) { - updateUserInfo.setNickName(Constant.systemCommonConfig.getDefaultNickName()); + // 楠岃瘉鏁版嵁 + String wxUnionIdExist = invitee.getWxUnionId(); + if (StringUtil.isNullOrEmpty(wxUnionIdExist)) { + UserInfo newUser = userInfoService.getEffectiveUserInfoByWXUnionId(weiXinUser.getUnionid()); + if (newUser != null) { + throw new UserInfoExtraException(1, "姝ゅ井淇″凡琚叾浠栧笎鍙风粦瀹�"); + } + + // 鑷姩缁戝畾寰俊 + UserInfo updateUserInfo = new UserInfo(uid); + updateUserInfo.setWxOpenId(weiXinUser.getOpenid()); + updateUserInfo.setWxUnionId(weiXinUser.getUnionid()); + if (!StringUtil.isNullOrEmpty(weiXinUser.getNickname())) { + updateUserInfo.setWxName(weiXinUser.getNickname()); + updateUserInfo.setNickName(weiXinUser.getNickname()); + } + if (!StringUtil.isNullOrEmpty(weiXinUser.getHeadimgurl())) { + updateUserInfo.setWxPic(weiXinUser.getHeadimgurl()); + updateUserInfo.setPortrait(weiXinUser.getHeadimgurl()); + } + userInfoService.updateByPrimaryKeySelective(updateUserInfo); + + } else if (!wxUnionId.equals(wxUnionIdExist)){ + throw new UserInfoExtraException(1, "缁戝畾寰俊涓庢縺娲诲井淇′笉涓�鑷�"); } - - if (StringUtil.isNullOrEmpty(weiXinUser.getHeadimgurl())) { - updateUserInfo.setPortrait(Constant.systemCommonConfig.getDefaultPortrait()); - } - userInfoService.updateByPrimaryKeySelective(updateUserInfo); - // 閭�璇蜂汉ID -1.5.3鏂扮増 @@ -436,7 +459,7 @@ // 娌℃湁琚個璇疯繃 if (inviterId == null && threeSale == null) { - throw new UserInfoExtraException(1, "寰俊婵�娲诲け璐�"); + throw new UserInfoExtraException(1, "娌℃湁瀵瑰簲鐨勯個璇峰叧绯�"); } // 缁戝畾鍏崇郴 @@ -448,7 +471,7 @@ } catch (Exception e1) { e1.printStackTrace(); } - throw new UserInfoExtraException(1, "婵�娲诲け璐�"); + throw new UserInfoExtraException(1, "鍏崇郴缁戝畾鏃跺け璐�"); } @@ -521,4 +544,25 @@ return userInfoExtraMapper.countByRankId(rankId); } + @Override + public boolean isNewUser(Long uid) { + boolean isNew = false; + if (uid == null) { + return isNew; + } + + UserInfoExtra extra = userInfoExtraMapper.getInfoExtraByUid(uid); + if (extra != null && extra.getFirstLoginTime() != null) { + try { + int day = DateUtil.daysBetween(extra.getFirstLoginTime(), new Date()); + if (day <= 15) { + isNew = true; + } + } catch (ParseException e) { + e.printStackTrace(); + } + } + return isNew; + } + } -- Gitblit v1.8.0