X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-distributed-datastore%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatastore%2Fmessages%2FShardLeaderStateChanged.java;fp=opendaylight%2Fmd-sal%2Fsal-distributed-datastore%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatastore%2Fmessages%2FShardLeaderStateChanged.java;h=d9a55ab1e98e7c0f752e73035d8f25494e9f34d1;hb=a2c4e27ea137ce9e2929916b2964116c4df188a0;hp=0000000000000000000000000000000000000000;hpb=4ded8407b8cc21fe329f49b378a088a703c707fc;p=controller.git diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/ShardLeaderStateChanged.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/ShardLeaderStateChanged.java new file mode 100644 index 0000000000..d9a55ab1e9 --- /dev/null +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/ShardLeaderStateChanged.java @@ -0,0 +1,36 @@ +/* + * Copyright (c) 2015 Brocade Communications Systems, Inc. and others. All rights reserved. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v1.0 which accompanies this distribution, + * and is available at http://www.eclipse.org/legal/epl-v10.html + */ +package org.opendaylight.controller.cluster.datastore.messages; + +import com.google.common.base.Optional; +import com.google.common.base.Preconditions; +import javax.annotation.Nonnull; +import org.opendaylight.controller.cluster.notifications.LeaderStateChanged; +import org.opendaylight.yangtools.yang.data.api.schema.tree.DataTree; + +/** + * A local message derived from LeaderStateChanged containing additional Shard-specific info that is sent + * when some state of the shard leader has changed. This message is used by the ShardManager to maintain + * current Shard information. + * + * @author Thomas Pantelis + */ +public class ShardLeaderStateChanged extends LeaderStateChanged { + + private final Optional localShardDataTree; + + public ShardLeaderStateChanged(@Nonnull String memberId, @Nonnull String leaderId, + @Nonnull Optional localShardDataTree) { + super(memberId, leaderId); + this.localShardDataTree = Preconditions.checkNotNull(localShardDataTree); + } + + public @Nonnull Optional getLocalShardDataTree() { + return localShardDataTree; + } +}