import static java.util.Objects.requireNonNull;
import com.google.common.annotations.Beta;
+import com.google.common.collect.ClassToInstanceMap;
import com.google.common.collect.ImmutableSet;
import com.google.common.util.concurrent.FluentFuture;
import java.lang.reflect.Proxy;
import java.util.Set;
import org.eclipse.jdt.annotation.NonNullByDefault;
+import org.eclipse.jdt.annotation.Nullable;
import org.opendaylight.mdsal.binding.api.ActionService;
import org.opendaylight.mdsal.binding.api.DataTreeIdentifier;
+import org.opendaylight.mdsal.binding.dom.adapter.BindingDOMAdapterBuilder.Factory;
import org.opendaylight.mdsal.binding.spec.reflect.BindingReflections;
-import org.opendaylight.mdsal.dom.api.DOMOperationService;
+import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
+import org.opendaylight.mdsal.dom.api.DOMActionService;
+import org.opendaylight.mdsal.dom.api.DOMService;
import org.opendaylight.yangtools.concepts.Delegator;
import org.opendaylight.yangtools.yang.binding.Action;
import org.opendaylight.yangtools.yang.binding.DataObject;
@Beta
@NonNullByDefault
-final class ActionServiceAdapter
- extends AbstractBindingLoadingAdapter<DOMOperationService, Class<? extends Action<?, ?, ?>>, ActionAdapter>
+// FIXME: make this class non-public once the controller user is gone
+public final class ActionServiceAdapter
+ extends AbstractBindingLoadingAdapter<DOMActionService, Class<? extends Action<?, ?, ?>>, ActionAdapter>
implements ActionService {
+ private static final class Builder extends BindingDOMAdapterBuilder<ActionService> {
+ @Override
+ protected ActionService createInstance(final @Nullable BindingToNormalizedNodeCodec codec,
+ final ClassToInstanceMap<DOMService> delegates) {
+ final DOMActionService domAction = delegates.getInstance(DOMActionService.class);
+ return new ActionServiceAdapter(requireNonNull(codec), domAction);
+ }
+
+ @Override
+ public Set<? extends Class<? extends DOMService>> getRequiredDelegates() {
+ return ImmutableSet.of(DOMActionService.class);
+ }
+ }
+
private static final class ConstrainedAction implements Delegator<Action<?, ?, ?>>,
Action<InstanceIdentifier<?>, RpcInput, RpcOutput> {
private final Action<InstanceIdentifier<?>, RpcInput, RpcOutput> delegate;
@Override
public FluentFuture<RpcResult<RpcOutput>> invoke(final InstanceIdentifier<?> path, final RpcInput input) {
- checkState(nodes.contains(path), "Cannot service %s", path);
+ checkState(nodes.contains(DataTreeIdentifier.create(LogicalDatastoreType.OPERATIONAL, path)),
+ "Cannot service %s", path);
return delegate.invoke(path, input);
}
}
}
- ActionServiceAdapter(final BindingToNormalizedNodeCodec codec, final DOMOperationService delegate) {
+ static final Factory<ActionService> BUILDER_FACTORY = Builder::new;
+
+ ActionServiceAdapter(final BindingToNormalizedNodeCodec codec, final DOMActionService delegate) {
super(codec, delegate);
}
+ @Deprecated
+ public static ActionServiceAdapter create(final BindingToNormalizedNodeCodec codec,
+ final DOMActionService delegate) {
+ return new ActionServiceAdapter(codec, delegate);
+ }
+
@Override
public <O extends DataObject, T extends Action<?, ?, ?>> T getActionHandle(final Class<T> actionInterface,
final Set<DataTreeIdentifier<O>> nodes) {