public class LockManagerImpl extends Object implements LockStateManager, SessionListener
LockManagerImpl...
TODO: TOBEFIXED. Lock objects obtained through this mgr are not informed if another session is or becomes lock-holder and removes the lock again.| Constructor and Description |
|---|
LockManagerImpl(WorkspaceManager wspManager,
ItemManager itemManager,
CacheBehaviour cacheBehaviour) |
| Modifier and Type | Method and Description |
|---|---|
void |
addLockToken(String lt)
Delegates this call to
WorkspaceManager.addLockToken(String). |
void |
checkLock(NodeState nodeState)
Check whether the given node state is locked by somebody else than the
current session.
|
Lock |
getLock(NodeState nodeState)
If the session created a lock on the node with the given state, we already
know the lock.
|
String[] |
getLockTokens()
Returns the lock tokens present on the
SessionInfo this
manager has been created with. |
boolean |
isLocked(NodeState nodeState)
Returns
true if this node is locked either as a result
of a lock held by this node or by a deep lock on a node above this
node; otherwise returns false. |
Lock |
lock(NodeState nodeState,
boolean isDeep,
boolean isSessionScoped)
Lock a node.
|
Lock |
lock(NodeState nodeState,
boolean isDeep,
boolean isSessionScoped,
long timeoutHint,
String ownerHint)
Lock a node.
|
void |
loggedOut(Session session)
Called when a
Session has been 'closed' by
calling . |
void |
loggingOut(Session session)
Called when a
Session is about to be 'closed' by
calling . |
void |
removeLockToken(String lt)
If the lock addressed by the token is session-scoped, this method will
throw a LockException, such as defined by JSR170 v.1.0.1 for
Session.removeLockToken(String).Otherwise the call is delegated to WorkspaceManager.removeLockToken(String). |
void |
unlock(NodeState nodeState)
Removes the lock on a node.
|
public LockManagerImpl(WorkspaceManager wspManager, ItemManager itemManager, CacheBehaviour cacheBehaviour)
public Lock lock(NodeState nodeState, boolean isDeep, boolean isSessionScoped) throws LockException, RepositoryException
LockStateManagerlock in interface LockStateManagerisDeep - whether the lock applies to this node onlyisSessionScoped - whether the lock is session scopedLockException - if this node already is locked, or some descendant
node is locked and isDeep is trueRepositoryExceptionLockStateManager.lock(NodeState,boolean,boolean)public Lock lock(NodeState nodeState, boolean isDeep, boolean isSessionScoped, long timeoutHint, String ownerHint) throws RepositoryException
LockStateManagerlock in interface LockStateManagerisDeep - whether the lock applies to this node onlyisSessionScoped - whether the lock is session scopedtimeoutHint - optional timeout hint.ownerHint - optional String defining the lock owner info to be
displayed.LockException - if this node already is locked, or some descendant
node is locked and isDeep is trueRepositoryExceptionLockStateManager.lock(NodeState,boolean,boolean,long,String)public void unlock(NodeState nodeState) throws LockException, RepositoryException
LockStateManagerunlock in interface LockStateManagerLockException - if this node is not locked or the session does not
have the correct lock tokenRepositoryExceptionLockStateManager.unlock(NodeState)public Lock getLock(NodeState nodeState) throws LockException, RepositoryException
getLock in interface LockStateManagernodeState - LockException - if this node is not lockedRepositoryExceptionLockStateManager.getLock(NodeState)public boolean isLocked(NodeState nodeState) throws RepositoryException
LockStateManagertrue if this node is locked either as a result
of a lock held by this node or by a deep lock on a node above this
node; otherwise returns false.isLocked in interface LockStateManagertrue if this node is locked either as a result
of a lock held by this node or by a deep lock on a node above this
node; otherwise returns falseRepositoryException - If an error occurs.LockStateManager.isLocked(NodeState)public void checkLock(NodeState nodeState) throws LockException, RepositoryException
LockStateManagercheckLock in interface LockStateManagerLockException - if write access to the specified node is not allowedRepositoryException - if some other error occursLockStateManager.checkLock(NodeState)public String[] getLockTokens() throws UnsupportedRepositoryOperationException, RepositoryException
SessionInfo this
manager has been created with.getLockTokens in interface LockStateManagerSession this
lock manager has been created for.UnsupportedRepositoryOperationExceptionRepositoryExceptionLockStateManager.getLockTokens()public void addLockToken(String lt) throws LockException, RepositoryException
WorkspaceManager.addLockToken(String).
If this succeeds this method will inform all locks stored in the local
map in order to give them the chance to update their lock information.addLockToken in interface LockStateManagerlt - added lock tokenLockExceptionRepositoryExceptionLockStateManager.addLockToken(String)public void removeLockToken(String lt) throws LockException, RepositoryException
Session.removeLockToken(String).WorkspaceManager.removeLockToken(String).
All locks stored in the local lock map are notified by the removed
token in order have them updated their lock information.removeLockToken in interface LockStateManagerlt - removed lock tokenLockExceptionRepositoryExceptionLockStateManager.removeLockToken(String)public void loggingOut(Session session)
SessionListenerSession is about to be 'closed' by
calling Session.logout(). At this
moment the session is still valid.loggingOut in interface SessionListenersession - the Session that is about to be 'closed'SessionListener.loggingOut(Session)public void loggedOut(Session session)
SessionListenerSession has been 'closed' by
calling Session.logout().loggedOut in interface SessionListenersession - the Session that has been 'closed'SessionListener.loggedOut(Session)Copyright © 2004–2021 The Apache Software Foundation. All rights reserved.