Files
alfresco-community-repo/source/java/org/alfresco/email/server/handler/DocumentEmailMessageHandler.java
Alan Davis 91eb2644ad Merged 5.2.N (5.2.1) to HEAD (5.2)
125781 rmunteanu: Merged 5.1.N (5.1.2) to 5.2.N (5.2.1)
      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/HEAD/root@127808 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
2016-06-03 16:40:56 +00:00

148 lines
5.2 KiB
Java

package org.alfresco.email.server.handler;
import java.io.Serializable;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import org.alfresco.email.server.EmailServiceImpl;
import org.alfresco.error.AlfrescoRuntimeException;
import org.alfresco.model.ApplicationModel;
import org.alfresco.model.ContentModel;
import org.alfresco.model.ForumModel;
import org.alfresco.service.cmr.dictionary.DictionaryService;
import org.alfresco.service.cmr.email.EmailMessage;
import org.alfresco.service.cmr.repository.ChildAssociationRef;
import org.alfresco.service.cmr.repository.NodeRef;
import org.alfresco.service.cmr.repository.NodeService;
import org.alfresco.service.namespace.QName;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
/**
* Handler implementation address to document node.
*
* @author maxim
* @since 2.2
*/
public class DocumentEmailMessageHandler extends AbstractForumEmailMessageHandler
{
private static Log logger = LogFactory.getLog(DocumentEmailMessageHandler.class);
private static final String forumNodeName = "EmailForum";
public void processMessage(NodeRef contentNodeRef, EmailMessage message)
{
String messageSubject = message.getSubject();
if (messageSubject != null && messageSubject.length() > 0)
{
messageSubject = message.getSubject();
}
else
{
messageSubject = "EMPTY_SUBJECT_" + System.currentTimeMillis();
}
if(logger.isDebugEnabled())
{
logger.debug("process message:" + messageSubject);
}
QName nodeTypeQName = getNodeService().getType(contentNodeRef);
DictionaryService dictionaryService = getDictionaryService();
if (dictionaryService.isSubClass(nodeTypeQName, ContentModel.TYPE_CONTENT))
{
// Find where the content resides
NodeRef spaceNodeRef = getNodeService().getPrimaryParent(contentNodeRef).getParentRef();
NodeRef forumNode = getForumNode(contentNodeRef);
if (forumNode == null)
{
logger.debug("adding new forum node");
forumNode = addForumNode(contentNodeRef);
}
// Try to find existed node
NodeRef topicNodeRef = getTopicNode(forumNode, messageSubject);
if (topicNodeRef == null)
{
logger.debug("adding new topic node");
topicNodeRef = addTopicNode(forumNode, messageSubject);
}
// Create the post
logger.debug("add a post to the topic");
NodeRef postNodeRef = addPostNode(topicNodeRef, message);
// Add attachments
addAttachments(spaceNodeRef, postNodeRef, message);
}
else
{
throw new AlfrescoRuntimeException("\n" +
"Message handler " + this.getClass().getName() + " cannot handle type " + nodeTypeQName + ".\n" +
"Check the message handler mappings.");
}
}
/**
* Adds forum node
*
* @param nodeRef Paren node
* @return Reference to created node
*/
private NodeRef addForumNode(NodeRef nodeRef)
{
NodeService nodeService = getNodeService();
// //Add discussable aspect to content node
// if (!nodeService.hasAspect(nodeRef, ForumModel.ASPECT_DISCUSSABLE))
// {
// nodeService.addAspect(nodeRef, ForumModel.ASPECT_DISCUSSABLE, null);
// }
//Create forum node and associate it with content node
Map<QName, Serializable> properties = new HashMap<QName, Serializable>(1);
properties.put(ContentModel.PROP_NAME, forumNodeName);
ChildAssociationRef childAssoc = nodeService.createNode(nodeRef, ForumModel.ASSOC_DISCUSSION, ForumModel.ASSOC_DISCUSSION, ForumModel.TYPE_FORUM, properties);
NodeRef forumNode = childAssoc.getChildRef();
//Add necessary aspects to forum node
properties.clear();
properties.put(ApplicationModel.PROP_ICON, "forum");
nodeService.addAspect(forumNode, ApplicationModel.ASPECT_UIFACETS, properties);
return forumNode;
}
/**
* Finds the first forum node
*
* @param nodeRef Parent node
* @return Found node or null
*/
private NodeRef getForumNode(NodeRef nodeRef)
{
if (getNodeService().hasAspect(nodeRef, ForumModel.ASPECT_DISCUSSABLE))
{
List<ChildAssociationRef> assocRefList = getNodeService().getChildAssocs(nodeRef);
Iterator<ChildAssociationRef> assocRefIter = assocRefList.iterator();
while (assocRefIter.hasNext())
{
ChildAssociationRef assocRef = assocRefIter.next();
QName nodeTypeName = getNodeService().getType(assocRef.getChildRef());
if (nodeTypeName.equals(ForumModel.TYPE_FORUM))
return assocRef.getChildRef();
}
}
return null;
}
}