mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-31 17:39:05 +00:00
Merged V3.1 to HEAD
13356: Fix for ETHREEOH-1297. Fixes the more general issue that content related FreeMarker APIs on AVM Template Nodes were broken since 3.0. 13357: Fix for ETHREEOH-1445 - missing I18N labels for Site Invite workflow. 13375: Another I18N missing label patch to workflow tasks from wabson. git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@13595 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -23,4 +23,5 @@ wf_invitation-moderated.node.review.transition.approve.title=Approve
|
|||||||
wf_invitation-moderated.node.review.transition.approve.description=Approve
|
wf_invitation-moderated.node.review.transition.approve.description=Approve
|
||||||
wf_invitation-moderated.node.review.transition.cancel.title=Cancel
|
wf_invitation-moderated.node.review.transition.cancel.title=Cancel
|
||||||
wf_invitation-moderated.node.review.transition.cancel.description=Cancel
|
wf_invitation-moderated.node.review.transition.cancel.description=Cancel
|
||||||
|
wf_invitation-moderated.node.end.title=End
|
||||||
|
wf_invitation-moderated.node.end.description=End
|
@@ -31,11 +31,15 @@ wf_invitation-nominated.node.invitePending.transition.cancel.title=Cancel
|
|||||||
wf_invitation-nominated.node.invitePending.transition.cancel.description=Cancel
|
wf_invitation-nominated.node.invitePending.transition.cancel.description=Cancel
|
||||||
wf_invitation-nominated.node.inviteRejected.title=Rejected
|
wf_invitation-nominated.node.inviteRejected.title=Rejected
|
||||||
wf_invitation-nominated.node.inviteRejected.description=Rejected
|
wf_invitation-nominated.node.inviteRejected.description=Rejected
|
||||||
|
wf_invitation-nominated.node.inviteRejected.transition.end.title=End
|
||||||
|
wf_invitation-nominated.node.inviteRejected.transition.end.description=End
|
||||||
wf_invitation-nominated.task.wf_rejectInviteTask.title=Rejected
|
wf_invitation-nominated.task.wf_rejectInviteTask.title=Rejected
|
||||||
wf_invitation-nominated.task.wf_rejectInviteTask.description=Rejected
|
wf_invitation-nominated.task.wf_rejectInviteTask.description=Rejected
|
||||||
wf_invitation-nominated.node.inviteAccepted.title=Accepted
|
wf_invitation-nominated.node.inviteAccepted.title=Accepted
|
||||||
wf_invitation-nominated.node.inviteAccepted.description=Accepted
|
wf_invitation-nominated.node.inviteAccepted.description=Accepted
|
||||||
|
wf_invitation-nominated.node.inviteAccepted.transition.end.title=End
|
||||||
|
wf_invitation-nominated.node.inviteAccepted.transition.end.description=End
|
||||||
wf_invitation-nominated.task.wf_acceptInviteTask.title=Accepted
|
wf_invitation-nominated.task.wf_acceptInviteTask.title=Accepted
|
||||||
wf_invitation-nominated.task.wf_acceptInviteTask.description=Accepted
|
wf_invitation-nominated.task.wf_acceptInviteTask.description=Accepted
|
||||||
wf_invitation-nominated.node.end.title=End
|
wf_invitation-nominated.node.end.title=End
|
||||||
wf_invitation-nominated.node.end.description=End
|
wf_invitation-nominated.node.end.description=End
|
@@ -26,6 +26,7 @@ package org.alfresco.repo.template;
|
|||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.io.StringReader;
|
import java.io.StringReader;
|
||||||
|
import java.text.MessageFormat;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
@@ -33,9 +34,11 @@ import java.util.List;
|
|||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
import org.alfresco.model.ContentModel;
|
||||||
import org.alfresco.model.WCMModel;
|
import org.alfresco.model.WCMModel;
|
||||||
import org.alfresco.repo.avm.AVMNodeConverter;
|
import org.alfresco.repo.avm.AVMNodeConverter;
|
||||||
import org.alfresco.repo.domain.PropertyValue;
|
import org.alfresco.repo.domain.PropertyValue;
|
||||||
|
import org.alfresco.repo.template.BaseContentNode.TemplateContentData;
|
||||||
import org.alfresco.service.ServiceRegistry;
|
import org.alfresco.service.ServiceRegistry;
|
||||||
import org.alfresco.service.cmr.audit.AuditInfo;
|
import org.alfresco.service.cmr.audit.AuditInfo;
|
||||||
import org.alfresco.service.cmr.avm.AVMNodeDescriptor;
|
import org.alfresco.service.cmr.avm.AVMNodeDescriptor;
|
||||||
@@ -43,6 +46,8 @@ import org.alfresco.service.cmr.avm.locking.AVMLock;
|
|||||||
import org.alfresco.service.cmr.dictionary.DataTypeDefinition;
|
import org.alfresco.service.cmr.dictionary.DataTypeDefinition;
|
||||||
import org.alfresco.service.cmr.repository.ChildAssociationRef;
|
import org.alfresco.service.cmr.repository.ChildAssociationRef;
|
||||||
import org.alfresco.service.cmr.repository.ContentData;
|
import org.alfresco.service.cmr.repository.ContentData;
|
||||||
|
import org.alfresco.service.cmr.repository.ContentReader;
|
||||||
|
import org.alfresco.service.cmr.repository.ContentService;
|
||||||
import org.alfresco.service.cmr.repository.NodeRef;
|
import org.alfresco.service.cmr.repository.NodeRef;
|
||||||
import org.alfresco.service.cmr.repository.StoreRef;
|
import org.alfresco.service.cmr.repository.StoreRef;
|
||||||
import org.alfresco.service.cmr.repository.TemplateImageResolver;
|
import org.alfresco.service.cmr.repository.TemplateImageResolver;
|
||||||
@@ -51,8 +56,10 @@ import org.alfresco.service.namespace.NamespacePrefixResolverProvider;
|
|||||||
import org.alfresco.service.namespace.QName;
|
import org.alfresco.service.namespace.QName;
|
||||||
import org.alfresco.service.namespace.QNameMap;
|
import org.alfresco.service.namespace.QNameMap;
|
||||||
import org.alfresco.util.Pair;
|
import org.alfresco.util.Pair;
|
||||||
|
import org.alfresco.util.URLEncoder;
|
||||||
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.util.StringUtils;
|
||||||
import org.xml.sax.InputSource;
|
import org.xml.sax.InputSource;
|
||||||
|
|
||||||
import freemarker.ext.dom.NodeModel;
|
import freemarker.ext.dom.NodeModel;
|
||||||
@@ -430,6 +437,105 @@ public class AVMTemplateNode extends BasePermissionsNode implements NamespacePre
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// ------------------------------------------------------------------------------
|
||||||
|
// Content API
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return the content String for this node from the default content property
|
||||||
|
* (@see ContentModel.PROP_CONTENT)
|
||||||
|
*/
|
||||||
|
public String getContent()
|
||||||
|
{
|
||||||
|
ContentReader reader = this.services.getAVMService().getContentReader(this.version, this.path);
|
||||||
|
|
||||||
|
return (reader != null && reader.exists()) ? reader.getContentString() : "";
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return For a content document, this method returns the URL to the content stream for
|
||||||
|
* the default content property (@see ContentModel.PROP_CONTENT)
|
||||||
|
* <p>
|
||||||
|
* For a container node, this method return the URL to browse to the folder in the web-client
|
||||||
|
*/
|
||||||
|
public String getUrl()
|
||||||
|
{
|
||||||
|
if (getIsDocument() == true)
|
||||||
|
{
|
||||||
|
return MessageFormat.format(CONTENT_GET_URL, new Object[] {
|
||||||
|
getNodeRef().getStoreRef().getProtocol(),
|
||||||
|
getNodeRef().getStoreRef().getIdentifier(),
|
||||||
|
getNodeRef().getId(),
|
||||||
|
URLEncoder.encode(getName()) } );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return MessageFormat.format(FOLDER_BROWSE_URL, new Object[] {
|
||||||
|
getNodeRef().getStoreRef().getProtocol(),
|
||||||
|
getNodeRef().getStoreRef().getIdentifier(),
|
||||||
|
getNodeRef().getId() } );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return For a content document, this method returns the download URL to the content for
|
||||||
|
* the default content property (@see ContentModel.PROP_CONTENT)
|
||||||
|
* <p>
|
||||||
|
* For a container node, this method returns an empty string
|
||||||
|
*/
|
||||||
|
public String getDownloadUrl()
|
||||||
|
{
|
||||||
|
if (getIsDocument() == true)
|
||||||
|
{
|
||||||
|
return MessageFormat.format(CONTENT_DOWNLOAD_URL, new Object[] {
|
||||||
|
getNodeRef().getStoreRef().getProtocol(),
|
||||||
|
getNodeRef().getStoreRef().getIdentifier(),
|
||||||
|
getNodeRef().getId(),
|
||||||
|
URLEncoder.encode(getName()) } );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return The mimetype encoding for content attached to the node from the default content property
|
||||||
|
* (@see ContentModel.PROP_CONTENT)
|
||||||
|
*/
|
||||||
|
public String getMimetype()
|
||||||
|
{
|
||||||
|
return this.services.getAVMService().getContentDataForRead(this.avmRef).getMimetype();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return The display label of the mimetype encoding for content attached to the node from the default
|
||||||
|
* content property (@see ContentModel.PROP_CONTENT)
|
||||||
|
*/
|
||||||
|
public String getDisplayMimetype()
|
||||||
|
{
|
||||||
|
final String mimetype = this.services.getAVMService().getContentDataForRead(this.avmRef).getMimetype();
|
||||||
|
return services.getMimetypeService().getDisplaysByMimetype().get(mimetype);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return The character encoding for content attached to the node from the default content property
|
||||||
|
* (@see ContentModel.PROP_CONTENT)
|
||||||
|
*/
|
||||||
|
public String getEncoding()
|
||||||
|
{
|
||||||
|
return this.services.getAVMService().getContentDataForRead(this.avmRef).getEncoding();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return The size in bytes of the content attached to the node from the default content property
|
||||||
|
* (@see ContentModel.PROP_CONTENT)
|
||||||
|
*/
|
||||||
|
public long getSize()
|
||||||
|
{
|
||||||
|
return this.services.getAVMService().getContentDataForRead(this.avmRef).getSize();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------
|
||||||
// Audit API
|
// Audit API
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user