Merged HEAD (5.2) to 5.2.N (5.2.1)

126547 jkaabimofrad: Merged FILE-FOLDER-API (5.2.0) to HEAD (5.2)
      124158 jkaabimofrad: SFS-405, RA-778: (WIP)
         - Added quick-share client registry config.
         - Modified the send shared-link email API, based on the revised acceptance criteria.


git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/DEV/5.2.N/root@126893 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
Ancuta Morarasu
2016-05-11 12:06:58 +00:00
parent 5f08bf7da5
commit 8701f3cad1
4 changed files with 49 additions and 66 deletions

View File

@@ -83,11 +83,11 @@ public interface QuickShareLinks
/** /**
* Notifies users by email that a content has been shared with them. * Notifies users by email that a content has been shared with them.
* *
* @param nodeId The content id * @param sharedId The string id of the quick share
* @param emailRequest The email details including its template details * @param emailRequest The email details including its template details
* @param parameters The {@link Parameters} object to get the parameters passed into the request * @param parameters The {@link Parameters} object to get the parameters passed into the request
*/ */
void emailSharedLink(String nodeId, QuickShareLinkEmailRequest emailRequest, Parameters parameters); void emailSharedLink(String sharedId, QuickShareLinkEmailRequest emailRequest, Parameters parameters);
/** /**
* Find (search) for shared links visible to current user. * Find (search) for shared links visible to current user.

View File

@@ -21,6 +21,7 @@ package org.alfresco.rest.api.impl;
import org.alfresco.model.ContentModel; import org.alfresco.model.ContentModel;
import org.alfresco.model.QuickShareModel; import org.alfresco.model.QuickShareModel;
import org.alfresco.query.PagingRequest; import org.alfresco.query.PagingRequest;
import org.alfresco.repo.quickshare.QuickShareClientNotFoundException;
import org.alfresco.repo.quickshare.QuickShareServiceImpl.QuickShareEmailRequest; import org.alfresco.repo.quickshare.QuickShareServiceImpl.QuickShareEmailRequest;
import org.alfresco.repo.search.QueryParameterDefImpl; import org.alfresco.repo.search.QueryParameterDefImpl;
import org.alfresco.repo.security.authentication.AuthenticationUtil; import org.alfresco.repo.security.authentication.AuthenticationUtil;
@@ -74,6 +75,7 @@ import org.alfresco.service.namespace.QName;
import org.alfresco.util.Pair; import org.alfresco.util.Pair;
import org.alfresco.util.ParameterCheck; import org.alfresco.util.ParameterCheck;
import org.alfresco.util.SearchLanguageConversion; import org.alfresco.util.SearchLanguageConversion;
import org.apache.commons.lang.StringUtils;
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.beans.factory.InitializingBean; import org.springframework.beans.factory.InitializingBean;
@@ -353,33 +355,37 @@ public class QuickShareLinksImpl implements QuickShareLinks, InitializingBean
} }
@Override @Override
public void emailSharedLink(String nodeId, QuickShareLinkEmailRequest emailRequest, Parameters parameters) public void emailSharedLink(String sharedId, QuickShareLinkEmailRequest emailRequest, Parameters parameters)
{ {
checkEnabled(); checkEnabled();
checkValidShareId(sharedId);
validateEmailRequest(emailRequest);
try try
{ NodeRef nodeRef = nodes.validateNode(nodeId); {
final String nodeName = (String) nodeService.getProperty(nodeRef, ContentModel.PROP_NAME); NodeRef nodeRef = quickShareService.getTenantNodeRefFromSharedId(sharedId).getSecond();
String sharedNodeName = (String) nodeService.getProperty(nodeRef, ContentModel.PROP_NAME);
QuickShareEmailRequest request = new QuickShareEmailRequest(); QuickShareEmailRequest request = new QuickShareEmailRequest();
request.setSharedNodeName(nodeName); request.setSharedNodeName(sharedNodeName);
request.setSharedNodeURL(emailRequest.getSharedNodeUrl()); request.setClient(emailRequest.getClient());
request.setSharedId(sharedId);
request.setSenderMessage(emailRequest.getMessage()); request.setSenderMessage(emailRequest.getMessage());
request.setLocale(I18NUtil.parseLocale(emailRequest.getLocale())); request.setLocale(I18NUtil.parseLocale(emailRequest.getLocale()));
request.setTemplateId(emailRequest.getTemplateId());
request.setToEmails(emailRequest.getRecipientEmails()); request.setToEmails(emailRequest.getRecipientEmails());
request.setSendFromDefaultEmail(emailRequest.getIsSendFromDefaultEmail());
request.setIgnoreSendFailure(emailRequest.getIsIgnoreSendFailure());
quickShareService.sendEmailNotification(request); quickShareService.sendEmailNotification(request);
} }
catch (Exception ex) catch (InvalidSharedIdException ex)
{ {
String errorMsg = ex.getMessage(); throw new EntityNotFoundException(sharedId);
if (errorMsg == null)
{
errorMsg = "";
} }
throw new InvalidArgumentException("Couldn't send an email. " + errorMsg); catch (InvalidNodeRefException inre)
{
logger.warn("Unable to find: " + sharedId + " [" + inre.getNodeRef() + "]");
throw new EntityNotFoundException(sharedId);
}
catch (QuickShareClientNotFoundException ex)
{
throw new InvalidArgumentException("Client is not registered [" + emailRequest.getClient() + "]");
} }
} }
@@ -585,4 +591,16 @@ public class QuickShareLinksImpl implements QuickShareLinks, InitializingBean
throw new InvalidArgumentException("A valid sharedId must be specified !"); throw new InvalidArgumentException("A valid sharedId must be specified !");
} }
} }
private void validateEmailRequest(QuickShareLinkEmailRequest emailRequest)
{
if (StringUtils.isEmpty(emailRequest.getClient()))
{
throw new InvalidArgumentException("A valid client must be specified.");
}
if (emailRequest.getRecipientEmails() == null || emailRequest.getRecipientEmails().isEmpty())
{
throw new InvalidArgumentException("A valid recipientEmail must be specified.");
}
}
} }

View File

@@ -28,32 +28,20 @@ import java.util.List;
*/ */
public class QuickShareLinkEmailRequest extends Target public class QuickShareLinkEmailRequest extends Target
{ {
private String templateId; private String client;
private String sharedNodeUrl;
private String message; private String message;
private String locale; private String locale;
private List<String> recipientEmails; private List<String> recipientEmails;
private Boolean isSendFromDefaultEmail;
private Boolean isIgnoreSendFailure;
public String getTemplateId() public String getClient()
{ {
return templateId; return client;
} }
public void setTemplateId(String templateId) public QuickShareLinkEmailRequest setClient(String client)
{ {
this.templateId = templateId; this.client = client;
} return this;
public String getSharedNodeUrl()
{
return sharedNodeUrl;
}
public void setSharedNodeUrl(String sharedNodeUrl)
{
this.sharedNodeUrl = sharedNodeUrl;
} }
public String getMessage() public String getMessage()
@@ -86,37 +74,14 @@ public class QuickShareLinkEmailRequest extends Target
this.recipientEmails = recipientEmails; this.recipientEmails = recipientEmails;
} }
public Boolean getIsSendFromDefaultEmail()
{
return isSendFromDefaultEmail;
}
public void setIsSendFromDefaultEmail(Boolean isSendFromDefaultEmail)
{
this.isSendFromDefaultEmail = isSendFromDefaultEmail;
}
public Boolean getIsIgnoreSendFailure()
{
return isIgnoreSendFailure;
}
public void setIsIgnoreSendFailure(Boolean isIgnoreSendFailure)
{
this.isIgnoreSendFailure = isIgnoreSendFailure;
}
@Override @Override
public String toString() public String toString()
{ {
final StringBuilder sb = new StringBuilder(250); final StringBuilder sb = new StringBuilder(250);
sb.append("QuickShareLinkEmailRequest [templateId='").append(templateId) sb.append("QuickShareLinkEmailRequest [client=").append(client)
.append(", sharedNodeUrl='").append(sharedNodeUrl) .append(", message=").append(message)
.append(", message='").append(message) .append(", locale=").append(locale)
.append(", locale='").append(locale)
.append(", recipientEmails=").append(recipientEmails) .append(", recipientEmails=").append(recipientEmails)
.append(", isSendFromDefaultEmail").append(isSendFromDefaultEmail)
.append(", isIgnoreSendFailure=").append(isIgnoreSendFailure)
.append(']'); .append(']');
return sb.toString(); return sb.toString();
} }

View File

@@ -32,9 +32,9 @@ import org.alfresco.rest.framework.resource.actions.interfaces.EntityResourceAct
import org.alfresco.rest.framework.resource.content.BinaryResource; import org.alfresco.rest.framework.resource.content.BinaryResource;
import org.alfresco.rest.framework.resource.parameters.CollectionWithPagingInfo; import org.alfresco.rest.framework.resource.parameters.CollectionWithPagingInfo;
import org.alfresco.rest.framework.resource.parameters.Parameters; import org.alfresco.rest.framework.resource.parameters.Parameters;
import org.alfresco.rest.framework.webscripts.WithResponse;
import org.alfresco.util.ParameterCheck; import org.alfresco.util.ParameterCheck;
import org.springframework.beans.factory.InitializingBean; import org.springframework.beans.factory.InitializingBean;
import org.springframework.extensions.webscripts.Status;
import java.util.List; import java.util.List;
@@ -131,10 +131,10 @@ public class QuickShareLinkEntityResource implements EntityResourceAction.ReadBy
} }
@Operation("email") @Operation("email")
@WebApiDescription(title = "Email shared link", description = "Email the shared link") @WebApiDescription(title = "Email shared link", successStatus = Status.STATUS_ACCEPTED)
public void email(String nodeId, QuickShareLinkEmailRequest emailRequest, Parameters parameters, WithResponse withResponse) public void email(String sharedId, QuickShareLinkEmailRequest emailRequest, Parameters parameters)
{ {
quickShareLinks.emailSharedLink(nodeId, emailRequest, parameters); quickShareLinks.emailSharedLink(sharedId, emailRequest, parameters);
} }
/** /**