mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	REPO-1681 / MNT-17228: CMIS: Attempt to delete non-current version throws "Unexpected: current version does not appear ..."
- Fixed the misuse of the version node instead of live node - Added permission check for deleting a version - Uncommented the test added by JanV (REPO-1228) + added testcase for deleting with no permission - PublicApiCallContextHandler inherits basic auth parameters from BasicAuthCallContextHandler, to ensure proper exceptions are thrown by CMIS servlets (in this case, CmisPermissionDeniedException instead of CmisUnauthorizedException). git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/DEV/5.2.N/root@133954 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
		| @@ -77,6 +77,8 @@ import org.alfresco.service.cmr.repository.NodeRef; | |||||||
| import org.alfresco.service.cmr.search.ResultSet; | import org.alfresco.service.cmr.search.ResultSet; | ||||||
| import org.alfresco.service.cmr.search.SearchParameters; | import org.alfresco.service.cmr.search.SearchParameters; | ||||||
| import org.alfresco.service.cmr.search.SearchService; | import org.alfresco.service.cmr.search.SearchService; | ||||||
|  | import org.alfresco.service.cmr.security.AccessStatus; | ||||||
|  | import org.alfresco.service.cmr.security.PermissionService; | ||||||
| import org.alfresco.service.cmr.version.Version; | import org.alfresco.service.cmr.version.Version; | ||||||
| import org.alfresco.service.cmr.version.VersionHistory; | import org.alfresco.service.cmr.version.VersionHistory; | ||||||
| import org.alfresco.service.cmr.version.VersionType; | import org.alfresco.service.cmr.version.VersionType; | ||||||
| @@ -117,6 +119,7 @@ import org.apache.chemistry.opencmis.commons.exceptions.CmisConstraintException; | |||||||
| import org.apache.chemistry.opencmis.commons.exceptions.CmisContentAlreadyExistsException; | import org.apache.chemistry.opencmis.commons.exceptions.CmisContentAlreadyExistsException; | ||||||
| import org.apache.chemistry.opencmis.commons.exceptions.CmisInvalidArgumentException; | import org.apache.chemistry.opencmis.commons.exceptions.CmisInvalidArgumentException; | ||||||
| import org.apache.chemistry.opencmis.commons.exceptions.CmisObjectNotFoundException; | import org.apache.chemistry.opencmis.commons.exceptions.CmisObjectNotFoundException; | ||||||
|  | import org.apache.chemistry.opencmis.commons.exceptions.CmisPermissionDeniedException; | ||||||
| import org.apache.chemistry.opencmis.commons.exceptions.CmisRuntimeException; | import org.apache.chemistry.opencmis.commons.exceptions.CmisRuntimeException; | ||||||
| import org.apache.chemistry.opencmis.commons.exceptions.CmisStorageException; | import org.apache.chemistry.opencmis.commons.exceptions.CmisStorageException; | ||||||
| import org.apache.chemistry.opencmis.commons.exceptions.CmisStreamNotSupportedException; | import org.apache.chemistry.opencmis.commons.exceptions.CmisStreamNotSupportedException; | ||||||
| @@ -1767,6 +1770,11 @@ public class AlfrescoCmisServiceImpl extends AbstractCmisService implements Alfr | |||||||
|             } |             } | ||||||
|  |  | ||||||
|             // handle versions |             // handle versions | ||||||
|  |             if (info.isVariant(CMISObjectVariant.VERSION)) | ||||||
|  |             { | ||||||
|  |                 nodeRef = info.getCurrentNodeNodeRef(); | ||||||
|  |             } | ||||||
|  |  | ||||||
|             if (allVersions) |             if (allVersions) | ||||||
|             { |             { | ||||||
|                 NodeRef workingCopy = connector.getCheckOutCheckInService().getWorkingCopy(nodeRef); |                 NodeRef workingCopy = connector.getCheckOutCheckInService().getWorkingCopy(nodeRef); | ||||||
| @@ -1777,16 +1785,16 @@ public class AlfrescoCmisServiceImpl extends AbstractCmisService implements Alfr | |||||||
|             } |             } | ||||||
|             else if (info.isVariant(CMISObjectVariant.VERSION)) |             else if (info.isVariant(CMISObjectVariant.VERSION)) | ||||||
|             { |             { | ||||||
|  |                 // Check the DELETE permission since the version service has no restrictions.  | ||||||
|  |                 if (connector.getServiceRegistry().getPermissionService().hasPermission(nodeRef, PermissionService.DELETE) != AccessStatus.ALLOWED) | ||||||
|  |                 { | ||||||
|  |                     throw new CmisPermissionDeniedException("Cannot delete the node version."); | ||||||
|  |                 } | ||||||
|                 Version version = ((CMISNodeInfoImpl) info).getVersion(); |                 Version version = ((CMISNodeInfoImpl) info).getVersion(); | ||||||
|                 connector.getVersionService().deleteVersion(nodeRef, version); |                 connector.getVersionService().deleteVersion(nodeRef, version); | ||||||
|                 break;      // Reason for do-while |                 break;      // Reason for do-while | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             if (info.isVariant(CMISObjectVariant.VERSION)) |  | ||||||
|             { |  | ||||||
|                 nodeRef = info.getCurrentNodeNodeRef(); |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             // attempt to delete the node |             // attempt to delete the node | ||||||
|             if (allVersions) |             if (allVersions) | ||||||
|             { |             { | ||||||
| @@ -1794,7 +1802,7 @@ public class AlfrescoCmisServiceImpl extends AbstractCmisService implements Alfr | |||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
|                 CMISNodeInfoImpl infoImpl = ((CMISNodeInfoImpl) info); |                 CMISNodeInfoImpl infoImpl = (CMISNodeInfoImpl) info; | ||||||
|                 Version version = infoImpl.getVersion(); |                 Version version = infoImpl.getVersion(); | ||||||
|  |  | ||||||
|                 if (infoImpl.getVersionHistory().getPredecessor(version) == null) |                 if (infoImpl.getVersionHistory().getPredecessor(version) == null) | ||||||
| @@ -1803,6 +1811,10 @@ public class AlfrescoCmisServiceImpl extends AbstractCmisService implements Alfr | |||||||
|                 } |                 } | ||||||
|                 else |                 else | ||||||
|                 { |                 { | ||||||
|  |                     if (connector.getServiceRegistry().getPermissionService().hasPermission(nodeRef, PermissionService.DELETE) != AccessStatus.ALLOWED) | ||||||
|  |                     { | ||||||
|  |                         throw new CmisPermissionDeniedException("Cannot delete the node version."); | ||||||
|  |                     } | ||||||
|                     connector.getVersionService().deleteVersion(nodeRef, version); |                     connector.getVersionService().deleteVersion(nodeRef, version); | ||||||
|                     // MNT-10032 revert node version to predecessor |                     // MNT-10032 revert node version to predecessor | ||||||
|                     connector.getVersionService().revert(nodeRef); |                     connector.getVersionService().revert(nodeRef); | ||||||
|   | |||||||
| @@ -507,6 +507,14 @@ public class CMISConnector implements ApplicationContextAware, ApplicationListen | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|  |      * Return the service registry | ||||||
|  |      */ | ||||||
|  |     public final ServiceRegistry getServiceRegistry() | ||||||
|  |     { | ||||||
|  |     	return this.serviceRegistry; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|      * Sets the descriptor service. |      * Sets the descriptor service. | ||||||
|      */ |      */ | ||||||
|     public void setDescriptorService(DescriptorService descriptorService) |     public void setDescriptorService(DescriptorService descriptorService) | ||||||
|   | |||||||
| @@ -40,6 +40,13 @@ public class PublicApiCallContextHandler extends BasicAuthCallContextHandler | |||||||
| 	public Map<String, String> getCallContextMap(HttpServletRequest request) | 	public Map<String, String> getCallContextMap(HttpServletRequest request) | ||||||
| 	{ | 	{ | ||||||
|         Map<String, String> map = new HashMap<String, String>(); |         Map<String, String> map = new HashMap<String, String>(); | ||||||
|  |          | ||||||
|  |         Map<String, String> basicAuthMap = super.getCallContextMap(request); | ||||||
|  |         if (basicAuthMap != null && !basicAuthMap.isEmpty())  | ||||||
|  |         { | ||||||
|  |             map.putAll(basicAuthMap); | ||||||
|  |         } | ||||||
|  |          | ||||||
|         map.put("isPublicApi", "true"); |         map.put("isPublicApi", "true"); | ||||||
|         return map; |         return map; | ||||||
| 	} | 	} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user