X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-binding-api%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fsal%2Fbinding%2Fapi%2FAbstractBindingAwareProvider.java;h=fdff997467e46014879b1f5c286cdc555775f259;hp=b1a0fe0c286075420b5ae02744dc5ee5dcb5b183;hb=aaea3e9a92ae9d6fac04c4a065db4b35cbca9ed0;hpb=a251833f27fd00040904e2df316cd707c8129d1e diff --git a/opendaylight/md-sal/sal-binding-api/src/main/java/org/opendaylight/controller/sal/binding/api/AbstractBindingAwareProvider.java b/opendaylight/md-sal/sal-binding-api/src/main/java/org/opendaylight/controller/sal/binding/api/AbstractBindingAwareProvider.java index b1a0fe0c28..fdff997467 100644 --- a/opendaylight/md-sal/sal-binding-api/src/main/java/org/opendaylight/controller/sal/binding/api/AbstractBindingAwareProvider.java +++ b/opendaylight/md-sal/sal-binding-api/src/main/java/org/opendaylight/controller/sal/binding/api/AbstractBindingAwareProvider.java @@ -7,144 +7,13 @@ */ package org.opendaylight.controller.sal.binding.api; -import java.util.Collection; -import java.util.Collections; - -import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.ConsumerContext; -import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.ProviderContext; -import org.opendaylight.yangtools.yang.binding.RpcService; -import org.osgi.framework.BundleActivator; import org.osgi.framework.BundleContext; -import org.osgi.framework.ServiceReference; - -public abstract class AbstractBindingAwareProvider implements BindingAwareProvider, BundleActivator { - - /** - * Initializes the bundle. - * - * Implementation of initialization get's the Binding Aware Broker from - * service registry and register itself as a {@link BindingAwareProvider} - * - * Callback order is: - *
    - *
  1. {@link #startImpl(BundleContext)} - *
  2. {@link #onSessionInitiated(ProviderContext)} - *
  3. Registration of global {@link RpcService} implementations returned by - * {@link #getImplementations()} - *
  4. Registration of {@link ProviderFunctionality} implementations - * returned by {@link #getFunctionality()} - *
- * - */ - @Override - public final void start(BundleContext context) throws Exception { - startImpl(context); - ServiceReference brokerRef = context.getServiceReference(BindingAwareBroker.class); - BindingAwareBroker broker = context.getService(brokerRef); - - ProviderContext ctx = broker.registerProvider(this, context); - registerRpcImplementations(ctx); - registerFunctionality(ctx); - } - - private void registerFunctionality(ProviderContext ctx) { - Collection functionality = this.getFunctionality(); - if (functionality == null || functionality.isEmpty()) { - return; - } - for (ProviderFunctionality providerFunctionality : functionality) { - ctx.registerFunctionality(providerFunctionality); - } - - } - - private void registerRpcImplementations(ProviderContext ctx) { - Collection rpcs = this.getImplementations(); - if (rpcs == null || rpcs.isEmpty()) { - return; - } - for (RpcService rpcService : rpcs) { - // ctx.addRpcImplementation(type, implementation); - } - - } - /** - * Called when this bundle is started (before - * {@link #onSessionInitiated(ProviderContext)} so the Framework can perform - * the bundle-specific activities necessary to start this bundle. This - * method can be used to register services or to allocate any resources that - * this bundle needs. - * - *

- * This method must complete and return to its caller in a timely manner. - * - * @param context - * The execution context of the bundle being started. - * @throws Exception - * If this method throws an exception, this bundle is marked as - * stopped and the Framework will remove this bundle's - * listeners, unregister all services registered by this bundle, - * and release all services used by this bundle. - */ - protected void startImpl(BundleContext context) { - // NOOP - } - - /** - * Called when this bundle is stopped so the Framework can perform the - * bundle-specific activities necessary to stop the bundle. In general, this - * method should undo the work that the {@code BundleActivator.start} method - * started. There should be no active threads that were started by this - * bundle when this bundle returns. A stopped bundle must not call any - * Framework objects. - * - *

- * This method must complete and return to its caller in a timely manner. - * - * @param context The execution context of the bundle being stopped. - * @throws Exception If this method throws an exception, the bundle is still - * marked as stopped, and the Framework will remove the bundle's - * listeners, unregister all services registered by the bundle, and - * release all services used by the bundle. - */ - protected void stopImpl(BundleContext context) { - // NOOP - } - - /** - * Bundle stop callback - * - * - * Custom implementation of bundle stop could be carried by overriding - * {@link #stopImpl(BundleContext)} method. - * - */ - @Override - public final void stop(BundleContext context) throws Exception { - stopImpl(context); - } - - @Override - public Collection getFunctionality() { - return Collections.emptySet(); - } - - @Override - public Collection getImplementations() { - return Collections.emptySet(); - } - - /** - * Initialization of consumer context. - * - * {@link ProviderContext} is replacement of {@link ConsumerContext} - * so this method is not needed in case of Provider. - * - */ - @Deprecated +@Deprecated(forRemoval = true) +public abstract class AbstractBindingAwareProvider extends AbstractBrokerAwareActivator + implements BindingAwareProvider { @Override - public final void onSessionInitialized(ConsumerContext session) { - // NOOP + protected final void onBrokerAvailable(BindingAwareBroker broker, BundleContext context) { + broker.registerProvider(this, context); } }