Add read-write transaction to the AsyncDataBroker APIs
[mdsal.git] / binding / mdsal-binding-api / src / main / java / org / opendaylight / mdsal / binding / api / DataBroker.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.api;
9
10 import org.opendaylight.mdsal.common.api.AsyncDataBroker;
11 import org.opendaylight.mdsal.common.api.TransactionChainFactory;
12 import org.opendaylight.mdsal.common.api.TransactionChainListener;
13 import org.opendaylight.yangtools.yang.binding.DataObject;
14 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
15
16 /**
17  * Provides access to a conceptual data tree store and also provides the ability to
18  * subscribe for changes to data under a given branch of the tree.
19  *
20  * <p>
21  * For more information on usage, please see the documentation in {@link AsyncDataBroker}.
22  *
23  * @see AsyncDataBroker
24  * @see TransactionChainFactory
25  */
26 public interface DataBroker extends  AsyncDataBroker<InstanceIdentifier<?>, DataObject>,
27     TransactionChainFactory<InstanceIdentifier<?>, DataObject>, TransactionFactory, BindingService,
28         DataTreeChangeService {
29
30     @Override
31     ReadTransaction newReadOnlyTransaction();
32
33     @Override
34     WriteTransaction newWriteOnlyTransaction();
35
36     @Override
37     ReadWriteTransaction newReadWriteTransaction();
38
39     @Override
40     BindingTransactionChain createTransactionChain(TransactionChainListener listener);
41 }