All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.osgi.service.repository.Repository Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) OSGi Alliance (2006, 2014). All Rights Reserved.
 *
 * 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.
 */

package org.osgi.service.repository;

import java.util.Collection;
import java.util.Map;
import org.osgi.annotation.versioning.ProviderType;
import org.osgi.resource.Capability;
import org.osgi.resource.Requirement;
import org.osgi.resource.Resource;
import org.osgi.util.promise.Promise;

/**
 * A repository service that contains {@link Resource resources}.
 * 
 * 

* Repositories may be registered as services and may be used as by a resolve * context during resolver operations. * *

* Repositories registered as services may be filtered using standard service * properties. * * @ThreadSafe * @author $Id: be8094486733aaf1e15921123391477eedf6d752 $ */ @ProviderType public interface Repository { /** * Service property to provide URLs related to this repository. * *

* The value of this property must be of type {@code String}, * {@code String[]}, or {@code Collection}. */ String URL = "repository.url"; /** * 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. The returned map may be * lazily populated, so calling {@code size()} may result in a long * running operation. */ Map> findProviders(Collection requirements); /** * Find the resources that match the specified requirement expression. * * @param expression The {@code RequirementExpression} for which matching * capabilities should be returned. Must not be {@code null}. * @return A promise to a collection of matching {@code Resource}s. If there * are no matching resources, an empty collection is returned. The * returned collection is the property of the caller and can be * modified by the caller. The returned collection may be lazily * populated, so calling {@code size()} may result in a long running * operation. * @since 1.1 */ Promise> findProviders(RequirementExpression expression); /** * Return an expression combiner. An expression combiner can be used to * combine multiple requirement expressions into more complex requirement * expressions using {@link AndExpression and}, {@link OrExpression or} and * {@link NotExpression not} operators. * * @return An {@code ExpressionCombiner}. * @since 1.1 */ ExpressionCombiner getExpressionCombiner(); /** * Return a new {@code RequirementBuilder} which provides a convenient way * to create a requirement. * *

* For example: * *

 
     * Requirement myReq = repository.newRequirementBuilder("org.foo.ns1").
     *   addDirective("filter", "(org.foo.ns1=val1)").
     *   addDirective("cardinality", "multiple").build();
	 * 
* * @param namespace The namespace for the requirement to be created. * @return A new requirement builder for a requirement in the specified * namespace. * @since 1.1 */ RequirementBuilder newRequirementBuilder(String namespace); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy