Search in sources :

Example 11 with User

use of com.hb0730.boot.admin.security.model.User in project boot-admin by hb0730.

the class RedisTokenServiceImpl method verifyAccessToken.

@Override
public void verifyAccessToken(HttpServletRequest request) {
    User loginUser = getLoginUser(request);
    if (Objects.nonNull(loginUser)) {
        Date expireTime = loginUser.getExpireTime();
        Date currentTime = DateUtils.now();
        long refreshTime = TimeUnit.MILLISECONDS.convert(super.getProperties().getRefreshTime(), super.getProperties().getTimeUnit());
        // 校验 刷新
        if (expireTime.getTime() - currentTime.getTime() <= refreshTime) {
            String accessToken = getAccessToken(request);
            String accessTokenKey = getAccessTokenKey(accessToken);
            stringRedisTemplate.opsForValue().set(accessTokenKey, loginUser.getToken(), super.getProperties().getExpireTime(), super.getProperties().getTimeUnit());
            refreshAccessToken(loginUser);
        }
    }
}
Also used : User(com.hb0730.boot.admin.security.model.User) Date(java.util.Date)

Example 12 with User

use of com.hb0730.boot.admin.security.model.User in project boot-admin by hb0730.

the class UserInfoServiceImpl method loadUserByUsername.

@Override
public UserDTO loadUserByUsername(String username) {
    UserAccountEntity accountEntity = accountService.findUserAccountByUsername(username);
    if (null == accountEntity) {
        return null;
    }
    Long userId = accountEntity.getUserId();
    UserInfoEntity entity = super.getById(userId);
    UserDTO user = BeanUtil.toBean(entity, UserDTO.class);
    assert user != null;
    user.setUsername(accountEntity.getUsername());
    user.setPassword(accountEntity.getPassword());
    // 用户角色
    Collection<Long> roleIds = userRoleService.findRoleByUserId(userId);
    if (CollectionUtils.isEmpty(roleIds)) {
        return user;
    }
    List<RoleEntity> roles = roleService.findEnabledRoleByIds(roleIds);
    if (CollectionUtils.isEmpty(roles)) {
        return user;
    }
    Map<Long, String> roleMap = roles.parallelStream().collect(Collectors.toMap(RoleEntity::getId, RoleEntity::getCode));
    user.setRoleIds(roleMap.keySet());
    user.setRole(roleMap.values());
    // 权限
    Map<Long, List<Long>> permission = rolePermissionService.findPermissionIdByRoleId(roleIds);
    if (CollectionUtils.isEmpty(permission)) {
        return user;
    }
    Set<Long> permissionIds = permission.values().stream().flatMap(List::stream).collect(Collectors.toSet());
    List<PermissionEntity> permissionEntities = permissionService.findEnabledPermissionByIds(permissionIds);
    if (CollectionUtils.isEmpty(permissionEntities)) {
        return user;
    }
    Map<Long, String> permissionMap = permissionEntities.parallelStream().collect(Collectors.toMap(PermissionEntity::getId, PermissionEntity::getPermission));
    user.setPermission(permissionMap.values());
    user.setPermissionIds(permissionMap.keySet());
    // 岗位
    List<Long> postIds = userPostService.findPostIdByUserIds(Collections.singletonList(userId));
    user.setPostIds(postIds);
    return user;
}
Also used : UserAccountEntity(com.hb0730.boot.admin.project.system.user.model.entity.UserAccountEntity) UserDTO(com.hb0730.boot.admin.project.system.user.model.dto.UserDTO) UserInfoEntity(com.hb0730.boot.admin.project.system.user.model.entity.UserInfoEntity) UserRoleEntity(com.hb0730.boot.admin.project.system.user.model.entity.UserRoleEntity) RoleEntity(com.hb0730.boot.admin.project.system.role.model.entity.RoleEntity) List(java.util.List) PermissionEntity(com.hb0730.boot.admin.project.system.permission.model.entity.PermissionEntity)

Example 13 with User

use of com.hb0730.boot.admin.security.model.User in project boot-admin by hb0730.

the class UserInfoController method getCurrentInfo.

/**
 * 获取当前请求认证的用户
 *
 * @param request 请求
 * @return 用户详情(不包含相关信息)
 */
@GetMapping
public Result<UserInfoDTO> getCurrentInfo(HttpServletRequest request) {
    User user = SecurityUtils.getCurrentUser();
    UserInfoDTO info = BeanUtil.toBean(user, UserInfoDTO.class);
    return R.success(info);
}
Also used : User(com.hb0730.boot.admin.security.model.User) UserInfoDTO(com.hb0730.boot.admin.project.system.user.model.dto.UserInfoDTO) GetMapping(org.springframework.web.bind.annotation.GetMapping)

Example 14 with User

use of com.hb0730.boot.admin.security.model.User in project boot-admin by hb0730.

the class MenuEventListener method onApplicationEvent.

@Override
public void onApplicationEvent(@Nonnull MenuEvent event) {
    Long userId = event.getUserId();
    if (null == userId) {
        return;
    }
    UserDTO user = findUserById(userId);
    if (null == user) {
        return;
    }
    // 
    List<TreeMenuDTO> menu = findMenuByUser(user);
    if (CollectionUtils.isEmpty(menu)) {
        return;
    }
    HashOperations<String, Long, List<TreeMenuDTO>> hash = redisTemplate.opsForHash();
    hash.put(RedisConstant.MENU_KEY_PREFIX, userId, menu);
}
Also used : TreeMenuDTO(com.hb0730.boot.admin.project.system.menu.model.dto.TreeMenuDTO) UserDTO(com.hb0730.boot.admin.project.system.user.model.dto.UserDTO) List(java.util.List)

Example 15 with User

use of com.hb0730.boot.admin.security.model.User in project boot-admin by hb0730.

the class RolePermissionListener method onApplicationEvent.

@Override
@Async("threadPoolTaskExecutor")
public void onApplicationEvent(@Nonnull RolePermissionEvent event) {
    Long roleId = event.getRoleId();
    Set<UserDetails> onlineUser = getOnlineUserByRoleId(roleId);
    if (CollectionUtils.isEmpty(onlineUser)) {
        return;
    }
    Set<String> usernameList = onlineUser.stream().map(UserDetails::getUsername).collect(Collectors.toSet());
    Map<String, UserDetails> onlineUserMap = onlineUser.stream().collect(Collectors.toMap(UserDetails::getUsername, Function.identity()));
    // 用户
    for (String username : usernameList) {
        UserDTO userDTO = userInfoService.loadUserByUsername(username);
        UserDetails details = onlineUserMap.get(username);
        BeanUtil.copyProperties(userDTO, details);
        // 刷新token
        tokenService.refreshAccessToken((User) details);
        eventPublisher.publishEvent(new MenuEvent(this, userDTO.getId()));
    }
}
Also used : UserDetails(org.springframework.security.core.userdetails.UserDetails) UserDTO(com.hb0730.boot.admin.project.system.user.model.dto.UserDTO) MenuEvent(com.hb0730.boot.admin.event.menu.MenuEvent) Async(org.springframework.scheduling.annotation.Async)

Aggregations

User (com.hb0730.boot.admin.security.model.User)13 List (java.util.List)4 MenuEvent (com.hb0730.boot.admin.event.menu.MenuEvent)3 LoginException (com.hb0730.boot.admin.exceptions.LoginException)3 TreeMenuDTO (com.hb0730.boot.admin.project.system.menu.model.dto.TreeMenuDTO)3 UserDTO (com.hb0730.boot.admin.project.system.user.model.dto.UserDTO)3 UserDetails (org.springframework.security.core.userdetails.UserDetails)3 PermissionEntity (com.hb0730.boot.admin.project.system.permission.model.entity.PermissionEntity)2 LoginUser (com.hb0730.boot.admin.security.model.LoginUser)2 HttpServletRequest (javax.servlet.http.HttpServletRequest)2 SneakyThrows (lombok.SneakyThrows)2 Test (org.junit.Test)2 SpringBootTest (org.springframework.boot.test.context.SpringBootTest)2 UsernamePasswordAuthenticationToken (org.springframework.security.authentication.UsernamePasswordAuthenticationToken)2 MvcResult (org.springframework.test.web.servlet.MvcResult)2 RequestAttributes (org.springframework.web.context.request.RequestAttributes)2 ServletRequestAttributes (org.springframework.web.context.request.ServletRequestAttributes)2 UpdateWrapper (com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper)1 ClassDescribe (com.hb0730.boot.admin.annotation.ClassDescribe)1 Log (com.hb0730.boot.admin.annotation.Log)1