X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-dom-broker%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fsal%2Fdom%2Fbroker%2FConsumerContextImpl.xtend;h=9f21823e3efb33c56e841fc1ad2af52ba481ad7f;hb=3979e330c9f95a898c54a9234f3a07e3b2ae4349;hp=6d57a4e2247392089f4a0895b439e8f2d3c84b76;hpb=a251833f27fd00040904e2df316cd707c8129d1e;p=controller.git diff --git a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/ConsumerContextImpl.xtend b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/ConsumerContextImpl.xtend index 6d57a4e224..9f21823e3e 100644 --- a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/ConsumerContextImpl.xtend +++ b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/ConsumerContextImpl.xtend @@ -1,13 +1,15 @@ package org.opendaylight.controller.sal.dom.broker -import java.util.Collections import org.opendaylight.controller.sal.core.api.Broker.ConsumerSession -import java.util.HashMap import org.opendaylight.controller.sal.core.api.BrokerService import org.opendaylight.controller.sal.core.api.Consumer import org.osgi.framework.BundleContext import org.opendaylight.yangtools.yang.common.QName import org.opendaylight.yangtools.yang.data.api.CompositeNode +import org.opendaylight.controller.sal.dom.broker.osgi.AbstractBrokerServiceProxy +import com.google.common.collect.ClassToInstanceMap +import com.google.common.collect.MutableClassToInstanceMap +import org.opendaylight.controller.sal.dom.broker.osgi.ProxyFactory class ConsumerContextImpl implements ConsumerSession { @@ -17,8 +19,7 @@ class ConsumerContextImpl implements ConsumerSession { @Property private var BrokerImpl broker; - private val instantiatedServices = Collections.synchronizedMap( - new HashMap, BrokerService>()); + private val ClassToInstanceMap instantiatedServices = MutableClassToInstanceMap.create(); private boolean closed = false; private BundleContext context; @@ -33,14 +34,20 @@ class ConsumerContextImpl implements ConsumerSession { } override T getService(Class service) { - val potential = instantiatedServices.get(service); - if(potential != null) { - val ret = potential as T; - return ret; + val localProxy = instantiatedServices.getInstance(service); + if(localProxy != null) { + return localProxy; } - val ret = broker.serviceFor(service, this); + val serviceRef = context.getServiceReference(service); + if(serviceRef == null) { + return null; + } + val serviceImpl = context.getService(serviceRef); + + + val ret = ProxyFactory.createProxy(serviceRef,serviceImpl); if(ret != null) { - instantiatedServices.put(service, ret); + instantiatedServices.putInstance(service, ret); } return ret; } @@ -49,7 +56,9 @@ class ConsumerContextImpl implements ConsumerSession { val toStop = instantiatedServices.values(); this.closed = true; for (BrokerService brokerService : toStop) { - //brokerService.closeSession(); + if(brokerService instanceof AbstractBrokerServiceProxy) { + (brokerService as AutoCloseable).close(); + } } broker.consumerSessionClosed(this); }