/* * $Header: /cvshome/build/org.osgi.service.component/src/org/osgi/service/component/ComponentContext.java,v 1.20 2006/06/16 16:31:26 hargrave Exp $ * * Copyright (c) OSGi Alliance (2004, 2006). 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.component; import java.util.Dictionary; import org.osgi.framework.*; /** * A Component Context object is used by a component instance to interact with * its execution context including locating services by reference name. Each * component instance has a unique Component Context. * *

* A component's implementation class may optionaly implement an activate * method: * *

 * protected void activate(ComponentContext context);
 * 
* * If a component implements this method, this method will be called when a * component configuration is activated to provide the component instance's * Component Context object. * *

* A component's implementation class may optionaly implement a deactivate * method: * *

 * protected void deactivate(ComponentContext context);
 * 
* * If a component implements this method, this method will be called when the * component configuration is deactivated. * *

* The activate and deactivate methods will be called using reflection and must * be protected or public accessible. These methods should not be public methods * so that they do not appear as public methods on the component instance when * used as a service object. These methods will be located by looking through * the component's implementation class hierarchy for the first declaration of * the method. If the method is found, if it is declared protected or public, * the method will be called. Otherwise, the method will not be called. * * @version $Revision: 1.20 $ */ public interface ComponentContext { /** * Returns the component properties for this Component Context. * * @return The properties for this Component Context. The Dictionary is read * only and cannot be modified. */ public Dictionary getProperties(); /** * Returns the service object for the specified reference name. * *

* If the cardinality of the reference is 0..n or * 1..n and multiple services are bound to the reference, the * service with the highest ranking (as specified in its * Constants.SERVICE_RANKING property) is returned. If there * is a tie in ranking, the service with the lowest service ID (as specified * in its Constants.SERVICE_ID property); that is, the * service that was registered first is returned. * * @param name The name of a reference as specified in a * reference element in this component's description. * @return A service object for the referenced service or null * if the reference cardinality is 0..1 or * 0..n and no bound service is available. * @throws ComponentException If the Service Component Runtime catches an * exception while activating the bound service. */ public Object locateService(String name); /** * Returns the service object for the specified reference name and * ServiceReference. * * @param name The name of a reference as specified in a * reference element in this component's description. * @param reference The ServiceReference to a bound service. * This must be a ServiceReference provided to the * component via the bind or unbind method for the specified * reference name. * @return A service object for the referenced service or null * if the specified ServiceReference is not a bound * service for the specified reference name. * @throws ComponentException If the Service Component Runtime catches an * exception while activating the bound service. */ public Object locateService(String name, ServiceReference reference); /** * Returns the service objects for the specified reference name. * * @param name The name of a reference as specified in a * reference element in this component's description. * @return An array of service objects for the referenced service or * null if the reference cardinality is * 0..1 or 0..n and no bound service * is available. * @throws ComponentException If the Service Component Runtime catches an * exception while activating a bound service. */ public Object[] locateServices(String name); /** * Returns the BundleContext of the bundle which contains * this component. * * @return The BundleContext of the bundle containing this * component. */ public BundleContext getBundleContext(); /** * If the component instance is registered as a service using the * servicefactory="true" attribute, then this * method returns the bundle using the service provided by the component * instance. *

* This method will return null if: *

* * @return The bundle using the component instance as a service or * null. */ public Bundle getUsingBundle(); /** * Returns the Component Instance object for the component instance * associated with this Component Context. * * @return The Component Instance object for the component instance. */ public ComponentInstance getComponentInstance(); /** * Enables the specified component name. The specified component name must * be in the same bundle as this component. * * @param name The name of a component or null to indicate * all components in the bundle. */ public void enableComponent(String name); /** * Disables the specified component name. The specified component name must * be in the same bundle as this component. * * @param name The name of a component. */ public void disableComponent(String name); /** * If the component instance is registered as a service using the * service element, then this method returns the service * reference of the service provided by this component instance. *

* This method will return null if the component instance is * not registered as a service. * * @return The ServiceReference object for the component * instance or null if the component instance is not * registered as a service. */ public ServiceReference getServiceReference(); }