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.

CleanupReleasedSnapshotsRepositoryPurge.java 9.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  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.admin.model.RepositoryAdminException;
  21. import org.apache.archiva.admin.model.beans.ManagedRepository;
  22. import org.apache.archiva.admin.model.managed.ManagedRepositoryAdmin;
  23. import org.apache.archiva.metadata.repository.MetadataRepository;
  24. import org.apache.archiva.metadata.repository.RepositorySession;
  25. import org.apache.archiva.repository.events.RepositoryListener;
  26. import org.apache.archiva.common.utils.VersionComparator;
  27. import org.apache.archiva.common.utils.VersionUtil;
  28. import org.apache.archiva.model.ArtifactReference;
  29. import org.apache.archiva.model.ProjectReference;
  30. import org.apache.archiva.model.VersionedReference;
  31. import org.apache.archiva.repository.ContentNotFoundException;
  32. import org.apache.archiva.repository.ManagedRepositoryContent;
  33. import org.apache.archiva.repository.RepositoryContentFactory;
  34. import org.apache.archiva.repository.RepositoryException;
  35. import org.apache.archiva.repository.RepositoryNotFoundException;
  36. import org.apache.archiva.repository.layout.LayoutException;
  37. import org.apache.archiva.repository.metadata.MetadataTools;
  38. import org.apache.archiva.repository.metadata.RepositoryMetadataException;
  39. import java.io.File;
  40. import java.io.IOException;
  41. import java.util.ArrayList;
  42. import java.util.Collections;
  43. import java.util.List;
  44. /**
  45. * <p>
  46. * This will look in a single managed repository, and purge any snapshots that are present
  47. * that have a corresponding released version on the same repository.
  48. * </p>
  49. * <p/>
  50. * <p>
  51. * So, if you have the following (presented in the m2/default layout form) ...
  52. * <pre>
  53. * /com/foo/foo-tool/1.0-SNAPSHOT/foo-tool-1.0-SNAPSHOT.jar
  54. * /com/foo/foo-tool/1.1-SNAPSHOT/foo-tool-1.1-SNAPSHOT.jar
  55. * /com/foo/foo-tool/1.2.1-SNAPSHOT/foo-tool-1.2.1-SNAPSHOT.jar
  56. * /com/foo/foo-tool/1.2.1/foo-tool-1.2.1.jar
  57. * /com/foo/foo-tool/2.0-SNAPSHOT/foo-tool-2.0-SNAPSHOT.jar
  58. * /com/foo/foo-tool/2.0/foo-tool-2.0.jar
  59. * /com/foo/foo-tool/2.1-SNAPSHOT/foo-tool-2.1-SNAPSHOT.jar
  60. * </pre>
  61. * then the current highest ranked released (non-snapshot) version is 2.0, which means
  62. * the snapshots from 1.0-SNAPSHOT, 1.1-SNAPSHOT, 1.2.1-SNAPSHOT, and 2.0-SNAPSHOT can
  63. * be purged. Leaving 2.1-SNAPSHOT in alone.
  64. * </p>
  65. *
  66. *
  67. */
  68. public class CleanupReleasedSnapshotsRepositoryPurge
  69. extends AbstractRepositoryPurge
  70. {
  71. private MetadataTools metadataTools;
  72. private ManagedRepositoryAdmin managedRepositoryAdmin;
  73. private RepositoryContentFactory repoContentFactory;
  74. public CleanupReleasedSnapshotsRepositoryPurge( ManagedRepositoryContent repository, MetadataTools metadataTools,
  75. ManagedRepositoryAdmin managedRepositoryAdmin,
  76. RepositoryContentFactory repoContentFactory,
  77. RepositorySession repositorySession,
  78. List<RepositoryListener> listeners )
  79. {
  80. super( repository, repositorySession, listeners );
  81. this.metadataTools = metadataTools;
  82. this.managedRepositoryAdmin = managedRepositoryAdmin;
  83. this.repoContentFactory = repoContentFactory;
  84. }
  85. public void process( String path )
  86. throws RepositoryPurgeException
  87. {
  88. try
  89. {
  90. File artifactFile = new File( repository.getRepoRoot(), path );
  91. if ( !artifactFile.exists() )
  92. {
  93. // Nothing to do here, file doesn't exist, skip it.
  94. return;
  95. }
  96. ArtifactReference artifactRef = repository.toArtifactReference( path );
  97. if ( !VersionUtil.isSnapshot( artifactRef.getVersion() ) )
  98. {
  99. // Nothing to do here, not a snapshot, skip it.
  100. return;
  101. }
  102. ProjectReference reference = new ProjectReference();
  103. reference.setGroupId( artifactRef.getGroupId() );
  104. reference.setArtifactId( artifactRef.getArtifactId() );
  105. // Gether the released versions
  106. List<String> releasedVersions = new ArrayList<String>();
  107. List<ManagedRepository> repos = managedRepositoryAdmin.getManagedRepositories();
  108. for ( ManagedRepository repo : repos )
  109. {
  110. if ( repo.isReleases() )
  111. {
  112. try
  113. {
  114. ManagedRepositoryContent repoContent =
  115. repoContentFactory.getManagedRepositoryContent( repo.getId() );
  116. for ( String version : repoContent.getVersions( reference ) )
  117. {
  118. if ( !VersionUtil.isSnapshot( version ) )
  119. {
  120. releasedVersions.add( version );
  121. }
  122. }
  123. }
  124. catch ( RepositoryNotFoundException e )
  125. {
  126. // swallow
  127. }
  128. catch ( RepositoryException e )
  129. {
  130. // swallow
  131. }
  132. }
  133. }
  134. Collections.sort( releasedVersions, VersionComparator.getInstance() );
  135. // Now clean out any version that is earlier than the highest released version.
  136. boolean needsMetadataUpdate = false;
  137. VersionedReference versionRef = new VersionedReference();
  138. versionRef.setGroupId( artifactRef.getGroupId() );
  139. versionRef.setArtifactId( artifactRef.getArtifactId() );
  140. MetadataRepository metadataRepository = repositorySession.getRepository();
  141. if ( releasedVersions.contains( VersionUtil.getReleaseVersion( artifactRef.getVersion() ) ) )
  142. {
  143. versionRef.setVersion( artifactRef.getVersion() );
  144. repository.deleteVersion( versionRef );
  145. // FIXME: looks incomplete, might not delete related metadata?
  146. for ( RepositoryListener listener : listeners )
  147. {
  148. listener.deleteArtifact( metadataRepository, repository.getId(), artifactRef.getGroupId(),
  149. artifactRef.getArtifactId(), artifactRef.getVersion(),
  150. artifactFile.getName() );
  151. }
  152. needsMetadataUpdate = true;
  153. }
  154. if ( needsMetadataUpdate )
  155. {
  156. updateMetadata( artifactRef );
  157. }
  158. } catch ( RepositoryAdminException e )
  159. {
  160. throw new RepositoryPurgeException( e.getMessage(), e );
  161. }
  162. catch ( LayoutException e )
  163. {
  164. log.debug( "Not processing file that is not an artifact: {}", e.getMessage() );
  165. }
  166. catch ( ContentNotFoundException e )
  167. {
  168. throw new RepositoryPurgeException( e.getMessage(), e );
  169. }
  170. }
  171. private void updateMetadata( ArtifactReference artifact )
  172. {
  173. VersionedReference versionRef = new VersionedReference();
  174. versionRef.setGroupId( artifact.getGroupId() );
  175. versionRef.setArtifactId( artifact.getArtifactId() );
  176. versionRef.setVersion( artifact.getVersion() );
  177. ProjectReference projectRef = new ProjectReference();
  178. projectRef.setGroupId( artifact.getGroupId() );
  179. projectRef.setArtifactId( artifact.getArtifactId() );
  180. try
  181. {
  182. metadataTools.updateMetadata( repository, versionRef );
  183. }
  184. catch ( ContentNotFoundException e )
  185. {
  186. // Ignore. (Just means we have no snapshot versions left to reference).
  187. }
  188. catch ( RepositoryMetadataException e )
  189. {
  190. // Ignore.
  191. }
  192. catch ( IOException e )
  193. {
  194. // Ignore.
  195. }
  196. catch ( LayoutException e )
  197. {
  198. // Ignore.
  199. }
  200. try
  201. {
  202. metadataTools.updateMetadata( repository, projectRef );
  203. }
  204. catch ( ContentNotFoundException e )
  205. {
  206. // Ignore. (Just means we have no snapshot versions left to reference).
  207. }
  208. catch ( RepositoryMetadataException e )
  209. {
  210. // Ignore.
  211. }
  212. catch ( IOException e )
  213. {
  214. // Ignore.
  215. }
  216. catch ( LayoutException e )
  217. {
  218. // Ignore.
  219. }
  220. }
  221. }