diff --git a/archiva-modules/archiva-web/archiva-security/src/main/java/org/apache/maven/archiva/security/SecurityStartup.java b/archiva-modules/archiva-web/archiva-security/src/main/java/org/apache/maven/archiva/security/SecurityStartup.java deleted file mode 100644 index 20d1b6fd4..000000000 --- a/archiva-modules/archiva-web/archiva-security/src/main/java/org/apache/maven/archiva/security/SecurityStartup.java +++ /dev/null @@ -1,206 +0,0 @@ -package org.apache.maven.archiva.security; - -/* - * 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 java.util.ArrayList; -import java.util.List; -import java.util.Map; -import java.util.Map.Entry; - -import org.apache.commons.collections.CollectionUtils; -import org.apache.maven.archiva.common.ArchivaException; -import org.apache.maven.archiva.configuration.ArchivaConfiguration; -import org.apache.maven.archiva.configuration.ConfigurationNames; -import org.apache.maven.archiva.configuration.ManagedRepositoryConfiguration; -import org.codehaus.plexus.redback.rbac.RBACManager; -import org.codehaus.plexus.redback.rbac.RbacManagerException; -import org.codehaus.plexus.redback.rbac.UserAssignment; -import org.codehaus.plexus.redback.system.check.EnvironmentCheck; -import org.codehaus.plexus.redback.users.UserManager; -import org.codehaus.plexus.registry.Registry; -import org.codehaus.plexus.registry.RegistryListener; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -/** - * SecurityStartup - * - * @version $Id$ - * @plexus.component role="org.apache.maven.archiva.security.SecurityStartup" - */ -public class SecurityStartup - implements RegistryListener -{ - private Logger log = LoggerFactory.getLogger( SecurityStartup.class ); - - /** - * @plexus.requirement - */ - private UserRepositories userRepos; - - /** - * @plexus.requirement role-hint="cached" - */ - private RBACManager rbacManager; - - /** - * @plexus.requirement role="org.codehaus.plexus.redback.system.check.EnvironmentCheck" - */ - private Map checkers; - - /** - * @plexus.requirement - */ - private ArchivaConfiguration archivaConfiguration; - - public void afterConfigurationChange( Registry registry, String propertyName, Object propertyValue ) - { - if ( ConfigurationNames.isManagedRepositories( propertyName ) ) - { - createMissingManagedRepositoryRoles( archivaConfiguration.getConfiguration().getManagedRepositories() ); - } - } - - public void assignRepositoryObserverToGuestUser( List repos ) - { - for ( ManagedRepositoryConfiguration repoConfig : repos ) - { - String repoId = repoConfig.getId(); - - String principal = UserManager.GUEST_USERNAME; - - try - { - UserAssignment ua; - - if ( rbacManager.userAssignmentExists( principal ) ) - { - ua = rbacManager.getUserAssignment( principal ); - } - else - { - ua = rbacManager.createUserAssignment( principal ); - } - - ua.addRoleName( ArchivaRoleConstants.toRepositoryObserverRoleName( repoId ) ); - rbacManager.saveUserAssignment( ua ); - } - catch ( RbacManagerException e ) - { - log.warn( - "Unable to add role [" + ArchivaRoleConstants.toRepositoryObserverRoleName( repoId ) + "] to " + - principal + " user.", e ); - } - } - } - - public void beforeConfigurationChange( Registry registry, String propertyName, Object propertyValue ) - { - /* do nothing */ - } - - public void createMissingManagedRepositoryRoles( List repos ) - { - // NOTE: Remote Repositories do not have roles or security placed around them. - - for ( ManagedRepositoryConfiguration repoConfig : repos ) - { - // manage roles for repositories - try - { - userRepos.createMissingRepositoryRoles( repoConfig.getId() ); - } - catch ( ArchivaSecurityException e ) - { - log.warn( e.getMessage(), e ); - } - } - } - - public void createMissingRepositoryRoles( List repoIds ) - { - for ( String repoId : repoIds ) - { - // manage roles for repositories - try - { - userRepos.createMissingRepositoryRoles( repoId ); - } - catch ( ArchivaSecurityException e ) - { - log.warn( e.getMessage(), e ); - } - } - } - - public void executeEnvironmentChecks() - throws ArchivaException - { - if ( ( checkers == null ) || CollectionUtils.isEmpty( checkers.values() ) ) - { - throw new ArchivaException( - "Unable to initialize the Redback Security Environment, " + "no Environment Check components found." ); - } - - List violations = new ArrayList(); - - for ( Entry entry : checkers.entrySet() ) - { - EnvironmentCheck check = entry.getValue(); - log.info( "Running Environment Check: " + entry.getKey() ); - check.validateEnvironment( violations ); - } - - if ( CollectionUtils.isNotEmpty( violations ) ) - { - StringBuffer msg = new StringBuffer(); - msg.append( "EnvironmentCheck Failure.\n" ); - msg.append( "======================================================================\n" ); - msg.append( " ENVIRONMENT FAILURE !! \n" ); - msg.append( "\n" ); - - for ( String violation : violations ) - { - msg.append( violation ).append( "\n" ); - } - - msg.append( "\n" ); - msg.append( "======================================================================" ); - log.error( msg.toString() ); - - throw new ArchivaException( "Unable to initialize Redback Security Environment, [" + violations.size() + - "] violation(s) encountered, See log for details." ); - } - } - - public void startup() - throws ArchivaException - { - executeEnvironmentChecks(); - - createMissingManagedRepositoryRoles( archivaConfiguration.getConfiguration().getManagedRepositories() ); - archivaConfiguration.addChangeListener( this ); - - if ( archivaConfiguration.isDefaulted() ) - { - assignRepositoryObserverToGuestUser( archivaConfiguration.getConfiguration().getManagedRepositories() ); - } - } -} diff --git a/archiva-modules/archiva-web/archiva-security/src/test/java/org/apache/maven/archiva/security/SecurityStartupTest.java b/archiva-modules/archiva-web/archiva-security/src/test/java/org/apache/maven/archiva/security/SecurityStartupTest.java deleted file mode 100644 index 1684cb2a7..000000000 --- a/archiva-modules/archiva-web/archiva-security/src/test/java/org/apache/maven/archiva/security/SecurityStartupTest.java +++ /dev/null @@ -1,48 +0,0 @@ -package org.apache.maven.archiva.security; - -/* - * 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.codehaus.plexus.spring.PlexusInSpringTestCase; - -/** - * SecurityStartupTest - * - * @version $Id$ - */ -public class SecurityStartupTest - extends PlexusInSpringTestCase -{ - private SecurityStartup secStart; - - @Override - protected void setUp() - throws Exception - { - super.setUp(); - - secStart = (SecurityStartup) lookup( SecurityStartup.class ); - } - - public void testEnvironmentChecks() - throws Exception - { - secStart.executeEnvironmentChecks(); - } -}