mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/DEV/5.2.N/root@131887 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
			
				
	
	
		
			223 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			223 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| /*
 | |
|  * #%L
 | |
|  * Alfresco Repository
 | |
|  * %%
 | |
|  * Copyright (C) 2005 - 2016 Alfresco Software Limited
 | |
|  * %%
 | |
|  * This file is part of the Alfresco software. 
 | |
|  * If the software was purchased under a paid Alfresco license, the terms of 
 | |
|  * the paid license agreement will prevail.  Otherwise, the software is 
 | |
|  * provided under the following open source license terms:
 | |
|  * 
 | |
|  * 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/>.
 | |
|  * #L%
 | |
|  */
 | |
| package org.alfresco.service.cmr.audit;
 | |
| 
 | |
| import java.io.Serializable;
 | |
| import java.util.List;
 | |
| import java.util.Map;
 | |
| 
 | |
| /**
 | |
|  * The public API by which applications can query the audit logs and enable or disable auditing.
 | |
|  * 
 | |
|  * @author Derek Hulley
 | |
|  */
 | |
| public interface AuditService
 | |
| {
 | |
|     /**
 | |
|      * @return                  Returns <tt>true</tt> if auditing is globally enabled
 | |
|      * 
 | |
|      * @since 3.4
 | |
|      */
 | |
|     boolean isAuditEnabled();
 | |
|     
 | |
|     /**
 | |
|      * Enable or disable the global auditing state
 | |
|      * 
 | |
|      * @param enable            <tt>true</tt> to enable auditing globally or <tt>false</tt> to disable
 | |
|      * 
 | |
|      * @since 3.4
 | |
|      */
 | |
|     void setAuditEnabled(boolean enable);
 | |
| 
 | |
|     /**
 | |
|      * Helper bean to carry information about an audit application.
 | |
|      * 
 | |
|      * @author Derek Hulley
 | |
|      * @since 3.4
 | |
|      */
 | |
|     public static class AuditApplication
 | |
|     {
 | |
|         private final String name;
 | |
|         private final String key;
 | |
|         private final boolean enabled;
 | |
|         /**
 | |
|          * Constructor for final variables
 | |
|          */
 | |
|         public AuditApplication(String name, String key, boolean enabled)
 | |
|         {
 | |
|             this.name = name;
 | |
|             this.key = key;
 | |
|             this.enabled = enabled;
 | |
|         }
 | |
|         public String getName()
 | |
|         {
 | |
|             return name;
 | |
|         }
 | |
|         public String getKey()
 | |
|         {
 | |
|             return key;
 | |
|         }
 | |
|         public boolean isEnabled()
 | |
|         {
 | |
|             return enabled;
 | |
|         }
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * Get all registered audit applications
 | |
|      * 
 | |
|      * @return                  Returns a map of audit applications keyed by their name
 | |
|      * 
 | |
|      * @since 3.4
 | |
|      */
 | |
|     Map<String, AuditApplication> getAuditApplications();
 | |
|     
 | |
|     /**
 | |
|      * @param applicationName   the name of the application to check 
 | |
|      * @param path              the path to check
 | |
|      * @return                  Returns <tt>true</tt> if auditing is enabled for the given path
 | |
|      * 
 | |
|      * @since 3.2
 | |
|      */
 | |
|     boolean isAuditEnabled(String applicationName, String path);
 | |
|     
 | |
|     /**
 | |
|      * Enable auditing for an application path
 | |
|      * 
 | |
|      * @param applicationName   the name of the application to check 
 | |
|      * @param path              the path to enable
 | |
|      * 
 | |
|      * @since 3.2
 | |
|      */
 | |
|     void enableAudit(String applicationName, String path);
 | |
|     
 | |
|     /**
 | |
|      * Disable auditing for an application path
 | |
|      * 
 | |
|      * @param applicationName   the name of the application to check 
 | |
|      * @param path              the path to disable
 | |
|      * 
 | |
|      * @since 3.2
 | |
|      */
 | |
|     void disableAudit(String applicationName, String path);
 | |
|     
 | |
|     /**
 | |
|      * Remove all audit entries for the given application
 | |
|      * 
 | |
|      * @param applicationName   the name of the application for which to remove entries
 | |
|      * @return                  Returns the number of audit entries deleted
 | |
|      * 
 | |
|      * @since 3.2
 | |
|      * 
 | |
|      * @deprecated          Use {@link #clearAudit(String, Long, Long)}
 | |
|      */
 | |
|     int clearAudit(String applicationName);
 | |
|     
 | |
|     /**
 | |
|      * Remove audit entries for the given application between the time ranges.  If no start
 | |
|      * time is given then entries are deleted as far back as they exist.  If no end time is
 | |
|      * given then entries are deleted up until the current time.
 | |
|      * 
 | |
|      * @param applicationName   the name of the application for which to remove entries
 | |
|      * @param fromTime          the start time of entries to remove (inclusive and optional)
 | |
|      * @param toTime            the end time of entries to remove (exclusive and optional)
 | |
|      * @return                  Returns the number of audit entries deleted
 | |
|      * 
 | |
|      * @since 3.4
 | |
|      */
 | |
|     int clearAudit(String applicationName, Long fromTime, Long toTime);
 | |
|     
 | |
|     /**
 | |
|      * Delete a discrete list of audit entries.
 | |
|      * <p/>
 | |
|      * This method should not be called <i>while</i> processing
 | |
|      * {@link #auditQuery(AuditQueryCallback, AuditQueryParameters, int) query results}.
 | |
|      * 
 | |
|      * @param auditEntryIds     the IDs of all audit entries to delete
 | |
|      * @return                  Returns the number of audit entries deleted
 | |
|      * 
 | |
|      * @since 3.4
 | |
|      */
 | |
|     int clearAudit(List<Long> auditEntryIds);
 | |
|     
 | |
|     /**
 | |
|      * The interface that will be used to give query results to the calling code.
 | |
|      * 
 | |
|      * @since 3.2
 | |
|      */
 | |
|     public static interface AuditQueryCallback
 | |
|     {
 | |
|         /**
 | |
|          * Determines whether this callback requires the values argument to be populated when {@link #handleAuditEntry}
 | |
|          * is called.
 | |
|          * 
 | |
|          * @return <code>true</code> if this callback requires the values argument to be populated
 | |
|          */
 | |
|         boolean valuesRequired();
 | |
|         
 | |
|         /**
 | |
|          * Handle a row of audit entry data.
 | |
|          * 
 | |
|          * @param entryId                   the unique audit entry ID
 | |
|          * @param applicationName           the name of the application
 | |
|          * @param user                      the user that logged the entry
 | |
|          * @param time                      the time of the entry
 | |
|          * @param values                    the values map as created
 | |
|          * @return                          Return <tt>true</tt> to continue processing rows or <tt>false</tt> to stop
 | |
|          */
 | |
|         boolean handleAuditEntry(
 | |
|                 Long entryId,
 | |
|                 String applicationName,
 | |
|                 String user,
 | |
|                 long time,
 | |
|                 Map<String, Serializable> values);
 | |
|         
 | |
|         /**
 | |
|          * Handle audit entry failures
 | |
|          * 
 | |
|          * @param entryId                   the entry ID
 | |
|          * @param errorMsg                  the error message
 | |
|          * @param error                     the exception causing the error (may be <tt>null</tt>)
 | |
|          * @return                          Return <tt>true</tt> to continue processing rows or <tt>false</tt> to stop
 | |
|          */
 | |
|         boolean handleAuditEntryError(Long entryId, String errorMsg, Throwable error);
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * Issue an audit query using the given parameters and consuming results in the callback.
 | |
|      * Results are returned in entry order, corresponding to time order.
 | |
|      * 
 | |
|      * @param callback          the callback that will handle results
 | |
|      * @param parameters        the parameters for the query (may not be <tt>null</tt>)
 | |
|      * @param maxResults        the maximum number of results to retrieve (must be greater than 0)
 | |
|      * 
 | |
|      * @throws IllegalArgumentException if maxResults less or equal to zero
 | |
|      * 
 | |
|      * @since 3.3
 | |
|      */
 | |
|     void auditQuery(AuditQueryCallback callback, AuditQueryParameters parameters, int maxResults);
 | |
| }
 |