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%2FMountPointImpl.java;h=b4fccff3b0fe745ae71088942ed05e92429f5e0e;hb=1dd1433d1e2f30855b098cca7cc48039a9747df8;hp=7037b46ce978dea4d717692498e526c8706cb7a8;hpb=9108efddf9a5f3e2c81202a17ccdeca22cb5ca09;p=controller.git diff --git a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/MountPointImpl.java b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/MountPointImpl.java index 7037b46ce9..b4fccff3b0 100644 --- a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/MountPointImpl.java +++ b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/MountPointImpl.java @@ -1,15 +1,21 @@ package org.opendaylight.controller.sal.dom.broker; +import java.util.List; import java.util.Set; import java.util.concurrent.Future; +import org.opendaylight.controller.md.sal.common.api.RegistrationListener; +import org.opendaylight.controller.md.sal.common.api.data.DataCommitHandler; +import org.opendaylight.controller.md.sal.common.api.data.DataCommitHandlerRegistration; import org.opendaylight.controller.md.sal.common.api.data.DataReader; +import org.opendaylight.controller.sal.common.DataStoreIdentifier; import org.opendaylight.controller.sal.core.api.Broker.RoutedRpcRegistration; import org.opendaylight.controller.sal.core.api.RpcImplementation; import org.opendaylight.controller.sal.core.api.Broker.RpcRegistration; import org.opendaylight.controller.sal.core.api.RpcRegistrationListener; import org.opendaylight.controller.sal.core.api.data.DataChangeListener; import org.opendaylight.controller.sal.core.api.data.DataModificationTransaction; +import org.opendaylight.controller.sal.core.api.data.DataValidator; import org.opendaylight.controller.sal.core.api.mount.MountProvisionInstance; import org.opendaylight.controller.sal.core.api.notify.NotificationListener; import org.opendaylight.controller.sal.dom.broker.impl.DataReaderRouter; @@ -23,17 +29,36 @@ import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.common.RpcResult; import org.opendaylight.yangtools.yang.data.api.CompositeNode; import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier; +import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.InstanceIdentifierBuilder; +import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.PathArgument; +import org.opendaylight.yangtools.yang.model.api.SchemaContext; public class MountPointImpl implements MountProvisionInstance { - final RpcRouter rpcs; - final DataReaderRouter dataReader; - final NotificationRouter notificationRouter; + private final RpcRouter rpcs; + private final DataBrokerImpl dataReader; + private final NotificationRouter notificationRouter; + private final DataReader readWrapper; + + + private final InstanceIdentifier mountPath; + + private SchemaContext schemaContext; public MountPointImpl(InstanceIdentifier path) { + this.mountPath = path; rpcs = new RpcRouterImpl(""); - dataReader = new DataReaderRouter(); + dataReader = new DataBrokerImpl(); notificationRouter = new NotificationRouterImpl(); + readWrapper = new ReadWrapper(); + } + + public InstanceIdentifier getMountPath() { + return mountPath; + } + + public DataReader getReadWrapper() { + return readWrapper; } @Override @@ -99,20 +124,87 @@ public class MountPointImpl implements MountProvisionInstance { @Override public DataModificationTransaction beginTransaction() { - // TODO Auto-generated method stub - return null; + return dataReader.beginTransaction(); } @Override public ListenerRegistration registerDataChangeListener(InstanceIdentifier path, DataChangeListener listener) { - // TODO Auto-generated method stub - return null; + return dataReader.registerDataChangeListener(path, listener); } @Override public void sendNotification(CompositeNode notification) { publish(notification); + } + + @Override + public Registration> registerCommitHandler( + InstanceIdentifier path, DataCommitHandler commitHandler) { + return dataReader.registerCommitHandler(path, commitHandler); + } + + @Override + public void removeRefresher(DataStoreIdentifier store, DataRefresher refresher) { + // NOOP + } + + @Override + public void addRefresher(DataStoreIdentifier store, DataRefresher refresher) { + // NOOP + } + + @Override + public void addValidator(DataStoreIdentifier store, DataValidator validator) { + // NOOP + } + @Override + public void removeValidator(DataStoreIdentifier store, DataValidator validator) { + // NOOP + } + + public SchemaContext getSchemaContext() { + return schemaContext; + } + + public void setSchemaContext(SchemaContext schemaContext) { + this.schemaContext = schemaContext; + } + + class ReadWrapper implements DataReader { + + + private InstanceIdentifier shortenPath(InstanceIdentifier path) { + InstanceIdentifier ret = null; + if(mountPath.contains(path)) { + List newArgs = path.getPath().subList(mountPath.getPath().size(), path.getPath().size()); + ret = new InstanceIdentifier(newArgs); + } + return ret; + } + @Override + public CompositeNode readConfigurationData(InstanceIdentifier path) { + InstanceIdentifier newPath = shortenPath(path); + if(newPath == null) { + return null; + } + return MountPointImpl.this.readConfigurationData(newPath); + } + + @Override + public CompositeNode readOperationalData(InstanceIdentifier path) { + InstanceIdentifier newPath = shortenPath(path); + if(newPath == null) { + return null; + } + return MountPointImpl.this.readOperationalData(newPath); + } + } + + @Override + public ListenerRegistration>> registerCommitHandlerListener( + RegistrationListener> commitHandlerListener) { + return dataReader.registerCommitHandlerListener(commitHandlerListener); } }