2 * Copyright (c) 2014 Cisco Systems, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.controller.md.sal.binding.impl;
11 import com.google.common.collect.ClassToInstanceMap;
12 import com.google.common.collect.ImmutableSet;
14 import org.opendaylight.controller.md.sal.binding.api.BindingTransactionChain;
15 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
16 import org.opendaylight.controller.md.sal.binding.api.DataTreeChangeListener;
17 import org.opendaylight.controller.md.sal.binding.api.DataTreeChangeService;
18 import org.opendaylight.controller.md.sal.binding.api.DataTreeIdentifier;
19 import org.opendaylight.controller.md.sal.binding.api.ReadOnlyTransaction;
20 import org.opendaylight.controller.md.sal.binding.api.ReadWriteTransaction;
21 import org.opendaylight.controller.md.sal.binding.api.WriteTransaction;
22 import org.opendaylight.controller.md.sal.binding.impl.BindingDOMAdapterBuilder.Factory;
23 import org.opendaylight.controller.md.sal.common.api.data.TransactionChainListener;
24 import org.opendaylight.controller.md.sal.dom.api.DOMDataBroker;
25 import org.opendaylight.controller.md.sal.dom.api.DOMDataTreeChangeService;
26 import org.opendaylight.controller.md.sal.dom.api.DOMService;
27 import org.opendaylight.yangtools.concepts.ListenerRegistration;
28 import org.opendaylight.yangtools.yang.binding.DataObject;
31 * The DataBrokerImpl simply defers to the DOMDataBroker for all its operations.
32 * All transactions and listener registrations are wrapped by the DataBrokerImpl
33 * to allow binding aware components to use the DataBroker transparently.
35 * Besides this the DataBrokerImpl and it's collaborators also cache data that
36 * is already transformed from the binding independent to binding aware format
40 public class BindingDOMDataBrokerAdapter extends AbstractForwardedDataBroker implements DataBroker, DataTreeChangeService {
43 static final Factory<DataBroker> BUILDER_FACTORY = () -> new Builder();
44 private final DataTreeChangeService treeChangeService;
46 public BindingDOMDataBrokerAdapter(final DOMDataBroker domDataBroker, final BindingToNormalizedNodeCodec codec) {
47 super(domDataBroker, codec);
48 final DOMDataTreeChangeService domTreeChange = (DOMDataTreeChangeService) domDataBroker.getSupportedExtensions().get(DOMDataTreeChangeService.class);
49 if(domTreeChange != null) {
50 treeChangeService = BindingDOMDataTreeChangeServiceAdapter.create(codec, domTreeChange);
52 treeChangeService = null;
58 public ReadOnlyTransaction newReadOnlyTransaction() {
59 return new BindingDOMReadTransactionAdapter(getDelegate().newReadOnlyTransaction(),getCodec());
63 public ReadWriteTransaction newReadWriteTransaction() {
64 return new BindingDOMReadWriteTransactionAdapter(getDelegate().newReadWriteTransaction(),getCodec());
68 public WriteTransaction newWriteOnlyTransaction() {
69 return new BindingDOMWriteTransactionAdapter<>(getDelegate().newWriteOnlyTransaction(),getCodec());
73 public BindingTransactionChain createTransactionChain(final TransactionChainListener listener) {
74 return new BindingDOMTransactionChainAdapter(getDelegate(), getCodec(), listener);
78 public String toString() {
79 return "BindingDOMDataBrokerAdapter for " + getDelegate();
82 private static class Builder extends BindingDOMAdapterBuilder<DataBroker> {
85 public Set<? extends Class<? extends DOMService>> getRequiredDelegates() {
86 return ImmutableSet.of(DOMDataBroker.class);
90 protected DataBroker createInstance(final BindingToNormalizedNodeCodec codec,
91 final ClassToInstanceMap<DOMService> delegates) {
92 final DOMDataBroker domDataBroker = delegates.getInstance(DOMDataBroker.class);
93 return new BindingDOMDataBrokerAdapter(domDataBroker, codec);
99 public <T extends DataObject, L extends DataTreeChangeListener<T>> ListenerRegistration<L> registerDataTreeChangeListener(
100 final DataTreeIdentifier<T> treeId, final L listener) {
101 if(treeChangeService == null) {
102 throw new UnsupportedOperationException("Underlying data broker does not expose DOMDataTreeChangeService.");
104 return treeChangeService.registerDataTreeChangeListener(treeId, listener);