X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-dom-broker%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fmd%2Fsal%2Fdom%2Fbroker%2Fimpl%2FAbstractDOMForwardedTransactionFactory.java;h=399dcd1df400b140845dd164265d1e093dd58a3f;hp=5694d0bca9a68fccd5f31557418a8824b35d7a5a;hb=aaea3e9a92ae9d6fac04c4a065db4b35cbca9ed0;hpb=aa7b316a424f60fb1b5179e44924e9457147093a diff --git a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/broker/impl/AbstractDOMForwardedTransactionFactory.java b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/broker/impl/AbstractDOMForwardedTransactionFactory.java index 5694d0bca9..399dcd1df4 100644 --- a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/broker/impl/AbstractDOMForwardedTransactionFactory.java +++ b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/broker/impl/AbstractDOMForwardedTransactionFactory.java @@ -7,27 +7,32 @@ */ package org.opendaylight.controller.md.sal.dom.broker.impl; +import com.google.common.base.Preconditions; +import com.google.common.base.Supplier; +import com.google.common.util.concurrent.ListenableFuture; +import java.util.Collection; +import java.util.EnumMap; import java.util.Map; import java.util.Map.Entry; - -import javax.annotation.concurrent.GuardedBy; - +import java.util.concurrent.atomic.AtomicIntegerFieldUpdater; import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType; +import org.opendaylight.controller.md.sal.common.api.data.TransactionCommitFailedException; import org.opendaylight.controller.md.sal.dom.api.DOMDataReadOnlyTransaction; import org.opendaylight.controller.md.sal.dom.api.DOMDataReadWriteTransaction; import org.opendaylight.controller.md.sal.dom.api.DOMDataWriteTransaction; import org.opendaylight.controller.sal.core.spi.data.DOMStoreReadTransaction; import org.opendaylight.controller.sal.core.spi.data.DOMStoreReadWriteTransaction; +import org.opendaylight.controller.sal.core.spi.data.DOMStoreThreePhaseCommitCohort; import org.opendaylight.controller.sal.core.spi.data.DOMStoreTransactionFactory; import org.opendaylight.controller.sal.core.spi.data.DOMStoreWriteTransaction; - -import com.google.common.base.Preconditions; -import com.google.common.collect.ImmutableMap; +import org.opendaylight.yangtools.concepts.Path; +import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; +import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; /** - * * Abstract composite transaction factory. * + *

* Provides an convenience common implementation for composite DOM Transactions, * where subtransaction is identified by {@link LogicalDatastoreType} type and * implementation of subtransaction is provided by @@ -40,51 +45,76 @@ import com.google.common.collect.ImmutableMap; * @param * Type of {@link DOMStoreTransactionFactory} factory. */ -public abstract class AbstractDOMForwardedTransactionFactory implements DOMDataCommitImplementation, AutoCloseable { - - private final ImmutableMap storeTxFactories; - - private boolean closed; +@Deprecated(forRemoval = true) +abstract class AbstractDOMForwardedTransactionFactory implements AutoCloseable { + @SuppressWarnings("rawtypes") + private static final AtomicIntegerFieldUpdater UPDATER = + AtomicIntegerFieldUpdater.newUpdater(AbstractDOMForwardedTransactionFactory.class, "closed"); + private final Map storeTxFactories; + private volatile int closed = 0; protected AbstractDOMForwardedTransactionFactory(final Map txFactories) { - this.storeTxFactories = ImmutableMap.copyOf(txFactories); + this.storeTxFactories = new EnumMap<>(txFactories); } /** * Implementations must return unique identifier for each and every call of - * this method; + * this method. * * @return new Unique transaction identifier. */ protected abstract Object newTransactionIdentifier(); + /** + * User-supplied implementation of {@link DOMDataWriteTransaction#commit()} + * for transaction. + * + *

+ * Callback invoked when {@link DOMDataWriteTransaction#commit()} is invoked + * on transaction created by this factory. + * + * @param transaction + * Transaction on which {@link DOMDataWriteTransaction#commit()} + * was invoked. + * @param cohorts + * Iteratable of cohorts for subtransactions associated with + * the transaction being committed. + * @return a ListenableFuture. if commit coordination on cohorts finished successfully, + * a CommitInfo is returned from the Future, On failure, + * the Future fails with a {@link TransactionCommitFailedException}. + */ + protected abstract ListenableFuture commit(DOMDataWriteTransaction transaction, + Collection cohorts, Supplier futureValueSupplier); + /** * Creates a new composite read-only transaction * + *

* Creates a new composite read-only transaction backed by one transaction * per factory in {@link #getTxFactories()}. * + *

* Subtransaction for reading is selected by supplied * {@link LogicalDatastoreType} as parameter for - * {@link DOMDataReadOnlyTransaction#read(LogicalDatastoreType,org.opendaylight.yangtools.yang.data.api.InstanceIdentifier)} - * . + * {@link DOMDataReadOnlyTransaction#read(LogicalDatastoreType, + * org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier)}. * + *

* Id of returned transaction is retrieved via * {@link #newTransactionIdentifier()}. * * @return New composite read-only transaction. */ - public DOMDataReadOnlyTransaction newReadOnlyTransaction() { + public final DOMDataReadOnlyTransaction newReadOnlyTransaction() { checkNotClosed(); - ImmutableMap.Builder builder = ImmutableMap.builder(); + + final Map txns = new EnumMap<>(LogicalDatastoreType.class); for (Entry store : storeTxFactories.entrySet()) { - builder.put(store.getKey(), store.getValue().newReadOnlyTransaction()); + txns.put(store.getKey(), store.getValue().newReadOnlyTransaction()); } - return new DOMForwardedReadOnlyTransaction(newTransactionIdentifier(), builder.build()); + return new DOMForwardedReadOnlyTransaction(newTransactionIdentifier(), txns); } - - /** * Creates a new composite write-only transaction * @@ -95,97 +125,109 @@ public abstract class AbstractDOMForwardedTransactionFactory * Implementation of composite Write-only transaction is following: * - *