ed4bb01530668d7da5a5d2a0ed83eede072321ba
[mdsal.git] / binding / mdsal-binding-dom-adapter / src / main / java / org / opendaylight / mdsal / binding / dom / adapter / BindingDOMDataBrokerAdapter.java
1 /*
2  * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
3  *
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
7  */
8 package org.opendaylight.mdsal.binding.dom.adapter;
9
10
11 import org.opendaylight.mdsal.common.api.TransactionChainListener;
12
13 import org.opendaylight.mdsal.dom.api.DOMDataBroker;
14 import org.opendaylight.mdsal.dom.api.DOMDataTreeChangeService;
15 import org.opendaylight.mdsal.dom.api.DOMService;
16 import org.opendaylight.mdsal.binding.api.BindingTransactionChain;
17 import org.opendaylight.mdsal.binding.api.DataBroker;
18 import org.opendaylight.mdsal.binding.api.DataTreeChangeListener;
19 import org.opendaylight.mdsal.binding.api.DataTreeChangeService;
20 import org.opendaylight.mdsal.binding.api.DataTreeIdentifier;
21 import org.opendaylight.mdsal.binding.api.ReadOnlyTransaction;
22 import org.opendaylight.mdsal.binding.api.WriteTransaction;
23 import org.opendaylight.mdsal.binding.dom.adapter.BindingDOMAdapterBuilder.Factory;
24 import com.google.common.collect.ClassToInstanceMap;
25 import com.google.common.collect.ImmutableSet;
26 import java.util.Set;
27 import org.opendaylight.yangtools.concepts.ListenerRegistration;
28 import org.opendaylight.yangtools.yang.binding.DataObject;
29
30 /**
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.
34  *
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
37  *
38
39  */
40 public class BindingDOMDataBrokerAdapter extends AbstractForwardedDataBroker implements DataBroker, DataTreeChangeService {
41
42
43     static final Factory<DataBroker> BUILDER_FACTORY = new BindingDOMAdapterBuilder.Factory<DataBroker>() {
44
45         @Override
46         public BindingDOMAdapterBuilder<DataBroker> newBuilder() {
47             return new Builder();
48         }
49
50     };
51     private final DataTreeChangeService treeChangeService;
52
53     public BindingDOMDataBrokerAdapter(final DOMDataBroker domDataBroker, final BindingToNormalizedNodeCodec codec) {
54         super(domDataBroker, codec);
55         final DOMDataTreeChangeService domTreeChange = (DOMDataTreeChangeService) domDataBroker.getSupportedExtensions().get(DOMDataTreeChangeService.class);
56         if(domTreeChange != null) {
57             treeChangeService = BindingDOMDataTreeChangeServiceAdapter.create(codec, domTreeChange);
58         } else {
59             treeChangeService = null;
60         }
61     }
62
63     @Override
64     public ReadOnlyTransaction newReadOnlyTransaction() {
65         return new BindingDOMReadTransactionAdapter(getDelegate().newReadOnlyTransaction(),getCodec());
66     }
67
68     @Override
69     public WriteTransaction newWriteOnlyTransaction() {
70         return new BindingDOMWriteTransactionAdapter<>(getDelegate().newWriteOnlyTransaction(),getCodec());
71     }
72
73     @Override
74     public BindingTransactionChain createTransactionChain(final TransactionChainListener listener) {
75         return new BindingDOMTransactionChainAdapter(getDelegate(), getCodec(), listener);
76     }
77
78     private static class Builder extends BindingDOMAdapterBuilder<DataBroker> {
79
80         @Override
81         public Set<? extends Class<? extends DOMService>> getRequiredDelegates() {
82             return ImmutableSet.of(DOMDataBroker.class);
83         }
84
85         @Override
86         protected DataBroker createInstance(final BindingToNormalizedNodeCodec codec,
87                 final ClassToInstanceMap<DOMService> delegates) {
88             final DOMDataBroker domDataBroker = delegates.getInstance(DOMDataBroker.class);
89             return new BindingDOMDataBrokerAdapter(domDataBroker, codec);
90         }
91
92     }
93
94     @Override
95     public <T extends DataObject, L extends DataTreeChangeListener<T>> ListenerRegistration<L> registerDataTreeChangeListener(
96             final DataTreeIdentifier<T> treeId, final L listener) {
97         if(treeChangeService == null) {
98             throw new UnsupportedOperationException("Underlying data broker does not expose DOMDataTreeChangeService.");
99         }
100         return treeChangeService.registerDataTreeChangeListener(treeId, listener);
101     }
102
103 }