package org.apache.archiva.metadata.repository;
/*
* 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.apache.archiva.metadata.model.ArtifactMetadata;
import org.apache.archiva.metadata.model.MetadataFacet;
import org.apache.archiva.metadata.model.ProjectMetadata;
import org.apache.archiva.metadata.model.ProjectVersionMetadata;
import org.apache.archiva.metadata.model.ProjectVersionReference;
import java.util.Collection;
import java.util.Date;
import java.util.List;
public interface MetadataRepository
{
/**
* Update metadata for a particular project in the metadata repository, or create it if it does not already exist.
*
* @param repositoryId the repository the project is in
* @param project the project metadata to create or update
*/
void updateProject( String repositoryId, ProjectMetadata project )
throws MetadataRepositoryException;
void updateArtifact( String repositoryId, String namespace, String projectId, String projectVersion,
ArtifactMetadata artifactMeta )
throws MetadataRepositoryException;
void updateProjectVersion( String repositoryId, String namespace, String projectId,
ProjectVersionMetadata versionMetadata )
throws MetadataRepositoryException;
/**
* create the namespace in the repository. (if not exist)
*
* @param repositoryId
* @param namespace
* @throws MetadataRepositoryException
*/
void updateNamespace( String repositoryId, String namespace )
throws MetadataRepositoryException;
List<String> getMetadataFacets( String repositoryId, String facetId )
throws MetadataRepositoryException;
/**
* @param repositoryId
* @param facetId
* @return true if the repository datas for this facetId
* @throws MetadataRepositoryException
* @since 1.4-M4
*/
boolean hasMetadataFacet( String repositoryId, String facetId )
throws MetadataRepositoryException;
MetadataFacet getMetadataFacet( String repositoryId, String facetId, String name )
throws MetadataRepositoryException;
void addMetadataFacet( String repositoryId, MetadataFacet metadataFacet )
throws MetadataRepositoryException;
void removeMetadataFacets( String repositoryId, String facetId )
throws MetadataRepositoryException;
void removeMetadataFacet( String repositoryId, String facetId, String name )
throws MetadataRepositoryException;
/**
* if startTime or endTime are <code>null</code> they are not used for search
*
* @param repositoryId
* @param startTime can be <code>null</code>
* @param endTime can be <code>null</code>
* @return
* @throws MetadataRepositoryException
*/
List<ArtifactMetadata> getArtifactsByDateRange( String repositoryId, Date startTime, Date endTime )
throws MetadataRepositoryException;
// TODO: remove from API, just use configuration
Collection<String> getRepositories()
throws MetadataRepositoryException;
Collection<ArtifactMetadata> getArtifactsByChecksum( String repositoryId, String checksum )
throws MetadataRepositoryException;
/**
* Get artifacts with a project version metadata key that matches the passed value.
*
* @param key
* @param value
* @param repositoryId can be null, meaning search in all repositories
* @return a list of artifacts
* @throws MetadataRepositoryException
*/
List<ArtifactMetadata> getArtifactsByProjectVersionMetadata( String key, String value, String repositoryId )
throws MetadataRepositoryException;
/**
* Get artifacts with an artifact metadata key that matches the passed value.
*
* @param key
* @param value
* @param repositoryId can be null, meaning search in all repositories
* @return a list of artifacts
* @throws MetadataRepositoryException
*/
List<ArtifactMetadata> getArtifactsByMetadata( String key, String value, String repositoryId )
throws MetadataRepositoryException;
/**
* Get artifacts with a property key that matches the passed value.
* Possible keys are 'scm.url', 'org.name', 'url', 'mailingList.0.name', 'license.0.name',...
*
* @param key
* @param value
* @param repositoryId can be null, meaning search in all repositories
* @return a list of artifacts
* @throws MetadataRepositoryException
*/
List<ArtifactMetadata> getArtifactsByProperty( String key, String value, String repositoryId )
throws MetadataRepositoryException;
void removeArtifact( String repositoryId, String namespace, String project, String version, String id )
throws MetadataRepositoryException;
/**
* used for deleting timestamped version of SNAPSHOT artifacts
*
* @param artifactMetadata the artifactMetadata with the timestamped version (2.0-20120618.214135-2)
* @param baseVersion the base version of the snapshot (2.0-SNAPSHOT)
* @throws MetadataRepositoryException
* @since 1.4-M3
*/
void removeArtifact( ArtifactMetadata artifactMetadata, String baseVersion )
throws MetadataRepositoryException;
/**
* FIXME need a unit test!!!
* Only remove {@link MetadataFacet} for the artifact
*
* @param repositoryId
* @param namespace
* @param project
* @param version
* @param metadataFacet
* @throws MetadataRepositoryException
* @since 1.4-M3
*/
void removeArtifact( String repositoryId, String namespace, String project, String version,
MetadataFacet metadataFacet )
throws MetadataRepositoryException;
/**
* Delete a repository's metadata. This includes all associated metadata facets.
*
* @param repositoryId the repository to delete
*/
void removeRepository( String repositoryId )
throws MetadataRepositoryException;
/**
* @param repositoryId
* @param namespace (groupId for maven )
* @throws MetadataRepositoryException
* @since 1.4-M3
*/
void removeNamespace( String repositoryId, String namespace )
throws MetadataRepositoryException;
List<ArtifactMetadata> getArtifacts( String repositoryId )
throws MetadataRepositoryException;
/**
* basically just checking it exists not complete data returned
*
* @param repoId
* @param namespace
* @param projectId
* @return
* @throws MetadataResolutionException
*/
ProjectMetadata getProject( String repoId, String namespace, String projectId )
throws MetadataResolutionException;
ProjectVersionMetadata getProjectVersion( String repoId, String namespace, String projectId, String projectVersion )
throws MetadataResolutionException;
Collection<String> getArtifactVersions( String repoId, String namespace, String projectId, String projectVersion )
throws MetadataResolutionException;
/**
* Retrieve project references from the metadata repository. Note that this is not built into the content model for
* a project version as a reference may be present (due to reverse-lookup of dependencies) before the actual
* project is, and we want to avoid adding a stub model to the content repository.
*
* @param repoId the repository ID to look within
* @param namespace the namespace of the project to get references to
* @param projectId the identifier of the project to get references to
* @param projectVersion the version of the project to get references to
* @return a list of project references
*/
Collection<ProjectVersionReference> getProjectReferences( String repoId, String namespace, String projectId,
String projectVersion )
throws MetadataResolutionException;
Collection<String> getRootNamespaces( String repoId )
throws MetadataResolutionException;
/**
* @param repoId
* @param namespace
* @return {@link Collection} of child namespaces of the namespace argument
* @throws MetadataResolutionException
*/
Collection<String> getNamespaces( String repoId, String namespace )
throws MetadataResolutionException;
/**
* @param repoId
* @param namespace
* @return
* @throws MetadataResolutionException
*/
Collection<String> getProjects( String repoId, String namespace )
throws MetadataResolutionException;
/**
* @param repoId
* @param namespace
* @param projectId
* @return
* @throws MetadataResolutionException
*/
Collection<String> getProjectVersions( String repoId, String namespace, String projectId )
throws MetadataResolutionException;
/**
* @param repoId
* @param namespace
* @param projectId
* @param projectVersion
* @throws MetadataRepositoryException
* @since 1.4-M4
*/
void removeProjectVersion( String repoId, String namespace, String projectId, String projectVersion )
throws MetadataRepositoryException;
/**
* @param repoId
* @param namespace
* @param projectId
* @param projectVersion
* @return
* @throws MetadataResolutionException
*/
Collection<ArtifactMetadata> getArtifacts( String repoId, String namespace, String projectId,
String projectVersion )
throws MetadataResolutionException;
/**
* remove a project
*
* @param repositoryId
* @param namespace
* @param projectId
* @throws MetadataRepositoryException
* @since 1.4-M4
*/
void removeProject( String repositoryId, String namespace, String projectId )
throws MetadataRepositoryException;
/**
* <b>implementations can throw RuntimeException</b>
*/
void save();
void close()
throws MetadataRepositoryException;
/**
* <b>implementations can throw RuntimeException</b>
*/
void revert();
boolean canObtainAccess( Class<?> aClass );
<T> T obtainAccess( Class<T> aClass )
throws MetadataRepositoryException;
/**
* Full text artifacts search.
*
* @param text
* @param repositoryId can be null to search in all repositories
* @param exact running an exact search, the value must exactly match the text.
* @return a list of artifacts
* @throws MetadataRepositoryException
*/
List<ArtifactMetadata> searchArtifacts( String text, String repositoryId, boolean exact )
throws MetadataRepositoryException;
/**
* Full text artifacts search inside the specified key.
*
* @param key search only inside this key
* @param text
* @param repositoryId can be null to search in all repositories
* @param exact running an exact search, the value must exactly match the text.
* @return a list of artifacts
* @throws MetadataRepositoryException
*/
List<ArtifactMetadata> searchArtifacts( String key, String text, String repositoryId, boolean exact )
throws MetadataRepositoryException;
}