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.mdsal.dom.broker;
10 import org.opendaylight.mdsal.dom.spi.store.DOMStoreReadTransaction;
12 import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
13 import org.opendaylight.mdsal.common.api.ReadFailedException;
14 import org.opendaylight.mdsal.dom.api.DOMDataReadOnlyTransaction;
15 import com.google.common.base.Optional;
16 import com.google.common.util.concurrent.CheckedFuture;
18 import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
19 import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
22 * Read Only Transaction, which is composed of several
23 * {@link DOMStoreReadTransaction} transactions. Subtransaction is selected by
24 * {@link LogicalDatastoreType} type parameter in
25 * {@link #read(LogicalDatastoreType, YangInstanceIdentifier)}.
27 class DOMForwardedReadOnlyTransaction extends
28 AbstractDOMForwardedCompositeTransaction<LogicalDatastoreType, DOMStoreReadTransaction> implements
29 DOMDataReadOnlyTransaction {
31 protected DOMForwardedReadOnlyTransaction(final Object identifier,
32 final Map<LogicalDatastoreType, DOMStoreReadTransaction> backingTxs) {
33 super(identifier, backingTxs);
37 public CheckedFuture<Optional<NormalizedNode<?,?>>, ReadFailedException> read(
38 final LogicalDatastoreType store, final YangInstanceIdentifier path) {
39 return getSubtransaction(store).read(path);
43 public CheckedFuture<Boolean, ReadFailedException> exists(
44 final LogicalDatastoreType store,
45 final YangInstanceIdentifier path) {
46 return getSubtransaction(store).exists(path);
51 closeSubtransactions();