Merge "Small fix to xsql dependencies"
[controller.git] / opendaylight / md-sal / sal-distributed-datastore / src / main / java / org / opendaylight / controller / cluster / datastore / ShardContext.java
1 /*
2  * Copyright (c) 2014 Brocade Communications 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.controller.cluster.datastore;
10
11 import java.util.concurrent.TimeUnit;
12
13 import org.opendaylight.controller.md.sal.dom.store.impl.InMemoryDOMDataStoreConfigProperties;
14 import com.google.common.base.Preconditions;
15
16 import scala.concurrent.duration.Duration;
17
18 /**
19  * Contains contextual data for shards.
20  *
21  * @author Thomas Pantelis
22  */
23 public class ShardContext {
24
25     private final InMemoryDOMDataStoreConfigProperties dataStoreProperties;
26     private final Duration shardTransactionIdleTimeout;
27
28     public ShardContext() {
29         this.dataStoreProperties = null;
30         this.shardTransactionIdleTimeout = Duration.create(10, TimeUnit.MINUTES);
31     }
32
33     public ShardContext(InMemoryDOMDataStoreConfigProperties dataStoreProperties,
34             Duration shardTransactionIdleTimeout) {
35         this.dataStoreProperties = Preconditions.checkNotNull(dataStoreProperties);
36         this.shardTransactionIdleTimeout = Preconditions.checkNotNull(shardTransactionIdleTimeout);
37     }
38
39     public InMemoryDOMDataStoreConfigProperties getDataStoreProperties() {
40         return dataStoreProperties;
41     }
42
43     public Duration getShardTransactionIdleTimeout() {
44         return shardTransactionIdleTimeout;
45     }
46 }