You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

DefaultAuditManager.java 6.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. package org.apache.archiva.audit;
  2. /*
  3. * Licensed to the Apache Software Foundation (ASF) under one
  4. * or more contributor license agreements. See the NOTICE file
  5. * distributed with this work for additional information
  6. * regarding copyright ownership. The ASF licenses this file
  7. * to you under the Apache License, Version 2.0 (the
  8. * "License"); you may not use this file except in compliance
  9. * with the License. You may obtain a copy of the License at
  10. *
  11. * http://www.apache.org/licenses/LICENSE-2.0
  12. *
  13. * Unless required by applicable law or agreed to in writing,
  14. * software distributed under the License is distributed on an
  15. * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
  16. * KIND, either express or implied. See the License for the
  17. * specific language governing permissions and limitations
  18. * under the License.
  19. */
  20. import org.apache.archiva.metadata.model.facets.AuditEvent;
  21. import org.apache.archiva.metadata.repository.MetadataRepository;
  22. import org.apache.archiva.metadata.repository.MetadataRepositoryException;
  23. import org.slf4j.Logger;
  24. import org.slf4j.LoggerFactory;
  25. import org.springframework.stereotype.Service;
  26. import java.text.ParseException;
  27. import java.text.SimpleDateFormat;
  28. import java.util.ArrayList;
  29. import java.util.Collection;
  30. import java.util.Collections;
  31. import java.util.Comparator;
  32. import java.util.Date;
  33. import java.util.List;
  34. import java.util.TimeZone;
  35. /**
  36. *
  37. */
  38. @Service("auditManager#default")
  39. public class DefaultAuditManager
  40. implements AuditManager
  41. {
  42. private static final int NUM_RECENT_EVENTS = 10;
  43. private static final Logger log = LoggerFactory.getLogger( DefaultAuditManager.class );
  44. private static final TimeZone UTC_TIME_ZONE = TimeZone.getTimeZone( "UTC" );
  45. @Override
  46. public List<AuditEvent> getMostRecentAuditEvents( MetadataRepository metadataRepository,
  47. List<String> repositoryIds )
  48. throws MetadataRepositoryException
  49. {
  50. // TODO: consider a more efficient implementation that directly gets the last ten from the content repository
  51. List<AuditRecord> records = new ArrayList<>();
  52. for ( String repositoryId : repositoryIds )
  53. {
  54. List<String> names = metadataRepository.getMetadataFacets( repositoryId, AuditEvent.FACET_ID );
  55. for ( String name : names )
  56. {
  57. records.add( new AuditRecord( repositoryId, name ) );
  58. }
  59. }
  60. Collections.sort( records );
  61. records = records.subList( 0, records.size() < NUM_RECENT_EVENTS ? records.size() : NUM_RECENT_EVENTS );
  62. List<AuditEvent> events = new ArrayList<>( records.size() );
  63. for ( AuditRecord record : records )
  64. {
  65. AuditEvent auditEvent = (AuditEvent) metadataRepository.getMetadataFacet( record.repositoryId,
  66. AuditEvent.FACET_ID,
  67. record.name );
  68. events.add( auditEvent );
  69. }
  70. return events;
  71. }
  72. @Override
  73. public void addAuditEvent( MetadataRepository repository, AuditEvent event )
  74. throws MetadataRepositoryException
  75. {
  76. // ignore those with no repository - they will still be logged to the textual audit log
  77. if ( event.getRepositoryId() != null )
  78. {
  79. repository.addMetadataFacet( event.getRepositoryId(), event );
  80. }
  81. }
  82. @Override
  83. public void deleteAuditEvents( MetadataRepository metadataRepository, String repositoryId )
  84. throws MetadataRepositoryException
  85. {
  86. metadataRepository.removeMetadataFacets( repositoryId, AuditEvent.FACET_ID );
  87. }
  88. @Override
  89. public List<AuditEvent> getAuditEventsInRange( MetadataRepository metadataRepository,
  90. Collection<String> repositoryIds, Date startTime, Date endTime )
  91. throws MetadataRepositoryException
  92. {
  93. return getAuditEventsInRange( metadataRepository, repositoryIds, null, startTime, endTime );
  94. }
  95. @Override
  96. public List<AuditEvent> getAuditEventsInRange( MetadataRepository metadataRepository,
  97. Collection<String> repositoryIds, String resource, Date startTime,
  98. Date endTime )
  99. throws MetadataRepositoryException
  100. {
  101. List<AuditEvent> results = new ArrayList<>();
  102. for ( String repositoryId : repositoryIds )
  103. {
  104. List<String> list = metadataRepository.getMetadataFacets( repositoryId, AuditEvent.FACET_ID );
  105. for ( String name : list )
  106. {
  107. try
  108. {
  109. Date date = createNameFormat().parse( name );
  110. if ( ( startTime == null || !date.before( startTime ) ) && ( endTime == null || !date.after(
  111. endTime ) ) )
  112. {
  113. AuditEvent event = (AuditEvent) metadataRepository.getMetadataFacet( repositoryId,
  114. AuditEvent.FACET_ID,
  115. name );
  116. if ( resource == null || event.getResource().startsWith( resource ) )
  117. {
  118. results.add( event );
  119. }
  120. }
  121. }
  122. catch ( ParseException e )
  123. {
  124. log.error( "Invalid audit event found in the metadata repository: " + e.getMessage() );
  125. // continue and ignore this one
  126. }
  127. }
  128. }
  129. Collections.sort( results, new Comparator<AuditEvent>()
  130. {
  131. @Override
  132. public int compare( AuditEvent o1, AuditEvent o2 )
  133. {
  134. return o2.getTimestamp().compareTo( o1.getTimestamp() );
  135. }
  136. } );
  137. return results;
  138. }
  139. private static SimpleDateFormat createNameFormat()
  140. {
  141. SimpleDateFormat fmt = new SimpleDateFormat( AuditEvent.TIMESTAMP_FORMAT );
  142. fmt.setTimeZone( UTC_TIME_ZONE );
  143. return fmt;
  144. }
  145. private static final class AuditRecord
  146. implements Comparable<AuditRecord>
  147. {
  148. private String repositoryId;
  149. private String name;
  150. public AuditRecord( String repositoryId, String name )
  151. {
  152. this.repositoryId = repositoryId;
  153. this.name = name;
  154. }
  155. @Override
  156. public int compareTo( AuditRecord other )
  157. {
  158. // reverse ordering
  159. return other.name.compareTo( name );
  160. }
  161. }
  162. }