mirror of https://github.com/apache/archiva.git
[MRM-1490] Expose Archiva services trough REST : search service more impl
git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1170261 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
cd57d56fe9
commit
3d29a9d3f4
|
@ -381,6 +381,18 @@ public class NexusRepositorySearch
|
|||
hit.setBundleExportService( artifactInfo.bundleExportService );
|
||||
hit.setBundleSymbolicName( artifactInfo.bundleSymbolicName );
|
||||
hit.setBundleVersion( artifactInfo.bundleVersion );
|
||||
hit.setBundleDescription( artifactInfo.bundleDescription );
|
||||
hit.setBundleDocUrl( artifactInfo.bundleDocUrl );
|
||||
|
||||
hit.setBundleRequireBundle( artifactInfo.bundleRequireBundle );
|
||||
hit.setBundleImportPackage( artifactInfo.bundleImportPackage );
|
||||
hit.setBundleLicense( artifactInfo.bundleLicense );
|
||||
hit.setBundleName( artifactInfo.bundleName );
|
||||
hit.setContext( artifactInfo.context );
|
||||
hit.setGoals( artifactInfo.goals );
|
||||
hit.setPrefix( artifactInfo.prefix );
|
||||
// sure ??
|
||||
hit.setUrl( artifactInfo.remoteUrl );
|
||||
}
|
||||
|
||||
results.addHit( id, hit );
|
||||
|
|
|
@ -41,41 +41,80 @@ public class SearchResultHit
|
|||
// Advanced hit, reference to artifactId.
|
||||
private String artifactId;
|
||||
|
||||
// TODO: remove/deprecate this field!
|
||||
private String version = "";
|
||||
|
||||
private String repositoryId = "";
|
||||
|
||||
private List<String> versions = new ArrayList<String>();
|
||||
|
||||
/**
|
||||
* Plugin goal prefix (only if packaging is "maven-plugin")
|
||||
*/
|
||||
public String prefix;
|
||||
|
||||
/**
|
||||
* Plugin goals (only if packaging is "maven-plugin")
|
||||
*/
|
||||
public List<String> goals;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Bundle-Version if available
|
||||
*
|
||||
* @since 1.4
|
||||
*/
|
||||
private String bundleVersion;
|
||||
public String bundleVersion;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Bundle-SymbolicName if available
|
||||
*
|
||||
* @since 1.4
|
||||
*/
|
||||
private String bundleSymbolicName;
|
||||
public String bundleSymbolicName;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Export-Package if available
|
||||
*
|
||||
* @since 1.4
|
||||
*/
|
||||
private String bundleExportPackage;
|
||||
public String bundleExportPackage;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Export-Service if available
|
||||
*
|
||||
* @since 1.4
|
||||
*/
|
||||
private String bundleExportService;
|
||||
public String bundleExportService;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Bundle-Description if available
|
||||
* @since 1.4
|
||||
*/
|
||||
public String bundleDescription;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Bundle-Name if available
|
||||
* @since 1.4
|
||||
*/
|
||||
public String bundleName;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Bundle-License if available
|
||||
* @since 1.4
|
||||
*/
|
||||
public String bundleLicense;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Bundle-DocURL if available
|
||||
* @since 1.4
|
||||
*/
|
||||
public String bundleDocUrl;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Import-Package if available
|
||||
* @since 1.4
|
||||
*/
|
||||
public String bundleImportPackage;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Require-Bundle if available
|
||||
* @since 1.4
|
||||
*/
|
||||
public String bundleRequireBundle;
|
||||
|
||||
|
||||
public String getContext()
|
||||
{
|
||||
|
@ -122,16 +161,6 @@ public class SearchResultHit
|
|||
this.groupId = groupId;
|
||||
}
|
||||
|
||||
public String getVersion()
|
||||
{
|
||||
return version;
|
||||
}
|
||||
|
||||
public void setVersion(String version)
|
||||
{
|
||||
this.version = version;
|
||||
}
|
||||
|
||||
public List<String> getVersions()
|
||||
{
|
||||
return versions;
|
||||
|
@ -197,6 +226,86 @@ public class SearchResultHit
|
|||
this.bundleExportService = bundleExportService;
|
||||
}
|
||||
|
||||
public String getPrefix()
|
||||
{
|
||||
return prefix;
|
||||
}
|
||||
|
||||
public void setPrefix( String prefix )
|
||||
{
|
||||
this.prefix = prefix;
|
||||
}
|
||||
|
||||
public List<String> getGoals()
|
||||
{
|
||||
return goals;
|
||||
}
|
||||
|
||||
public void setGoals( List<String> goals )
|
||||
{
|
||||
this.goals = goals;
|
||||
}
|
||||
|
||||
public String getBundleDescription()
|
||||
{
|
||||
return bundleDescription;
|
||||
}
|
||||
|
||||
public void setBundleDescription( String bundleDescription )
|
||||
{
|
||||
this.bundleDescription = bundleDescription;
|
||||
}
|
||||
|
||||
public String getBundleName()
|
||||
{
|
||||
return bundleName;
|
||||
}
|
||||
|
||||
public void setBundleName( String bundleName )
|
||||
{
|
||||
this.bundleName = bundleName;
|
||||
}
|
||||
|
||||
public String getBundleLicense()
|
||||
{
|
||||
return bundleLicense;
|
||||
}
|
||||
|
||||
public void setBundleLicense( String bundleLicense )
|
||||
{
|
||||
this.bundleLicense = bundleLicense;
|
||||
}
|
||||
|
||||
public String getBundleDocUrl()
|
||||
{
|
||||
return bundleDocUrl;
|
||||
}
|
||||
|
||||
public void setBundleDocUrl( String bundleDocUrl )
|
||||
{
|
||||
this.bundleDocUrl = bundleDocUrl;
|
||||
}
|
||||
|
||||
public String getBundleImportPackage()
|
||||
{
|
||||
return bundleImportPackage;
|
||||
}
|
||||
|
||||
public void setBundleImportPackage( String bundleImportPackage )
|
||||
{
|
||||
this.bundleImportPackage = bundleImportPackage;
|
||||
}
|
||||
|
||||
public String getBundleRequireBundle()
|
||||
{
|
||||
return bundleRequireBundle;
|
||||
}
|
||||
|
||||
public void setBundleRequireBundle( String bundleRequireBundle )
|
||||
{
|
||||
this.bundleRequireBundle = bundleRequireBundle;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString()
|
||||
{
|
||||
|
@ -206,13 +315,20 @@ public class SearchResultHit
|
|||
sb.append( ", url='" ).append( url ).append( '\'' );
|
||||
sb.append( ", groupId='" ).append( groupId ).append( '\'' );
|
||||
sb.append( ", artifactId='" ).append( artifactId ).append( '\'' );
|
||||
sb.append( ", version='" ).append( version ).append( '\'' );
|
||||
sb.append( ", repositoryId='" ).append( repositoryId ).append( '\'' );
|
||||
sb.append( ", versions=" ).append( versions );
|
||||
sb.append( ", prefix='" ).append( prefix ).append( '\'' );
|
||||
sb.append( ", goals=" ).append( goals );
|
||||
sb.append( ", bundleVersion='" ).append( bundleVersion ).append( '\'' );
|
||||
sb.append( ", bundleSymbolicName='" ).append( bundleSymbolicName ).append( '\'' );
|
||||
sb.append( ", bundleExportPackage='" ).append( bundleExportPackage ).append( '\'' );
|
||||
sb.append( ", bundleExportService='" ).append( bundleExportService ).append( '\'' );
|
||||
sb.append( ", bundleDescription='" ).append( bundleDescription ).append( '\'' );
|
||||
sb.append( ", bundleName='" ).append( bundleName ).append( '\'' );
|
||||
sb.append( ", bundleLicense='" ).append( bundleLicense ).append( '\'' );
|
||||
sb.append( ", bundleDocUrl='" ).append( bundleDocUrl ).append( '\'' );
|
||||
sb.append( ", bundleImportPackage='" ).append( bundleImportPackage ).append( '\'' );
|
||||
sb.append( ", bundleRequireBundle='" ).append( bundleRequireBundle ).append( '\'' );
|
||||
sb.append( '}' );
|
||||
return sb.toString();
|
||||
}
|
||||
|
|
|
@ -21,22 +21,37 @@ package org.apache.archiva.rest.api.model;
|
|||
|
||||
import javax.xml.bind.annotation.XmlRootElement;
|
||||
import java.io.Serializable;
|
||||
import java.util.List;
|
||||
|
||||
@XmlRootElement( name = "artifact" )
|
||||
public class Artifact
|
||||
implements Serializable
|
||||
{
|
||||
private String repositoryId;
|
||||
// The (optional) context for this result.
|
||||
private String context;
|
||||
|
||||
// Basic hit, direct to non-artifact resource.
|
||||
private String url;
|
||||
|
||||
// Advanced hit, reference to groupId.
|
||||
private String groupId;
|
||||
|
||||
// Advanced hit, reference to artifactId.
|
||||
private String artifactId;
|
||||
|
||||
private String repositoryId;
|
||||
|
||||
private String version;
|
||||
|
||||
private String type;
|
||||
/**
|
||||
* Plugin goal prefix (only if packaging is "maven-plugin")
|
||||
*/
|
||||
private String prefix;
|
||||
|
||||
private String url;
|
||||
/**
|
||||
* Plugin goals (only if packaging is "maven-plugin")
|
||||
*/
|
||||
private List<String> goals;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Bundle-Version if available
|
||||
|
@ -66,21 +81,54 @@ public class Artifact
|
|||
*/
|
||||
private String bundleExportService;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Bundle-Description if available
|
||||
*
|
||||
* @since 1.4
|
||||
*/
|
||||
private String bundleDescription;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Bundle-Name if available
|
||||
*
|
||||
* @since 1.4
|
||||
*/
|
||||
private String bundleName;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Bundle-License if available
|
||||
*
|
||||
* @since 1.4
|
||||
*/
|
||||
private String bundleLicense;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Bundle-DocURL if available
|
||||
*
|
||||
* @since 1.4
|
||||
*/
|
||||
private String bundleDocUrl;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Import-Package if available
|
||||
*
|
||||
* @since 1.4
|
||||
*/
|
||||
private String bundleImportPackage;
|
||||
|
||||
/**
|
||||
* contains osgi metadata Require-Bundle if available
|
||||
*
|
||||
* @since 1.4
|
||||
*/
|
||||
private String bundleRequireBundle;
|
||||
|
||||
|
||||
public Artifact()
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
public Artifact( String repositoryId, String groupId, String artifactId, String version, String type )
|
||||
{
|
||||
this.repositoryId = repositoryId;
|
||||
this.groupId = groupId;
|
||||
this.artifactId = artifactId;
|
||||
this.version = version;
|
||||
this.type = type;
|
||||
}
|
||||
|
||||
public String getGroupId()
|
||||
{
|
||||
return groupId;
|
||||
|
@ -96,11 +144,6 @@ public class Artifact
|
|||
return version;
|
||||
}
|
||||
|
||||
public String getType()
|
||||
{
|
||||
return type;
|
||||
}
|
||||
|
||||
public String getRepositoryId()
|
||||
{
|
||||
return repositoryId;
|
||||
|
@ -121,63 +164,149 @@ public class Artifact
|
|||
this.version = version;
|
||||
}
|
||||
|
||||
public void setType( String type )
|
||||
{
|
||||
this.type = type;
|
||||
}
|
||||
|
||||
public void setRepositoryId( String repositoryId )
|
||||
{
|
||||
this.repositoryId = repositoryId;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equals( Object o )
|
||||
public String getContext()
|
||||
{
|
||||
if ( this == o )
|
||||
{
|
||||
return true;
|
||||
}
|
||||
if ( o == null || getClass() != o.getClass() )
|
||||
{
|
||||
return false;
|
||||
return context;
|
||||
}
|
||||
|
||||
Artifact artifact = (Artifact) o;
|
||||
|
||||
if ( !artifactId.equals( artifact.artifactId ) )
|
||||
public void setContext( String context )
|
||||
{
|
||||
return false;
|
||||
}
|
||||
if ( !groupId.equals( artifact.groupId ) )
|
||||
{
|
||||
return false;
|
||||
}
|
||||
if ( !repositoryId.equals( artifact.repositoryId ) )
|
||||
{
|
||||
return false;
|
||||
}
|
||||
if ( type != null ? !type.equals( artifact.type ) : artifact.type != null )
|
||||
{
|
||||
return false;
|
||||
}
|
||||
if ( !version.equals( artifact.version ) )
|
||||
{
|
||||
return false;
|
||||
this.context = context;
|
||||
}
|
||||
|
||||
return true;
|
||||
public String getUrl()
|
||||
{
|
||||
return url;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashCode()
|
||||
public void setUrl( String url )
|
||||
{
|
||||
int result = repositoryId.hashCode();
|
||||
result = 31 * result + groupId.hashCode();
|
||||
result = 31 * result + artifactId.hashCode();
|
||||
result = 31 * result + version.hashCode();
|
||||
result = 31 * result + ( type != null ? type.hashCode() : 0 );
|
||||
return result;
|
||||
this.url = url;
|
||||
}
|
||||
|
||||
public String getPrefix()
|
||||
{
|
||||
return prefix;
|
||||
}
|
||||
|
||||
public void setPrefix( String prefix )
|
||||
{
|
||||
this.prefix = prefix;
|
||||
}
|
||||
|
||||
public List<String> getGoals()
|
||||
{
|
||||
return goals;
|
||||
}
|
||||
|
||||
public void setGoals( List<String> goals )
|
||||
{
|
||||
this.goals = goals;
|
||||
}
|
||||
|
||||
public String getBundleVersion()
|
||||
{
|
||||
return bundleVersion;
|
||||
}
|
||||
|
||||
public void setBundleVersion( String bundleVersion )
|
||||
{
|
||||
this.bundleVersion = bundleVersion;
|
||||
}
|
||||
|
||||
public String getBundleSymbolicName()
|
||||
{
|
||||
return bundleSymbolicName;
|
||||
}
|
||||
|
||||
public void setBundleSymbolicName( String bundleSymbolicName )
|
||||
{
|
||||
this.bundleSymbolicName = bundleSymbolicName;
|
||||
}
|
||||
|
||||
public String getBundleExportPackage()
|
||||
{
|
||||
return bundleExportPackage;
|
||||
}
|
||||
|
||||
public void setBundleExportPackage( String bundleExportPackage )
|
||||
{
|
||||
this.bundleExportPackage = bundleExportPackage;
|
||||
}
|
||||
|
||||
public String getBundleExportService()
|
||||
{
|
||||
return bundleExportService;
|
||||
}
|
||||
|
||||
public void setBundleExportService( String bundleExportService )
|
||||
{
|
||||
this.bundleExportService = bundleExportService;
|
||||
}
|
||||
|
||||
public String getBundleDescription()
|
||||
{
|
||||
return bundleDescription;
|
||||
}
|
||||
|
||||
public void setBundleDescription( String bundleDescription )
|
||||
{
|
||||
this.bundleDescription = bundleDescription;
|
||||
}
|
||||
|
||||
public String getBundleName()
|
||||
{
|
||||
return bundleName;
|
||||
}
|
||||
|
||||
public void setBundleName( String bundleName )
|
||||
{
|
||||
this.bundleName = bundleName;
|
||||
}
|
||||
|
||||
public String getBundleLicense()
|
||||
{
|
||||
return bundleLicense;
|
||||
}
|
||||
|
||||
public void setBundleLicense( String bundleLicense )
|
||||
{
|
||||
this.bundleLicense = bundleLicense;
|
||||
}
|
||||
|
||||
public String getBundleDocUrl()
|
||||
{
|
||||
return bundleDocUrl;
|
||||
}
|
||||
|
||||
public void setBundleDocUrl( String bundleDocUrl )
|
||||
{
|
||||
this.bundleDocUrl = bundleDocUrl;
|
||||
}
|
||||
|
||||
public String getBundleImportPackage()
|
||||
{
|
||||
return bundleImportPackage;
|
||||
}
|
||||
|
||||
public void setBundleImportPackage( String bundleImportPackage )
|
||||
{
|
||||
this.bundleImportPackage = bundleImportPackage;
|
||||
}
|
||||
|
||||
public String getBundleRequireBundle()
|
||||
{
|
||||
return bundleRequireBundle;
|
||||
}
|
||||
|
||||
public void setBundleRequireBundle( String bundleRequireBundle )
|
||||
{
|
||||
this.bundleRequireBundle = bundleRequireBundle;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -185,11 +314,24 @@ public class Artifact
|
|||
{
|
||||
final StringBuilder sb = new StringBuilder();
|
||||
sb.append( "Artifact" );
|
||||
sb.append( "{repositoryId='" ).append( repositoryId ).append( '\'' );
|
||||
sb.append( "{context='" ).append( context ).append( '\'' );
|
||||
sb.append( ", url='" ).append( url ).append( '\'' );
|
||||
sb.append( ", groupId='" ).append( groupId ).append( '\'' );
|
||||
sb.append( ", artifactId='" ).append( artifactId ).append( '\'' );
|
||||
sb.append( ", repositoryId='" ).append( repositoryId ).append( '\'' );
|
||||
sb.append( ", version='" ).append( version ).append( '\'' );
|
||||
sb.append( ", type='" ).append( type ).append( '\'' );
|
||||
sb.append( ", prefix='" ).append( prefix ).append( '\'' );
|
||||
sb.append( ", goals=" ).append( goals );
|
||||
sb.append( ", bundleVersion='" ).append( bundleVersion ).append( '\'' );
|
||||
sb.append( ", bundleSymbolicName='" ).append( bundleSymbolicName ).append( '\'' );
|
||||
sb.append( ", bundleExportPackage='" ).append( bundleExportPackage ).append( '\'' );
|
||||
sb.append( ", bundleExportService='" ).append( bundleExportService ).append( '\'' );
|
||||
sb.append( ", bundleDescription='" ).append( bundleDescription ).append( '\'' );
|
||||
sb.append( ", bundleName='" ).append( bundleName ).append( '\'' );
|
||||
sb.append( ", bundleLicense='" ).append( bundleLicense ).append( '\'' );
|
||||
sb.append( ", bundleDocUrl='" ).append( bundleDocUrl ).append( '\'' );
|
||||
sb.append( ", bundleImportPackage='" ).append( bundleImportPackage ).append( '\'' );
|
||||
sb.append( ", bundleRequireBundle='" ).append( bundleRequireBundle ).append( '\'' );
|
||||
sb.append( '}' );
|
||||
return sb.toString();
|
||||
}
|
||||
|
|
|
@ -60,7 +60,7 @@ public interface ManagedRepositoriesService
|
|||
@RedbackAuthorization( permission = ArchivaRoleConstants.OPERATION_MANAGE_CONFIGURATION )
|
||||
Boolean deleteManagedRepository( @QueryParam( "repositoryId" ) String repositoryId,
|
||||
@QueryParam( "deleteContent" ) boolean deleteContent )
|
||||
throws Exception;
|
||||
throws ArchivaRestServiceException;
|
||||
|
||||
|
||||
@Path( "addManagedRepository" )
|
||||
|
@ -69,7 +69,7 @@ public interface ManagedRepositoriesService
|
|||
@Produces( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML, MediaType.TEXT_PLAIN } )
|
||||
@RedbackAuthorization( permission = ArchivaRoleConstants.OPERATION_MANAGE_CONFIGURATION )
|
||||
Boolean addManagedRepository( ManagedRepository managedRepository )
|
||||
throws Exception;
|
||||
throws ArchivaRestServiceException;
|
||||
|
||||
|
||||
@Path( "updateManagedRepository" )
|
||||
|
@ -78,7 +78,7 @@ public interface ManagedRepositoriesService
|
|||
@Produces( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML, MediaType.TEXT_PLAIN } )
|
||||
@RedbackAuthorization( permission = ArchivaRoleConstants.OPERATION_MANAGE_CONFIGURATION )
|
||||
Boolean updateManagedRepository( ManagedRepository managedRepository )
|
||||
throws Exception;
|
||||
throws ArchivaRestServiceException;
|
||||
|
||||
|
||||
|
||||
|
|
|
@ -50,13 +50,6 @@ public interface SearchService
|
|||
List<Artifact> quickSearch( @QueryParam( "queryString" ) String queryString )
|
||||
throws ArchivaRestServiceException;
|
||||
|
||||
@Path( "getArtifactByChecksum" )
|
||||
@GET
|
||||
@Produces( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML, MediaType.TEXT_PLAIN } )
|
||||
@RedbackAuthorization( noPermission = true, noRestriction = true )
|
||||
List<Artifact> getArtifactByChecksum( @QueryParam( "checksum" ) String checksum )
|
||||
throws ArchivaRestServiceException;
|
||||
|
||||
@Path( "getArtifactVersions" )
|
||||
@GET
|
||||
@Produces( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML, MediaType.TEXT_PLAIN } )
|
||||
|
@ -74,4 +67,11 @@ public interface SearchService
|
|||
@QueryParam( "version" ) String version )
|
||||
throws ArchivaRestServiceException;
|
||||
|
||||
@Path( "getArtifactByChecksum" )
|
||||
@GET
|
||||
@Produces( { MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML, MediaType.TEXT_PLAIN } )
|
||||
@RedbackAuthorization( noPermission = true, noRestriction = true )
|
||||
List<Artifact> getArtifactByChecksum( @QueryParam( "checksum" ) String checksum )
|
||||
throws ArchivaRestServiceException;
|
||||
|
||||
}
|
||||
|
|
|
@ -23,6 +23,8 @@ import org.apache.archiva.audit.AuditListener;
|
|||
import org.codehaus.plexus.redback.users.User;
|
||||
import org.codehaus.redback.rest.services.RedbackAuthenticationThreadLocal;
|
||||
import org.codehaus.redback.rest.services.RedbackRequestInformation;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
import javax.inject.Inject;
|
||||
import java.util.ArrayList;
|
||||
|
@ -37,6 +39,8 @@ import java.util.List;
|
|||
public abstract class AbstractRestService
|
||||
{
|
||||
|
||||
protected Logger log = LoggerFactory.getLogger( getClass() );
|
||||
|
||||
@Inject
|
||||
private List<AuditListener> auditListeners = new ArrayList<AuditListener>();
|
||||
|
||||
|
|
|
@ -20,6 +20,7 @@ package org.apache.archiva.rest.services;
|
|||
|
||||
import org.apache.archiva.admin.model.RepositoryAdminException;
|
||||
import org.apache.archiva.admin.model.managed.ManagedRepositoryAdmin;
|
||||
import org.apache.archiva.common.plexusbridge.PlexusSisuBridge;
|
||||
import org.apache.archiva.rest.api.model.ManagedRepository;
|
||||
import org.apache.archiva.rest.api.services.ArchivaRestServiceException;
|
||||
import org.apache.archiva.rest.api.services.ManagedRepositoriesService;
|
||||
|
@ -43,6 +44,10 @@ public class DefaultManagedRepositoriesService
|
|||
@Inject
|
||||
private ManagedRepositoryAdmin managedRepositoryAdmin;
|
||||
|
||||
@Inject
|
||||
private PlexusSisuBridge plexusSisuBridge;
|
||||
|
||||
|
||||
public List<ManagedRepository> getManagedRepositories()
|
||||
throws ArchivaRestServiceException
|
||||
{
|
||||
|
@ -87,14 +92,22 @@ public class DefaultManagedRepositoriesService
|
|||
|
||||
|
||||
public Boolean deleteManagedRepository( String repoId, boolean deleteContent )
|
||||
throws Exception
|
||||
throws ArchivaRestServiceException
|
||||
{
|
||||
|
||||
try
|
||||
{
|
||||
return managedRepositoryAdmin.deleteManagedRepository( repoId, getAuditInformation(), deleteContent );
|
||||
}
|
||||
catch ( RepositoryAdminException e )
|
||||
{
|
||||
log.error( e.getMessage(), e );
|
||||
throw new ArchivaRestServiceException( e.getMessage() );
|
||||
}
|
||||
}
|
||||
|
||||
public Boolean addManagedRepository( ManagedRepository managedRepository )
|
||||
throws Exception
|
||||
throws ArchivaRestServiceException
|
||||
{
|
||||
org.apache.archiva.admin.model.managed.ManagedRepository repo =
|
||||
new org.apache.archiva.admin.model.managed.ManagedRepository();
|
||||
|
@ -106,13 +119,20 @@ public class DefaultManagedRepositoriesService
|
|||
repo.setName( managedRepository.getName() );
|
||||
repo.setReleases( managedRepository.isReleases() );
|
||||
repo.setSnapshots( managedRepository.isSnapshots() );
|
||||
try
|
||||
{
|
||||
return managedRepositoryAdmin.addManagedRepository( repo, managedRepository.isStageRepoNeeded(),
|
||||
getAuditInformation() );
|
||||
}
|
||||
catch ( RepositoryAdminException e )
|
||||
{
|
||||
throw new ArchivaRestServiceException( e.getMessage() );
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
public Boolean updateManagedRepository( ManagedRepository managedRepository )
|
||||
throws Exception
|
||||
throws ArchivaRestServiceException
|
||||
{
|
||||
org.apache.archiva.admin.model.managed.ManagedRepository repo =
|
||||
new org.apache.archiva.admin.model.managed.ManagedRepository();
|
||||
|
@ -124,9 +144,16 @@ public class DefaultManagedRepositoriesService
|
|||
repo.setName( managedRepository.getName() );
|
||||
repo.setReleases( managedRepository.isReleases() );
|
||||
repo.setSnapshots( managedRepository.isSnapshots() );
|
||||
try
|
||||
{
|
||||
return managedRepositoryAdmin.updateManagedRepository( repo, managedRepository.isStageRepoNeeded(),
|
||||
getAuditInformation(),
|
||||
managedRepository.isResetStats() );
|
||||
}
|
||||
catch ( RepositoryAdminException e )
|
||||
{
|
||||
throw new ArchivaRestServiceException( e.getMessage() );
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -126,6 +126,7 @@ public class DefaultRepositoriesService
|
|||
mavenIndexerUtils.getAllIndexCreators() ) );
|
||||
ArtifactIndexingTask task =
|
||||
new ArtifactIndexingTask( repository, null, ArtifactIndexingTask.Action.FINISH, context );
|
||||
|
||||
task.setExecuteOnEntireRepo( true );
|
||||
task.setOnlyUpdate( false );
|
||||
|
||||
|
@ -134,6 +135,7 @@ public class DefaultRepositoriesService
|
|||
}
|
||||
catch ( Exception e )
|
||||
{
|
||||
log.error( e.getMessage(), e );
|
||||
throw new ArchivaRestServiceException( e.getMessage() );
|
||||
}
|
||||
}
|
||||
|
|
|
@ -21,6 +21,7 @@ package org.apache.archiva.rest.services;
|
|||
import net.sf.beanlib.provider.replicator.BeanReplicator;
|
||||
import org.apache.archiva.indexer.search.RepositorySearch;
|
||||
import org.apache.archiva.indexer.search.RepositorySearchException;
|
||||
import org.apache.archiva.indexer.search.SearchFields;
|
||||
import org.apache.archiva.indexer.search.SearchResultHit;
|
||||
import org.apache.archiva.indexer.search.SearchResultLimits;
|
||||
import org.apache.archiva.indexer.search.SearchResults;
|
||||
|
@ -85,16 +86,30 @@ public class DefaultSearchService
|
|||
}
|
||||
}
|
||||
|
||||
public List<Artifact> getArtifactByChecksum( String checksum )
|
||||
throws ArchivaRestServiceException
|
||||
{
|
||||
return null; //To change body of implemented methods use File | Settings | File Templates.
|
||||
}
|
||||
|
||||
public List<Artifact> getArtifactVersions( String groupId, String artifactId )
|
||||
throws ArchivaRestServiceException
|
||||
{
|
||||
return null; //To change body of implemented methods use File | Settings | File Templates.
|
||||
if ( StringUtils.isBlank( groupId ) || StringUtils.isBlank( artifactId ) )
|
||||
{
|
||||
return Collections.emptyList();
|
||||
}
|
||||
SearchFields searchField = new SearchFields();
|
||||
searchField.setGroupId( groupId );
|
||||
searchField.setArtifactId( artifactId );
|
||||
SearchResultLimits limits = new SearchResultLimits( 0 );
|
||||
|
||||
try
|
||||
{
|
||||
SearchResults searchResults = repositorySearch.search( getPrincipal(), searchField, limits );
|
||||
return getArtifacts( searchResults );
|
||||
}
|
||||
catch ( RepositorySearchException e )
|
||||
{
|
||||
log.error( e.getMessage(), e );
|
||||
throw new ArchivaRestServiceException( e.getMessage() );
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
public List<Dependency> getDependencies( String groupId, String artifactId, String version )
|
||||
|
@ -103,6 +118,12 @@ public class DefaultSearchService
|
|||
return null; //To change body of implemented methods use File | Settings | File Templates.
|
||||
}
|
||||
|
||||
public List<Artifact> getArtifactByChecksum( String checksum )
|
||||
throws ArchivaRestServiceException
|
||||
{
|
||||
return null; //To change body of implemented methods use File | Settings | File Templates.
|
||||
}
|
||||
|
||||
|
||||
protected List<String> getObservableRepos()
|
||||
{
|
||||
|
@ -144,21 +165,48 @@ public class DefaultSearchService
|
|||
return Collections.emptyList();
|
||||
}
|
||||
List<Artifact> artifacts = new ArrayList<Artifact>( searchResults.getReturnedHitsCount() );
|
||||
for ( SearchResultHit searchResultHit : searchResults.getHits() )
|
||||
for ( SearchResultHit hit : searchResults.getHits() )
|
||||
{
|
||||
Artifact artifact = new BeanReplicator().replicateBean( searchResultHit, Artifact.class );
|
||||
artifacts.add( artifact );
|
||||
// duplicate Artifact one per available version
|
||||
if ( searchResultHit.getVersions().size() > 1 )
|
||||
if ( hit.getVersions().size() > 0 )
|
||||
{
|
||||
for ( String version : searchResultHit.getVersions() )
|
||||
for ( String version : hit.getVersions() )
|
||||
{
|
||||
/*
|
||||
Artifact versionned = new Artifact( );
|
||||
versionned.setArtifactId( hit.getArtifactId());
|
||||
versionned.setGroupId( hit.getGroupId() );
|
||||
versionned.setRepositoryId(hit.getRepositoryId() );
|
||||
|
||||
|
||||
versionned.setBundleExportPackage( hit.getBundleExportPackage() );
|
||||
versionned.setBundleExportService( hit.getBundleExportService());
|
||||
versionned.setBundleSymbolicName(hit.getBundleSymbolicName() );
|
||||
versionned.setBundleVersion( artifactInfo.bundleVersion );
|
||||
versionned.setBundleDescription( artifactInfo.bundleDescription );
|
||||
versionned.setBundleDocUrl( artifactInfo.bundleDocUrl );
|
||||
|
||||
versionned.setBundleRequireBundle( artifactInfo.bundleRequireBundle );
|
||||
versionned.setBundleImportPackage( artifactInfo.bundleImportPackage );
|
||||
versionned.setBundleLicense( artifactInfo.bundleLicense );
|
||||
versionned.setBundleName( artifactInfo.bundleName );
|
||||
versionned.setContext( artifactInfo.context );
|
||||
versionned.setGoals( artifactInfo.goals );
|
||||
versionned.setPrefix( artifactInfo.prefix );
|
||||
// sure ??
|
||||
versionned.setUrl( artifactInfo.remoteUrl );
|
||||
*/
|
||||
// FIXME archiva url ??
|
||||
|
||||
Artifact versionned = new BeanReplicator().replicateBean( hit, Artifact.class );
|
||||
if ( StringUtils.isNotBlank( version ) )
|
||||
{
|
||||
Artifact versionned = new BeanReplicator().replicateBean( searchResultHit, Artifact.class );
|
||||
versionned.setVersion( version );
|
||||
artifacts.add( versionned );
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return artifacts;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -34,6 +34,8 @@ import java.util.List;
|
|||
public class SearchServiceTest
|
||||
extends AbstractArchivaRestTest
|
||||
{
|
||||
|
||||
|
||||
@Test
|
||||
public void quickSearchOnArtifactId()
|
||||
throws Exception
|
||||
|
@ -46,28 +48,49 @@ public class SearchServiceTest
|
|||
assertNotNull( getUserService( authorizationHeader ).createGuestUser() );
|
||||
}
|
||||
|
||||
createAndIndexRepo( testRepoId );
|
||||
File targetRepo = createAndIndexRepo( testRepoId );
|
||||
|
||||
SearchService searchService = getSearchService( authorizationHeader );
|
||||
|
||||
List<Artifact> artifacts = searchService.quickSearch( "commons-logging" );
|
||||
|
||||
assertNotNull( artifacts );
|
||||
assertTrue( " empty results for commons-logging search", artifacts.size() > 0 );
|
||||
log.info( "artifacts for commons-logginf search {}", artifacts );
|
||||
assertTrue( " empty results for commons-logging search", artifacts.size() == 6 );
|
||||
log.info( "artifacts for commons-logging size {} search {}", artifacts.size(), artifacts );
|
||||
|
||||
deleteTestRepo( testRepoId );
|
||||
deleteTestRepo( testRepoId, targetRepo );
|
||||
}
|
||||
|
||||
private void createAndIndexRepo( String testRepoId )
|
||||
@Test
|
||||
public void searchArtifactVersions()
|
||||
throws Exception
|
||||
{
|
||||
|
||||
String testRepoId = "test-repo";
|
||||
// force guest user creation if not exists
|
||||
if ( getUserService( authorizationHeader ).getGuestUser() == null )
|
||||
{
|
||||
assertNotNull( getUserService( authorizationHeader ).createGuestUser() );
|
||||
}
|
||||
|
||||
File targetRepo = createAndIndexRepo( testRepoId );
|
||||
|
||||
SearchService searchService = getSearchService( authorizationHeader );
|
||||
|
||||
List<Artifact> artifacts = searchService.getArtifactVersions( "commons-logging", "commons-logging" );
|
||||
|
||||
assertNotNull( artifacts );
|
||||
assertTrue( " empty results for commons-logging search", artifacts.size() == 6 );
|
||||
log.info( "artifacts for commons-logging size {} search {}", artifacts.size(), artifacts );
|
||||
|
||||
deleteTestRepo( testRepoId, targetRepo );
|
||||
}
|
||||
|
||||
private File createAndIndexRepo( String testRepoId )
|
||||
throws Exception
|
||||
{
|
||||
File targetRepo = new File( System.getProperty( "targetDir", "./target" ), "test-repo" );
|
||||
|
||||
if ( targetRepo.exists() )
|
||||
{
|
||||
FileUtils.deleteDirectory( targetRepo );
|
||||
}
|
||||
cleanupFiles( targetRepo );
|
||||
|
||||
File sourceRepo = new File( "src/test/repo-with-osgi" );
|
||||
|
||||
|
@ -76,24 +99,54 @@ public class SearchServiceTest
|
|||
ManagedRepository managedRepository = new ManagedRepository();
|
||||
managedRepository.setId( testRepoId );
|
||||
managedRepository.setName( "test repo" );
|
||||
managedRepository.setCronExpression( "* * * * * ?" );
|
||||
managedRepository.setScanned( false );
|
||||
|
||||
managedRepository.setLocation( targetRepo.getPath() );
|
||||
|
||||
ManagedRepositoriesService service = getManagedRepositoriesService( authorizationHeader );
|
||||
service.addManagedRepository( managedRepository );
|
||||
|
||||
|
||||
getRepositoriesService( authorizationHeader ).scanRepositoryNow( testRepoId, true );
|
||||
|
||||
return targetRepo;
|
||||
}
|
||||
|
||||
private void deleteTestRepo( String id )
|
||||
private void deleteTestRepo( String id, File targetRepo )
|
||||
throws Exception
|
||||
{
|
||||
if ( getManagedRepositoriesService( authorizationHeader ).getManagedRepository( id ) != null )
|
||||
{
|
||||
getManagedRepositoriesService( authorizationHeader ).deleteManagedRepository( id, true );
|
||||
}
|
||||
cleanupFiles( targetRepo );
|
||||
|
||||
}
|
||||
|
||||
private void cleanupFiles(File targetRepo)
|
||||
throws Exception
|
||||
{
|
||||
|
||||
File indexerDir = new File( targetRepo, ".indexer" );
|
||||
|
||||
if ( targetRepo.exists() )
|
||||
{
|
||||
FileUtils.deleteDirectory( targetRepo );
|
||||
}
|
||||
|
||||
if ( indexerDir.exists() )
|
||||
{
|
||||
FileUtils.deleteDirectory( indexerDir );
|
||||
}
|
||||
|
||||
File lockFile = new File( indexerDir, "write.lock" );
|
||||
if ( lockFile.exists() )
|
||||
{
|
||||
FileUtils.forceDelete( lockFile );
|
||||
}
|
||||
|
||||
assertFalse( targetRepo.exists() );
|
||||
assertFalse( indexerDir.exists() );
|
||||
assertFalse( lockFile.exists() );
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -38,14 +38,14 @@
|
|||
|
||||
|
||||
<logger name="org.codehaus.redback.rest.services" >
|
||||
<level value="debug"/>
|
||||
<level value="ERROR"/>
|
||||
</logger>
|
||||
<logger name="JPOX">
|
||||
<level value="ERROR"/>
|
||||
</logger>
|
||||
|
||||
<logger name="org.springframework">
|
||||
<level value="info"/>
|
||||
<level value="ERROR"/>
|
||||
</logger>
|
||||
|
||||
<root>
|
||||
|
|
Loading…
Reference in New Issue