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%2FFrontendMetadata.java;h=e3a18997e43e68fc3597936e99a4a58890d73403;hb=99f80f27bee37bb23e345420bf14bb7bb4793c28;hp=969accd583c130160177be9316992da98704d559;hpb=62cddd88e42e8f3c6a92bbf42c97b0d6806f44ae;p=controller.git diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/FrontendMetadata.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/FrontendMetadata.java index 969accd583..e3a18997e4 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/FrontendMetadata.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/FrontendMetadata.java @@ -7,8 +7,11 @@ */ package org.opendaylight.controller.cluster.datastore; -import com.google.common.base.Preconditions; +import static com.google.common.base.Verify.verify; +import static java.util.Objects.requireNonNull; + import com.google.common.collect.Collections2; +import com.google.common.collect.ImmutableSet; import com.google.common.collect.Maps; import java.util.HashMap; import java.util.Map; @@ -19,6 +22,7 @@ import org.opendaylight.controller.cluster.access.concepts.LocalHistoryIdentifie import org.opendaylight.controller.cluster.access.concepts.TransactionIdentifier; import org.opendaylight.controller.cluster.datastore.persisted.FrontendClientMetadata; import org.opendaylight.controller.cluster.datastore.persisted.FrontendShardDataTreeSnapshotMetadata; +import org.opendaylight.controller.cluster.datastore.utils.ImmutableUnsignedLongSet; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -36,7 +40,7 @@ final class FrontendMetadata extends ShardDataTreeMetadata toLeaderState(final @NonNull Shard shard) { return new HashMap<>(Maps.transformValues(clients, meta -> meta.toLeaderState(shard))); } + + void disableTracking(final ClientIdentifier clientId) { + final FrontendIdentifier frontendId = clientId.getFrontendId(); + final FrontendClientMetadataBuilder client = clients.get(frontendId); + if (client == null) { + // When we have not seen the client before, we still need to disable tracking for him since this only gets + // triggered once. + LOG.debug("{}: disableTracking {} does not match any client, pre-disabling client.", shardName, clientId); + clients.put(frontendId, new FrontendClientMetadataBuilder.Disabled(shardName, clientId)); + return; + } + if (!clientId.equals(client.getIdentifier())) { + LOG.debug("{}: disableTracking {} does not match client {}, ignoring", shardName, clientId, client); + return; + } + if (client instanceof FrontendClientMetadataBuilder.Disabled) { + LOG.debug("{}: client {} is has already disabled tracking", shardName, client); + return; + } + + verify(clients.replace(frontendId, client, new FrontendClientMetadataBuilder.Disabled(shardName, clientId))); + } + + ImmutableSet getClients() { + return clients.values().stream() + .map(FrontendClientMetadataBuilder::getIdentifier) + .collect(ImmutableSet.toImmutableSet()); + } }