mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
ENH-560 - Inbound email server not working with custom types
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@42117 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -68,7 +68,8 @@
|
|||||||
|
|
||||||
<alias name="emailService" alias="EmailService"/>
|
<alias name="emailService" alias="EmailService"/>
|
||||||
|
|
||||||
<bean id="emailService" class="org.alfresco.email.server.EmailServiceImpl">
|
<bean id="emailService" class="org.alfresco.email.server.EmailServiceImpl"
|
||||||
|
init-method="init">
|
||||||
<property name="emailInboundEnabled">
|
<property name="emailInboundEnabled">
|
||||||
<value>${email.inbound.enabled}</value>
|
<value>${email.inbound.enabled}</value>
|
||||||
</property>
|
</property>
|
||||||
@@ -115,6 +116,9 @@
|
|||||||
<property name="authorityService">
|
<property name="authorityService">
|
||||||
<ref bean="authorityService" />
|
<ref bean="authorityService" />
|
||||||
</property>
|
</property>
|
||||||
|
<property name="dictionaryService">
|
||||||
|
<ref bean="DictionaryService" />
|
||||||
|
</property>
|
||||||
</bean>
|
</bean>
|
||||||
|
|
||||||
<bean id="emailMessageHandlerBase" abstract="true">
|
<bean id="emailMessageHandlerBase" abstract="true">
|
||||||
|
@@ -18,6 +18,7 @@
|
|||||||
*/
|
*/
|
||||||
package org.alfresco.email.server;
|
package org.alfresco.email.server;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import javax.mail.internet.InternetAddress;
|
import javax.mail.internet.InternetAddress;
|
||||||
@@ -31,6 +32,8 @@ import org.alfresco.repo.security.authentication.AuthenticationUtil.RunAsWork;
|
|||||||
import org.alfresco.repo.security.permissions.AccessDeniedException;
|
import org.alfresco.repo.security.permissions.AccessDeniedException;
|
||||||
import org.alfresco.repo.transaction.RetryingTransactionHelper;
|
import org.alfresco.repo.transaction.RetryingTransactionHelper;
|
||||||
import org.alfresco.repo.transaction.RetryingTransactionHelper.RetryingTransactionCallback;
|
import org.alfresco.repo.transaction.RetryingTransactionHelper.RetryingTransactionCallback;
|
||||||
|
import org.alfresco.service.cmr.dictionary.DictionaryService;
|
||||||
|
import org.alfresco.service.cmr.dictionary.TypeDefinition;
|
||||||
import org.alfresco.service.cmr.email.EmailDelivery;
|
import org.alfresco.service.cmr.email.EmailDelivery;
|
||||||
import org.alfresco.service.cmr.email.EmailMessage;
|
import org.alfresco.service.cmr.email.EmailMessage;
|
||||||
import org.alfresco.service.cmr.email.EmailMessageException;
|
import org.alfresco.service.cmr.email.EmailMessageException;
|
||||||
@@ -45,6 +48,7 @@ import org.alfresco.service.cmr.security.AuthorityService;
|
|||||||
import org.alfresco.service.cmr.security.AuthorityType;
|
import org.alfresco.service.cmr.security.AuthorityType;
|
||||||
import org.alfresco.service.namespace.NamespaceService;
|
import org.alfresco.service.namespace.NamespaceService;
|
||||||
import org.alfresco.service.namespace.QName;
|
import org.alfresco.service.namespace.QName;
|
||||||
|
import org.alfresco.util.PropertyCheck;
|
||||||
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.Log;
|
||||||
import org.apache.commons.logging.LogFactory;
|
import org.apache.commons.logging.LogFactory;
|
||||||
import org.springframework.extensions.surf.util.ParameterCheck;
|
import org.springframework.extensions.surf.util.ParameterCheck;
|
||||||
@@ -70,6 +74,7 @@ public class EmailServiceImpl implements EmailService
|
|||||||
private SearchService searchService;
|
private SearchService searchService;
|
||||||
private RetryingTransactionHelper retryingTransactionHelper;
|
private RetryingTransactionHelper retryingTransactionHelper;
|
||||||
private AuthorityService authorityService;
|
private AuthorityService authorityService;
|
||||||
|
private DictionaryService dictionaryService;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The authority that needs to contain the users and groups
|
* The authority that needs to contain the users and groups
|
||||||
@@ -85,6 +90,15 @@ public class EmailServiceImpl implements EmailService
|
|||||||
/** List of message handlers */
|
/** List of message handlers */
|
||||||
private Map<String, EmailMessageHandler> emailMessageHandlerMap;
|
private Map<String, EmailMessageHandler> emailMessageHandlerMap;
|
||||||
|
|
||||||
|
public void init()
|
||||||
|
{
|
||||||
|
PropertyCheck.mandatory(this, "namespaceService", namespaceService);
|
||||||
|
PropertyCheck.mandatory(this, "dictionaryService", getDictionaryService());
|
||||||
|
PropertyCheck.mandatory(this, "searchService", searchService);
|
||||||
|
PropertyCheck.mandatory(this, "authorityService", authorityService);
|
||||||
|
PropertyCheck.mandatory(this, "emailMessageHandlerMap", emailMessageHandlerMap);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @param namespaceService the service to resolve namespace prefixes
|
* @param namespaceService the service to resolve namespace prefixes
|
||||||
@@ -320,6 +334,38 @@ public class EmailServiceImpl implements EmailService
|
|||||||
QName nodeTypeQName = nodeService.getType(nodeRef);
|
QName nodeTypeQName = nodeService.getType(nodeRef);
|
||||||
String prefixedNodeTypeStr = nodeTypeQName.toPrefixString(namespaceService);
|
String prefixedNodeTypeStr = nodeTypeQName.toPrefixString(namespaceService);
|
||||||
EmailMessageHandler handler = emailMessageHandlerMap.get(prefixedNodeTypeStr);
|
EmailMessageHandler handler = emailMessageHandlerMap.get(prefixedNodeTypeStr);
|
||||||
|
|
||||||
|
if( handler == null)
|
||||||
|
{
|
||||||
|
if(logger.isDebugEnabled())
|
||||||
|
{
|
||||||
|
logger.debug("did not find a handler for type:" + prefixedNodeTypeStr);
|
||||||
|
}
|
||||||
|
|
||||||
|
// not a direct match on type
|
||||||
|
// need to check the super-types (if any) of the target node
|
||||||
|
TypeDefinition typeDef = dictionaryService.getType(nodeTypeQName);
|
||||||
|
while(typeDef != null)
|
||||||
|
{
|
||||||
|
QName parentName = typeDef.getParentName();
|
||||||
|
if(parentName != null)
|
||||||
|
{
|
||||||
|
String prefixedSubTypeStr = parentName.toPrefixString(namespaceService);
|
||||||
|
handler = emailMessageHandlerMap.get(prefixedSubTypeStr);
|
||||||
|
if(handler != null)
|
||||||
|
{
|
||||||
|
if(logger.isDebugEnabled())
|
||||||
|
{
|
||||||
|
logger.debug("found a handler for a subtype:" + prefixedSubTypeStr);
|
||||||
|
}
|
||||||
|
return handler;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
typeDef = dictionaryService.getType(parentName);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
if (handler == null)
|
if (handler == null)
|
||||||
{
|
{
|
||||||
throw new EmailMessageException(ERR_HANDLER_NOT_FOUND, prefixedNodeTypeStr);
|
throw new EmailMessageException(ERR_HANDLER_NOT_FOUND, prefixedNodeTypeStr);
|
||||||
@@ -477,4 +523,14 @@ public class EmailServiceImpl implements EmailService
|
|||||||
{
|
{
|
||||||
return emailContributorsAuthority;
|
return emailContributorsAuthority;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setDictionaryService(DictionaryService dictionaryService)
|
||||||
|
{
|
||||||
|
this.dictionaryService = dictionaryService;
|
||||||
|
}
|
||||||
|
|
||||||
|
public DictionaryService getDictionaryService()
|
||||||
|
{
|
||||||
|
return dictionaryService;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -40,6 +40,7 @@ import org.alfresco.model.ContentModel;
|
|||||||
import org.alfresco.model.ForumModel;
|
import org.alfresco.model.ForumModel;
|
||||||
import org.alfresco.repo.management.subsystems.ChildApplicationContextFactory;
|
import org.alfresco.repo.management.subsystems.ChildApplicationContextFactory;
|
||||||
import org.alfresco.repo.security.authentication.AuthenticationUtil;
|
import org.alfresco.repo.security.authentication.AuthenticationUtil;
|
||||||
|
import org.alfresco.repo.transfer.TransferModel;
|
||||||
import org.alfresco.service.cmr.email.EmailDelivery;
|
import org.alfresco.service.cmr.email.EmailDelivery;
|
||||||
import org.alfresco.service.cmr.email.EmailMessageException;
|
import org.alfresco.service.cmr.email.EmailMessageException;
|
||||||
import org.alfresco.service.cmr.email.EmailService;
|
import org.alfresco.service.cmr.email.EmailService;
|
||||||
@@ -757,6 +758,107 @@ public class EmailServiceImplTest extends TestCase
|
|||||||
} // end of test sending to cm:content node
|
} // end of test sending to cm:content node
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ENH-560 - Inbound email server not working with custom types
|
||||||
|
*/
|
||||||
|
public void testMessagesToSubTypeOfDocument() throws Exception
|
||||||
|
{
|
||||||
|
logger.debug("Start testMessagesToSubTypesOfDocument");
|
||||||
|
|
||||||
|
String TEST_EMAIL="buffy@sunnydale.high";
|
||||||
|
|
||||||
|
String TEST_SUBJECT="Practical Bee Keeping";
|
||||||
|
|
||||||
|
String TEST_LONG_SUBJECT = "This is a very very long name in particular it is greater than eitghty six characters which was a problem explored in ALF-9544";
|
||||||
|
|
||||||
|
|
||||||
|
// TODO Investigate why setting PROP_EMAIL on createPerson does not work.
|
||||||
|
NodeRef person = personService.getPerson(TEST_USER);
|
||||||
|
if(person == null)
|
||||||
|
{
|
||||||
|
logger.debug("new person created");
|
||||||
|
Map<QName, Serializable> props = new HashMap<QName, Serializable>();
|
||||||
|
props.put(ContentModel.PROP_USERNAME, TEST_USER);
|
||||||
|
props.put(ContentModel.PROP_EMAIL, TEST_EMAIL);
|
||||||
|
person = personService.createPerson(props);
|
||||||
|
}
|
||||||
|
nodeService.setProperty(person, ContentModel.PROP_EMAIL, TEST_EMAIL);
|
||||||
|
|
||||||
|
Set<String> auths = authorityService.getContainedAuthorities(null, "GROUP_EMAIL_CONTRIBUTORS", true);
|
||||||
|
if(!auths.contains(TEST_USER))
|
||||||
|
{
|
||||||
|
authorityService.addAuthority("GROUP_EMAIL_CONTRIBUTORS", TEST_USER);
|
||||||
|
}
|
||||||
|
|
||||||
|
String companyHomePathInStore = "/app:company_home";
|
||||||
|
String storePath = "workspace://SpacesStore";
|
||||||
|
StoreRef storeRef = new StoreRef(storePath);
|
||||||
|
|
||||||
|
NodeRef storeRootNodeRef = nodeService.getRootNode(storeRef);
|
||||||
|
List<NodeRef> nodeRefs = searchService.selectNodes(storeRootNodeRef, companyHomePathInStore, null, namespaceService, false);
|
||||||
|
NodeRef companyHomeNodeRef = nodeRefs.get(0);
|
||||||
|
assertNotNull("company home is null", companyHomeNodeRef);
|
||||||
|
String companyHomeDBID = ((Long)nodeService.getProperty(companyHomeNodeRef, ContentModel.PROP_NODE_DBID)).toString() + "@Alfresco.com";
|
||||||
|
// String testUserDBID = ((Long)nodeService.getProperty(person, ContentModel.PROP_NODE_DBID)).toString() + "@Alfresco.com";
|
||||||
|
NodeRef testUserHomeFolder = (NodeRef)nodeService.getProperty(person, ContentModel.PROP_HOMEFOLDER);
|
||||||
|
assertNotNull("testUserHomeFolder is null", testUserHomeFolder);
|
||||||
|
// String testUserHomeDBID = ((Long)nodeService.getProperty(testUserHomeFolder, ContentModel.PROP_NODE_DBID)).toString() + "@Alfresco.com";
|
||||||
|
|
||||||
|
// Clean up old messages in test folder
|
||||||
|
List<ChildAssociationRef> assocs = nodeService.getChildAssocs(testUserHomeFolder, ContentModel.ASSOC_CONTAINS, RegexQNamePattern.MATCH_ALL);
|
||||||
|
for(ChildAssociationRef assoc : assocs)
|
||||||
|
{
|
||||||
|
nodeService.deleteNode(assoc.getChildRef());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Map<QName, Serializable> properties = new HashMap<QName, Serializable>();
|
||||||
|
properties.put(ContentModel.PROP_NAME, "hamster");
|
||||||
|
properties.put(ContentModel.PROP_DESCRIPTION, "syrian hamsters - test doc for email tests, sending to a subtype of cm:content");
|
||||||
|
|
||||||
|
// Transfer report is a subtype of cm:content
|
||||||
|
ChildAssociationRef testDoc = nodeService.createNode(testUserHomeFolder, ContentModel.ASSOC_CONTAINS, QName.createQName(NamespaceService.CONTENT_MODEL_1_0_URI, "bees"), TransferModel.TYPE_TRANSFER_REPORT, properties);
|
||||||
|
NodeRef testDocNodeRef = testDoc.getChildRef();
|
||||||
|
|
||||||
|
String testDocDBID = ((Long)nodeService.getProperty(testDocNodeRef, ContentModel.PROP_NODE_DBID)).toString();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Send From the test user TEST_EMAIL to the test user's home
|
||||||
|
*/
|
||||||
|
String from = TEST_EMAIL;
|
||||||
|
String to = testDocDBID + "@alfresco.com";
|
||||||
|
String content = "hello world";
|
||||||
|
|
||||||
|
Session sess = Session.getDefaultInstance(new Properties());
|
||||||
|
assertNotNull("sess is null", sess);
|
||||||
|
SMTPMessage msg = new SMTPMessage(sess);
|
||||||
|
InternetAddress[] toa = { new InternetAddress(to) };
|
||||||
|
|
||||||
|
msg.setFrom(new InternetAddress(TEST_EMAIL));
|
||||||
|
msg.setRecipients(Message.RecipientType.TO, toa);
|
||||||
|
msg.setSubject(TEST_SUBJECT);
|
||||||
|
msg.setContent(content, "text/plain");
|
||||||
|
|
||||||
|
ByteArrayOutputStream bos = new ByteArrayOutputStream();
|
||||||
|
msg.writeTo(bos);
|
||||||
|
InputStream is = new StringInputStream(bos.toString());
|
||||||
|
assertNotNull("is is null", is);
|
||||||
|
|
||||||
|
SubethaEmailMessage m = new SubethaEmailMessage(is);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Turn on overwriteDuplicates
|
||||||
|
*/
|
||||||
|
logger.debug("Step 1: send an email to a transfer report");
|
||||||
|
|
||||||
|
EmailDelivery delivery = new EmailDelivery(to, from, null);
|
||||||
|
|
||||||
|
emailService.importMessage(delivery, m);
|
||||||
|
|
||||||
|
} // end of test sending to trx:transferReport
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Reference in New Issue
Block a user