aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorOlivier Lamy <olamy@apache.org>2014-03-20 23:23:56 +0000
committerOlivier Lamy <olamy@apache.org>2014-03-20 23:23:56 +0000
commite0167478883a10e25545e5996d78c688c659f184 (patch)
tree580c2e0422b0ae9d9b53f9f60adfde79a590d3fb
parentc3bb4dc7143de41ea8e81b37d2db92f27197dba8 (diff)
downloadarchiva-e0167478883a10e25545e5996d78c688c659f184.tar.gz
archiva-e0167478883a10e25545e5996d78c688c659f184.zip
more impl with Hector
git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1579829 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r--archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraArchivaManager.java4
-rw-r--r--archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraMetadataRepository.java449
-rw-r--r--archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/DefaultCassandraArchivaManager.java117
-rw-r--r--archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/model/ArtifactMetadataModel.java53
-rw-r--r--archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/model/ProjectVersionMetadataModel.java43
5 files changed, 428 insertions, 238 deletions
diff --git a/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraArchivaManager.java b/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraArchivaManager.java
index 38e7e2519..7ba76c422 100644
--- a/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraArchivaManager.java
+++ b/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraArchivaManager.java
@@ -44,4 +44,8 @@ public interface CassandraArchivaManager
String getProjectFamilyName();
+ String getProjectVersionMetadataModelFamilyName();
+
+ String getArtifactMetadataModelFamilyName();
+
}
diff --git a/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraMetadataRepository.java b/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraMetadataRepository.java
index 31751224c..8a7a9d621 100644
--- a/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraMetadataRepository.java
+++ b/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraMetadataRepository.java
@@ -20,6 +20,9 @@ package org.apache.archiva.metadata.repository.cassandra;
*/
import me.prettyprint.cassandra.serializers.StringSerializer;
+import me.prettyprint.cassandra.service.template.ColumnFamilyTemplate;
+import me.prettyprint.cassandra.service.template.ColumnFamilyUpdater;
+import me.prettyprint.cassandra.service.template.ThriftColumnFamilyTemplate;
import me.prettyprint.hector.api.Keyspace;
import me.prettyprint.hector.api.beans.ColumnSlice;
import me.prettyprint.hector.api.beans.OrderedRows;
@@ -42,6 +45,7 @@ import org.apache.archiva.metadata.repository.MetadataResolutionException;
import org.apache.archiva.metadata.repository.cassandra.model.ArtifactMetadataModel;
import org.apache.archiva.metadata.repository.cassandra.model.Namespace;
import org.apache.archiva.metadata.repository.cassandra.model.Project;
+import org.apache.archiva.metadata.repository.cassandra.model.ProjectVersionMetadataModel;
import org.apache.archiva.metadata.repository.cassandra.model.Repository;
import org.apache.commons.lang.StringUtils;
import org.modelmapper.ModelMapper;
@@ -72,7 +76,9 @@ public class CassandraMetadataRepository
private final Map<String, MetadataFacetFactory> metadataFacetFactories;
- private CassandraArchivaManager cassandraArchivaManager;
+ private final CassandraArchivaManager cassandraArchivaManager;
+
+ private final ColumnFamilyTemplate<String, String> projectVersionMetadataModelTemplate;
public CassandraMetadataRepository( Map<String, MetadataFacetFactory> metadataFacetFactories,
ArchivaConfiguration configuration,
@@ -81,6 +87,12 @@ public class CassandraMetadataRepository
this.metadataFacetFactories = metadataFacetFactories;
this.configuration = configuration;
this.cassandraArchivaManager = cassandraArchivaManager;
+
+ this.projectVersionMetadataModelTemplate =
+ new ThriftColumnFamilyTemplate<String, String>( cassandraArchivaManager.getKeyspace(), //
+ cassandraArchivaManager.getProjectVersionMetadataModelFamilyName(),
+ StringSerializer.get(), //
+ StringSerializer.get() );
}
@@ -650,48 +662,314 @@ public class CassandraMetadataRepository
public Collection<String> getProjectVersions( final String repoId, final String namespace, final String projectId )
throws MetadataResolutionException
{
- return null;
-/* final Set<String> versions = new HashSet<String>();
- getProjectVersionMetadataModelEntityManager().visitAll( new Function<ProjectVersionMetadataModel, Boolean>()
+
+ Keyspace keyspace = cassandraArchivaManager.getKeyspace();
+
+ QueryResult<OrderedRows<String, String, String>> result = HFactory //
+ .createRangeSlicesQuery( keyspace, //
+ StringSerializer.get(), //
+ StringSerializer.get(), //
+ StringSerializer.get() ) //
+ .setColumnFamily( cassandraArchivaManager.getProjectVersionMetadataModelFamilyName() ) //
+ .setColumnNames( "id" ) //
+ .addEqualsExpression( "repositoryName", repoId ) //
+ .addEqualsExpression( "namespaceId", namespace ) //
+ .addEqualsExpression( "projectId", projectId ) //
+ .execute();
+
+ int count = result.get().getCount();
+
+ if ( count < 1 )
+ {
+ return Collections.emptyList();
+ }
+
+ Set<String> versions = new HashSet<String>( count );
+
+ for ( Row<String, String, String> orderedRows : result.get() )
+ {
+ versions.add( orderedRows.getColumnSlice().getColumnByName( "id" ).getValue() );
+ }
+
+ return versions;
+
+ }
+
+ @Override
+ public ProjectMetadata getProject( final String repoId, final String namespace, final String id )
+ throws MetadataResolutionException
+ {
+
+ Keyspace keyspace = cassandraArchivaManager.getKeyspace();
+
+ QueryResult<OrderedRows<String, String, String>> result = HFactory //
+ .createRangeSlicesQuery( keyspace, //
+ StringSerializer.get(), //
+ StringSerializer.get(), //
+ StringSerializer.get() ) //
+ .setColumnFamily( cassandraArchivaManager.getProjectFamilyName() ) //
+ .setColumnNames( "projectId" ) //
+ .addEqualsExpression( "repositoryName", repoId ) //
+ .addEqualsExpression( "namespaceId", namespace ) //
+ .addEqualsExpression( "projectId", id ) //
+ .execute();
+
+ int count = result.get().getCount();
+
+ if ( count < 1 )
+ {
+ return null;
+ }
+
+ ProjectMetadata projectMetadata = new ProjectMetadata();
+ projectMetadata.setId( id );
+ projectMetadata.setNamespace( namespace );
+
+ logger.debug( "getProject repoId: {}, namespace: {}, projectId: {} -> {}", repoId, namespace, id,
+ projectMetadata );
+
+ return projectMetadata;
+
+
+/* //basically just checking it exists
+ // FIXME use cql query
+
+ final BooleanHolder booleanHolder = new BooleanHolder();
+
+ getProjectEntityManager().visitAll( new Function<Project, Boolean>()
{
@Override
- public Boolean apply( ProjectVersionMetadataModel projectVersionMetadataModel )
+ public Boolean apply( Project project )
{
- if ( projectVersionMetadataModel != null )
+ if ( project != null )
{
- if ( StringUtils.equals( repoId,
- projectVersionMetadataModel.getNamespace().getRepository().getName() )
- && StringUtils.startsWith( projectVersionMetadataModel.getNamespace().getName(), namespace )
- && StringUtils.equals( projectId, projectVersionMetadataModel.getProjectId() ) )
+ if ( StringUtils.equals( repoId, project.getNamespace().getRepository().getName() )
+ && StringUtils.equals( namespace, project.getNamespace().getName() ) && StringUtils.equals( id,
+ project.getProjectId() ) )
{
- versions.add( projectVersionMetadataModel.getId() );
+ booleanHolder.value = true;
}
}
return Boolean.TRUE;
}
} );
- // FIXME use cql query
- getArtifactMetadataModelEntityManager().visitAll( new Function<ArtifactMetadataModel, Boolean>()
+
+ if ( !booleanHolder.value )
{
- @Override
- public Boolean apply( ArtifactMetadataModel artifactMetadataModel )
+ return null;
+ }
+
+ ProjectMetadata projectMetadata = new ProjectMetadata();
+ projectMetadata.setId( id );
+ projectMetadata.setNamespace( namespace );
+
+ logger.debug( "getProject repoId: {}, namespace: {}, projectId: {} -> {}", repoId, namespace, id,
+ projectMetadata );
+
+ return projectMetadata;*/
+ }
+
+ protected ProjectVersionMetadataModel map( ColumnSlice<String, String> columnSlice )
+ {
+ ProjectVersionMetadataModel projectVersionMetadataModel = new ProjectVersionMetadataModel();
+ projectVersionMetadataModel.setId( columnSlice.getColumnByName( "id" ).getValue() );
+ projectVersionMetadataModel.setDescription( columnSlice.getColumnByName( "description" ).getValue() );
+ projectVersionMetadataModel.setName( columnSlice.getColumnByName( "name" ).getValue() );
+ projectVersionMetadataModel.setNamespace(
+ new Namespace( columnSlice.getColumnByName( "namespaceId" ).getValue(), //
+ new Repository( columnSlice.getColumnByName( "repositoryName" ).getValue() ) )
+ );
+ projectVersionMetadataModel.setIncomplete(
+ Boolean.parseBoolean( columnSlice.getColumnByName( "incomplete" ).getValue() ) );
+ projectVersionMetadataModel.setProjectId( columnSlice.getColumnByName( "projectId" ).getValue() );
+ projectVersionMetadataModel.setUrl( columnSlice.getColumnByName( "url" ).getValue() );
+ return projectVersionMetadataModel;
+ }
+
+ @Override
+ public void updateProjectVersion( String repositoryId, String namespaceId, String projectId,
+ ProjectVersionMetadata versionMetadata )
+ throws MetadataRepositoryException
+ {
+ try
+ {
+ Namespace namespace = getNamespace( repositoryId, namespaceId );
+
+ if ( namespace == null )
{
- if ( artifactMetadataModel != null )
- {
- if ( StringUtils.equals( repoId, artifactMetadataModel.getRepositoryId() ) && StringUtils.equals(
- namespace, artifactMetadataModel.getNamespace() ) && StringUtils.equals( projectId,
- artifactMetadataModel.getProject() ) )
- {
- versions.add( artifactMetadataModel.getProjectVersion() );
- }
- }
- return Boolean.TRUE;
+ namespace = updateOrAddNamespace( repositoryId, namespaceId );
}
- } );
- return versions;*/
+ if ( getProject( repositoryId, namespaceId, projectId ) == null )
+ {
+ ProjectMetadata projectMetadata = new ProjectMetadata();
+ projectMetadata.setNamespace( namespaceId );
+ projectMetadata.setId( projectId );
+ updateProject( repositoryId, projectMetadata );
+ }
+
+ }
+ catch ( MetadataResolutionException e )
+ {
+ throw new MetadataRepositoryException( e.getMessage(), e );
+ }
+
+ Keyspace keyspace = cassandraArchivaManager.getKeyspace();
+ QueryResult<OrderedRows<String, String, String>> result = HFactory //
+ .createRangeSlicesQuery( keyspace, //
+ StringSerializer.get(), //
+ StringSerializer.get(), //
+ StringSerializer.get() ) //
+ .setColumnFamily( cassandraArchivaManager.getProjectVersionMetadataModelFamilyName() ) //
+ .setColumnNames( "id" ) //
+ .addEqualsExpression( "repositoryName", repositoryId ) //
+ .addEqualsExpression( "namespaceId", namespaceId ) //
+ .addEqualsExpression( "projectId", projectId ) //
+ .addEqualsExpression( "id", versionMetadata.getId() ).execute();
+
+ ProjectVersionMetadataModel projectVersionMetadataModel = null;
+ boolean creation = true;
+ if ( result.get().getCount() > 0 )
+ {
+ projectVersionMetadataModel = map( result.get().getList().get( 0 ).getColumnSlice() );
+ creation = false;
+ }
+ else
+ {
+ projectVersionMetadataModel = getModelMapper().map( versionMetadata, ProjectVersionMetadataModel.class );
+ }
+
+ projectVersionMetadataModel.setProjectId( projectId );
+ projectVersionMetadataModel.setNamespace( new Namespace( namespaceId, new Repository( repositoryId ) ) );
+ projectVersionMetadataModel.setCiManagement( versionMetadata.getCiManagement() );
+ projectVersionMetadataModel.setIssueManagement( versionMetadata.getIssueManagement() );
+ projectVersionMetadataModel.setOrganization( versionMetadata.getOrganization() );
+ projectVersionMetadataModel.setScm( versionMetadata.getScm() );
+
+ projectVersionMetadataModel.setMailingLists( versionMetadata.getMailingLists() );
+ projectVersionMetadataModel.setDependencies( versionMetadata.getDependencies() );
+ projectVersionMetadataModel.setLicenses( versionMetadata.getLicenses() );
+
+ // we don't test of repository and namespace really exist !
+ String key = new ProjectVersionMetadataModel.KeyBuilder().withRepository( repositoryId ).withNamespace(
+ namespaceId ).withProjectId( projectId ).withId( versionMetadata.getId() ).build();
+
+ // FIXME nested objects to store!!!
+ if ( creation )
+ {
+ String cf = cassandraArchivaManager.getProjectFamilyName();
+ projectVersionMetadataModelTemplate.createMutator()
+ // values
+ .addInsertion( key, //
+ cf, //
+ CassandraUtils.column( "projectId", projectId ) ) //
+ .addInsertion( key, //
+ cf, //
+ CassandraUtils.column( "repositoryName", repositoryId ) ) //
+ .addInsertion( key, //
+ cf, //
+ CassandraUtils.column( "namespaceId", namespaceId ) )//
+ .addInsertion( key, //
+ cf, //
+ CassandraUtils.column( "id", versionMetadata.getVersion() ) ) //
+ .addInsertion( key, //
+ cf, //
+ CassandraUtils.column( "description", versionMetadata.getDescription() ) ) //
+ .addInsertion( key, //
+ cf, //
+ CassandraUtils.column( "name", versionMetadata.getName() ) ) //
+ .addInsertion( key, //
+ cf, //
+ CassandraUtils.column( "incomplete",
+ Boolean.toString( versionMetadata.isIncomplete() ) ) ) //
+ .addInsertion( key, //
+ cf, //
+ CassandraUtils.column( "url", versionMetadata.getUrl() ) ) //
+ .execute();
+ }
+ else
+ {
+ ColumnFamilyUpdater<String, String> updater = projectVersionMetadataModelTemplate.createUpdater( key );
+ updater.setString( "projectId", projectId );
+ updater.setString( "repositoryName", repositoryId );
+ updater.setString( "namespaceId", namespaceId );
+ updater.setString( "id", versionMetadata.getVersion() );
+ updater.setString( "description", versionMetadata.getDescription() );
+ updater.setString( "name", versionMetadata.getName() );
+ updater.setString( "incomplete", Boolean.toString( versionMetadata.isIncomplete() ) );
+ updater.setString( "url", versionMetadata.getUrl() );
+
+ projectVersionMetadataModelTemplate.update( updater );
+
+ }
+ // FIXME
+ //updateFacets( versionMetadata, artifactMetadataModel );
+
+/* String namespaceKey =
+ new Namespace.KeyBuilder().withRepositoryId( repositoryId ).withNamespace( namespaceId ).build();
+ Namespace namespace = getNamespaceEntityManager().get( namespaceKey );
+ if ( namespace == null )
+ {
+ namespace = updateOrAddNamespace( repositoryId, namespaceId );
+ }
+
+ String key = new Project.KeyBuilder().withNamespace( namespace ).withProjectId( projectId ).build();
+
+ Project project = getProjectEntityManager().get( key );
+ if ( project == null )
+ {
+ project = new Project( key, projectId, namespace );
+ getProjectEntityManager().put( project );
+ }
+
+ // we don't test of repository and namespace really exist !
+ key = new ProjectVersionMetadataModel.KeyBuilder().withRepository( repositoryId ).withNamespace(
+ namespaceId ).withProjectId( projectId ).withId( versionMetadata.getId() ).build();
+
+ ProjectVersionMetadataModel projectVersionMetadataModel =
+ getProjectVersionMetadataModelEntityManager().get( key );
+
+ if ( projectVersionMetadataModel == null )
+ {
+ projectVersionMetadataModel = getModelMapper().map( versionMetadata, ProjectVersionMetadataModel.class );
+ projectVersionMetadataModel.setRowId( key );
+ }
+ projectVersionMetadataModel.setProjectId( projectId );
+ projectVersionMetadataModel.setNamespace( new Namespace( namespaceId, new Repository( repositoryId ) ) );
+ projectVersionMetadataModel.setCiManagement( versionMetadata.getCiManagement() );
+ projectVersionMetadataModel.setIssueManagement( versionMetadata.getIssueManagement() );
+ projectVersionMetadataModel.setOrganization( versionMetadata.getOrganization() );
+ projectVersionMetadataModel.setScm( versionMetadata.getScm() );
+
+ projectVersionMetadataModel.setMailingLists( versionMetadata.getMailingLists() );
+ projectVersionMetadataModel.setDependencies( versionMetadata.getDependencies() );
+ projectVersionMetadataModel.setLicenses( versionMetadata.getLicenses() );
+
+ try
+ {
+ getProjectVersionMetadataModelEntityManager().put( projectVersionMetadataModel );
+
+ ArtifactMetadataModel artifactMetadataModel = new ArtifactMetadataModel();
+ artifactMetadataModel.setArtifactMetadataModelId(
+ new ArtifactMetadataModel.KeyBuilder().withId( versionMetadata.getId() ).withRepositoryId(
+ repositoryId ).withNamespace( namespaceId ).withProjectVersion(
+ versionMetadata.getVersion() ).withProject( projectId ).build()
+ );
+ artifactMetadataModel.setRepositoryId( repositoryId );
+ artifactMetadataModel.setNamespace( namespaceId );
+ artifactMetadataModel.setProject( projectId );
+ artifactMetadataModel.setProjectVersion( versionMetadata.getVersion() );
+ artifactMetadataModel.setVersion( versionMetadata.getVersion() );
+ // facets etc...
+ updateFacets( versionMetadata, artifactMetadataModel );
+ }
+ catch ( PersistenceException e )
+ {
+ throw new MetadataRepositoryException( e.getMessage(), e );
+ }*/
}
+
@Override
public void updateArtifact( String repositoryId, String namespaceId, String projectId, String projectVersion,
ArtifactMetadata artifactMeta )
@@ -868,80 +1146,6 @@ public class CassandraMetadataRepository
}*/
}
- @Override
- public void updateProjectVersion( String repositoryId, String namespaceId, String projectId,
- ProjectVersionMetadata versionMetadata )
- throws MetadataRepositoryException
- {
-/* String namespaceKey =
- new Namespace.KeyBuilder().withRepositoryId( repositoryId ).withNamespace( namespaceId ).build();
- Namespace namespace = getNamespaceEntityManager().get( namespaceKey );
- if ( namespace == null )
- {
- namespace = updateOrAddNamespace( repositoryId, namespaceId );
- }
-
- String key = new Project.KeyBuilder().withNamespace( namespace ).withProjectId( projectId ).build();
-
- Project project = getProjectEntityManager().get( key );
- if ( project == null )
- {
- project = new Project( key, projectId, namespace );
- getProjectEntityManager().put( project );
- }
-
- // we don't test of repository and namespace really exist !
- key = new ProjectVersionMetadataModel.KeyBuilder().withRepository( repositoryId ).withNamespace(
- namespaceId ).withProjectId( projectId ).withId( versionMetadata.getId() ).build();
-
- ProjectVersionMetadataModel projectVersionMetadataModel =
- getProjectVersionMetadataModelEntityManager().get( key );
-
- if ( projectVersionMetadataModel == null )
- {
- projectVersionMetadataModel = getModelMapper().map( versionMetadata, ProjectVersionMetadataModel.class );
- projectVersionMetadataModel.setRowId( key );
- }
- projectVersionMetadataModel.setProjectId( projectId );
- projectVersionMetadataModel.setNamespace( new Namespace( namespaceId, new Repository( repositoryId ) ) );
- projectVersionMetadataModel.setCiManagement( versionMetadata.getCiManagement() );
- projectVersionMetadataModel.setIssueManagement( versionMetadata.getIssueManagement() );
- projectVersionMetadataModel.setOrganization( versionMetadata.getOrganization() );
- projectVersionMetadataModel.setScm( versionMetadata.getScm() );
-
- projectVersionMetadataModel.setMailingLists( versionMetadata.getMailingLists() );
- projectVersionMetadataModel.setDependencies( versionMetadata.getDependencies() );
- projectVersionMetadataModel.setLicenses( versionMetadata.getLicenses() );
-
- try
- {
- getProjectVersionMetadataModelEntityManager().put( projectVersionMetadataModel );
-
- ArtifactMetadataModel artifactMetadataModel = new ArtifactMetadataModel();
- artifactMetadataModel.setArtifactMetadataModelId(
- new ArtifactMetadataModel.KeyBuilder().withId( versionMetadata.getId() ).withRepositoryId(
- repositoryId ).withNamespace( namespaceId ).withProjectVersion(
- versionMetadata.getVersion() ).withProject( projectId ).build()
- );
- artifactMetadataModel.setRepositoryId( repositoryId );
- artifactMetadataModel.setNamespace( namespaceId );
- artifactMetadataModel.setProject( projectId );
- artifactMetadataModel.setProjectVersion( versionMetadata.getVersion() );
- artifactMetadataModel.setVersion( versionMetadata.getVersion() );
- // facets etc...
- updateFacets( versionMetadata, artifactMetadataModel );
- }
- catch ( PersistenceException e )
- {
- throw new MetadataRepositoryException( e.getMessage(), e );
- }*/
- }
-
-
- private static class BooleanHolder
- {
- private boolean value = false;
- }
@Override
public List<String> getMetadataFacets( final String repositoryId, final String facetId )
@@ -1423,49 +1627,6 @@ public class CassandraMetadataRepository
return Collections.emptyList();
}
- @Override
- public ProjectMetadata getProject( final String repoId, final String namespace, final String id )
- throws MetadataResolutionException
- {
-
-/* //basically just checking it exists
- // FIXME use cql query
-
- final BooleanHolder booleanHolder = new BooleanHolder();
-
- getProjectEntityManager().visitAll( new Function<Project, Boolean>()
- {
- @Override
- public Boolean apply( Project project )
- {
- if ( project != null )
- {
- if ( StringUtils.equals( repoId, project.getNamespace().getRepository().getName() )
- && StringUtils.equals( namespace, project.getNamespace().getName() ) && StringUtils.equals( id,
- project.getProjectId() ) )
- {
- booleanHolder.value = true;
- }
- }
- return Boolean.TRUE;
- }
- } );
-
- if ( !booleanHolder.value )
- {
- return null;
- }
-
- ProjectMetadata projectMetadata = new ProjectMetadata();
- projectMetadata.setId( id );
- projectMetadata.setNamespace( namespace );
-
- logger.debug( "getProject repoId: {}, namespace: {}, projectId: {} -> {}", repoId, namespace, id,
- projectMetadata );
-
- return projectMetadata;*/
- return null;
- }
@Override
public ProjectVersionMetadata getProjectVersion( final String repoId, final String namespace,
diff --git a/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/DefaultCassandraArchivaManager.java b/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/DefaultCassandraArchivaManager.java
index 2a51a1e7b..6d3d0facc 100644
--- a/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/DefaultCassandraArchivaManager.java
+++ b/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/DefaultCassandraArchivaManager.java
@@ -75,6 +75,10 @@ public class DefaultCassandraArchivaManager
private String projectFamilyName = "project";
+ private String projectVersionMetadataModelFamilyName = "projectversionmetadatamodel";
+
+ private String artifactMetadataModelFamilyName = "artifactmetadatamodel";
+
@PostConstruct
public void initialize()
@@ -152,10 +156,9 @@ public class DefaultCassandraArchivaManager
// project table
{
- final ColumnFamilyDefinition project =
- HFactory.createColumnFamilyDefinition( keyspace.getKeyspaceName(), //
- getProjectFamilyName(), //
- ComparatorType.UTF8TYPE );
+ final ColumnFamilyDefinition project = HFactory.createColumnFamilyDefinition( keyspace.getKeyspaceName(), //
+ getProjectFamilyName(), //
+ ComparatorType.UTF8TYPE );
cfds.add( project );
// creating indexes for cql query
@@ -182,6 +185,102 @@ public class DefaultCassandraArchivaManager
project.addColumnDefinition( namespaceIdColumn );
}
+ //projectversionmetadatamodel
+ {
+
+ final ColumnFamilyDefinition projectVersionMetadataModel =
+ HFactory.createColumnFamilyDefinition( keyspace.getKeyspaceName(), //
+ getProjectVersionMetadataModelFamilyName(), //
+ ComparatorType.UTF8TYPE );
+ cfds.add( projectVersionMetadataModel );
+
+ // creating indexes for cql query
+
+ BasicColumnDefinition namespaceIdColumn = new BasicColumnDefinition();
+ namespaceIdColumn.setName( StringSerializer.get().toByteBuffer( "namespaceId" ) );
+ namespaceIdColumn.setIndexName( "namespaceId" );
+ namespaceIdColumn.setIndexType( ColumnIndexType.KEYS );
+ namespaceIdColumn.setValidationClass( ComparatorType.UTF8TYPE.getClassName() );
+ projectVersionMetadataModel.addColumnDefinition( namespaceIdColumn );
+
+ BasicColumnDefinition repositoryNameColumn = new BasicColumnDefinition();
+ repositoryNameColumn.setName( StringSerializer.get().toByteBuffer( "repositoryName" ) );
+ repositoryNameColumn.setIndexName( "repositoryName" );
+ repositoryNameColumn.setIndexType( ColumnIndexType.KEYS );
+ repositoryNameColumn.setValidationClass( ComparatorType.UTF8TYPE.getClassName() );
+ projectVersionMetadataModel.addColumnDefinition( repositoryNameColumn );
+
+ BasicColumnDefinition idColumn = new BasicColumnDefinition();
+ idColumn.setName( StringSerializer.get().toByteBuffer( "id" ) );
+ idColumn.setIndexName( "id" );
+ idColumn.setIndexType( ColumnIndexType.KEYS );
+ idColumn.setValidationClass( ComparatorType.UTF8TYPE.getClassName() );
+ projectVersionMetadataModel.addColumnDefinition( idColumn );
+
+ BasicColumnDefinition projectIdColumn = new BasicColumnDefinition();
+ projectIdColumn.setName( StringSerializer.get().toByteBuffer( "projectId" ) );
+ projectIdColumn.setIndexName( "projectId" );
+ projectIdColumn.setIndexType( ColumnIndexType.KEYS );
+ projectIdColumn.setValidationClass( ComparatorType.UTF8TYPE.getClassName() );
+ projectVersionMetadataModel.addColumnDefinition( projectIdColumn );
+
+ }
+
+ // artifactmetadatamodel table
+ {
+
+ final ColumnFamilyDefinition artifactMetadataModel =
+ HFactory.createColumnFamilyDefinition( keyspace.getKeyspaceName(), //
+ getArtifactMetadataModelFamilyName(), //
+ ComparatorType.UTF8TYPE );
+ cfds.add( artifactMetadataModel );
+
+ // creating indexes for cql query
+
+ BasicColumnDefinition idColumn = new BasicColumnDefinition();
+ idColumn.setName( StringSerializer.get().toByteBuffer( "id" ) );
+ idColumn.setIndexName( "id" );
+ idColumn.setIndexType( ColumnIndexType.KEYS );
+ idColumn.setValidationClass( ComparatorType.UTF8TYPE.getClassName() );
+ artifactMetadataModel.addColumnDefinition( idColumn );
+
+ BasicColumnDefinition repositoryNameColumn = new BasicColumnDefinition();
+ repositoryNameColumn.setName( StringSerializer.get().toByteBuffer( "repositoryName" ) );
+ repositoryNameColumn.setIndexName( "repositoryName" );
+ repositoryNameColumn.setIndexType( ColumnIndexType.KEYS );
+ repositoryNameColumn.setValidationClass( ComparatorType.UTF8TYPE.getClassName() );
+ artifactMetadataModel.addColumnDefinition( repositoryNameColumn );
+
+ BasicColumnDefinition namespaceIdColumn = new BasicColumnDefinition();
+ namespaceIdColumn.setName( StringSerializer.get().toByteBuffer( "namespaceId" ) );
+ namespaceIdColumn.setIndexName( "namespaceId" );
+ namespaceIdColumn.setIndexType( ColumnIndexType.KEYS );
+ namespaceIdColumn.setValidationClass( ComparatorType.UTF8TYPE.getClassName() );
+ artifactMetadataModel.addColumnDefinition( namespaceIdColumn );
+
+ BasicColumnDefinition projectColumn = new BasicColumnDefinition();
+ projectColumn.setName( StringSerializer.get().toByteBuffer( "project" ) );
+ projectColumn.setIndexName( "project" );
+ projectColumn.setIndexType( ColumnIndexType.KEYS );
+ projectColumn.setValidationClass( ComparatorType.UTF8TYPE.getClassName() );
+ artifactMetadataModel.addColumnDefinition( projectColumn );
+
+ BasicColumnDefinition projectVersionColumn = new BasicColumnDefinition();
+ projectVersionColumn.setName( StringSerializer.get().toByteBuffer( "project" ) );
+ projectVersionColumn.setIndexName( "projectVersion" );
+ projectVersionColumn.setIndexType( ColumnIndexType.KEYS );
+ projectVersionColumn.setValidationClass( ComparatorType.UTF8TYPE.getClassName() );
+ artifactMetadataModel.addColumnDefinition( projectVersionColumn );
+
+ BasicColumnDefinition versionColumn = new BasicColumnDefinition();
+ versionColumn.setName( StringSerializer.get().toByteBuffer( "project" ) );
+ versionColumn.setIndexName( "version" );
+ versionColumn.setIndexType( ColumnIndexType.KEYS );
+ versionColumn.setValidationClass( ComparatorType.UTF8TYPE.getClassName() );
+ artifactMetadataModel.addColumnDefinition( versionColumn );
+
+ }
+
{ // ensure keyspace exists, here if the keyspace doesn't exist we suppose nothing exist
if ( cluster.describeKeyspace( keyspaceName ) == null )
{
@@ -238,4 +337,14 @@ public class DefaultCassandraArchivaManager
{
return projectFamilyName;
}
+
+ public String getProjectVersionMetadataModelFamilyName()
+ {
+ return projectVersionMetadataModelFamilyName;
+ }
+
+ public String getArtifactMetadataModelFamilyName()
+ {
+ return artifactMetadataModelFamilyName;
+ }
}
diff --git a/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/model/ArtifactMetadataModel.java b/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/model/ArtifactMetadataModel.java
index c500c7b97..6efe19743 100644
--- a/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/model/ArtifactMetadataModel.java
+++ b/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/model/ArtifactMetadataModel.java
@@ -22,7 +22,6 @@ package org.apache.archiva.metadata.repository.cassandra.model;
import org.apache.archiva.metadata.repository.cassandra.CassandraUtils;
import javax.persistence.Column;
-import javax.persistence.Id;
import java.io.Serializable;
import java.util.Date;
@@ -36,17 +35,13 @@ public class ArtifactMetadataModel
implements Serializable
{
- // repositoryId + namespaceId + project + projectVersion + id
- @Id
- private String artifactMetadataModelId;
-
@Column(name = "id")
private String id;
- @Column(name = "repositoryId")
+ @Column(name = "repositoryName")
private String repositoryId;
- @Column(name = "namespace")
+ @Column(name = "namespaceId")
private String namespace;
@Column(name = "project")
@@ -78,11 +73,10 @@ public class ArtifactMetadataModel
// no op
}
- public ArtifactMetadataModel( String artifactMetadataModelId, String id, String repositoryId, String namespace,
- String project, String projectVersion, String version, Date fileLastModified,
- long size, String md5, String sha1, Date whenGathered )
+ public ArtifactMetadataModel( String id, String repositoryId, String namespace, String project,
+ String projectVersion, String version, Date fileLastModified, long size, String md5,
+ String sha1, Date whenGathered )
{
- this.artifactMetadataModelId = artifactMetadataModelId;
this.id = id;
this.repositoryId = repositoryId;
this.namespace = namespace;
@@ -96,15 +90,6 @@ public class ArtifactMetadataModel
this.whenGathered = whenGathered != null ? whenGathered.getTime() : new Date().getTime();
}
- public String getArtifactMetadataModelId()
- {
- return artifactMetadataModelId;
- }
-
- public void setArtifactMetadataModelId( String artifactMetadataModelId )
- {
- this.artifactMetadataModelId = artifactMetadataModelId;
- }
public String getId()
{
@@ -216,39 +201,11 @@ public class ArtifactMetadataModel
this.whenGathered = whenGathered;
}
- @Override
- public boolean equals( Object o )
- {
- if ( this == o )
- {
- return true;
- }
- if ( o == null || getClass() != o.getClass() )
- {
- return false;
- }
-
- ArtifactMetadataModel that = (ArtifactMetadataModel) o;
-
- if ( !artifactMetadataModelId.equals( that.artifactMetadataModelId ) )
- {
- return false;
- }
-
- return true;
- }
-
- @Override
- public int hashCode()
- {
- return artifactMetadataModelId.hashCode();
- }
@Override
public String toString()
{
final StringBuilder sb = new StringBuilder( "ArtifactMetadataModel{" );
- sb.append( "artifactMetadataModelId='" ).append( artifactMetadataModelId ).append( '\'' );
sb.append( ", id='" ).append( id ).append( '\'' );
sb.append( ", repositoryId='" ).append( repositoryId ).append( '\'' );
sb.append( ", namespace='" ).append( namespace ).append( '\'' );
diff --git a/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/model/ProjectVersionMetadataModel.java b/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/model/ProjectVersionMetadataModel.java
index b083529c8..f8069f136 100644
--- a/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/model/ProjectVersionMetadataModel.java
+++ b/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/model/ProjectVersionMetadataModel.java
@@ -29,7 +29,6 @@ import org.apache.archiva.metadata.model.Scm;
import org.apache.archiva.metadata.repository.cassandra.CassandraUtils;
import javax.persistence.Column;
-import javax.persistence.Id;
import java.util.ArrayList;
import java.util.List;
@@ -39,9 +38,7 @@ import java.util.List;
*/
public class ProjectVersionMetadataModel
{
- // repositoryName + namespace + projectId + id (version)
- @Id
- private String rowId;
+
@Column(name = "namespace")
private Namespace namespace;
@@ -99,16 +96,6 @@ public class ProjectVersionMetadataModel
this.projectId = projectId;
}
- public String getRowId()
- {
- return rowId;
- }
-
- public void setRowId( String rowId )
- {
- this.rowId = rowId;
- }
-
// FIXME must be renamed getVersion !!!
public String getId()
{
@@ -245,7 +232,6 @@ public class ProjectVersionMetadataModel
public String toString()
{
final StringBuilder sb = new StringBuilder( "ProjectVersionMetadataModel{" );
- sb.append( "rowId='" ).append( rowId ).append( '\'' );
sb.append( ", namespace=" ).append( namespace );
sb.append( ", id='" ).append( id ).append( '\'' );
sb.append( ", projectId='" ).append( projectId ).append( '\'' );
@@ -261,34 +247,7 @@ public class ProjectVersionMetadataModel
return sb.toString();
}
- @Override
- public boolean equals( Object o )
- {
- if ( this == o )
- {
- return true;
- }
- if ( o == null || getClass() != o.getClass() )
- {
- return false;
- }
-
- ProjectVersionMetadataModel that = (ProjectVersionMetadataModel) o;
-
- if ( !rowId.equals( that.rowId ) )
- {
- return false;
- }
- return true;
- }
-
-
- @Override
- public int hashCode()
- {
- return rowId.hashCode();
- }
public static class KeyBuilder
{