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%2FAbstractBrokerAwareActivator.java;h=b169ac4d1a1a6e93492638e5c660da373b4d5ac7;hp=b62e4529f341f76a53d522f49dd4f935e781887d;hb=HEAD;hpb=70cc15d2d298a9bc3869ac2badc71196f9cd6dea diff --git a/opendaylight/md-sal/sal-binding-api/src/main/java/org/opendaylight/controller/sal/binding/api/AbstractBrokerAwareActivator.java b/opendaylight/md-sal/sal-binding-api/src/main/java/org/opendaylight/controller/sal/binding/api/AbstractBrokerAwareActivator.java deleted file mode 100644 index b62e4529f3..0000000000 --- a/opendaylight/md-sal/sal-binding-api/src/main/java/org/opendaylight/controller/sal/binding/api/AbstractBrokerAwareActivator.java +++ /dev/null @@ -1,122 +0,0 @@ -/* - * Copyright (c) 2014 Cisco Systems, Inc. and others. All rights reserved. - * - * This program and the accompanying materials are made available under the - * terms of the Eclipse Public License v1.0 which accompanies this distribution, - * and is available at http://www.eclipse.org/legal/epl-v10.html - */ -package org.opendaylight.controller.sal.binding.api; - -import java.util.concurrent.ExecutorService; -import java.util.concurrent.Executors; - -import org.osgi.framework.BundleActivator; -import org.osgi.framework.BundleContext; -import org.osgi.framework.ServiceReference; -import org.osgi.util.tracker.ServiceTracker; -import org.osgi.util.tracker.ServiceTrackerCustomizer; - -public abstract class AbstractBrokerAwareActivator implements BundleActivator { - - private static final ExecutorService mdActivationPool = Executors.newCachedThreadPool(); - private BundleContext context; - private ServiceTracker tracker; - private BindingAwareBroker broker; - private ServiceTrackerCustomizer customizer = new ServiceTrackerCustomizer() { - - @Override - public BindingAwareBroker addingService(ServiceReference reference) { - broker = context.getService(reference); - mdActivationPool.execute(new Runnable() { - - @Override - public void run() { - onBrokerAvailable(broker, context); - } - }); - return broker; - } - - @Override - public void modifiedService(ServiceReference reference, BindingAwareBroker service) { - // TODO Auto-generated method stub - - } - - @Override - public void removedService(ServiceReference reference, BindingAwareBroker service) { - // TODO Auto-generated method stub - - } - - }; - - - @Override - public final void start(BundleContext context) throws Exception { - this.context = context; - startImpl(context); - tracker = new ServiceTracker<>(context, BindingAwareBroker.class, customizer); - tracker.open(); - - } - - - - @Override - public final void stop(BundleContext context) throws Exception { - tracker.close(); - stopImpl(context); - } - - - /** - * 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 - } - - - protected abstract void onBrokerAvailable(BindingAwareBroker broker, BundleContext context); - - protected void onBrokerRemoved(BindingAwareBroker broker, BundleContext context) { - - } -}