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.metadata.audit.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 = null;
63 try
64 {
65 repositorySession = repositorySessionFactory.createSession();
66 }
67 catch ( MetadataRepositoryException e )
68 {
69 e.printStackTrace( );
70 }
71 try
72 {
73 auditManager.addAuditEvent( repositorySession.getRepository(), event );
74 repositorySession.save();
75 }
76 catch ( MetadataRepositoryException e )
77 {
78 log.warn( "Unable to write audit event to repository: {}", e.getMessage(), e );
79 }
80 catch ( org.apache.archiva.metadata.repository.MetadataSessionException e )
81 {
82 e.printStackTrace( );
83 }
84 finally
85 {
86 repositorySession.close();
87 }
88 }
89 }
90 }