Package org.springside.examples.miniweb.service.account

Source Code of org.springside.examples.miniweb.service.account.UserDetailsServiceImpl

package org.springside.examples.miniweb.service.account;

import java.util.Set;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.dao.DataAccessException;
import org.springframework.security.core.GrantedAuthority;
import org.springframework.security.core.authority.GrantedAuthorityImpl;
import org.springframework.security.core.userdetails.UserDetails;
import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.core.userdetails.UsernameNotFoundException;
import org.springframework.transaction.annotation.Transactional;
import org.springside.examples.miniweb.entity.account.Authority;
import org.springside.examples.miniweb.entity.account.Role;
import org.springside.examples.miniweb.entity.account.User;

import com.google.common.collect.Sets;

/**
* 实现SpringSecurity的UserDetailsService接口,实现获取用户Detail信息的回调函数.
*
* @author calvin
*/
@Transactional(readOnly = true)
public class UserDetailsServiceImpl implements UserDetailsService {

  private AccountManager accountManager;

  /**
   * 获取用户Details信息的回调函数.
   */
  public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException, DataAccessException {

    User user = accountManager.findUserByLoginName(username);
    if (user == null) {
      throw new UsernameNotFoundException("用户" + username + " 不存在");
    }

    Set<GrantedAuthority> grantedAuths = obtainGrantedAuthorities(user);

    //-- mini-web示例中无以下属性, 暂时全部设为true. --//
    boolean enabled = true;
    boolean accountNonExpired = true;
    boolean credentialsNonExpired = true;
    boolean accountNonLocked = true;

    UserDetails userdetails = new org.springframework.security.core.userdetails.User(user.getLoginName(), user
        .getPassword(), enabled, accountNonExpired, credentialsNonExpired, accountNonLocked, grantedAuths);

    return userdetails;
  }

  /**
   * 获得用户所有角色的权限集合.
   */
  private Set<GrantedAuthority> obtainGrantedAuthorities(User user) {
    Set<GrantedAuthority> authSet = Sets.newHashSet();
    for (Role role : user.getRoleList()) {
      for (Authority authority : role.getAuthorityList()) {
        authSet.add(new GrantedAuthorityImpl(authority.getPrefixedName()));
      }
    }
    return authSet;
  }

  @Autowired
  public void setAccountManager(AccountManager accountManager) {
    this.accountManager = accountManager;
  }
}
TOP

Related Classes of org.springside.examples.miniweb.service.account.UserDetailsServiceImpl

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.