2 * Copyright (c) 2016 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.dom.broker.impl.legacy.sharded.adapter;
10 import static com.google.common.base.Preconditions.checkNotNull;
12 import java.util.Collections;
14 import java.util.concurrent.atomic.AtomicLong;
15 import org.opendaylight.controller.md.sal.common.api.data.TransactionChainListener;
16 import org.opendaylight.controller.md.sal.dom.api.DOMDataBroker;
17 import org.opendaylight.controller.md.sal.dom.api.DOMDataBrokerExtension;
18 import org.opendaylight.controller.md.sal.dom.api.DOMDataReadOnlyTransaction;
19 import org.opendaylight.controller.md.sal.dom.api.DOMDataReadWriteTransaction;
20 import org.opendaylight.controller.md.sal.dom.api.DOMDataWriteTransaction;
21 import org.opendaylight.controller.md.sal.dom.api.DOMTransactionChain;
22 import org.opendaylight.mdsal.dom.api.DOMSchemaService;
23 import org.opendaylight.mdsal.dom.broker.ShardedDOMDataBrokerAdapter;
26 * DOMDataBroker implementation that forwards calls to
27 * {@link org.opendaylight.mdsal.dom.broker.ShardedDOMDataBrokerAdapter},
28 * which in turn translates calls to shard aware implementation of
29 * {@link org.opendaylight.mdsal.dom.api.DOMDataTreeService}
32 * The incompatibility between first and latter APIs, puts restriction on {@link DOMDataReadWriteTransaction}
33 * and {@link DOMDataReadOnlyTransaction} provided by this data broker. See
34 * {@link ShardedDOMDataBrokerDelegatingReadWriteTransaction}
35 * and {@link ShardedDOMDataBrokerDelegatingReadTransaction} respectively.
37 // FIXME try to refactor some of the implementation to abstract class for better reusability
38 public class LegacyShardedDOMDataBrokerAdapter implements DOMDataBroker {
40 private final org.opendaylight.mdsal.dom.api.DOMDataBroker delegateDataBroker;
41 private final DOMSchemaService schemaService;
42 private final AtomicLong txNum = new AtomicLong();
43 private final AtomicLong chainNum = new AtomicLong();
45 public LegacyShardedDOMDataBrokerAdapter(final ShardedDOMDataBrokerAdapter delegateDataBroker,
46 final DOMSchemaService schemaService) {
47 this.delegateDataBroker = checkNotNull(delegateDataBroker);
48 this.schemaService = checkNotNull(schemaService);
52 public DOMDataReadOnlyTransaction newReadOnlyTransaction() {
53 return new ShardedDOMDataBrokerDelegatingReadTransaction(newTransactionIdentifier(),
54 delegateDataBroker.newReadOnlyTransaction());
58 public DOMDataReadWriteTransaction newReadWriteTransaction() {
59 return new ShardedDOMDataBrokerDelegatingReadWriteTransaction(newTransactionIdentifier(),
60 schemaService.getGlobalContext(),
61 newReadOnlyTransaction(),
62 newWriteOnlyTransaction());
66 public DOMDataWriteTransaction newWriteOnlyTransaction() {
67 return new ShardedDOMDataBrokerDelegatingWriteTransaction(newTransactionIdentifier(),
68 delegateDataBroker.newWriteOnlyTransaction());
72 public DOMTransactionChain createTransactionChain(final TransactionChainListener listener) {
73 return new ShardedDOMDataBrokerDelegatingTransactionChain(chainNum.getAndIncrement(),
74 schemaService.getGlobalContext(), delegateDataBroker,
79 public Map<Class<? extends DOMDataBrokerExtension>, DOMDataBrokerExtension> getSupportedExtensions() {
80 return Collections.emptyMap();
83 private Object newTransactionIdentifier() {
84 return "DOM-" + txNum.getAndIncrement();