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/HEAD/root@18931 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
			
				
	
	
		
			224 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			224 lines
		
	
	
		
			7.4 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.audit;
 | |
| 
 | |
| import java.io.Serializable;
 | |
| import java.util.List;
 | |
| 
 | |
| import javax.transaction.UserTransaction;
 | |
| 
 | |
| import org.alfresco.repo.security.authentication.AuthenticationUtil;
 | |
| import org.alfresco.service.cmr.audit.AuditInfo;
 | |
| import org.alfresco.service.cmr.audit.AuditQueryParameters;
 | |
| import org.alfresco.service.cmr.audit.AuditService;
 | |
| import org.alfresco.service.cmr.repository.NodeRef;
 | |
| import org.alfresco.service.cmr.repository.StoreRef;
 | |
| import org.alfresco.service.transaction.TransactionService;
 | |
| import org.alfresco.util.ApplicationContextHelper;
 | |
| import org.springframework.extensions.surf.util.ParameterCheck;
 | |
| import org.springframework.context.ApplicationContext;
 | |
| 
 | |
| /**
 | |
|  * The implementation of the AuditService for application auditing.
 | |
|  * 
 | |
|  * @author Andy Hind
 | |
|  */
 | |
| public class AuditServiceImpl implements AuditService
 | |
| {
 | |
|     private AuditComponent auditComponent;
 | |
| 
 | |
|     public AuditServiceImpl()
 | |
|     {
 | |
|         super();
 | |
|     }
 | |
| 
 | |
|     public void setAuditComponent(AuditComponent auditComponent)
 | |
|     {
 | |
|         this.auditComponent = auditComponent;
 | |
|     }
 | |
| 
 | |
|     public void audit(String source, String description)
 | |
|     {
 | |
|         auditComponent.audit(source, description, null, (Object[]) null);
 | |
|     }
 | |
| 
 | |
|     public void audit(String source, String description, NodeRef key)
 | |
|     {
 | |
|         auditComponent.audit(source, description, key, (Object[]) null);
 | |
|     }
 | |
| 
 | |
|     public void audit(String source, String description, Object... args)
 | |
|     {
 | |
|         auditComponent.audit(source, description, null, args);
 | |
|     }
 | |
| 
 | |
|     public void audit(String source, String description, NodeRef key, Object... args)
 | |
|     {
 | |
|         auditComponent.audit(source, description, key, args);
 | |
|     }
 | |
| 
 | |
|     public List<AuditInfo> getAuditTrail(NodeRef nodeRef)
 | |
|     {
 | |
|         return  auditComponent.getAuditTrail(nodeRef);
 | |
|     }
 | |
|     
 | |
|     public static void main(String[] args) throws Exception
 | |
|     {
 | |
| 
 | |
|         ApplicationContext ctx = ApplicationContextHelper.getApplicationContext();
 | |
|         AuditService as = (AuditService) ctx.getBean("AuditService");
 | |
| 
 | |
|         TransactionService txs = (TransactionService) ctx.getBean("transactionComponent");
 | |
|         UserTransaction tx = txs.getUserTransaction();
 | |
|         tx.begin();
 | |
| 
 | |
|         AuthenticationUtil.setRunAsUserSystem();
 | |
|         try
 | |
|         {
 | |
| 
 | |
|             NodeRef nodeRef = new NodeRef(new StoreRef("test", "audit"), "id");
 | |
|             as.audit("AuditedApp", "First");
 | |
|             System.out.println("Audit entries for node "+as.getAuditTrail(nodeRef).size());
 | |
|             as.audit("AuditedApp", "Second", nodeRef);
 | |
|             System.out.println("Audit entries for node "+as.getAuditTrail(nodeRef).size());
 | |
|             as.audit("AuditedApp", "Third", new Object[] { "one", "two", "three" });
 | |
|             System.out.println("Audit entries for node "+as.getAuditTrail(nodeRef).size());
 | |
|             as.audit("AuditedApp", "Fourth",nodeRef, new Object[] { "one",
 | |
|                     "two", "three" });
 | |
|             System.out.println("Audit entries for node "+as.getAuditTrail(nodeRef).size());
 | |
|             as.audit("UnAuditedApp", "First");
 | |
|             System.out.println("Audit entries for node "+as.getAuditTrail(nodeRef).size());
 | |
|             as.audit("UnAuditedApp", "Second", nodeRef);
 | |
|             System.out.println("Audit entries for node "+as.getAuditTrail(nodeRef).size());
 | |
|             as.audit("UnAuditedApp", "Third", new Object[] { "one", "two", "three" });
 | |
|             System.out.println("Audit entries for node "+as.getAuditTrail(nodeRef).size());
 | |
|             as.audit("UnAuditedApp", "Fourth", nodeRef, new Object[] { "one",
 | |
|                     "two", "three" });
 | |
|             System.out.println("Audit entries for node "+as.getAuditTrail(nodeRef).size());
 | |
|         }
 | |
|         finally
 | |
|         {
 | |
|             AuthenticationUtil.clearCurrentSecurityContext();
 | |
|         }
 | |
|         tx.commit();
 | |
| 
 | |
|     }
 | |
| 
 | |
|     /*
 | |
|      * V3.2 from here on.  Put all fixes to the older audit code before this point, please.
 | |
|      */
 | |
| 
 | |
|     /**
 | |
|      * {@inheritDoc}
 | |
|      * @since 3.2
 | |
|      */
 | |
|     public boolean isAuditEnabled(String applicationName, String path)
 | |
|     {
 | |
|         // Get the root path for the application
 | |
|         return auditComponent.isAuditPathEnabled(applicationName, path);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * {@inheritDoc}
 | |
|      * @since 3.2
 | |
|      */
 | |
|     public void enableAudit(String applicationName, String path)
 | |
|     {
 | |
|         auditComponent.enableAudit(applicationName, path);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * {@inheritDoc}
 | |
|      * @since 3.2
 | |
|      */
 | |
|     public void disableAudit(String applicationName, String path)
 | |
|     {
 | |
|         auditComponent.disableAudit(applicationName, path);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * {@inheritDoc}
 | |
|      * @since 3.2
 | |
|      */
 | |
|     public void clearAudit(String applicationName)
 | |
|     {
 | |
|         Long now = Long.valueOf(System.currentTimeMillis());
 | |
|         auditComponent.deleteAuditEntries(applicationName, null, now);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * {@inheritDoc}
 | |
|      * @since 3.3
 | |
|      */
 | |
|     public void auditQuery(AuditQueryCallback callback, AuditQueryParameters parameters, int maxResults)
 | |
|     {
 | |
|         auditComponent.auditQuery(callback, parameters, maxResults);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * {@inheritDoc}
 | |
|      * @since 3.2
 | |
|      */
 | |
|     public void auditQuery(
 | |
|             AuditQueryCallback callback,
 | |
|             boolean forward,
 | |
|             String applicationName, String user, Long from, Long to,
 | |
|             int maxResults)
 | |
| 
 | |
|     {
 | |
|         ParameterCheck.mandatory("callback", callback);
 | |
|         
 | |
|         AuditQueryParameters params = new AuditQueryParameters();
 | |
|         params.setForward(true);
 | |
|         params.setApplicationName(applicationName);
 | |
|         params.setUser(user);
 | |
|         params.setFromTime(from);
 | |
|         params.setToTime(to);
 | |
|         
 | |
|         auditComponent.auditQuery(callback, params, maxResults);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * {@inheritDoc}
 | |
|      * @since 3.2
 | |
|      */
 | |
|     public void auditQuery(
 | |
|             AuditQueryCallback callback,
 | |
|             boolean forward,
 | |
|             String applicationName, String user, Long from, Long to,
 | |
|             String searchKey, Serializable searchValue,
 | |
|             int maxResults)
 | |
| 
 | |
|     {
 | |
|         ParameterCheck.mandatory("callback", callback);
 | |
|         
 | |
|         AuditQueryParameters params = new AuditQueryParameters();
 | |
|         params.setForward(true);
 | |
|         params.setApplicationName(applicationName);
 | |
|         params.setUser(user);
 | |
|         params.setFromTime(from);
 | |
|         params.setToTime(to);
 | |
|         if (searchKey != null || searchValue != null)
 | |
|         {
 | |
|             params.addSearchKey(searchKey, searchValue);
 | |
|         }
 | |
|         
 | |
|         auditComponent.auditQuery(callback, params, maxResults);
 | |
|     }
 | |
| } |