X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-distributed-datastore%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatastore%2FShardTransactionChain.java;h=42bd257ad1cdb97b3d28ab2588bbe6161894b8e9;hp=c508255ea490ee09b370dae8a49320495166c820;hb=9cd4e7995210f8381892004373acc71c8b3ae7af;hpb=bc7b4edec3c868a14e0a0de3a3b8e1af2406448b diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/ShardTransactionChain.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/ShardTransactionChain.java index c508255ea4..42bd257ad1 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/ShardTransactionChain.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/ShardTransactionChain.java @@ -11,6 +11,7 @@ package org.opendaylight.controller.cluster.datastore; import akka.actor.ActorRef; import akka.actor.Props; import akka.japi.Creator; + import org.opendaylight.controller.cluster.datastore.messages.CloseTransactionChain; import org.opendaylight.controller.cluster.datastore.messages.CloseTransactionChainReply; import org.opendaylight.controller.cluster.datastore.messages.CreateTransaction; @@ -24,10 +25,13 @@ import org.opendaylight.yangtools.yang.model.api.SchemaContext; public class ShardTransactionChain extends AbstractUntypedActor { private final DOMStoreTransactionChain chain; + private final ShardContext shardContext; private final SchemaContext schemaContext; - public ShardTransactionChain(DOMStoreTransactionChain chain, SchemaContext schemaContext) { + public ShardTransactionChain(DOMStoreTransactionChain chain, SchemaContext schemaContext, + ShardContext shardContext) { this.chain = chain; + this.shardContext = shardContext; this.schemaContext = schemaContext; } @@ -48,23 +52,29 @@ public class ShardTransactionChain extends AbstractUntypedActor { return getContext().parent(); } - private ActorRef createTypedTransactionActor(CreateTransaction createTransaction,String transactionId){ - if(createTransaction.getTransactionType()== TransactionProxy.TransactionType.READ_ONLY.ordinal()){ - return getContext().actorOf( - ShardTransaction.props( chain.newReadOnlyTransaction(), getShardActor(), schemaContext), transactionId); - - }else if (createTransaction.getTransactionType()== TransactionProxy.TransactionType.READ_WRITE.ordinal()){ - return getContext().actorOf( - ShardTransaction.props( chain.newReadWriteTransaction(), getShardActor(), schemaContext), transactionId); - - - }else if (createTransaction.getTransactionType()== TransactionProxy.TransactionType.WRITE_ONLY.ordinal()){ - return getContext().actorOf( - ShardTransaction.props( chain.newWriteOnlyTransaction(), getShardActor(), schemaContext), transactionId); - }else{ - throw new IllegalArgumentException ("CreateTransaction message has unidentified transaction type="+createTransaction.getTransactionType()) ; + private ActorRef createTypedTransactionActor(CreateTransaction createTransaction, + String transactionId) { + if(createTransaction.getTransactionType() == + TransactionProxy.TransactionType.READ_ONLY.ordinal()) { + return getContext().actorOf( + ShardTransaction.props( chain.newReadOnlyTransaction(), getShardActor(), + schemaContext, shardContext), transactionId); + } else if (createTransaction.getTransactionType() == + TransactionProxy.TransactionType.READ_WRITE.ordinal()) { + return getContext().actorOf( + ShardTransaction.props( chain.newReadWriteTransaction(), getShardActor(), + schemaContext, shardContext), transactionId); + } else if (createTransaction.getTransactionType() == + TransactionProxy.TransactionType.WRITE_ONLY.ordinal()) { + return getContext().actorOf( + ShardTransaction.props( chain.newWriteOnlyTransaction(), getShardActor(), + schemaContext, shardContext), transactionId); + } else { + throw new IllegalArgumentException ( + "CreateTransaction message has unidentified transaction type=" + + createTransaction.getTransactionType()); + } } - } private void createTransaction(CreateTransaction createTransaction) { @@ -74,13 +84,28 @@ public class ShardTransactionChain extends AbstractUntypedActor { getSelf()); } - public static Props props(final DOMStoreTransactionChain chain, final SchemaContext schemaContext) { - return Props.create(new Creator() { + public static Props props(DOMStoreTransactionChain chain, SchemaContext schemaContext, + ShardContext shardContext) { + return Props.create(new ShardTransactionChainCreator(chain, schemaContext, shardContext)); + } - @Override - public ShardTransactionChain create() throws Exception { - return new ShardTransactionChain(chain, schemaContext); - } - }); + private static class ShardTransactionChainCreator implements Creator { + private static final long serialVersionUID = 1L; + + final DOMStoreTransactionChain chain; + final ShardContext shardContext; + final SchemaContext schemaContext; + + ShardTransactionChainCreator(DOMStoreTransactionChain chain, SchemaContext schemaContext, + ShardContext shardContext) { + this.chain = chain; + this.shardContext = shardContext; + this.schemaContext = schemaContext; + } + + @Override + public ShardTransactionChain create() throws Exception { + return new ShardTransactionChain(chain, schemaContext, shardContext); + } } }