123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440 |
- package org.apache.archiva.rest.services;
- /*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- */
-
- import org.apache.archiva.admin.model.RepositoryAdminException;
- import org.apache.archiva.admin.model.admin.ArchivaAdministration;
- import org.apache.archiva.admin.model.beans.*;
- import org.apache.archiva.repository.scanner.RepositoryContentConsumers;
- import org.apache.archiva.rest.api.model.AdminRepositoryConsumer;
- import org.apache.archiva.rest.api.services.ArchivaAdministrationService;
- import org.apache.archiva.rest.api.services.ArchivaRestServiceException;
- import org.apache.archiva.rest.services.utils.AddAdminRepoConsumerClosure;
- import org.apache.archiva.rest.services.utils.AdminRepositoryConsumerComparator;
- import org.apache.commons.collections4.IterableUtils;
- import org.apache.commons.lang.StringUtils;
- import org.springframework.stereotype.Service;
-
- import javax.inject.Inject;
- import java.util.ArrayList;
- import java.util.Collections;
- import java.util.List;
-
- /**
- * @author Olivier Lamy
- * @since 1.4-M1
- */
- @Service ( "archivaAdministrationService#default" )
- public class DefaultArchivaAdministrationService
- extends AbstractRestService
- implements ArchivaAdministrationService
- {
- @Inject
- private ArchivaAdministration archivaAdministration;
-
-
- @Inject
- private RepositoryContentConsumers repoConsumerUtil;
-
- @Override
- public List<LegacyArtifactPath> getLegacyArtifactPaths()
- throws ArchivaRestServiceException
- {
- try
- {
- return archivaAdministration.getLegacyArtifactPaths();
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
-
- @Override
- public Boolean deleteLegacyArtifactPath( String path )
- throws ArchivaRestServiceException
- {
- try
- {
- archivaAdministration.deleteLegacyArtifactPath( path, getAuditInformation() );
- return Boolean.TRUE;
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
-
- @Override
- public Boolean addFileTypePattern( String fileTypeId, String pattern )
- throws ArchivaRestServiceException
- {
- try
- {
- archivaAdministration.addFileTypePattern( fileTypeId, pattern, getAuditInformation() );
- return Boolean.TRUE;
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public Boolean removeFileTypePattern( String fileTypeId, String pattern )
- throws ArchivaRestServiceException
- {
- try
- {
- archivaAdministration.removeFileTypePattern( fileTypeId, pattern, getAuditInformation() );
- return Boolean.TRUE;
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public FileType getFileType( String fileTypeId )
- throws ArchivaRestServiceException
- {
- try
- {
- return archivaAdministration.getFileType( fileTypeId );
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public void addFileType( FileType fileType )
- throws ArchivaRestServiceException
- {
- try
- {
- archivaAdministration.addFileType( fileType, getAuditInformation() );
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public Boolean removeFileType( String fileTypeId )
- throws ArchivaRestServiceException
- {
- try
- {
- archivaAdministration.removeFileType( fileTypeId, getAuditInformation() );
- return Boolean.TRUE;
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public Boolean enabledKnownContentConsumer( String knownContentConsumer )
- throws ArchivaRestServiceException
- {
- try
- {
- archivaAdministration.addKnownContentConsumer( knownContentConsumer, getAuditInformation() );
- return Boolean.TRUE;
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public void enabledKnownContentConsumers( List<String> knownContentConsumers )
- throws ArchivaRestServiceException
- {
- try
- {
- archivaAdministration.setKnownContentConsumers( knownContentConsumers, getAuditInformation() );
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public Boolean disabledKnownContentConsumer( String knownContentConsumer )
- throws ArchivaRestServiceException
- {
- try
- {
- archivaAdministration.removeKnownContentConsumer( knownContentConsumer, getAuditInformation() );
- return Boolean.TRUE;
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public Boolean enabledInvalidContentConsumer( String invalidContentConsumer )
- throws ArchivaRestServiceException
- {
- try
- {
- archivaAdministration.addInvalidContentConsumer( invalidContentConsumer, getAuditInformation() );
- return Boolean.TRUE;
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public void enabledInvalidContentConsumers( List<String> invalidContentConsumers )
- throws ArchivaRestServiceException
- {
- try
- {
- archivaAdministration.setInvalidContentConsumers( invalidContentConsumers, getAuditInformation() );
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public Boolean disabledInvalidContentConsumer( String invalidContentConsumer )
- throws ArchivaRestServiceException
- {
- try
- {
- archivaAdministration.removeInvalidContentConsumer( invalidContentConsumer, getAuditInformation() );
- return Boolean.TRUE;
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public List<FileType> getFileTypes()
- throws ArchivaRestServiceException
- {
- try
- {
- List<FileType> modelfileTypes = archivaAdministration.getFileTypes();
- if ( modelfileTypes == null || modelfileTypes.isEmpty() )
- {
- return Collections.emptyList();
- }
- return modelfileTypes;
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public List<String> getKnownContentConsumers()
- throws ArchivaRestServiceException
- {
- try
- {
- return new ArrayList<>( archivaAdministration.getKnownContentConsumers( ) );
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public List<String> getInvalidContentConsumers()
- throws ArchivaRestServiceException
- {
- try
- {
- return new ArrayList<>( archivaAdministration.getInvalidContentConsumers( ) );
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public OrganisationInformation getOrganisationInformation()
- throws ArchivaRestServiceException
- {
- try
- {
- return archivaAdministration.getOrganisationInformation();
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public void setOrganisationInformation( OrganisationInformation organisationInformation )
- throws ArchivaRestServiceException
- {
- try
- {
- archivaAdministration.setOrganisationInformation( organisationInformation );
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), 400, e );
- }
- }
-
- @Override
- public Boolean registrationDisabled()
- throws ArchivaRestServiceException
- {
- return getUiConfiguration().isDisableRegistration();
- }
-
- @Override
- public UiConfiguration getUiConfiguration()
- throws ArchivaRestServiceException
- {
- try
- {
- return archivaAdministration.getUiConfiguration();
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public void setUiConfiguration( UiConfiguration uiConfiguration )
- throws ArchivaRestServiceException
- {
- try
- {
- // fix for MRM-1757
- // strip any trailing '/' at the end of the url so it won't affect url/link calculations in UI
- uiConfiguration.setApplicationUrl(StringUtils.stripEnd(uiConfiguration.getApplicationUrl(), "/"));
-
- archivaAdministration.updateUiConfiguration( uiConfiguration );
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public String getApplicationUrl()
- throws ArchivaRestServiceException
- {
- try
- {
- return archivaAdministration.getUiConfiguration().getApplicationUrl();
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public NetworkConfiguration getNetworkConfiguration()
- throws ArchivaRestServiceException
- {
- try
- {
- return archivaAdministration.getNetworkConfiguration();
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public void setNetworkConfiguration( NetworkConfiguration networkConfiguration )
- throws ArchivaRestServiceException
- {
- try
- {
- archivaAdministration.setNetworkConfiguration( networkConfiguration );
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public List<AdminRepositoryConsumer> getKnownContentAdminRepositoryConsumers()
- throws ArchivaRestServiceException
- {
- try
- {
- AddAdminRepoConsumerClosure addAdminRepoConsumer =
- new AddAdminRepoConsumerClosure( archivaAdministration.getKnownContentConsumers() );
- IterableUtils.forEach( repoConsumerUtil.getAvailableKnownConsumers(), addAdminRepoConsumer );
- List<AdminRepositoryConsumer> knownContentConsumers = addAdminRepoConsumer.getList();
- knownContentConsumers.sort( AdminRepositoryConsumerComparator.getInstance( ) );
- return knownContentConsumers;
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
-
- @Override
- public List<AdminRepositoryConsumer> getInvalidContentAdminRepositoryConsumers()
- throws ArchivaRestServiceException
- {
- try
- {
- AddAdminRepoConsumerClosure addAdminRepoConsumer =
- new AddAdminRepoConsumerClosure( archivaAdministration.getInvalidContentConsumers() );
- IterableUtils.forEach( repoConsumerUtil.getAvailableInvalidConsumers(), addAdminRepoConsumer );
- List<AdminRepositoryConsumer> invalidContentConsumers = addAdminRepoConsumer.getList();
- invalidContentConsumers.sort( AdminRepositoryConsumerComparator.getInstance( ) );
- return invalidContentConsumers;
- }
- catch ( RepositoryAdminException e )
- {
- throw new ArchivaRestServiceException( e.getMessage(), e );
- }
- }
- }
|