123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151 |
- package org.apache.maven.archiva.web.action.admin.repositories;
-
- /*
- * 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 com.opensymphony.xwork2.Preparable;
- import com.opensymphony.xwork2.Validateable;
-
- import org.apache.maven.archiva.configuration.Configuration;
- import org.apache.maven.archiva.configuration.ManagedRepositoryConfiguration;
- import org.codehaus.plexus.redback.role.RoleManagerException;
- import org.codehaus.plexus.scheduler.CronExpressionValidator;
- import java.io.File;
- import java.io.IOException;
-
- /**
- * AddManagedRepositoryAction
- *
- * @author <a href="mailto:joakime@apache.org">Joakim Erdfelt</a>
- * @version $Id$
- *
- * @plexus.component role="com.opensymphony.xwork2.Action" role-hint="addManagedRepositoryAction"
- */
- public class AddManagedRepositoryAction
- extends AbstractManagedRepositoriesAction
- implements Preparable, Validateable
- {
- /**
- * The model for this action.
- */
- private ManagedRepositoryConfiguration repository;
-
- private String action = "addRepository";
-
- public void prepare()
- {
- this.repository = new ManagedRepositoryConfiguration();
- this.repository.setReleases( false );
- this.repository.setScanned( false );
- }
-
- public String input()
- {
- this.repository.setReleases( true );
- this.repository.setScanned( true );
-
- return INPUT;
- }
-
- public String confirmAdd()
- {
- return save();
- }
-
- public String commit()
- {
- File location = new File( repository.getLocation() );
- if( location.exists() )
- {
- return CONFIRM;
- }
-
- return save();
- }
-
- private String save()
- {
- Configuration configuration = archivaConfiguration.getConfiguration();
-
- String result;
- try
- {
- addRepository( repository, configuration );
- addRepositoryRoles( repository );
- result = saveConfiguration( configuration );
- }
- catch ( RoleManagerException e )
- {
- addActionError( "Role Manager Exception: " + e.getMessage() );
- result = INPUT;
- }
- catch ( IOException e )
- {
- addActionError( "Role Manager Exception: " + e.getMessage() );
- result = INPUT;
- }
-
- return result;
- }
-
- @Override
- public void validate()
- {
- Configuration config = archivaConfiguration.getConfiguration();
-
- CronExpressionValidator validator = new CronExpressionValidator();
- String repoId = repository.getId();
-
- if ( config.getManagedRepositoriesAsMap().containsKey( repoId ) )
- {
- addFieldError( "repository.id", "Unable to add new repository with id [" + repoId
- + "], that id already exists as a managed repository." );
- }
- else if ( config.getRemoteRepositoriesAsMap().containsKey( repoId ) )
- {
- addFieldError( "repository.id", "Unable to add new repository with id [" + repoId
- + "], that id already exists as a remote repository." );
- }
- else if( config.getRepositoryGroupsAsMap().containsKey( repoId ) )
- {
- addFieldError( "repository.id", "Unable to add new repository with id [" + repoId
- + "], that id already exists as a repository group." );
- }
-
- if ( !validator.validate( repository.getRefreshCronExpression() ) )
- {
- addFieldError( "repository.refreshCronExpression", "Invalid cron expression." );
- }
- }
-
- public ManagedRepositoryConfiguration getRepository()
- {
- return repository;
- }
-
- public void setRepository( ManagedRepositoryConfiguration repository )
- {
- this.repository = repository;
- }
-
- public String getAction()
- {
- return action;
- }
- }
|