mirror of https://github.com/apache/archiva.git
validate managedRepository before remowing it for update. In case of non valid cronExpression it was removed before the validation
git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1231900 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
3536e59d18
commit
f4c55ef0d4
|
@ -33,6 +33,9 @@ import java.util.Map;
|
||||||
*/
|
*/
|
||||||
public interface ManagedRepositoryAdmin
|
public interface ManagedRepositoryAdmin
|
||||||
{
|
{
|
||||||
|
|
||||||
|
String REPOSITORY_LOCATION_VALID_EXPRESSION = "^[-a-zA-Z0-9._/~:?!&=\\\\]+$";
|
||||||
|
|
||||||
List<ManagedRepository> getManagedRepositories()
|
List<ManagedRepository> getManagedRepositories()
|
||||||
throws RepositoryAdminException;
|
throws RepositoryAdminException;
|
||||||
|
|
||||||
|
|
|
@ -18,13 +18,16 @@ package org.apache.archiva.admin.repository;
|
||||||
* under the License.
|
* under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import org.apache.archiva.admin.model.beans.AbstractRepository;
|
|
||||||
import org.apache.archiva.admin.model.RepositoryAdminException;
|
import org.apache.archiva.admin.model.RepositoryAdminException;
|
||||||
import org.apache.commons.lang.StringUtils;
|
import org.apache.archiva.admin.model.beans.AbstractRepository;
|
||||||
import org.apache.commons.validator.GenericValidator;
|
import org.apache.archiva.admin.model.beans.ManagedRepository;
|
||||||
|
import org.apache.archiva.admin.model.managed.ManagedRepositoryAdmin;
|
||||||
import org.apache.archiva.configuration.ArchivaConfiguration;
|
import org.apache.archiva.configuration.ArchivaConfiguration;
|
||||||
import org.apache.archiva.configuration.Configuration;
|
import org.apache.archiva.configuration.Configuration;
|
||||||
|
import org.apache.commons.lang.StringUtils;
|
||||||
|
import org.apache.commons.validator.GenericValidator;
|
||||||
import org.codehaus.plexus.registry.Registry;
|
import org.codehaus.plexus.registry.Registry;
|
||||||
|
import org.codehaus.redback.components.scheduler.CronExpressionValidator;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
|
@ -110,7 +113,42 @@ public class RepositoryCommonValidator
|
||||||
+ "forward-slashes(/), open-parenthesis('('), close-parenthesis(')'), underscores(_), dots(.), and dashes(-)." );
|
+ "forward-slashes(/), open-parenthesis('('), close-parenthesis(')'), underscores(_), dots(.), and dashes(-)." );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* validate cronExpression and location format
|
||||||
|
*
|
||||||
|
* @param managedRepository
|
||||||
|
* @since 1.4-M2
|
||||||
|
*/
|
||||||
|
public void validateManagedRepository( ManagedRepository managedRepository )
|
||||||
|
throws RepositoryAdminException
|
||||||
|
{
|
||||||
|
String cronExpression = managedRepository.getCronExpression();
|
||||||
|
// FIXME : olamy can be empty to avoid scheduled scan ?
|
||||||
|
if ( StringUtils.isNotBlank( cronExpression ) )
|
||||||
|
{
|
||||||
|
CronExpressionValidator validator = new CronExpressionValidator();
|
||||||
|
|
||||||
|
if ( !validator.validate( cronExpression ) )
|
||||||
|
{
|
||||||
|
throw new RepositoryAdminException( "Invalid cron expression." );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw new RepositoryAdminException( "Cron expression cannot be empty." );
|
||||||
|
}
|
||||||
|
|
||||||
|
String repoLocation = removeExpressions( managedRepository.getLocation() );
|
||||||
|
|
||||||
|
if ( !GenericValidator.matchRegexp( repoLocation,
|
||||||
|
ManagedRepositoryAdmin.REPOSITORY_LOCATION_VALID_EXPRESSION ) )
|
||||||
|
{
|
||||||
|
throw new RepositoryAdminException(
|
||||||
|
"Invalid repository location. Directory must only contain alphanumeric characters, equals(=), question-marks(?), "
|
||||||
|
+ "exclamation-points(!), ampersands(&), forward-slashes(/), back-slashes(\\), underscores(_), dots(.), colons(:), tildes(~), and dashes(-)." );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -41,7 +41,6 @@ import org.apache.archiva.scheduler.repository.RepositoryTask;
|
||||||
import org.apache.archiva.security.common.ArchivaRoleConstants;
|
import org.apache.archiva.security.common.ArchivaRoleConstants;
|
||||||
import org.apache.commons.io.FileUtils;
|
import org.apache.commons.io.FileUtils;
|
||||||
import org.apache.commons.lang.StringUtils;
|
import org.apache.commons.lang.StringUtils;
|
||||||
import org.apache.commons.validator.GenericValidator;
|
|
||||||
import org.apache.maven.index.NexusIndexer;
|
import org.apache.maven.index.NexusIndexer;
|
||||||
import org.apache.maven.index.context.IndexCreator;
|
import org.apache.maven.index.context.IndexCreator;
|
||||||
import org.apache.maven.index.context.IndexingContext;
|
import org.apache.maven.index.context.IndexingContext;
|
||||||
|
@ -49,7 +48,6 @@ import org.apache.maven.index.context.UnsupportedExistingLuceneIndexException;
|
||||||
import org.codehaus.plexus.redback.role.RoleManager;
|
import org.codehaus.plexus.redback.role.RoleManager;
|
||||||
import org.codehaus.plexus.redback.role.RoleManagerException;
|
import org.codehaus.plexus.redback.role.RoleManagerException;
|
||||||
import org.codehaus.plexus.taskqueue.TaskQueueException;
|
import org.codehaus.plexus.taskqueue.TaskQueueException;
|
||||||
import org.codehaus.redback.components.scheduler.CronExpressionValidator;
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
@ -80,7 +78,6 @@ public class DefaultManagedRepositoryAdmin
|
||||||
implements ManagedRepositoryAdmin
|
implements ManagedRepositoryAdmin
|
||||||
{
|
{
|
||||||
|
|
||||||
public static final String REPOSITORY_LOCATION_VALID_EXPRESSION = "^[-a-zA-Z0-9._/~:?!&=\\\\]+$";
|
|
||||||
|
|
||||||
private Logger log = LoggerFactory.getLogger( getClass() );
|
private Logger log = LoggerFactory.getLogger( getClass() );
|
||||||
|
|
||||||
|
@ -215,6 +212,7 @@ public class DefaultManagedRepositoryAdmin
|
||||||
{
|
{
|
||||||
|
|
||||||
getRepositoryCommonValidator().basicValidation( managedRepository, false );
|
getRepositoryCommonValidator().basicValidation( managedRepository, false );
|
||||||
|
getRepositoryCommonValidator().validateManagedRepository( managedRepository );
|
||||||
triggerAuditEvent( managedRepository.getId(), null, AuditEvent.ADD_MANAGED_REPO, auditInformation );
|
triggerAuditEvent( managedRepository.getId(), null, AuditEvent.ADD_MANAGED_REPO, auditInformation );
|
||||||
Boolean res =
|
Boolean res =
|
||||||
addManagedRepository( managedRepository.getId(), managedRepository.getLayout(), managedRepository.getName(),
|
addManagedRepository( managedRepository.getId(), managedRepository.getLayout(), managedRepository.getName(),
|
||||||
|
@ -241,30 +239,6 @@ public class DefaultManagedRepositoryAdmin
|
||||||
throws RepositoryAdminException
|
throws RepositoryAdminException
|
||||||
{
|
{
|
||||||
|
|
||||||
// FIXME : olamy can be empty to avoid scheduled scan ?
|
|
||||||
if ( StringUtils.isNotBlank( cronExpression ) )
|
|
||||||
{
|
|
||||||
CronExpressionValidator validator = new CronExpressionValidator();
|
|
||||||
|
|
||||||
if ( !validator.validate( cronExpression ) )
|
|
||||||
{
|
|
||||||
throw new RepositoryAdminException( "Invalid cron expression." );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
throw new RepositoryAdminException( "Cron expression cannot be empty." );
|
|
||||||
}
|
|
||||||
|
|
||||||
String repoLocation = getRepositoryCommonValidator().removeExpressions( location );
|
|
||||||
|
|
||||||
if ( !GenericValidator.matchRegexp( repoLocation, REPOSITORY_LOCATION_VALID_EXPRESSION ) )
|
|
||||||
{
|
|
||||||
throw new RepositoryAdminException(
|
|
||||||
"Invalid repository location. Directory must only contain alphanumeric characters, equals(=), question-marks(?), "
|
|
||||||
+ "exclamation-points(!), ampersands(&), forward-slashes(/), back-slashes(\\), underscores(_), dots(.), colons(:), tildes(~), and dashes(-)." );
|
|
||||||
}
|
|
||||||
|
|
||||||
ManagedRepositoryConfiguration repository = new ManagedRepositoryConfiguration();
|
ManagedRepositoryConfiguration repository = new ManagedRepositoryConfiguration();
|
||||||
|
|
||||||
repository.setId( repoId );
|
repository.setId( repoId );
|
||||||
|
@ -272,7 +246,7 @@ public class DefaultManagedRepositoryAdmin
|
||||||
repository.setReleases( releasesIncluded );
|
repository.setReleases( releasesIncluded );
|
||||||
repository.setSnapshots( snapshotsIncluded );
|
repository.setSnapshots( snapshotsIncluded );
|
||||||
repository.setName( name );
|
repository.setName( name );
|
||||||
repository.setLocation( repoLocation );
|
repository.setLocation( getRepositoryCommonValidator().removeExpressions( location ) );
|
||||||
repository.setLayout( layout );
|
repository.setLayout( layout );
|
||||||
repository.setRefreshCronExpression( cronExpression );
|
repository.setRefreshCronExpression( cronExpression );
|
||||||
repository.setIndexDir( indexDir );
|
repository.setIndexDir( indexDir );
|
||||||
|
@ -482,6 +456,8 @@ public class DefaultManagedRepositoryAdmin
|
||||||
|
|
||||||
getRepositoryCommonValidator().basicValidation( managedRepository, true );
|
getRepositoryCommonValidator().basicValidation( managedRepository, true );
|
||||||
|
|
||||||
|
getRepositoryCommonValidator().validateManagedRepository( managedRepository );
|
||||||
|
|
||||||
Configuration configuration = getArchivaConfiguration().getConfiguration();
|
Configuration configuration = getArchivaConfiguration().getConfiguration();
|
||||||
|
|
||||||
ManagedRepositoryConfiguration toremove = configuration.findManagedRepositoryById( managedRepository.getId() );
|
ManagedRepositoryConfiguration toremove = configuration.findManagedRepositoryById( managedRepository.getId() );
|
||||||
|
|
Loading…
Reference in New Issue