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=e3099969c0aa249cbcd5ca18cd06920b3da802e5;hp=c1ac0e1a1fd7cbc0cce85f10ed934833a35823ec;hb=e1ede0942d3bff1f1b150816e6bfa96ed9366c20;hpb=4019c9fd2ad99628dd790acc1ad4c104f48b6428 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 c1ac0e1a1f..e3099969c0 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 @@ -8,23 +8,31 @@ 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 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 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 @@ -37,7 +45,7 @@ import org.opendaylight.controller.sal.core.spi.data.DOMStoreWriteTransaction; * @param * Type of {@link DOMStoreTransactionFactory} factory. */ -abstract class AbstractDOMForwardedTransactionFactory implements DOMDataCommitImplementation, AutoCloseable { +abstract class AbstractDOMForwardedTransactionFactory implements AutoCloseable { @SuppressWarnings("rawtypes") private static final AtomicIntegerFieldUpdater UPDATER = AtomicIntegerFieldUpdater.newUpdater(AbstractDOMForwardedTransactionFactory.class, "closed"); @@ -50,23 +58,47 @@ abstract class AbstractDOMForwardedTransactionFactory + * 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()}. * @@ -92,34 +124,36 @@ abstract class AbstractDOMForwardedTransactionFactory * Implementation of composite Write-only transaction is following: * - *