X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=netconf%2Fsal-netconf-connector%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fnetconf%2Fsal%2Fconnect%2Fnetconf%2Fsal%2FNetconfDeviceTopologyAdapter.java;h=202517fb14d5c98b9950f016dacac6d6190ab494;hb=33d6351332b51e2cfd454daf673c7663b03f096c;hp=1e65ec83df5683095cc10aa84050f68ec5754031;hpb=1d91e1bbe29d0da6ea427a5d0837064c8a3d5134;p=netconf.git diff --git a/netconf/sal-netconf-connector/src/main/java/org/opendaylight/netconf/sal/connect/netconf/sal/NetconfDeviceTopologyAdapter.java b/netconf/sal-netconf-connector/src/main/java/org/opendaylight/netconf/sal/connect/netconf/sal/NetconfDeviceTopologyAdapter.java index 1e65ec83df..202517fb14 100644 --- a/netconf/sal-netconf-connector/src/main/java/org/opendaylight/netconf/sal/connect/netconf/sal/NetconfDeviceTopologyAdapter.java +++ b/netconf/sal-netconf-connector/src/main/java/org/opendaylight/netconf/sal/connect/netconf/sal/NetconfDeviceTopologyAdapter.java @@ -96,20 +96,30 @@ public class NetconfDeviceTopologyAdapter implements AutoCloseable { commitTransaction(writeTx, "init"); } - public void updateDeviceData(final boolean up, final NetconfDeviceCapabilities capabilities) { - final NetconfNode data = buildDataForNetconfNode(up, capabilities); + public void updateDeviceData(final ConnectionStatus connectionStatus, + final NetconfDeviceCapabilities capabilities, final LogicalDatastoreType dsType, final NetconfNode node) { + NetconfNode data; + if (node != null && dsType == LogicalDatastoreType.CONFIGURATION) { + data = node; + } else { + data = buildDataForNetconfNode(connectionStatus, capabilities, dsType, node); + } final WriteTransaction writeTx = txChain.newWriteOnlyTransaction(); LOG.trace("{}: Update device state transaction {} merging operational data started.", id, writeTx.getIdentifier()); - writeTx.put(LogicalDatastoreType.OPERATIONAL, id.getTopologyBindingPath().augmentation(NetconfNode.class), - data, true); + writeTx.put(dsType, id.getTopologyBindingPath().augmentation(NetconfNode.class), data, true); LOG.trace("{}: Update device state transaction {} merging operational data ended.", id, writeTx.getIdentifier()); commitTransaction(writeTx, "update"); } + public void updateDeviceData(final boolean up, final NetconfDeviceCapabilities capabilities) { + updateDeviceData(up ? ConnectionStatus.Connected : ConnectionStatus.Connecting, capabilities, + LogicalDatastoreType.OPERATIONAL, null); + } + public void updateClusteredDeviceData(final boolean up, final String masterAddress, final NetconfDeviceCapabilities capabilities) { final NetconfNode data = buildDataForNetconfClusteredNode(up, masterAddress, capabilities); @@ -146,7 +156,8 @@ public class NetconfDeviceTopologyAdapter implements AutoCloseable { commitTransaction(writeTx, "update-failed-device"); } - private NetconfNode buildDataForNetconfNode(final boolean up, final NetconfDeviceCapabilities capabilities) { + private NetconfNode buildDataForNetconfNode(final ConnectionStatus connectionStatus, + final NetconfDeviceCapabilities capabilities, final LogicalDatastoreType dsType, final NetconfNode node) { List capabilityList = new ArrayList<>(); capabilityList.addAll(capabilities.getNonModuleBasedCapabilities()); capabilityList.addAll(capabilities.getResolvedCapabilities()); @@ -154,14 +165,13 @@ public class NetconfDeviceTopologyAdapter implements AutoCloseable { final AvailableCapabilitiesBuilder avCapabalitiesBuilder = new AvailableCapabilitiesBuilder(); avCapabalitiesBuilder.setAvailableCapability(capabilityList); - final NetconfNodeBuilder netconfNodeBuilder = new NetconfNodeBuilder() - .setHost(id.getHost()) - .setPort(new PortNumber(id.getAddress().getPort())) - .setConnectionStatus(up ? ConnectionStatus.Connected : ConnectionStatus.Connecting) - .setAvailableCapabilities(avCapabalitiesBuilder.build()) - .setUnavailableCapabilities(unavailableCapabilities(capabilities.getUnresolvedCapabilites())); - - return netconfNodeBuilder.build(); + return new NetconfNodeBuilder() + .setHost(id.getHost()) + .setPort(new PortNumber(id.getAddress().getPort())) + .setConnectionStatus(connectionStatus) + .setAvailableCapabilities(avCapabalitiesBuilder.build()) + .setUnavailableCapabilities(unavailableCapabilities(capabilities.getUnresolvedCapabilites())) + .build(); } private NetconfNode buildDataForNetconfClusteredNode(final boolean up, final String masterNodeAddress,