CustomerServicesImpl.java
Home
/
sm-shop /
src /
main /
java /
com /
salesmanager /
web /
services /
security /
CustomerServicesImpl.java
package com.salesmanager.web.services.security;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import org.apache.commons.collections.CollectionUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
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.User;
import org.springframework.security.core.userdetails.UserDetails;
import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.core.userdetails.UsernameNotFoundException;
import org.springframework.stereotype.Service;
import com.salesmanager.core.business.customer.model.Customer;
import com.salesmanager.core.business.customer.service.CustomerService;
import com.salesmanager.core.business.generic.exception.ServiceException;
import com.salesmanager.core.business.user.model.Group;
import com.salesmanager.core.business.user.model.Permission;
import com.salesmanager.core.business.user.service.GroupService;
import com.salesmanager.core.business.user.service.PermissionService;
import com.salesmanager.web.admin.security.SecurityDataAccessException;
/**
*
* @author casams1
* http://stackoverflow.com/questions/5105776/spring-security-with
* -custom-user-details
*/
@Service("customerDetailsService")
public class CustomerServicesImpl implements UserDetailsService{
private static final Logger LOGGER = LoggerFactory.getLogger(CustomerServicesImpl.class);
@Autowired
private CustomerService customerService;
@Autowired
protected PermissionService permissionService;
@Autowired
protected GroupService groupService;
@SuppressWarnings("deprecation")
public UserDetails loadUserByUsername(String userName)
throws UsernameNotFoundException, DataAccessException {
Customer user;
Collection<GrantedAuthority> authorities = new ArrayList<GrantedAuthority>();
try {
user = customerService.getByNick(userName);
if(user==null) {
return null;
}
List<Integer> groupsId = new ArrayList<Integer>();
List<Group> groups = user.getGroups();
for(Group group : groups) {
groupsId.add(group.getId());
}
if(CollectionUtils.isNotEmpty(groupsId)) {
List<Permission> permissions = permissionService.getPermissions(groupsId);
for(Permission permission : permissions) {
GrantedAuthority auth = new GrantedAuthorityImpl(permission.getPermissionName());
authorities.add(auth);
}
}
} catch (ServiceException e) {
LOGGER.error("Exception while querrying customer",e);
throw new SecurityDataAccessException("Cannot authenticate customer",e);
}
User authUser = new User(userName, user.getPassword(), true, true,
true, true, authorities);
return authUser;
}
}