2 * Copyright (c) 2014 Brocade Communications Systems, Inc. and others. All rights reserved.
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
9 package org.opendaylight.controller.cluster.datastore;
11 import java.util.concurrent.TimeUnit;
13 import org.opendaylight.controller.md.sal.dom.store.impl.InMemoryDOMDataStoreConfigProperties;
14 import com.google.common.base.Preconditions;
16 import scala.concurrent.duration.Duration;
19 * Contains contextual data for shards.
21 * @author Thomas Pantelis
23 public class ShardContext {
25 private final InMemoryDOMDataStoreConfigProperties dataStoreProperties;
26 private final Duration shardTransactionIdleTimeout;
28 public ShardContext() {
29 this.dataStoreProperties = null;
30 this.shardTransactionIdleTimeout = Duration.create(10, TimeUnit.MINUTES);
33 public ShardContext(InMemoryDOMDataStoreConfigProperties dataStoreProperties,
34 Duration shardTransactionIdleTimeout) {
35 this.dataStoreProperties = Preconditions.checkNotNull(dataStoreProperties);
36 this.shardTransactionIdleTimeout = Preconditions.checkNotNull(shardTransactionIdleTimeout);
39 public InMemoryDOMDataStoreConfigProperties getDataStoreProperties() {
40 return dataStoreProperties;
43 public Duration getShardTransactionIdleTimeout() {
44 return shardTransactionIdleTimeout;