1 package org.apache.archiva.audit;
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 import org.apache.archiva.metadata.model.facets.AuditEvent;
23 import org.apache.archiva.metadata.repository.MetadataRepositoryException;
24 import org.apache.archiva.metadata.repository.RepositorySession;
25 import org.apache.archiva.metadata.repository.RepositorySessionFactory;
26 import org.apache.archiva.repository.events.AuditListener;
27 import org.slf4j.Logger;
28 import org.slf4j.LoggerFactory;
29 import org.springframework.stereotype.Service;
30
31 import javax.inject.Inject;
32
33
34
35
36 @Service("auditListener#metadata")
37 public class MetadataAuditListener
38 implements AuditListener
39 {
40 private static final Logger log = LoggerFactory.getLogger( MetadataAuditListener.class );
41
42
43
44
45 @Inject
46 private AuditManager auditManager;
47
48
49
50
51
52 @Inject
53 private RepositorySessionFactory repositorySessionFactory;
54
55 @Override
56 public void auditEvent( AuditEvent event )
57 {
58
59 if ( event.getAction().equals( AuditEvent.CREATE_FILE ) || event.getAction().equals( AuditEvent.UPLOAD_FILE ) ||
60 event.getAction().equals( AuditEvent.MERGING_REPOSITORIES ) )
61 {
62 RepositorySession repositorySession = repositorySessionFactory.createSession();
63 try
64 {
65 auditManager.addAuditEvent( repositorySession.getRepository(), event );
66 repositorySession.save();
67 }
68 catch ( MetadataRepositoryException e )
69 {
70 log.warn( "Unable to write audit event to repository: {}", e.getMessage(), e );
71 }
72 finally
73 {
74 repositorySession.close();
75 }
76 }
77 }
78 }