/*
* #%L
* Gravia :: Repository
* %%
* Copyright (C) 2012 - 2014 JBoss by Red Hat
* %%
* Licensed 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.
* #L%
*/
package org.jboss.gravia.repository;
import java.io.IOException;
import java.util.Collection;
import java.util.Map;
import org.jboss.gravia.resource.Adaptable;
import org.jboss.gravia.resource.Capability;
import org.jboss.gravia.resource.MavenCoordinates;
import org.jboss.gravia.resource.Requirement;
import org.jboss.gravia.resource.Resource;
import org.jboss.gravia.resource.ResourceIdentity;
/**
* A repository that contains {@link Resource resources}.
*
* @author thomas.diesler@jboss.com
* @since 11-May-2012
*/
public interface Repository extends Adaptable {
/**
* Get the name for this repository
*/
String getName();
/**
* Find the capabilities that match the specified requirement.
*
* @param requirement The requirements for which matching capabilities
* should be returned. Must not be {@code null}.
* @return A collection of matching capabilities for the specified requirements.
* If there are no matching capabilities an empty collection is returned.
* The returned collection is the property of the caller and can be modified by the caller.
*/
Collection<Capability> findProviders(Requirement requirement);
/**
* Find the capabilities that match the specified requirements.
*
* @param requirements The requirements for which matching capabilities
* should be returned. Must not be {@code null}.
* @return A map of matching capabilities for the specified requirements.
* Each specified requirement must appear as a key in the map. If
* there are no matching capabilities for a specified requirement,
* then the value in the map for the specified requirement must be
* an empty collection. The returned map is the property of the
* caller and can be modified by the caller.
*/
Map<Requirement, Collection<Capability>> findProviders(Collection<Requirement> requirements);
/**
* Add a {@link Resource} to the associated {@link RepositoryStorage}
*/
Resource addResource(Resource resource) throws IOException;
/**
* Add a {@link Resource} to the associated {@link RepositoryStorage}
*/
Resource addResource(Resource resource, MavenCoordinates mavenid) throws IOException;
/**
* Remove a {@link Resource} grom the associated {@link RepositoryStorage}
*/
Resource removeResource(ResourceIdentity identity);
/**
* Get a a {@link Resource} by {@link ResourceIdentity}
*/
Resource getResource(ResourceIdentity identity);
/**
* Get the associated fallback repository or null.
*/
Repository getFallbackRepository();
}