mirror of
https://github.com/Athou/commafeed.git
synced 2026-03-21 21:37:29 +00:00
107 lines
2.9 KiB
Java
107 lines
2.9 KiB
Java
package com.commafeed.backend.services;
|
|
|
|
import java.util.Calendar;
|
|
import java.util.Collection;
|
|
import java.util.UUID;
|
|
|
|
import javax.ejb.Stateless;
|
|
import javax.inject.Inject;
|
|
|
|
import org.apache.commons.codec.digest.DigestUtils;
|
|
|
|
import com.commafeed.backend.dao.FeedCategoryDAO;
|
|
import com.commafeed.backend.dao.FeedEntryStatusDAO;
|
|
import com.commafeed.backend.dao.FeedSubscriptionDAO;
|
|
import com.commafeed.backend.dao.UserDAO;
|
|
import com.commafeed.backend.dao.UserRoleDAO;
|
|
import com.commafeed.backend.dao.UserSettingsDAO;
|
|
import com.commafeed.backend.model.User;
|
|
import com.commafeed.backend.model.UserRole;
|
|
import com.commafeed.backend.model.UserRole.Role;
|
|
import com.commafeed.backend.model.UserSettings.ReadingOrder;
|
|
import com.google.common.base.Preconditions;
|
|
|
|
@Stateless
|
|
public class UserService {
|
|
|
|
@Inject
|
|
UserDAO userDAO;
|
|
|
|
@Inject
|
|
FeedEntryStatusDAO feedEntryStatusDAO;
|
|
|
|
@Inject
|
|
FeedSubscriptionDAO feedSubscriptionDAO;
|
|
|
|
@Inject
|
|
FeedCategoryDAO feedCategoryDAO;
|
|
|
|
@Inject
|
|
UserSettingsDAO userSettingsDAO;
|
|
|
|
@Inject
|
|
UserRoleDAO userRoleDAO;
|
|
|
|
@Inject
|
|
PasswordEncryptionService encryptionService;
|
|
|
|
public User login(String name, String password) {
|
|
Preconditions.checkNotNull(name);
|
|
Preconditions.checkNotNull(password);
|
|
|
|
User user = userDAO.findByName(name);
|
|
if (user != null && !user.isDisabled()) {
|
|
boolean authenticated = encryptionService.authenticate(password,
|
|
user.getPassword(), user.getSalt());
|
|
if (authenticated) {
|
|
user.setLastLogin(Calendar.getInstance().getTime());
|
|
userDAO.update(user);
|
|
return user;
|
|
}
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
public User register(String name, String password, Collection<Role> roles) {
|
|
return register(name, password, null, roles);
|
|
}
|
|
|
|
public User register(String name, String password, String email,
|
|
Collection<Role> roles) {
|
|
Preconditions.checkNotNull(name);
|
|
Preconditions.checkNotNull(password);
|
|
|
|
if (userDAO.findByName(name) != null) {
|
|
return null;
|
|
}
|
|
User user = new User();
|
|
byte[] salt = encryptionService.generateSalt();
|
|
user.setName(name);
|
|
user.setEmail(email);
|
|
user.setSalt(salt);
|
|
user.setPassword(encryptionService.getEncryptedPassword(password, salt));
|
|
for (Role role : roles) {
|
|
user.getRoles().add(new UserRole(user, role));
|
|
}
|
|
userDAO.save(user);
|
|
return user;
|
|
}
|
|
|
|
public void unregister(User user) {
|
|
feedEntryStatusDAO.delete(feedEntryStatusDAO.findAll(user, false,
|
|
ReadingOrder.desc, false));
|
|
feedSubscriptionDAO.delete(feedSubscriptionDAO.findAll(user));
|
|
feedCategoryDAO.delete(feedCategoryDAO.findAll(user));
|
|
userSettingsDAO.delete(userSettingsDAO.findByUser(user));
|
|
userRoleDAO.delete(userRoleDAO.findAll(user));
|
|
userDAO.delete(user);
|
|
}
|
|
|
|
public String generateApiKey(User user) {
|
|
byte[] key = encryptionService.getEncryptedPassword(UUID.randomUUID()
|
|
.toString(), user.getSalt());
|
|
return DigestUtils.sha1Hex(key);
|
|
}
|
|
}
|