/*
* #%L
* Gravia :: Resolver
* %%
* Copyright (C) 2010 - 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.resolver;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import javax.naming.spi.Resolver;
import org.jboss.gravia.resource.Capability;
import org.jboss.gravia.resource.Requirement;
import org.jboss.gravia.resource.Resource;
import org.jboss.gravia.runtime.Wiring;
/**
* A resolve context provides resources, options and constraints to the
* potential solution of a {@link Resolver#resolve(ResolveContext) resolve}
* operation.
*
* <p>
* Resolve Contexts:
* <ul>
* <li>Specify the mandatory and optional resources to resolve. The mandatory
* and optional resources must be consistent and correct. For example, they must
* not violate the singleton policy of the implementer.</li>
* <li>Provide {@link Capability capabilities} that the Resolver can use to
* satisfy {@link Requirement requirements} via the
* {@link #findProviders(Requirement)} method</li>
* <li>Constrain solutions via the {@link #getWirings()} method. A wiring
* consists of a map of existing {@link Resource resources} to {@link Wiring
* wiring}.</li>
* <li>Filter requirements that are part of a resolve operation via the
* {@link #isEffective(Requirement)}.</li>
* </ul>
*
* <p>
* A resolver may call the methods on the resolve context any number of times
* during a resolve operation using any thread. Implementors should ensure that
* this class is properly thread safe.
*
* <p>
* The resolve context methods must be <i>idempotent</i>. This means that resources
* must have constant capabilities and requirements and the resolve context must
* return a consistent set of capabilities, wires and effective requirements.
*
* @author thomas.diesler@jboss.com
* @since 02-Apr-2012
*/
public interface ResolveContext {
/**
* Return the resources that must be resolved for this resolve context.
*
* <p>
* The default implementation returns an empty collection.
*
* @return The resources that must be resolved for this resolve context. May
* be empty if there are no mandatory resources.
*/
Collection<Resource> getMandatoryResources();
/**
* Return the resources that the resolver should attempt to resolve for this
* resolve context. Inability to resolve one of the specified resources will
* not result in a resolution exception.
*
* <p>
* The default implementation returns an empty collection.
*
* @return The resources that the resolver should attempt to resolve for
* this resolve context. May be empty if there are no mandatory
* resources.
*/
Collection<Resource> getOptionalResources();
/**
* Find Capabilities that match the given Requirement.
* <p>
* The returned list contains {@link Capability} objects where the Resource
* must be the declared Resource of the Capability.
*
* <p>
* The returned list is in priority order such that the Capabilities with a
* lower index have a preference over those with a higher index.
*
* <p>
* Each returned Capability must match the given Requirement.
*
* @param requirement The requirement that a resolver is attempting to
* satisfy. Must not be {@code null}.
* @return A list of {@link Capability} objects that match the specified
* requirement.
*/
List<Capability> findProviders(Requirement requirement);
/**
* Test if a given requirement should be wired in the resolve operation. If
* this method returns {@code false}, then the resolver should ignore this
* requirement during the resolve operation.
*
* <p>
* The primary use case for this is to test the {@code effective} directive
* on the requirement, though implementations are free to use any effective
* test.
*
* @param requirement The Requirement to test. Must not be {@code null}.
* @return {@code true} if the requirement should be considered as part of
* the resolve operation.
*/
boolean isEffective(Requirement requirement);
/**
* Returns the wirings for existing resolved resources.
*
* <p>
* Multiple calls to this method for this resolve context must return the
* same result.
*
* @return The wirings for existing resolved resources. The returned map is
* unmodifiable.
*/
Map<Resource, Wiring> getWirings();
}