c7b0ee6adc01ae91c3222d6a25f708615f220242
[mdsal.git] / dom / mdsal-dom-inmemory-datastore / src / main / java / org / opendaylight / mdsal / dom / store / inmemory / ShardSubmitCoordinationTask.java
1 /*
2  * Copyright (c) 2016 Cisco Systems, Inc. and others.  All rights reserved.
3  *
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
7  */
8
9 package org.opendaylight.mdsal.dom.store.inmemory;
10
11 import com.google.common.annotations.Beta;
12 import com.google.common.base.Preconditions;
13 import java.util.Collection;
14 import java.util.concurrent.Callable;
15 import org.opendaylight.mdsal.common.api.TransactionCommitFailedException;
16 import org.opendaylight.mdsal.dom.api.DOMDataTreeIdentifier;
17 import org.opendaylight.mdsal.dom.spi.store.DOMStoreThreePhaseCommitCohort;
18 import org.slf4j.Logger;
19 import org.slf4j.LoggerFactory;
20
21 /**
22  * Task that coordinates all phases of transaction submit from the provided {@link DOMStoreThreePhaseCommitCohort}'s.
23  * Each phase will only be started once all cohorts have finished the previous phase.
24  */
25 @Beta
26 public class ShardSubmitCoordinationTask implements Callable<Void> {
27
28     private static final Logger LOG = LoggerFactory.getLogger(ShardSubmitCoordinationTask.class);
29
30     private final DOMDataTreeIdentifier rootShardPrefix;
31     private final ShardCanCommitCoordinationTask canCommitCoordinationTask;
32     private final ShardPreCommitCoordinationTask preCommitCoordinationTask;
33     private final ShardCommitCoordinationTask commitCoordinationTask;
34
35
36     public ShardSubmitCoordinationTask(final DOMDataTreeIdentifier rootShardPrefix,
37                                        final Collection<DOMStoreThreePhaseCommitCohort> cohorts) {
38         this.rootShardPrefix = Preconditions.checkNotNull(rootShardPrefix);
39
40         canCommitCoordinationTask = new ShardCanCommitCoordinationTask(rootShardPrefix, cohorts);
41         preCommitCoordinationTask = new ShardPreCommitCoordinationTask(rootShardPrefix, cohorts);
42         commitCoordinationTask = new ShardCommitCoordinationTask(rootShardPrefix, cohorts);
43     }
44
45     @Override
46     public Void call() throws TransactionCommitFailedException {
47
48         LOG.debug("Shard {}, CanCommit started", rootShardPrefix);
49         canCommitCoordinationTask.canCommitBlocking();
50
51         LOG.debug("Shard {}, PreCommit started", rootShardPrefix);
52         preCommitCoordinationTask.preCommitBlocking();
53
54         LOG.debug("Shard {}, commit started", rootShardPrefix);
55         commitCoordinationTask.commitBlocking();
56
57         return null;
58     }
59 }