!105 【轻量级 PR】优化第三方认证授权绑定

Merge pull request !105 from MichelleChung/2.X
dev
疯狂的狮子Li 2 years ago committed by Gitee
commit 7c2b478cdc
No known key found for this signature in database
GPG Key ID: 173E9B9CA92EEF8F

@ -20,6 +20,11 @@ public interface RemoteSocialService {
*/
void insertByBo(RemoteSocialBo bo);
/**
*
*/
void updateByBo(RemoteSocialBo bo);
/**
*
*/

@ -31,6 +31,7 @@ import org.dromara.system.api.RemoteTenantService;
import org.dromara.system.api.RemoteUserService;
import org.dromara.system.api.domain.bo.RemoteSocialBo;
import org.dromara.system.api.domain.bo.RemoteUserBo;
import org.dromara.system.api.domain.vo.RemoteSocialVo;
import org.dromara.system.api.domain.vo.RemoteTenantVo;
import org.dromara.system.api.model.LoginUser;
import org.springframework.beans.factory.annotation.Autowired;
@ -66,14 +67,25 @@ public class SysLoginService {
* @param authUserData
*/
public void socialRegister(AuthUser authUserData) {
String authId = authUserData.getSource() + authUserData.getUuid();
// 第三方用户信息
RemoteSocialBo bo = BeanUtil.toBean(authUserData, RemoteSocialBo.class);
BeanUtil.copyProperties(authUserData.getToken(), bo);
bo.setUserId(LoginHelper.getUserId());
bo.setAuthId(authUserData.getSource() + authUserData.getUuid());
bo.setAuthId(authId);
bo.setOpenId(authUserData.getUuid());
bo.setUserName(authUserData.getUsername());
bo.setNickName(authUserData.getNickname());
remoteSocialService.insertByBo(bo);
// 查询是否已经绑定用户
RemoteSocialVo vo = remoteSocialService.selectByAuthId(authId);
if (ObjectUtil.isEmpty(vo)) {
// 没有绑定用户, 新增用户信息
remoteSocialService.insertByBo(bo);
} else {
// 更新用户信息
bo.setId(vo.getId());
remoteSocialService.updateByBo(bo);
}
}
/**

@ -6,8 +6,10 @@ import org.dromara.common.core.utils.MapstructUtils;
import org.dromara.system.api.RemoteSocialService;
import org.dromara.system.api.domain.bo.RemoteSocialBo;
import org.dromara.system.api.domain.vo.RemoteSocialVo;
import org.dromara.system.domain.SysSocial;
import org.dromara.system.domain.bo.SysSocialBo;
import org.dromara.system.domain.vo.SysSocialVo;
import org.dromara.system.mapper.SysSocialMapper;
import org.dromara.system.service.ISysSocialService;
import org.springframework.stereotype.Service;
@ -22,6 +24,7 @@ import org.springframework.stereotype.Service;
public class RemoteSocialServiceImpl implements RemoteSocialService {
private final ISysSocialService sysSocialService;
private final SysSocialMapper sysSocialMapper;
/**
* authId
@ -40,6 +43,14 @@ public class RemoteSocialServiceImpl implements RemoteSocialService {
sysSocialService.insertByBo(MapstructUtils.convert(bo, SysSocialBo.class));
}
/**
*
*/
@Override
public void updateByBo(RemoteSocialBo bo) {
sysSocialService.updateByBo(MapstructUtils.convert(bo, SysSocialBo.class));
}
/**
*
*/

@ -33,6 +33,11 @@ public interface ISysSocialService {
*/
Boolean insertByBo(SysSocialBo bo);
/**
*
*/
Boolean updateByBo(SysSocialBo bo);
/**
*

@ -65,6 +65,16 @@ public class SysSocialServiceImpl implements ISysSocialService {
return flag;
}
/**
*
*/
@Override
public Boolean updateByBo(SysSocialBo bo) {
SysSocial update = MapstructUtils.convert(bo, SysSocial.class);
validEntityBeforeSave(update);
return baseMapper.updateById(update) > 0;
}
/**
*

Loading…
Cancel
Save