mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-10-08 14:51:49 +00:00
125603 rmunteanu: Merged 5.1.1 (5.1.1) to 5.1.N (5.1.2) 125484 slanglois: MNT-16155 Update source headers - remove old Copyrights from Java and JSP dource files git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/DEV/5.2.N/root@125781 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
129 lines
3.9 KiB
Java
129 lines
3.9 KiB
Java
package org.alfresco.repo.imap;
|
|
|
|
import java.util.Collections;
|
|
import java.util.HashMap;
|
|
import java.util.Map;
|
|
|
|
import com.icegreen.greenmail.imap.ImapRequestLineReader;
|
|
import com.icegreen.greenmail.imap.ImapResponse;
|
|
import com.icegreen.greenmail.imap.ImapSession;
|
|
import org.alfresco.model.ContentModel;
|
|
import org.alfresco.repo.security.authentication.AuthenticationException;
|
|
import org.alfresco.service.cmr.repository.NodeRef;
|
|
import org.alfresco.service.cmr.repository.NodeService;
|
|
import org.alfresco.service.cmr.security.AuthenticationService;
|
|
import org.alfresco.service.cmr.security.PersonService;
|
|
import org.apache.commons.logging.Log;
|
|
import org.apache.commons.logging.LogFactory;
|
|
|
|
import com.icegreen.greenmail.user.GreenMailUser;
|
|
import com.icegreen.greenmail.user.UserException;
|
|
import com.icegreen.greenmail.user.UserManager;
|
|
|
|
/**
|
|
* @author Arseny Kovalchuk
|
|
*/
|
|
public class AlfrescoImapUserManager extends UserManager
|
|
{
|
|
private Log logger = LogFactory.getLog(AlfrescoImapUserManager.class);
|
|
|
|
protected Map<String, GreenMailUser> userMap = Collections.synchronizedMap(new HashMap<String, GreenMailUser>());
|
|
|
|
protected AuthenticationService authenticationService;
|
|
protected PersonService personService;
|
|
protected NodeService nodeService;
|
|
|
|
public AlfrescoImapUserManager()
|
|
{
|
|
super(null);
|
|
}
|
|
|
|
public GreenMailUser createUser(String email, String login, String password) throws UserException
|
|
{
|
|
// TODO: User creation/addition code should be implemented here (in the AlfrescoImapUserManager).
|
|
// Following code is not need and not used in the current implementation.
|
|
GreenMailUser user = new AlfrescoImapUser(email, login, password);
|
|
user.create();
|
|
addUser(user);
|
|
return user;
|
|
}
|
|
|
|
protected void addUser(GreenMailUser user)
|
|
{
|
|
userMap.put(user.getLogin(), user);
|
|
}
|
|
|
|
public GreenMailUser getUser(String login)
|
|
{
|
|
return (GreenMailUser) userMap.get(login);
|
|
}
|
|
|
|
public GreenMailUser getUserByEmail(String email)
|
|
{
|
|
GreenMailUser ret = getUser(email);
|
|
if (null == ret)
|
|
{
|
|
for (GreenMailUser user : userMap.values())
|
|
{
|
|
// TODO: NPE!
|
|
if (user.getEmail().trim().equalsIgnoreCase(email.trim()))
|
|
{
|
|
return user;
|
|
}
|
|
}
|
|
}
|
|
return ret;
|
|
}
|
|
|
|
public void deleteUser(GreenMailUser user) throws UserException
|
|
{
|
|
user = (GreenMailUser) userMap.remove(user.getLogin());
|
|
if (user != null)
|
|
{
|
|
user.delete();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* The login method.
|
|
*
|
|
*/
|
|
public boolean test(String userid, String password)
|
|
{
|
|
try
|
|
{
|
|
authenticationService.authenticate(userid, password.toCharArray());
|
|
String email = null;
|
|
if (personService.personExists(userid))
|
|
{
|
|
NodeRef personNodeRef = personService.getPerson(userid);
|
|
email = (String) nodeService.getProperty(personNodeRef, ContentModel.PROP_EMAIL);
|
|
}
|
|
GreenMailUser user = new AlfrescoImapUser(email, userid, password);
|
|
addUser(user);
|
|
}
|
|
catch (AuthenticationException ex)
|
|
{
|
|
logger.error("IMAP authentication failed for userid: " + userid);
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
public void setAuthenticationService(AuthenticationService authenticationService)
|
|
{
|
|
this.authenticationService = authenticationService;
|
|
}
|
|
|
|
public void setPersonService(PersonService personService)
|
|
{
|
|
this.personService = personService;
|
|
}
|
|
|
|
public void setNodeService(NodeService nodeService)
|
|
{
|
|
this.nodeService = nodeService;
|
|
}
|
|
|
|
}
|