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.

RepositoryProviderMock.java 13KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. package org.apache.archiva.repository.mock;
  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.ManagedRepositoryConfiguration;
  21. import org.apache.archiva.configuration.RemoteRepositoryConfiguration;
  22. import org.apache.archiva.configuration.RepositoryGroupConfiguration;
  23. import org.apache.archiva.event.EventHandler;
  24. import org.apache.archiva.repository.*;
  25. import org.apache.archiva.event.Event;
  26. import org.apache.archiva.repository.event.RepositoryEvent;
  27. import org.apache.archiva.repository.features.ArtifactCleanupFeature;
  28. import org.apache.archiva.repository.features.IndexCreationFeature;
  29. import org.apache.archiva.repository.features.RemoteIndexFeature;
  30. import org.apache.archiva.repository.features.StagingRepositoryFeature;
  31. import org.apache.archiva.repository.base.managed.BasicManagedRepository;
  32. import org.apache.archiva.repository.base.remote.BasicRemoteRepository;
  33. import org.apache.archiva.repository.base.PasswordCredentials;
  34. import org.springframework.stereotype.Service;
  35. import java.io.IOException;
  36. import java.net.URI;
  37. import java.nio.file.Paths;
  38. import java.time.Duration;
  39. import java.time.Period;
  40. import java.util.HashSet;
  41. import java.util.Set;
  42. /**
  43. * Just a simple mock class for the repository provider
  44. */
  45. @Service("mockRepositoryProvider")
  46. public class RepositoryProviderMock implements RepositoryProvider
  47. {
  48. private static final Set<RepositoryType> TYPES = new HashSet<>( );
  49. static
  50. {
  51. TYPES.add( RepositoryType.MAVEN );
  52. TYPES.add( RepositoryType.NPM );
  53. }
  54. @Override
  55. public Set<RepositoryType> provides( )
  56. {
  57. return TYPES;
  58. }
  59. @Override
  60. public EditableManagedRepository createManagedInstance( String id, String name ) throws IOException {
  61. return BasicManagedRepository.newFilesystemInstance(id, name, Paths.get("target/repositories").resolve(id));
  62. }
  63. @Override
  64. public EditableRemoteRepository createRemoteInstance( String id, String name )
  65. {
  66. try {
  67. return BasicRemoteRepository.newFilesystemInstance( id, name , Paths.get("target/remotes"));
  68. } catch (IOException e) {
  69. throw new RuntimeException(e);
  70. }
  71. }
  72. @Override
  73. public EditableRepositoryGroup createRepositoryGroup(String id, String name) {
  74. return null;
  75. }
  76. @Override
  77. public ManagedRepository createManagedInstance( ManagedRepositoryConfiguration configuration ) throws RepositoryException {
  78. BasicManagedRepository managedRepository = null;
  79. try {
  80. managedRepository = BasicManagedRepository.newFilesystemInstance(configuration.getId(), configuration.getName(), Paths.get("target/repositories").resolve(configuration.getId()));
  81. } catch (IOException e) {
  82. throw new RepositoryException(e);
  83. }
  84. updateManagedInstance( managedRepository, configuration );
  85. return managedRepository;
  86. }
  87. @Override
  88. public void updateManagedInstance( EditableManagedRepository managedRepository, ManagedRepositoryConfiguration configuration ) throws RepositoryException
  89. {
  90. try
  91. {
  92. managedRepository.setName( managedRepository.getPrimaryLocale(), configuration.getName( ) );
  93. managedRepository.setLocation( new URI( configuration.getLocation( )==null ?"" : configuration.getLocation() ) );
  94. managedRepository.setBaseUri( new URI( "" ) );
  95. managedRepository.setBlocksRedeployment( configuration.isBlockRedeployments( ) );
  96. managedRepository.setDescription( managedRepository.getPrimaryLocale(), configuration.getDescription( ) );
  97. managedRepository.setLayout( configuration.getLayout( ) );
  98. managedRepository.setScanned( configuration.isScanned( ) );
  99. managedRepository.setSchedulingDefinition( configuration.getRefreshCronExpression( ) );
  100. if (configuration.isReleases()) {
  101. managedRepository.addActiveReleaseScheme( ReleaseScheme.RELEASE );
  102. }
  103. if (configuration.isSnapshots()) {
  104. managedRepository.addActiveReleaseScheme( ReleaseScheme.SNAPSHOT );
  105. }
  106. ArtifactCleanupFeature acf = managedRepository.getFeature( ArtifactCleanupFeature.class ).get( );
  107. acf.setRetentionPeriod( Period.ofDays( configuration.getRetentionPeriod( ) ) );
  108. acf.setDeleteReleasedSnapshots( configuration.isDeleteReleasedSnapshots( ) );
  109. acf.setRetentionCount( configuration.getRetentionCount( ) );
  110. IndexCreationFeature icf = managedRepository.getFeature( IndexCreationFeature.class ).get( );
  111. icf.setIndexPath( new URI( configuration.getIndexDir( ) ) );
  112. icf.setSkipPackedIndexCreation( configuration.isSkipPackedIndexCreation( ) );
  113. StagingRepositoryFeature srf = managedRepository.getFeature( StagingRepositoryFeature.class ).get( );
  114. srf.setStageRepoNeeded( configuration.isStageRepoNeeded( ) );
  115. }
  116. catch ( Exception e )
  117. {
  118. throw new RepositoryException( "Error", e );
  119. }
  120. }
  121. @Override
  122. public ManagedRepository createStagingInstance( ManagedRepositoryConfiguration configuration ) throws RepositoryException {
  123. String id = configuration.getId( ) + StagingRepositoryFeature.STAGING_REPO_POSTFIX;
  124. BasicManagedRepository managedRepository = null;
  125. try {
  126. managedRepository = BasicManagedRepository.newFilesystemInstance(id, configuration.getName(), Paths.get("target/repositories").resolve(id));
  127. } catch (IOException e) {
  128. throw new RepositoryException(e);
  129. }
  130. updateManagedInstance( managedRepository, configuration );
  131. managedRepository.getFeature(StagingRepositoryFeature.class).get().setStageRepoNeeded(false);
  132. return managedRepository;
  133. }
  134. @Override
  135. public RemoteRepository createRemoteInstance( RemoteRepositoryConfiguration configuration ) throws RepositoryException
  136. {
  137. BasicRemoteRepository remoteRepository = null;
  138. try {
  139. remoteRepository = BasicRemoteRepository.newFilesystemInstance( configuration.getId( ), configuration.getName( ), Paths.get("target/remotes") );
  140. } catch (IOException e) {
  141. throw new RepositoryException(e);
  142. }
  143. updateRemoteInstance( remoteRepository, configuration );
  144. return remoteRepository;
  145. }
  146. @SuppressWarnings( "unchecked" )
  147. @Override
  148. public void updateRemoteInstance( EditableRemoteRepository remoteRepository, RemoteRepositoryConfiguration configuration ) throws RepositoryException
  149. {
  150. try
  151. {
  152. remoteRepository.setName( remoteRepository.getPrimaryLocale(), configuration.getName( ) );
  153. remoteRepository.setBaseUri( new URI( "" ) );
  154. remoteRepository.setDescription( remoteRepository.getPrimaryLocale(), configuration.getDescription( ) );
  155. remoteRepository.setLayout( configuration.getLayout( ) );
  156. remoteRepository.setSchedulingDefinition( configuration.getRefreshCronExpression( ) );
  157. remoteRepository.setCheckPath( configuration.getCheckPath( ) );
  158. remoteRepository.setExtraHeaders( configuration.getExtraHeaders( ) );
  159. remoteRepository.setExtraParameters( configuration.getExtraParameters( ) );
  160. remoteRepository.setTimeout( Duration.ofSeconds( configuration.getTimeout( ) ) );
  161. char[] pwd = configuration.getPassword()==null ? "".toCharArray() : configuration.getPassword().toCharArray();
  162. remoteRepository.setCredentials( new PasswordCredentials( configuration.getUsername( ), pwd ) );
  163. remoteRepository.setLocation( new URI( configuration.getUrl( )==null ? "" : configuration.getUrl() ) );
  164. RemoteIndexFeature rif = remoteRepository.getFeature( RemoteIndexFeature.class ).get( );
  165. rif.setDownloadRemoteIndexOnStartup( configuration.isDownloadRemoteIndexOnStartup( ) );
  166. rif.setDownloadRemoteIndex( configuration.isDownloadRemoteIndex( ) );
  167. rif.setIndexUri( new URI( configuration.getIndexDir( ) ) );
  168. rif.setDownloadTimeout( Duration.ofSeconds( configuration.getRemoteDownloadTimeout( ) ) );
  169. rif.setProxyId( configuration.getRemoteDownloadNetworkProxyId( ) );
  170. }
  171. catch ( Exception e )
  172. {
  173. throw new RepositoryException( "Error", e );
  174. }
  175. }
  176. @Override
  177. public RepositoryGroup createRepositoryGroup(RepositoryGroupConfiguration configuration) throws RepositoryException {
  178. return null;
  179. }
  180. @Override
  181. public void updateRepositoryGroupInstance(EditableRepositoryGroup repositoryGroup, RepositoryGroupConfiguration configuration) throws RepositoryException {
  182. }
  183. @Override
  184. public ManagedRepositoryConfiguration getManagedConfiguration( ManagedRepository managedRepository ) throws RepositoryException
  185. {
  186. ManagedRepositoryConfiguration configuration = new ManagedRepositoryConfiguration( );
  187. configuration.setId( managedRepository.getId( ) );
  188. configuration.setName(managedRepository.getName());
  189. configuration.setLocation( managedRepository.getLocation( ) == null ? "" : managedRepository.getLocation().toString( ) );
  190. configuration.setBlockRedeployments( managedRepository.blocksRedeployments( ) );
  191. configuration.setDescription( managedRepository.getDescription( ) );
  192. configuration.setLayout( managedRepository.getLayout( ) );
  193. configuration.setScanned( managedRepository.isScanned( ) );
  194. configuration.setRefreshCronExpression( managedRepository.getSchedulingDefinition( ) );
  195. configuration.setReleases( managedRepository.getActiveReleaseSchemes().contains(ReleaseScheme.RELEASE) );
  196. configuration.setSnapshots( managedRepository.getActiveReleaseSchemes().contains(ReleaseScheme.SNAPSHOT) );
  197. ArtifactCleanupFeature acf = managedRepository.getFeature( ArtifactCleanupFeature.class ).get( );
  198. configuration.setRetentionPeriod( acf.getRetentionPeriod( ).getDays( ) );
  199. configuration.setDeleteReleasedSnapshots( acf.isDeleteReleasedSnapshots( ) );
  200. configuration.setRetentionCount( acf.getRetentionCount( ) );
  201. IndexCreationFeature icf = managedRepository.getFeature( IndexCreationFeature.class ).get( );
  202. configuration.setSkipPackedIndexCreation( icf.isSkipPackedIndexCreation( ) );
  203. configuration.setIndexDir( icf.getIndexPath( ) == null ? "" : icf.getIndexPath().toString( ) );
  204. StagingRepositoryFeature srf = managedRepository.getFeature( StagingRepositoryFeature.class ).get( );
  205. configuration.setStageRepoNeeded( srf.isStageRepoNeeded( ) );
  206. return configuration;
  207. }
  208. @Override
  209. public RepositoryGroupConfiguration getRepositoryGroupConfiguration(RepositoryGroup repositoryGroup) throws RepositoryException {
  210. return null;
  211. }
  212. @Override
  213. public void addRepositoryEventHandler( EventHandler<? super RepositoryEvent> eventHandler )
  214. {
  215. // do nothing
  216. }
  217. @Override
  218. public RemoteRepositoryConfiguration getRemoteConfiguration( RemoteRepository remoteRepository ) throws RepositoryException
  219. {
  220. RemoteRepositoryConfiguration configuration = new RemoteRepositoryConfiguration( );
  221. configuration.setId( remoteRepository.getId( ) );
  222. configuration.setName( remoteRepository.getName( ) );
  223. configuration.setDescription( remoteRepository.getDescription( ) );
  224. configuration.setLayout( remoteRepository.getLayout( ) );
  225. configuration.setRefreshCronExpression( remoteRepository.getSchedulingDefinition( ) );
  226. configuration.setCheckPath( remoteRepository.getCheckPath( ) );
  227. configuration.setExtraHeaders( remoteRepository.getExtraHeaders( ) );
  228. configuration.setExtraParameters( remoteRepository.getExtraParameters( ) );
  229. configuration.setTimeout( (int) remoteRepository.getTimeout( ).getSeconds( ) );
  230. RepositoryCredentials creds = remoteRepository.getLoginCredentials( );
  231. if (creds!=null)
  232. {
  233. PasswordCredentials pwdCreds = (PasswordCredentials) creds;
  234. configuration.setUsername( pwdCreds.getUsername( ) );
  235. configuration.setPassword( new String( pwdCreds.getPassword( ) ) );
  236. }
  237. configuration.setUrl( remoteRepository.getLocation( ) == null ? "" : remoteRepository.getLocation().toString( ) );
  238. RemoteIndexFeature rif = remoteRepository.getFeature( RemoteIndexFeature.class ).get( );
  239. configuration.setDownloadRemoteIndex( rif.isDownloadRemoteIndex( ) );
  240. configuration.setDownloadRemoteIndexOnStartup( rif.isDownloadRemoteIndexOnStartup( ) );
  241. configuration.setIndexDir( rif.getIndexUri( )==null ? "" : rif.getIndexUri().toString( ) );
  242. configuration.setRemoteDownloadNetworkProxyId( rif.getProxyId( ) );
  243. return configuration;
  244. }
  245. @Override
  246. public void handle(Event event) {
  247. }
  248. }