X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-dom-broker%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fsal%2Fdom%2Fbroker%2FBrokerImpl.java;fp=opendaylight%2Fsal%2Fyang-prototype%2Fsal%2Fsal-broker-impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fsal%2Fcore%2Fimpl%2FBrokerImpl.java;h=24b2b4b6daa4e4d47dd40ce85d6b17f0a96be098;hp=f0d1cc609d22a54230bed5c2136ae2f32ba701e7;hb=fe024ad74b8656c3ee61b9ddff6009a779aa2189;hpb=437c1bdb967072319e81774bdcf570b2fb0f7b89 diff --git a/opendaylight/sal/yang-prototype/sal/sal-broker-impl/src/main/java/org/opendaylight/controller/sal/core/impl/BrokerImpl.java b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/BrokerImpl.java similarity index 89% rename from opendaylight/sal/yang-prototype/sal/sal-broker-impl/src/main/java/org/opendaylight/controller/sal/core/impl/BrokerImpl.java rename to opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/BrokerImpl.java index f0d1cc609d..24b2b4b6da 100644 --- a/opendaylight/sal/yang-prototype/sal/sal-broker-impl/src/main/java/org/opendaylight/controller/sal/core/impl/BrokerImpl.java +++ b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/BrokerImpl.java @@ -5,7 +5,7 @@ * 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.core.impl; +package org.opendaylight.controller.sal.dom.broker; import java.util.Collection; import java.util.Collections; @@ -25,6 +25,7 @@ import org.opendaylight.controller.sal.core.spi.BrokerModule; import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.common.RpcResult; import org.opendaylight.yangtools.yang.data.api.CompositeNode; +import org.osgi.framework.BundleContext; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -48,21 +49,23 @@ public class BrokerImpl implements Broker { // Implementation specific private ExecutorService executor; + private BundleContext bundleContext; + @Override - public ConsumerSession registerConsumer(Consumer consumer) { + public ConsumerSession registerConsumer(Consumer consumer,BundleContext ctx) { checkPredicates(consumer); log.info("Registering consumer " + consumer); - ConsumerSessionImpl session = newSessionFor(consumer); + ConsumerSessionImpl session = newSessionFor(consumer,ctx); consumer.onSessionInitiated(session); sessions.add(session); return session; } @Override - public ProviderSession registerProvider(Provider provider) { + public ProviderSession registerProvider(Provider provider,BundleContext ctx) { checkPredicates(provider); - ProviderSessionImpl session = newSessionFor(provider); + ProviderSessionImpl session = newSessionFor(provider,ctx); provider.onSessionInitiated(session); providerSessions.add(session); return session; @@ -153,12 +156,12 @@ public class BrokerImpl implements Broker { // Private Factory methods - private ConsumerSessionImpl newSessionFor(Consumer cons) { - return new ConsumerSessionImpl(cons); + private ConsumerSessionImpl newSessionFor(Consumer provider, BundleContext ctx) { + return new ConsumerSessionImpl(provider,ctx); } - private ProviderSessionImpl newSessionFor(Provider provider) { - return new ProviderSessionImpl(provider); + private ProviderSessionImpl newSessionFor(Provider provider, BundleContext ctx) { + return new ProviderSessionImpl(provider,ctx); } private void consumerSessionClosed(ConsumerSessionImpl consumerSessionImpl) { @@ -187,12 +190,15 @@ public class BrokerImpl implements Broker { .synchronizedMap(new HashMap, BrokerService>()); private boolean closed = false; + private BundleContext context; + public Consumer getConsumer() { return consumer; } - public ConsumerSessionImpl(Consumer consumer) { + public ConsumerSessionImpl(Consumer consumer, BundleContext ctx) { this.consumer = consumer; + this.context = ctx; } @Override @@ -239,8 +245,8 @@ public class BrokerImpl implements Broker { private Provider provider; private Map sessionRpcImpls = Collections.synchronizedMap(new HashMap()); - public ProviderSessionImpl(Provider provider) { - super(null); + public ProviderSessionImpl(Provider provider, BundleContext ctx) { + super(null,ctx); this.provider = provider; } @@ -277,4 +283,8 @@ public class BrokerImpl implements Broker { } } + + public void setBundleContext(BundleContext context) { + this.bundleContext = context; + } }