package org.opendaylight.controller.md.sal.common.api.clustering;
+import com.google.common.base.Optional;
import javax.annotation.Nonnull;
/**
* A component/application may also register interest in the ownership status of an Entity. The listener would be
* notified whenever the ownership status changes.
* </p>
+ *
+ * @deprecated Use org.opendaylight.mdsal.binding.api.clustering.EntityOwnershipService or
+ * org.opendaylight.mdsal.dom.api.clustering.DOMEntityOwnershipService instead
*/
+@Deprecated
public interface EntityOwnershipService {
/**
* Registers a candidate for ownership of the given entity. Only one such request can be made per entity
* per process. If multiple requests for registering a candidate for a given entity are received in the
* current process a CandidateAlreadyRegisteredException will be thrown.
+ *
* <p>
- * The registration is performed asynchronously and the {@link EntityOwnershipCandidate} instance is
- * notified whenever its process instance is granted ownership of the entity and also whenever it loses
- * ownership. Note that the {@link EntityOwnershipCandidate} is not notified when another process instance
- * is granted ownership.
+ * The registration is performed asynchronously and any registered {@link EntityOwnershipListener} is
+ * notified of ownership status changes for the entity.
*
* @param entity the entity which the Candidate wants to own
- * @param candidate the Candidate that wants to own the entity
* @return a registration object that can be used to unregister the Candidate
- * @throws org.opendaylight.controller.md.sal.common.api.clustering.CandidateAlreadyRegisteredException
+ * @throws CandidateAlreadyRegisteredException if the candidate is already registered
*/
- EntityOwnershipCandidateRegistration registerCandidate(@Nonnull Entity entity, @Nonnull EntityOwnershipCandidate candidate)
+ EntityOwnershipCandidateRegistration registerCandidate(@Nonnull Entity entity)
throws CandidateAlreadyRegisteredException;
/**
* @param listener the listener that is interested in the entities
* @return a registration object that can be used to unregister the Listener
*/
- EntityOwnershipListenerRegistration registerListener(@Nonnull String entityType, @Nonnull EntityOwnershipListener listener);
+ EntityOwnershipListenerRegistration registerListener(@Nonnull String entityType,
+ @Nonnull EntityOwnershipListener listener);
+ /**
+ * Gets the current ownership state information for an entity.
+ *
+ * @param forEntity the entity to query.
+ * @return an Optional EntityOwnershipState whose instance is present if the entity is found
+ */
+ Optional<EntityOwnershipState> getOwnershipState(@Nonnull Entity forEntity);
+
+ /**
+ * Check if a local candidate is registered for the given entity.
+ *
+ * @param entity the entity
+ * @return true if a candidate was registered locally, false otherwise
+ */
+ boolean isCandidateRegistered(@Nonnull Entity entity);
}