mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	84758: Merged PLATFORM1 (5.0/Cloud) to HEAD-BUG-FIX (5.0/Cloud)
      80284: ACE-2213
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@85123 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
	
		
			
				
	
	
		
			102 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2005-2010 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.content;
 | |
| 
 | |
| import org.alfresco.api.AlfrescoPublicApi;    
 | |
| import org.alfresco.repo.policy.ClassPolicy;
 | |
| import org.alfresco.service.cmr.repository.ContentData;
 | |
| import org.alfresco.service.cmr.repository.NodeRef;
 | |
| import org.alfresco.service.namespace.NamespaceService;
 | |
| import org.alfresco.service.namespace.QName;
 | |
| 
 | |
| /**
 | |
|  * Content service policies interface
 | |
|  * 
 | |
|  * @author Roy Wetherall
 | |
|  * @author Derek Hulley
 | |
|  */
 | |
| public interface ContentServicePolicies
 | |
| {
 | |
|     /** @deprecated Use {@link OnContentUpdatePolicy#QNAME} */
 | |
|     public static final QName ON_CONTENT_UPDATE = QName.createQName(NamespaceService.ALFRESCO_URI, "onContentUpdate");
 | |
|     /** @deprecated Use {@link OnContentPropertyUpdatePolicy#QNAME} */
 | |
|     public static final QName ON_CONTENT_PROPERTY_UPDATE = QName.createQName(NamespaceService.ALFRESCO_URI, "onContentPropertyUpdate");
 | |
|     /** @deprecated Use {@link OnContentReadPolicy#QNAME} */
 | |
|     public static final QName ON_CONTENT_READ = QName.createQName(NamespaceService.ALFRESCO_URI, "onContentRead");
 | |
|     
 | |
| 	/**
 | |
| 	 * Policy that is raised once per node when any of the content properties on the node are
 | |
| 	 * changed; the specific properties are irrelevant.  This is primarily useful to determine
 | |
| 	 * when a new file is introduced into the system.
 | |
| 	 */
 | |
| 	@AlfrescoPublicApi
 | |
| 	public interface OnContentUpdatePolicy extends ClassPolicy
 | |
| 	{
 | |
| 	    public static final QName QNAME = QName.createQName(NamespaceService.ALFRESCO_URI, "onContentUpdate");
 | |
| 		/**
 | |
| 		 * @param nodeRef	the node reference
 | |
| 		 */
 | |
| 		public void onContentUpdate(NodeRef nodeRef, boolean newContent);
 | |
| 	}
 | |
|     
 | |
|     /**
 | |
|      * Policy that is raised for each content property change.  Any policy implementations must be aware
 | |
|      * that the transaction in which this is called could still roll back; no filesystem changes should
 | |
|      * occur against the source content until after the transaction has <u>successfully</u> completed.
 | |
|      * 
 | |
|      * @since 3.2
 | |
|      */
 | |
|     public interface OnContentPropertyUpdatePolicy extends ClassPolicy
 | |
|     {
 | |
|         public static final QName QNAME = QName.createQName(NamespaceService.ALFRESCO_URI, "onContentPropertyUpdate");
 | |
|         /**
 | |
|          * @param nodeRef           the node reference
 | |
|          * @param propertyQName     the name of the property that changed
 | |
|          * @param beforeValue       the value of the content data prior to the change.
 | |
|          *                          Note that this value may be <tt>null</tt> or any of it's member
 | |
|          *                          values may be <tt>null</tt> according to the contract of the
 | |
|          *                          {@link ContentData} class.
 | |
|          * @param afterValue        the value of the content data after the change
 | |
|          * 
 | |
|          * @see ContentData#hasContent(ContentData)
 | |
|          * @see RoutingContentService#onUpdateProperties(NodeRef, java.util.Map, java.util.Map)
 | |
|          * @since 3.2
 | |
|          */
 | |
|         public void onContentPropertyUpdate(
 | |
|                 NodeRef nodeRef,
 | |
|                 QName propertyQName,
 | |
|                 ContentData beforeValue,
 | |
|                 ContentData afterValue);
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * On content read policy interface.
 | |
|      * 
 | |
|      * This policy is fired when a content reader is requested for a node that has content.
 | |
|      */
 | |
|     public interface OnContentReadPolicy extends ClassPolicy
 | |
|     {
 | |
|         public static final QName QNAME = QName.createQName(NamespaceService.ALFRESCO_URI, "onContentRead");
 | |
|         /**
 | |
|          * @param nodeRef   the node reference
 | |
|          */
 | |
|         public void onContentRead(NodeRef nodeRef);
 | |
|     }
 | |
| }
 |