X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=binding%2Fmdsal-binding-dom-adapter%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fmdsal%2Fbinding%2Fdom%2Fadapter%2FActionProviderServiceAdapter.java;h=a3ad6568c0eee1351db8701c92f71918d04094c9;hb=5f8a373c07549a901b70595067dd11c161d0c4e4;hp=dc3492a65533bf213c7d2473f063e57214b1ec64;hpb=c86b76bc49e598dbf62ee74be9518cef263d7586;p=mdsal.git diff --git a/binding/mdsal-binding-dom-adapter/src/main/java/org/opendaylight/mdsal/binding/dom/adapter/ActionProviderServiceAdapter.java b/binding/mdsal-binding-dom-adapter/src/main/java/org/opendaylight/mdsal/binding/dom/adapter/ActionProviderServiceAdapter.java index dc3492a655..a3ad6568c0 100644 --- a/binding/mdsal-binding-dom-adapter/src/main/java/org/opendaylight/mdsal/binding/dom/adapter/ActionProviderServiceAdapter.java +++ b/binding/mdsal-binding-dom-adapter/src/main/java/org/opendaylight/mdsal/binding/dom/adapter/ActionProviderServiceAdapter.java @@ -29,8 +29,7 @@ import org.opendaylight.mdsal.dom.api.DOMActionResult; import org.opendaylight.mdsal.dom.api.DOMDataTreeIdentifier; import org.opendaylight.mdsal.dom.api.DOMService; import org.opendaylight.mdsal.dom.spi.SimpleDOMActionResult; -import org.opendaylight.yangtools.concepts.AbstractObjectRegistration; -import org.opendaylight.yangtools.concepts.ObjectRegistration; +import org.opendaylight.yangtools.concepts.Registration; import org.opendaylight.yangtools.yang.binding.Action; import org.opendaylight.yangtools.yang.binding.DataObject; import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; @@ -75,29 +74,22 @@ public final class ActionProviderServiceAdapter extends AbstractBindingAdapter, ?, ?>, S extends A> - ObjectRegistration registerImplementation(final ActionSpec spec, final S implementation, + public

, ?, ?>> + Registration registerImplementation(final ActionSpec spec, final A implementation, final LogicalDatastoreType datastore, final Set> validNodes) { final CurrentAdapterSerializer serializer = currentSerializer(); final Absolute actionPath = serializer.getActionPath(spec); final Impl impl = new Impl(adapterContext(), actionPath, spec.type(), implementation); final DOMActionInstance instance = validNodes.isEmpty() // Register on the entire datastore - ? DOMActionInstance.of(actionPath, new DOMDataTreeIdentifier(datastore, YangInstanceIdentifier.of())) + ? DOMActionInstance.of(actionPath, DOMDataTreeIdentifier.of(datastore, YangInstanceIdentifier.of())) // Register on specific instances : DOMActionInstance.of(actionPath, validNodes.stream() - .map(node -> serializer.toDOMDataTreeIdentifier(DataTreeIdentifier.create(datastore, node))) + .map(node -> serializer.toDOMDataTreeIdentifier(DataTreeIdentifier.of(datastore, node))) .collect(Collectors.toUnmodifiableSet())); - final ObjectRegistration reg = getDelegate().registerActionImplementation(impl, instance); - - return new AbstractObjectRegistration<>(implementation) { - @Override - protected void removeRegistration() { - reg.close(); - } - }; + return getDelegate().registerActionImplementation(impl, instance); } private static final class Impl implements DOMActionImplementation { @@ -121,7 +113,7 @@ public final class ActionProviderServiceAdapter extends AbstractBindingAdapter invokeAction(final Absolute type, final DOMDataTreeIdentifier path, final ContainerNode input) { final CurrentAdapterSerializer codec = adapterContext.currentSerializer(); - final InstanceIdentifier instance = codec.fromYangInstanceIdentifier(path.getRootIdentifier()); + final InstanceIdentifier instance = codec.fromYangInstanceIdentifier(path.path()); if (instance == null) { // Not representable: return an error LOG.debug("Path {} is not representable in binding, rejecting invocation", path);