mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	109455: Merged modules/custommodelmanagement/HEAD to DEV. 93923: SHA-300: Added ALFRESCO_MODEL_ADMINISTRATORS group. 95982: SHA-401: Implemented repo service for retrieving Custom Models. (WIP) 95983: SHA-400: Added Private REST API to retrieve custom model(s) - Get All models: http://localhost:8080/alfresco/api/-default-/private/alfresco/versions/1/cmm - Get the model: http://localhost:8080/alfresco/api/-default-/private/alfresco/versions/1/cmm/<model-name> 95984: SHA-401: Fixed the service to return null rather than throwing an exception, when the model does not exist. 96053: SHA-400: Modified the custom model API response to return the "status" as "ACTIVE" or "DRAFT". 96775: SHA-542: Added support to create a custom model. (WIP) 96779: SHA-543: Added Private REST API to create custom model(s). - SHA-539: Cleaned up test data. 96850: SHA-543: Added Author and Description properties to the custom model API. 97410: SHA-407, SHA-555: Added tests for custom model backend service and the related REST API. Also, a minor modification as a result of added tests. 97570: Modified the CMM REST API, per Kevin's request, to return empty arrays for model's types and aspects if they don't exist. 97731: SHA-386: Added support to activate custom models. Also, a minor modification to the backend service and REST API, based on the Alfresco REST API guidelines. 97775: SHA-386: Added tests for custom model activation (backend service). As well as, fixed the build failure by refactoring the public API tests. 97992: SHA-573, SHA-393, SHA-494: Added support to deactivate custom model, create a new type and create a new property group (aspect). 97994: Fixed the test as a result of renaming the service method. 98123: SHA-393, SHA-494: Enabled the CMM REST API to create/update Types and/or Aspects via PUT. Also added validations for aspect/type's name. 98259: SHA-453: Added backend and REST API support to delete a custom model. 98690: SHA-393, SHA-494, SHA-453, SHA-575: Added tests for custom model backend service and the related REST API. Also, a minor modification as a result of added tests. 99276: SHA-549: Added backend support to update a custom model. Also, refactored the service to externalise the error messages. - SHA-550: Added REST API support to update a custom model. - SHA-619: Made sure the backend service validates the model before creating a node. - SHA-623: Added checks to not allow a user to create a custom model with the same name as the bootstrapped models. 99287: SHA-619: Added InvalidCustomModelException for the CMM service to throw when the model validation fails. 99514: SHA-506: added backend and API support to create custom Type/Aspect properties. Also refactored the API to overcome the Public API limitations. 99522: SHA-506: Modified the Type/Aspect JSON payload to include a new read only property "prefixedName". 99527: Fixed Bamboo build failure as the result of r99522 commit. 99630: SHA-506: - Updated the API to exclude the inherited properties. - Added API tests for creating properties. - Modified the Custom Properties JSON response to include a new read only attribute "prefixedName". 99662: SHA-351: Updated the API to support 'mandatory' and 'mandatoryEnforced' properties. - SHA-410: Updated the API to support 'defaultValue' property. - SHA-506: Modified the Custom Properties JSON response to include 'description' and 'multiValued' attributes. 99669: SHA-506: Removed the unnecessary (at least in this sprint) methods from the backend service. 99684: SHA-638: Added checks to not allow a user to create a custom model with already in-use namespace prefix. 99959: SHA-679: Modified the custom model API to not import the already defined namespace. 100211: SHA-607: Modified the custom model API to support delete model's type. Also, removed the unnecessary test as we depend on the dictionary service, so no need to test it in the custom model API. 100281: Added Types and Aspects to the GET a single model API response, when it is requested with "?select=all" query string. 100335: Added test for "?select=all" query string within the GET a single model API (see rev 100281). 100366: SHA-612: Modified the custom model API to support delete model's aspect. 100738: SHA-698: Added checks so the model Admin is not allowed to deactivate a custom model when its types/aspects are parent to other models' types/aspects (regardless of the model being active or not). 100740: SHA-698: Fixed Bamboo build failures. 101085: SHA-703: Added dependency validation before deleting custom type/aspect in the custom model API. 101160: Modified the custom model API to return all properties (including the inherited properties) of the type/aspect, when requested by "?select=allProps". 101636: SHA-697. 101771: SHA-706: Made custom models hidden in the data dictionary. 101863: SHA-701: Added checks to not allow creating duplicate properties within the same model. Also, removed unnecessary/duplicate constants from the custom model service class. 101983: SHA-688: Fixed the error message by getting the root-cause-exception and returning its message. However, DictionaryException messages are not localised, so this will be fixed in the alfresco core. 102223: Fix for SHA-726: Not able to edit prefix field of deactivated model when model type is referenced within same model - The API will update the parent prefixed name with the new prefix. - Also, added more validations to the CMM API, when setting a type/asptect's parent. 102587: SHA-741, SHA-745, SHA-747: Added custom model Constraints support. 102725: SHA-784: Fixed parent validation of the type/aspect. 103030: SHA-741, SHA-745, SHA-747: Added tests for custom model Constraints. - Also fixed and refactored the API code as the result of tests. 103753: SHA-846: Added inline constraints support. Also: - Modified the backend CMM service to throw CustomModelConstraintException when the root cause is DuplicateDefinitionException. - Removed the duplicate name check from the CMM API, as now it will depend on the exceptions thrown upon model compilation. 103885: SHA-819, SHA-833: Added support to edit existing type/aspect. 103973: SHA-819, SHA-833: Added API tests for types/aspects Edit. Also, refactored CMM API tests by moving the tests to their corresponding test class. 104079: SHA-808: Fixed custom models bidirectional dependency. 104158: Deleted the ExtendedRepoAdminService class as the required functionality has been added (see SHA-879) to the core alfresco code. 104287: SHA-843: Modified the custom model API to support delete property. Also, minor refactoring of the API tests. 104403: SHA-842: Modified the custom model API to support Edit property. 104475: SHA-842: Added API tests for Edit property. 104569: SHA-913 - Remove case sensitive option from the UI - SHA-914 - Update PO and tests that use the case sensitive option - Remove case sensitive option on LIST constraint throughout Also: - Update Aikau version to 1.0.18 104690: Fixed Bamboo build failure caused by r104569. 104849: SHA-808: Fixed custom models circular dependencies. 105297: SHA-807: Added property default-value and constraint (REGEX, MINMAX and LENGTH) validators. 105642: SHA-950: Wrapped backend CMM service method with a NEW transaction, in order to catch the thrown exception within DictionaryModelTypeTransactionListener. Also refactored the CMM backend service tests as the result of this change. 106677: SHA-888, SHA-889, SHA-890: Added Backend and API support to export a custom model and its associated Share form. 106722: SHA-888, SHA-889, SHA-890: Fixed a few minor issues raised during code review. 107007: ACE-4019: Modified the CMM service to not start a new TX when creating a new model. 107070: Temporarily enabled (hard coded) index and facetable attributes in the custom model properties. 107296: GERMAN: Model Manager files localised as per EN-rev105921 107297: FRENCH: Model Manager localised files based on EN-rev105921 107315: SPANISH: Model Manager localised files based on EN-rev105921 107317: JAPANESE: Model Manager localised files based on EN-rev105921 107321: ITALIAN: Model Manager localised files based on EN-rev105921 107322: DUTCH: Model Manager localised files based on EN-rev105921 107335: SHA-889: Modified the CMM service to not throw an exception when exporting the model and its associated share extension module, where the Share extension module has not been created for the model yet. 107456: SHA-893: Added API support to upload/import a custom model and its associated Share extension module. 107560: SHA-893: Added model upload API tests as well as minor fixes. 107647: SHA-893: Fixed minor issues raised during code review. 107773: Docs review of message labels and errors. 107866: SHA-1126: Added check for the maximum value of the MINMAX constraint to be a positive nonzero value. 108117: SHA-832: Added validation for properties' default values to be checked against the property defined constraint. 108256: SHA-1194: Modified CMM API to support indexing options. 108510: SHA-1151: Externalised CMM rest API error messages. - SHA-1196: Changed the CMM Rest API input validator to use the same RegExs as the CMM Share. 108518: SHA-1194: Changed CMM property facetable options to include "UNSET". 108561: GERMAN: Model Manager files updated as per EN-rev107962 108562: FRENCH: Model Manager files updated as per EN-rev107962 108565: ITALIAN: Model Manager files updated as per EN-rev107962 108566: SPANISH: Model Manager files updated as per EN-rev107962 108567: JAPANESE: Model Manager files updated as per EN-rev107962 108568: NORWEGIAN Bokmal: Model Manager files updated as per EN-rev107962 108570: DUTCH: Model Manager files updated as per EN-rev107962 108571: RUSSIAN: Model Manager files updated as per EN-rev107962 108572: BRAZILIAN Portuguese: Model Manager files updated as per EN-rev107962 108573: SIMPLIFIED CHINESE: Model Manager files updated as per EN-rev107962 108604: Removed the unnecessary escaped quotation from the strings which don't have variables. 108721: Api message changes from docs. 108728: Changed "Property group" to "Aspect" in the CMM API error messages. 108934: Added the missing escaped quotation into API messages. 109037: Changes from docs for mandatory field character messages in the API. 109204: ITALIAN: Updated bundle based on EN rev109039 109205: GERMAN: Updated bundle based on EN rev109039 109206: FRENCH: Updated bundle based on EN rev109039 109223: GERMAN: Updated bundle based on EN rev109039 - fixed single quotes 109226: FRENCH: Updated bundle based on EN rev109039 - fixed single quotes 109228: ITALIAN: Updated bundle based on EN rev109039 - fixed single quotes 109230: FRENCH: Updated bundle based on EN rev109039 - fixed single quotes again 109235: JAPANESE: Updated bundle based on EN rev109039 109293: SPANISH: Updated bundle based on EN rev109039 109300: DUTCH: Updated bundle based on EN rev109039 109412: - Refactored the CMM JMX support to return CompositeData for performance reasons. - Reorganised a few of CMM classes/interfaces to make it easier for merging to alfresco core. - A minor fixes as a result of Find Bugs analysis. - Added the minimum and maximum repo versions for CMM module. 109421: NORWEGIAN: Updated bundle based on EN rev109039 109424: BRAZILIAN PORTUGUESE: Updated bundle based on EN rev109039 109426: RUSSIAN: Updated bundle based on EN rev109039 109427: CHINESE: Updated bundle based on EN rev10903 109475: Added CMM Model into the core services (missed from previous commit). 109480: SHA-723: Added custom models analytics in HeartBeat data. 109481: SHA-528: Added GROUP_ALFRESCO_MODEL_ADMINISTRATORS_AUTHORITY patch. git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@109490 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
			
				
	
	
		
			279 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			279 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2005-2015 Alfresco Software Limited.
 | |
|  *
 | |
|  * This file is part of Alfresco
 | |
|  *
 | |
|  * Alfresco is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU Lesser General Public License as published by
 | |
|  * the Free Software Foundation, either version 3 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  *
 | |
|  * Alfresco is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU Lesser General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Lesser General Public License
 | |
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| 
 | |
| package org.alfresco.repo.dictionary;
 | |
| 
 | |
| import static org.junit.Assert.assertTrue;
 | |
| 
 | |
| import java.io.File;
 | |
| import java.io.Serializable;
 | |
| import java.util.Collection;
 | |
| import java.util.Collections;
 | |
| import java.util.List;
 | |
| import java.util.Set;
 | |
| import java.util.TreeSet;
 | |
| 
 | |
| import org.alfresco.model.ContentModel;
 | |
| import org.alfresco.repo.content.MimetypeMap;
 | |
| import org.alfresco.repo.transaction.RetryingTransactionHelper;
 | |
| import org.alfresco.repo.transaction.RetryingTransactionHelper.RetryingTransactionCallback;
 | |
| import org.alfresco.service.cmr.download.DownloadService;
 | |
| import org.alfresco.service.cmr.download.DownloadStatus;
 | |
| import org.alfresco.service.cmr.repository.ContentReader;
 | |
| import org.alfresco.service.cmr.repository.ContentService;
 | |
| import org.alfresco.service.cmr.repository.ContentWriter;
 | |
| import org.alfresco.service.cmr.repository.NodeRef;
 | |
| import org.alfresco.service.cmr.repository.NodeService;
 | |
| import org.alfresco.service.cmr.repository.StoreRef;
 | |
| import org.alfresco.service.cmr.search.SearchService;
 | |
| import org.alfresco.service.namespace.NamespaceService;
 | |
| import org.alfresco.service.namespace.QName;
 | |
| import org.alfresco.util.TempFileProvider;
 | |
| import org.apache.commons.compress.archivers.zip.ZipArchiveEntry;
 | |
| import org.apache.commons.compress.archivers.zip.ZipArchiveInputStream;
 | |
| import org.apache.commons.logging.Log;
 | |
| import org.apache.commons.logging.LogFactory;
 | |
| import org.springframework.context.ApplicationContext;
 | |
| 
 | |
| /**
 | |
|  * A utility class to test custom models download.
 | |
|  * 
 | |
|  * @author Jamal Kaabi-Mofrad
 | |
|  */
 | |
| public class CMMDownloadTestUtil
 | |
| {
 | |
|     private static final Log logger = LogFactory.getLog(CMMDownloadTestUtil.class);
 | |
| 
 | |
|     private static final String SURF_CONFIG_PATH = "./app:company_home/st:sites/cm:surf-config";
 | |
|     private static final String SHARE_EXTENSIONS_FOLDER = "extensions"; // app:company_home/st:sites/cm:surf-config/cm:extensions
 | |
|     private static final String SHARE_PERSISTED_EXTENSION_FILE = "default-persisted-extension.xml"; // app:company_home/st:sites/cm:surf-config/cm:extensions/cm:default-persisted-extension.xml
 | |
|     private static final String MKR = "{MKR}";
 | |
|     private static final String MODULE = 
 | |
|                 "<extension>"
 | |
|                 +    "<modules>"
 | |
|                 +        "<module>"
 | |
|                 +           "<id>CMM_" + MKR + "</id>"
 | |
|                 +           "<auto-deploy>true</auto-deploy>"
 | |
|                 +           "<configurations>"
 | |
|                 +               "<config evaluator=\"string-compare\" condition=\"DocumentLibrary\" replace=\"false\">"
 | |
|                 +                   "<types>"
 | |
|                 +                       "<type name=\"cm:content\">"
 | |
|                 +                           "<subtype label=\"type1 title\" name=\"testprefix:type1\"/>"
 | |
|                 +                       "</type>"
 | |
|                 +                   "</types>"
 | |
|                 +               "</config>"
 | |
|                 +               "<config evaluator=\"string-compare\" condition=\"FormDefinition\">"
 | |
|                 +               "</config>"
 | |
|                 +           "</configurations>"
 | |
|                 +        "</module>"
 | |
|                 +    "</modules>"
 | |
|                 +"</extension>";
 | |
| 
 | |
|     private RetryingTransactionHelper transactionHelper;
 | |
|     private ContentService contentService;
 | |
|     private NodeService nodeService;
 | |
|     private SearchService searchService;
 | |
|     private NamespaceService namespaceService;
 | |
|     private DownloadService downloadService;
 | |
| 
 | |
|     private NodeRef extensionsNodeRef;
 | |
|     private NodeRef sharePersistedExtNodeRef;
 | |
|     private boolean isExtFolderCreated = false;
 | |
|     private File originalShareExtFile;
 | |
| 
 | |
|     public CMMDownloadTestUtil(ApplicationContext ctx)
 | |
|     {
 | |
|         this.transactionHelper = ctx.getBean("retryingTransactionHelper", RetryingTransactionHelper.class);
 | |
|         this.contentService = ctx.getBean("contentService", ContentService.class);
 | |
|         this.searchService = ctx.getBean("searchService", SearchService.class);
 | |
|         this.nodeService = ctx.getBean("nodeService", NodeService.class);
 | |
|         this.namespaceService = ctx.getBean("namespaceService", NamespaceService.class);
 | |
|         this.downloadService = ctx.getBean("downloadService", DownloadService.class);
 | |
|     }
 | |
| 
 | |
|     private NodeRef getRootNode()
 | |
|     {
 | |
|         return nodeService.getRootNode(StoreRef.STORE_REF_WORKSPACE_SPACESSTORE);
 | |
|     }
 | |
| 
 | |
|     public synchronized void createShareExtModule(final String moduleId)
 | |
|     {
 | |
|         List<NodeRef> results = searchService.selectNodes(getRootNode(), SURF_CONFIG_PATH, null, namespaceService, false,
 | |
|                     SearchService.LANGUAGE_XPATH);
 | |
|         assertTrue(results.size() == 1);
 | |
|         final NodeRef surfConfigNodeRef = results.get(0);
 | |
| 
 | |
|         this.extensionsNodeRef = nodeService.getChildByName(surfConfigNodeRef, ContentModel.ASSOC_CONTAINS, SHARE_EXTENSIONS_FOLDER);
 | |
|         if (this.extensionsNodeRef == null)
 | |
|         {
 | |
|             extensionsNodeRef = transactionHelper.doInTransaction(new RetryingTransactionCallback<NodeRef>()
 | |
|             {
 | |
|                 @Override
 | |
|                 public NodeRef execute() throws Throwable
 | |
|                 {
 | |
|                     QName assocQName = QName.createQName(NamespaceService.CONTENT_MODEL_1_0_URI, SHARE_EXTENSIONS_FOLDER);
 | |
|                     NodeRef nodeRef = nodeService.createNode(surfConfigNodeRef, ContentModel.ASSOC_CONTAINS, assocQName, ContentModel.TYPE_FOLDER,
 | |
|                                 Collections.<QName, Serializable> singletonMap(ContentModel.PROP_NAME, SHARE_EXTENSIONS_FOLDER)).getChildRef();
 | |
| 
 | |
|                     isExtFolderCreated = true;
 | |
|                     return nodeRef;
 | |
|                 }
 | |
|             });
 | |
| 
 | |
|             logger.info("Created 'cm:extensions' folder within the 'app:company_home/st:sites/cm:surf-config'");
 | |
|         }
 | |
| 
 | |
|         this.sharePersistedExtNodeRef = nodeService.getChildByName(this.extensionsNodeRef, ContentModel.ASSOC_CONTAINS, SHARE_PERSISTED_EXTENSION_FILE);
 | |
|         if (this.sharePersistedExtNodeRef == null)
 | |
|         {
 | |
|             this.sharePersistedExtNodeRef = transactionHelper.doInTransaction(new RetryingTransactionCallback<NodeRef>()
 | |
|             {
 | |
| 
 | |
|                 @Override
 | |
|                 public NodeRef execute() throws Throwable
 | |
|                 {
 | |
|                     QName assocQName = QName.createQName(NamespaceService.CONTENT_MODEL_1_0_URI, SHARE_PERSISTED_EXTENSION_FILE);
 | |
|                     return nodeService.createNode(extensionsNodeRef, ContentModel.ASSOC_CONTAINS, assocQName, ContentModel.TYPE_CONTENT,
 | |
|                                 Collections.<QName, Serializable> singletonMap(ContentModel.PROP_NAME, SHARE_PERSISTED_EXTENSION_FILE)).getChildRef();
 | |
|                 }
 | |
|             });
 | |
| 
 | |
|             logger.info("Created 'cm:default-persisted-extension.xml' file within the 'app:company_home/st:sites/cm:surf-config/cm:extensions'");
 | |
|         }
 | |
|         else if(originalShareExtFile == null)
 | |
|         {
 | |
|             transactionHelper.doInTransaction(new RetryingTransactionCallback<Void>()
 | |
|             {
 | |
|                 @Override
 | |
|                 public Void execute() throws Throwable
 | |
|                 {
 | |
|                     ContentReader reader = contentService.getReader(sharePersistedExtNodeRef, ContentModel.PROP_CONTENT);
 | |
|                     originalShareExtFile = TempFileProvider.createTempFile(CustomModelServiceImplTest.class.getName(), ".xml");
 | |
|                     reader.getContent(originalShareExtFile);
 | |
| 
 | |
|                     return null;
 | |
|                 }
 | |
|             });
 | |
|         }
 | |
| 
 | |
|         transactionHelper.doInTransaction(new RetryingTransactionCallback<Void>()
 | |
|         {
 | |
|             @Override
 | |
|             public Void execute() throws Throwable
 | |
|             {
 | |
|                 ContentWriter writer = contentService.getWriter(sharePersistedExtNodeRef, ContentModel.PROP_CONTENT, true);
 | |
|                 writer.setMimetype(MimetypeMap.MIMETYPE_XML);
 | |
|                 writer.setEncoding("UTF-8");
 | |
|                 writer.putContent(MODULE.replace(MKR, moduleId));
 | |
| 
 | |
|                 return null;
 | |
|             }
 | |
|         });
 | |
|         logger.info("Added 'CM_" + moduleId + "' module.'");
 | |
|     }
 | |
| 
 | |
|     public synchronized void cleanup()
 | |
|     {
 | |
|         if (isExtFolderCreated)
 | |
|         {
 | |
|             transactionHelper.doInTransaction(new RetryingTransactionCallback<Void>()
 | |
|             {
 | |
|                 @Override
 | |
|                 public Void execute() throws Throwable
 | |
|                 {
 | |
|                     nodeService.deleteNode(extensionsNodeRef);
 | |
|                     return null;
 | |
|                 }
 | |
|             });
 | |
| 
 | |
|             logger.info("Deleted 'cm:extensions' folder within the 'app:company_home/st:sites/cm:surf-config");
 | |
|         }
 | |
|         else if (originalShareExtFile != null)
 | |
|         {
 | |
|             transactionHelper.doInTransaction(new RetryingTransactionCallback<Void>()
 | |
|             {
 | |
|                 @Override
 | |
|                 public Void execute() throws Throwable
 | |
|                 {
 | |
|                     ContentWriter writer = contentService.getWriter(sharePersistedExtNodeRef, ContentModel.PROP_CONTENT, true);
 | |
|                     writer.setMimetype(MimetypeMap.MIMETYPE_XML);
 | |
|                     writer.setEncoding("UTF-8");
 | |
|                     writer.putContent(originalShareExtFile); // put back the original extension file
 | |
|                     return null;
 | |
|                 }
 | |
|             });
 | |
| 
 | |
|             logger.info("Reverted default-persisted-extension.xml content.");
 | |
|         }
 | |
| 
 | |
|         if (originalShareExtFile != null)
 | |
|         {
 | |
|             originalShareExtFile.delete();
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     public Set<String> getDownloadEntries(final NodeRef downloadNode)
 | |
|     {
 | |
|         return transactionHelper.doInTransaction(new RetryingTransactionCallback<Set<String>>()
 | |
|         {
 | |
|             @Override
 | |
|             public Set<String> execute() throws Throwable
 | |
|             {
 | |
|                 Set<String> entryNames = new TreeSet<String>();
 | |
|                 ContentReader reader = contentService.getReader(downloadNode, ContentModel.PROP_CONTENT);
 | |
|                 try (ZipArchiveInputStream zipInputStream = new ZipArchiveInputStream(reader.getContentInputStream()))
 | |
|                 {
 | |
|                     ZipArchiveEntry zipEntry = null;
 | |
|                     while ((zipEntry = zipInputStream.getNextZipEntry()) != null)
 | |
|                     {
 | |
|                         String name = zipEntry.getName();
 | |
|                         entryNames.add(name);
 | |
|                     }
 | |
|                 }
 | |
|                 return entryNames;
 | |
|             }
 | |
|         });
 | |
|     }
 | |
| 
 | |
|     public String getDownloadEntry(Collection<String> entryNames, String entryName)
 | |
|     {
 | |
|         for (String expectedEntry : entryNames)
 | |
|         {
 | |
|             if (expectedEntry.equals(entryName))
 | |
|             {
 | |
|                 return expectedEntry;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         return null;
 | |
|     }
 | |
| 
 | |
|     public DownloadStatus getDownloadStatus(final NodeRef downloadNode)
 | |
|     {
 | |
|         return transactionHelper.doInTransaction(new RetryingTransactionCallback<DownloadStatus>()
 | |
|         {
 | |
|             @Override
 | |
|             public DownloadStatus execute() throws Throwable
 | |
|             {
 | |
|                 return downloadService.getDownloadStatus(downloadNode);
 | |
|             }
 | |
|         });
 | |
|     }
 | |
| }
 |