2013-03-20 20:33:42 +01:00
|
|
|
package com.commafeed.backend.dao;
|
|
|
|
|
|
2013-03-30 09:22:49 +01:00
|
|
|
import java.util.Collection;
|
2013-03-20 20:33:42 +01:00
|
|
|
|
2013-03-22 19:43:19 +01:00
|
|
|
import javax.ejb.Stateless;
|
2013-03-20 20:33:42 +01:00
|
|
|
import javax.inject.Inject;
|
2013-04-06 17:10:38 +02:00
|
|
|
import javax.persistence.NoResultException;
|
|
|
|
|
import javax.persistence.TypedQuery;
|
2013-03-20 20:33:42 +01:00
|
|
|
|
2013-03-23 16:17:19 +01:00
|
|
|
import com.commafeed.backend.model.User;
|
2013-03-30 09:22:49 +01:00
|
|
|
import com.commafeed.backend.model.UserRole;
|
2013-03-30 19:06:32 +01:00
|
|
|
import com.commafeed.backend.model.UserRole.Role;
|
2013-03-20 20:33:42 +01:00
|
|
|
import com.commafeed.backend.security.PasswordEncryptionService;
|
|
|
|
|
|
2013-03-22 19:43:19 +01:00
|
|
|
@Stateless
|
2013-03-25 12:24:00 +01:00
|
|
|
@SuppressWarnings("serial")
|
2013-03-30 11:37:57 +01:00
|
|
|
public class UserService extends GenericDAO<User> {
|
2013-03-20 20:33:42 +01:00
|
|
|
|
|
|
|
|
@Inject
|
|
|
|
|
PasswordEncryptionService encryptionService;
|
|
|
|
|
|
2013-04-06 21:38:18 +02:00
|
|
|
public User findByName(String name) {
|
2013-04-06 17:10:38 +02:00
|
|
|
TypedQuery<User> query = em.createNamedQuery("User.byName", User.class);
|
|
|
|
|
query.setParameter("name", name.toLowerCase());
|
|
|
|
|
|
|
|
|
|
User user = null;
|
|
|
|
|
try {
|
|
|
|
|
user = query.getSingleResult();
|
|
|
|
|
} catch (NoResultException e) {
|
|
|
|
|
user = null;
|
|
|
|
|
}
|
|
|
|
|
return user;
|
|
|
|
|
}
|
|
|
|
|
|
2013-03-20 20:33:42 +01:00
|
|
|
public User login(String name, String password) {
|
2013-04-06 17:10:38 +02:00
|
|
|
User user = findByName(name);
|
2013-03-29 12:59:21 +01:00
|
|
|
if (user != null && !user.isDisabled()) {
|
2013-03-20 20:33:42 +01:00
|
|
|
boolean authenticated = encryptionService.authenticate(password,
|
|
|
|
|
user.getPassword(), user.getSalt());
|
|
|
|
|
if (authenticated) {
|
|
|
|
|
return user;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return null;
|
|
|
|
|
}
|
2013-03-30 09:22:49 +01:00
|
|
|
|
2013-03-30 19:06:32 +01:00
|
|
|
public User register(String name, String password, Collection<Role> roles) {
|
2013-04-06 21:38:18 +02:00
|
|
|
return register(name, password, null, roles);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public User register(String name, String password, String email,
|
|
|
|
|
Collection<Role> roles) {
|
2013-04-06 17:10:38 +02:00
|
|
|
if (findByName(name) != null) {
|
2013-03-30 09:22:49 +01:00
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
User user = new User();
|
|
|
|
|
byte[] salt = encryptionService.generateSalt();
|
|
|
|
|
user.setName(name);
|
2013-04-06 21:38:18 +02:00
|
|
|
user.setEmail(email);
|
2013-03-30 09:22:49 +01:00
|
|
|
user.setSalt(salt);
|
|
|
|
|
user.setPassword(encryptionService.getEncryptedPassword(password, salt));
|
|
|
|
|
user.getRoles().add(new UserRole(user, Role.USER));
|
2013-03-30 19:06:32 +01:00
|
|
|
for (Role role : roles) {
|
2013-03-30 09:22:49 +01:00
|
|
|
user.getRoles().add(new UserRole(user, role));
|
|
|
|
|
user.getRoles().add(new UserRole(user, role));
|
|
|
|
|
}
|
|
|
|
|
save(user);
|
|
|
|
|
return user;
|
|
|
|
|
}
|
2013-03-20 20:33:42 +01:00
|
|
|
}
|