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.

RepositoryPurgeConsumer.java 9.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335
  1. package org.apache.archiva.consumers.core.repository;
  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.configuration.provider.ArchivaConfiguration;
  21. import org.apache.archiva.configuration.model.ConfigurationNames;
  22. import org.apache.archiva.configuration.provider.FileTypes;
  23. import org.apache.archiva.consumers.AbstractMonitoredConsumer;
  24. import org.apache.archiva.consumers.ConsumerException;
  25. import org.apache.archiva.consumers.KnownRepositoryContentConsumer;
  26. import org.apache.archiva.metadata.repository.RepositorySession;
  27. import org.apache.archiva.metadata.repository.RepositorySessionFactory;
  28. import org.apache.archiva.components.registry.Registry;
  29. import org.apache.archiva.components.registry.RegistryListener;
  30. import org.apache.archiva.repository.ManagedRepositoryContent;
  31. import org.apache.archiva.repository.ManagedRepository;
  32. import org.apache.archiva.repository.RepositoryContentFactory;
  33. import org.apache.archiva.repository.RepositoryRegistry;
  34. import org.apache.archiva.metadata.audit.RepositoryListener;
  35. import org.apache.archiva.repository.features.ArtifactCleanupFeature;
  36. import org.apache.archiva.repository.metadata.base.MetadataTools;
  37. import org.springframework.beans.factory.annotation.Autowired;
  38. import org.springframework.context.annotation.Scope;
  39. import org.springframework.stereotype.Service;
  40. import javax.annotation.PostConstruct;
  41. import javax.inject.Inject;
  42. import javax.inject.Named;
  43. import java.util.ArrayList;
  44. import java.util.Collections;
  45. import java.util.Date;
  46. import java.util.List;
  47. /**
  48. * Consumer for removing old snapshots in the repository based on the criteria
  49. * specified by the user.
  50. */
  51. @Service( "knownRepositoryContentConsumer#repository-purge" )
  52. @Scope( "prototype" )
  53. public class RepositoryPurgeConsumer
  54. extends AbstractMonitoredConsumer
  55. implements KnownRepositoryContentConsumer, RegistryListener
  56. {
  57. /**
  58. * default-value="repository-purge"
  59. */
  60. private String id = "repository-purge";
  61. /**
  62. * default-value="Purge repository of old snapshots"
  63. */
  64. private String description = "Purge repository of old snapshots";
  65. @Inject
  66. @Named( value = "archivaConfiguration#default" )
  67. private ArchivaConfiguration configuration;
  68. @Inject
  69. private RepositoryRegistry repositoryRegistry;
  70. @Inject
  71. @Named( value = "repositoryContentFactory#default" )
  72. private RepositoryContentFactory repositoryContentFactory;
  73. @Inject
  74. private MetadataTools metadataTools;
  75. @Inject
  76. @Named( value = "fileTypes" )
  77. private FileTypes filetypes;
  78. private List<String> includes = new ArrayList<>( );
  79. private RepositoryPurge repoPurge;
  80. private RepositoryPurge cleanUp;
  81. private boolean deleteReleasedSnapshots;
  82. /**
  83. *
  84. */
  85. @Inject
  86. @Autowired( required = false )
  87. private List<RepositoryListener> listeners = Collections.emptyList( );
  88. @Inject
  89. private RepositorySessionFactory repositorySessionFactory;
  90. private RepositorySession repositorySession;
  91. @Override
  92. public String getId( )
  93. {
  94. return this.id;
  95. }
  96. @Override
  97. public String getDescription( )
  98. {
  99. return this.description;
  100. }
  101. @Override
  102. public List<String> getExcludes( )
  103. {
  104. return getDefaultArtifactExclusions( );
  105. }
  106. @Override
  107. public List<String> getIncludes( )
  108. {
  109. return this.includes;
  110. }
  111. @Override
  112. public void beginScan( ManagedRepository repository, Date whenGathered )
  113. throws ConsumerException
  114. {
  115. ManagedRepositoryContent repositoryContent;
  116. repositoryContent = repository.getContent();
  117. try
  118. {
  119. repositorySession = repositorySessionFactory.createSession( );
  120. }
  121. catch ( org.apache.archiva.metadata.repository.MetadataRepositoryException e )
  122. {
  123. throw new ConsumerException( "Could not create session: " + e.getMessage( ), e );
  124. }
  125. if (repository.supportsFeature( ArtifactCleanupFeature.class ))
  126. {
  127. ArtifactCleanupFeature acf = repository.getFeature( ArtifactCleanupFeature.class ).get();
  128. int retentionPeriodInDays = acf.getRetentionPeriod( ).getDays( );
  129. int retentionCount = acf.getRetentionCount();
  130. if ( retentionPeriodInDays != 0 )
  131. {
  132. repoPurge = new DaysOldRepositoryPurge( repositoryContent, retentionPeriodInDays,
  133. retentionCount, repositorySession, listeners );
  134. }
  135. else
  136. {
  137. repoPurge =
  138. new RetentionCountRepositoryPurge( repositoryContent, retentionCount, repositorySession,
  139. listeners );
  140. }
  141. deleteReleasedSnapshots = acf.isDeleteReleasedSnapshots( );
  142. } else {
  143. throw new ConsumerException( "The repository does not support the ArtifactCleanup feature "+repository.getId() );
  144. }
  145. cleanUp = new CleanupReleasedSnapshotsRepositoryPurge( repositoryContent, metadataTools, repositoryRegistry,
  146. repositorySession, listeners );
  147. }
  148. @Override
  149. public void beginScan( ManagedRepository repository, Date whenGathered, boolean executeOnEntireRepo )
  150. throws ConsumerException
  151. {
  152. beginScan( repository, whenGathered );
  153. }
  154. @Override
  155. public void processFile( String path )
  156. throws ConsumerException
  157. {
  158. try
  159. {
  160. if ( deleteReleasedSnapshots )
  161. {
  162. cleanUp.process( path );
  163. }
  164. repoPurge.process( path );
  165. }
  166. catch ( RepositoryPurgeException rpe )
  167. {
  168. throw new ConsumerException( rpe.getMessage( ), rpe );
  169. }
  170. }
  171. @Override
  172. public void processFile( String path, boolean executeOnEntireRepo )
  173. throws Exception
  174. {
  175. processFile( path );
  176. }
  177. @Override
  178. public void completeScan( )
  179. {
  180. repositorySession.close( );
  181. }
  182. @Override
  183. public void completeScan( boolean executeOnEntireRepo )
  184. {
  185. completeScan( );
  186. }
  187. @Override
  188. public void afterConfigurationChange( Registry registry, String propertyName, Object propertyValue )
  189. {
  190. if ( ConfigurationNames.isRepositoryScanning( propertyName ) )
  191. {
  192. initIncludes( );
  193. }
  194. }
  195. @Override
  196. public void beforeConfigurationChange( Registry registry, String propertyName, Object propertyValue )
  197. {
  198. /* do nothing */
  199. }
  200. private void initIncludes( )
  201. {
  202. includes = new ArrayList<>( filetypes.getFileTypePatterns( FileTypes.ARTIFACTS ) );
  203. }
  204. @PostConstruct
  205. public void initialize( )
  206. {
  207. configuration.addChangeListener( this );
  208. initIncludes( );
  209. }
  210. @Override
  211. public boolean isProcessUnmodified( )
  212. {
  213. // we need to check all files for deletion, especially if not modified
  214. return true;
  215. }
  216. public ArchivaConfiguration getConfiguration( )
  217. {
  218. return configuration;
  219. }
  220. public void setConfiguration( ArchivaConfiguration configuration )
  221. {
  222. this.configuration = configuration;
  223. }
  224. public RepositoryContentFactory getRepositoryContentFactory( )
  225. {
  226. return repositoryContentFactory;
  227. }
  228. public void setRepositoryContentFactory( RepositoryContentFactory repositoryContentFactory )
  229. {
  230. this.repositoryContentFactory = repositoryContentFactory;
  231. }
  232. public MetadataTools getMetadataTools( )
  233. {
  234. return metadataTools;
  235. }
  236. public void setMetadataTools( MetadataTools metadataTools )
  237. {
  238. this.metadataTools = metadataTools;
  239. }
  240. public FileTypes getFiletypes( )
  241. {
  242. return filetypes;
  243. }
  244. public void setFiletypes( FileTypes filetypes )
  245. {
  246. this.filetypes = filetypes;
  247. }
  248. public RepositoryPurge getRepoPurge( )
  249. {
  250. return repoPurge;
  251. }
  252. public void setRepoPurge( RepositoryPurge repoPurge )
  253. {
  254. this.repoPurge = repoPurge;
  255. }
  256. public RepositoryPurge getCleanUp( )
  257. {
  258. return cleanUp;
  259. }
  260. public void setCleanUp( RepositoryPurge cleanUp )
  261. {
  262. this.cleanUp = cleanUp;
  263. }
  264. public boolean isDeleteReleasedSnapshots( )
  265. {
  266. return deleteReleasedSnapshots;
  267. }
  268. public void setDeleteReleasedSnapshots( boolean deleteReleasedSnapshots )
  269. {
  270. this.deleteReleasedSnapshots = deleteReleasedSnapshots;
  271. }
  272. public RepositorySessionFactory getRepositorySessionFactory( )
  273. {
  274. return repositorySessionFactory;
  275. }
  276. public void setRepositorySessionFactory( RepositorySessionFactory repositorySessionFactory )
  277. {
  278. this.repositorySessionFactory = repositorySessionFactory;
  279. }
  280. }