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%2FMountPointManagerImpl.xtend;h=c3bc88ed5e4acc55a85cc3829e743ed107150174;hp=19634d79c2203fafe5aaa0156c41bf45a62f905f;hb=be6af4093624353da25fe240ce9c77d5789a0e36;hpb=caee336f062eba4909ba53cbaccdde0714236134 diff --git a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/MountPointManagerImpl.xtend b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/MountPointManagerImpl.xtend index 19634d79c2..c3bc88ed5e 100644 --- a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/MountPointManagerImpl.xtend +++ b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/MountPointManagerImpl.xtend @@ -7,12 +7,16 @@ import java.util.concurrent.ConcurrentMap import java.util.concurrent.ConcurrentHashMap import static com.google.common.base.Preconditions.*; import org.opendaylight.controller.sal.core.api.data.DataProviderService +import org.opendaylight.controller.sal.core.api.mount.MountProvisionService.MountProvisionListener +import org.opendaylight.yangtools.concepts.util.ListenerRegistry class MountPointManagerImpl implements MountProvisionService { @Property DataProviderService dataBroker; + val ListenerRegistry listeners = ListenerRegistry.create() + ConcurrentMap mounts = new ConcurrentHashMap(); override createMountPoint(InstanceIdentifier path) { @@ -20,15 +24,26 @@ class MountPointManagerImpl implements MountProvisionService { val mount = new MountPointImpl(path); registerMountPoint(mount); mounts.put(path,mount); + notifyMountCreated(path); return mount; } + def notifyMountCreated(InstanceIdentifier identifier) { + for(listener : listeners) { + listener.instance.onMountPointCreated(identifier); + } + } + def registerMountPoint(MountPointImpl impl) { - dataBroker?.registerConfigurationReader(impl.mountPath,impl.readWrapper); - dataBroker?.registerOperationalReader(impl.mountPath,impl.readWrapper); + //dataBroker?.registerConfigurationReader(impl.mountPath,impl.readWrapper); + //dataBroker?.registerOperationalReader(impl.mountPath,impl.readWrapper); } + override registerProvisionListener(MountProvisionListener listener) { + listeners.register(listener) + } + override createOrGetMountPoint(InstanceIdentifier path) { val mount = mounts.get(path);