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%2Fmd%2Fsal%2Fdom%2Fbroker%2Fimpl%2Fcompat%2FBackwardsCompatibleTransaction.java;h=29f2af511e8b8bb03ab0921837b8acae80aa59a7;hb=refs%2Fchanges%2F38%2F6338%2F3;hp=fce24945549e9bf4c36cd7815216f550b5dc40b7;hpb=59cb3e27630fb1fd965152f9e1584213e89fa62f;p=controller.git diff --git a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/broker/impl/compat/BackwardsCompatibleTransaction.java b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/broker/impl/compat/BackwardsCompatibleTransaction.java index fce2494554..29f2af511e 100644 --- a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/broker/impl/compat/BackwardsCompatibleTransaction.java +++ b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/broker/impl/compat/BackwardsCompatibleTransaction.java @@ -1,3 +1,10 @@ +/* + * Copyright (c) 2014 Cisco Systems, Inc. and others. All rights reserved. + * + * This program and the accompanying materials are made available under the + * 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.md.sal.dom.broker.impl.compat; import static com.google.common.base.Preconditions.checkNotNull; @@ -14,6 +21,7 @@ import java.util.concurrent.Future; import org.opendaylight.controller.md.sal.common.api.TransactionStatus; import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType; +import org.opendaylight.controller.md.sal.common.impl.util.compat.DataNormalizationException; import org.opendaylight.controller.md.sal.common.impl.util.compat.DataNormalizationOperation; import org.opendaylight.controller.md.sal.common.impl.util.compat.DataNormalizer; import org.opendaylight.controller.md.sal.dom.api.DOMDataReadTransaction; @@ -24,21 +32,13 @@ import org.opendaylight.yangtools.concepts.ListenerRegistration; 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.AugmentationIdentifier; -import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.NodeIdentifier; import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.PathArgument; -import org.opendaylight.yangtools.yang.data.api.schema.AugmentationNode; -import org.opendaylight.yangtools.yang.data.api.schema.LeafSetNode; -import org.opendaylight.yangtools.yang.data.api.schema.MapEntryNode; -import org.opendaylight.yangtools.yang.data.api.schema.MapNode; import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; -import org.opendaylight.yangtools.yang.data.impl.schema.Builders; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import com.google.common.base.Optional; import com.google.common.base.Preconditions; -import com.google.common.collect.Iterables; import com.google.common.util.concurrent.ListenableFuture; public abstract class BackwardsCompatibleTransaction implements @@ -232,12 +232,16 @@ public abstract class BackwardsCompatibleTransaction iterator = normalizedPath.getPath().iterator(); while(iterator.hasNext()) { PathArgument currentArg = iterator.next(); - currentOp = currentOp.getChild(currentArg); + try { + currentOp = currentOp.getChild(currentArg); + } catch (DataNormalizationException e) { + throw new IllegalArgumentException(String.format("Invalid child encountered in path %s", normalizedPath), e); + } currentArguments.add(currentArg); InstanceIdentifier currentPath = new InstanceIdentifier(currentArguments); boolean isPresent = getDelegate().read(store, currentPath).get().isPresent(); if(isPresent == false && iterator.hasNext()) { - getDelegate().put(store, currentPath, currentOp.createDefault(currentArg)); + getDelegate().merge(store, currentPath, currentOp.createDefault(currentArg)); } } } catch (InterruptedException | ExecutionException e) { @@ -247,48 +251,6 @@ public abstract class BackwardsCompatibleTransaction parentArgs = parentPath(normalizedPath).getPath(); - if(parentArgs.isEmpty()) { - return false; - } - return Iterables.getLast(parentArgs) instanceof AugmentationIdentifier; - } - - private void ensureParentNode(final LogicalDatastoreType store, final InstanceIdentifier normalizedPath, - final NormalizedNode normalizedData) { - InstanceIdentifier parentPath = parentPath(normalizedPath); - PathArgument parentType = Iterables.getLast(parentPath.getPath()); - if(parentType instanceof AugmentationIdentifier) { - AugmentationNode node = Builders.augmentationBuilder() - .withNodeIdentifier((AugmentationIdentifier) parentType) - .build(); - getDelegate().put(store, parentPath, node); - } - if(normalizedData instanceof MapEntryNode) { - MapNode mapNode = Builders.mapBuilder().withNodeIdentifier(new NodeIdentifier(normalizedData.getNodeType())).build(); - getDelegate().put(store, parentPath, mapNode); - } else if (normalizedData instanceof LeafSetNode){ - LeafSetNode leafNode = Builders.leafSetBuilder().withNodeIdentifier(new NodeIdentifier(normalizedData.getNodeType())).build(); - getDelegate().put(store, parentPath, leafNode); - } - - - } - - private InstanceIdentifier parentPath(final InstanceIdentifier normalizedPath) { - List childArgs = normalizedPath.getPath(); - return new InstanceIdentifier(childArgs.subList(0, childArgs.size() -1)); - } - - private boolean parentNodeDoesNotExists(final LogicalDatastoreType store, final InstanceIdentifier normalizedPath) { - try { - return !getDelegate().read(store, parentPath(normalizedPath)).get().isPresent(); - } catch (InterruptedException | ExecutionException e) { - throw new IllegalStateException(e); - } - } - @Override public void removeConfigurationData(final InstanceIdentifier legacyPath) { checkNotNull(legacyPath, "Path MUST NOT be null.");