Class ViewStateManagerImpl
java.lang.Object
org.apache.sling.discovery.commons.providers.base.ViewStateManagerImpl
- All Implemented Interfaces:
 ViewStateManager
The ViewStateManager is at the core of managing TopologyEventListeners,
 the 'view state' (changing vs changed) and sending out the appropriate
 and according TopologyEvents to the registered listeners.
 
Note re synchronization: this class rquires a lock object to be passed in the constructor - this will be applied to all public methods appropriately. Additionally, the ClusterSyncService callback will also be locked using the provided lock object.
- 
Field Summary
Fields - 
Method Summary
Modifier and TypeMethodDescriptionvoidbind(TopologyEventListener eventListener) Binds the given eventListener, sending it an INIT event if applicable.protected booleanequalsIgnoreSyncToken(BaseTopologyView newView) Checks if the previouesView is equal to the newView, ignoring the syncToken (but only if the newView has partially started instances).protected booleanvoidHandles activation - ie marks this manager as activated thus the TOPOLOGY_INIT event can be sent to already bound listeners and subsequent calls to handleChanging/handleNewView will result in according/appropriate TOPOLOGY_CHANGING/ TOPOLOGY_CHANGED events.voidHandles the fact that some (possibly early) indicator of a change in a topology has been detected and that a new view is being agreed upon (whatever that means, be it voting or similar).voidMust be called when the corresponding service (typically a DiscoveryService implementation) is deactivated.voidhandleNewView(BaseTopologyView newView) Handles the fact that a new view became true/established and sends out TOPOLOGY_INIT to uninitialized listeners and TOPOLOGY_CHANGED to already initialized listeners (in the latter case, also sends a TOPOLOGY_CHANGING if that has not yet been done)voidinstallMinEventDelayHandler(DiscoveryService discoveryService, Scheduler scheduler, long minEventDelaySecs) Installs an optional 'min event delay handler' which, using the given scheduler, delays sending TOPOLOGY_CHANGED event after receiving a handleNewView - with the idea as to limit the number of toggling between view states.protected booleanonlyDiffersInProperties(BaseTopologyView newView) booleanunbind(TopologyEventListener eventListener) Unbinds the given eventListener, returning whether or not it was bound at all.protected booleanunchanged(BaseTopologyView newView) intwaitForAsyncEvents(long timeout) for testing only: wait for any potentially queued async events to be delivered before returning. 
- 
Field Details
- 
lock
The lock object with which all public methods are guarded - to be provided in the constructor. 
 - 
 - 
Method Details
- 
installMinEventDelayHandler
public void installMinEventDelayHandler(DiscoveryService discoveryService, Scheduler scheduler, long minEventDelaySecs) Description copied from interface:ViewStateManagerInstalls an optional 'min event delay handler' which, using the given scheduler, delays sending TOPOLOGY_CHANGED event after receiving a handleNewView - with the idea as to limit the number of toggling between view states.- Specified by:
 installMinEventDelayHandlerin interfaceViewStateManager
 - 
hadPreviousView
protected boolean hadPreviousView() - 
unchanged
 - 
bind
Description copied from interface:ViewStateManagerBinds the given eventListener, sending it an INIT event if applicable.- Specified by:
 bindin interfaceViewStateManager- Parameters:
 eventListener- the eventListener that is to bind
 - 
unbind
Description copied from interface:ViewStateManagerUnbinds the given eventListener, returning whether or not it was bound at all.- Specified by:
 unbindin interfaceViewStateManager- Parameters:
 eventListener- the eventListner that is to unbind- Returns:
 - whether or not the listener was added in the first place
 
 - 
handleActivated
public void handleActivated()Description copied from interface:ViewStateManagerHandles activation - ie marks this manager as activated thus the TOPOLOGY_INIT event can be sent to already bound listeners and subsequent calls to handleChanging/handleNewView will result in according/appropriate TOPOLOGY_CHANGING/ TOPOLOGY_CHANGED events.- Specified by:
 handleActivatedin interfaceViewStateManager
 - 
handleDeactivated
public void handleDeactivated()Description copied from interface:ViewStateManagerMust be called when the corresponding service (typically a DiscoveryService implementation) is deactivated.Will mark this manager as deactivated and flags the last available view as not current.
- Specified by:
 handleDeactivatedin interfaceViewStateManager
 - 
handleChanging
public void handleChanging()Description copied from interface:ViewStateManagerHandles the fact that some (possibly early) indicator of a change in a topology has been detected and that a new view is being agreed upon (whatever that means, be it voting or similar).Will send out TOPOLOGY_CHANGING to all initialized listeners.
- Specified by:
 handleChangingin interfaceViewStateManager
 - 
handleNewView
Description copied from interface:ViewStateManagerHandles the fact that a new view became true/established and sends out TOPOLOGY_INIT to uninitialized listeners and TOPOLOGY_CHANGED to already initialized listeners (in the latter case, also sends a TOPOLOGY_CHANGING if that has not yet been done)- Specified by:
 handleNewViewin interfaceViewStateManager- Parameters:
 newView- the new, established view true if we were either in changing mode or the newView was different from the previous one.
 - 
equalsIgnoreSyncToken
Checks if the previouesView is equal to the newView, ignoring the syncToken (but only if the newView has partially started instances).This caller of this method must ensure to be in a lock.lock() block
 - 
onlyDiffersInProperties
 - 
waitForAsyncEvents
public int waitForAsyncEvents(long timeout) Description copied from interface:ViewStateManagerfor testing only: wait for any potentially queued async events to be delivered before returning.- Specified by:
 waitForAsyncEventsin interfaceViewStateManager- Parameters:
 timeout- time in millis to wait for at max - 0 to not wait at all - -1 to wait indefinitely- Returns:
 - 0 if no more async events exist, or the number of queued or in-flight (being sent) events if the timeout hit early
 
 
 -