public class LockManagerImpl extends Object implements LockManager, SynchronousEventListener, LockEventListener
Constructor and Description |
---|
LockManagerImpl(SessionImpl session,
FileSystem fs,
ScheduledExecutorService executor)
Create a new instance of this class.
|
Modifier and Type | Method and Description |
---|---|
void |
addLockToken(SessionImpl session,
String lt)
Invoked by a session to inform that a lock token has been added.
|
void |
beginUpdate()
Start an update operation.
|
void |
cancelUpdate()
Cancel an update operation.
|
protected void |
checkLock(LockInfo info,
Session session)
Check whether a lock info allows access to a session.
|
void |
checkLock(NodeImpl node)
Check whether the node given is locked by somebody else than the
current session.
|
void |
checkLock(Path path,
Session session)
Check whether the path given is locked by somebody else than the
session described.
|
protected void |
checkUnlock(LockInfo info,
Session session)
Check whether a session is allowed to unlock a node.
|
void |
checkUnlock(Session session,
NodeImpl node)
Check whether a session is allowed to unlock a node.
|
void |
close()
Close this lock manager.
|
void |
copyOpenScopedLocksFrom(LockManagerImpl source)
Helper method that copies all the active open-scoped locks from the
given source to this lock manager.
|
void |
endUpdate()
End an update operation.
|
void |
externalLock(NodeId nodeId,
boolean isDeep,
String lockOwner)
Handle an external lock operation.
|
void |
externalUnlock(NodeId nodeId)
Handle an external unlock operation.
|
Lock |
getLock(NodeImpl node)
Returns the Lock object that applies to a node.
|
LockInfo |
getLockInfo(NodeId id)
Return the most appropriate lock information for a node.
|
Lock[] |
getLocks(SessionImpl session)
Returns all locks owned by the specified session.
|
boolean |
holdsLock(NodeImpl node)
Returns
true if the node given holds a lock;
otherwise returns false . |
boolean |
isLocked(NodeImpl node)
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(NodeImpl node,
boolean isDeep,
boolean isSessionScoped)
Lock a node.
|
Lock |
lock(NodeImpl node,
boolean isDeep,
boolean isSessionScoped,
long timoutHint,
String ownerInfo)
Lock a node.
|
void |
onEvent(EventIterator events) |
protected void |
removeLockProperties(NodeImpl node) |
void |
removeLockToken(SessionImpl session,
String lt)
Invoked by a session to inform that a lock token has been removed.
|
void |
setEventChannel(LockEventChannel eventChannel)
Set a lock event channel
|
String |
toString()
Dump contents of path map and elements included to a string.
|
void |
unlock(NodeImpl node)
Removes the lock on a node given by its path.
|
protected void |
writeLockProperties(NodeImpl node,
String lockOwner,
boolean isDeep)
Add the lock related properties to the target node.
|
public LockManagerImpl(SessionImpl session, FileSystem fs, ScheduledExecutorService executor) throws RepositoryException
session
- system sessionfs
- file system for persisting locksexecutor
- scheduled executor service for handling lock timeoutsRepositoryException
- if an error occurspublic void close()
public void copyOpenScopedLocksFrom(LockManagerImpl source)
source
- source lock managerRepositoryCopier
public LockInfo getLockInfo(NodeId id) throws RepositoryException
null
if node is not lockedRepositoryException
- if an error occurspublic Lock lock(NodeImpl node, boolean isDeep, boolean isSessionScoped) throws LockException, RepositoryException
lock
in interface LockManager
node
- nodeisDeep
- 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 true
RepositoryException
Node.lock(boolean, boolean)
public Lock lock(NodeImpl node, boolean isDeep, boolean isSessionScoped, long timoutHint, String ownerInfo) throws LockException, RepositoryException
LockManager
lock
in interface LockManager
node
- Node to create the lock for.isDeep
- whether the lock applies to this node onlyisSessionScoped
- whether the lock is session scopedtimoutHint
- Desired lock timeout in seconds.ownerInfo
- Optional string acting as information about the owner.LockException
- if this node already is locked, or some descendant
node is locked and isDeep
is true
RepositoryException
LockManager.lock(String, boolean, boolean, long, String)
public Lock getLock(NodeImpl node) throws LockException, RepositoryException
getLock
in interface LockManager
node
- nodeLockException
- if this node is not lockedRepositoryException
Node.getLock()
public Lock[] getLocks(SessionImpl session) throws RepositoryException
getLocks
in interface LockManager
session
- sessionRepositoryException
- if an error occursSessionImpl.getLocks()
public void unlock(NodeImpl node) throws LockException, RepositoryException
In order to prevent deadlocks from within the synchronous dispatching of events, content modifications should not be made from within code sections that hold monitors. (see #JCR-194)
unlock
in interface LockManager
node
- nodeLockException
- if this node is not locked or the session
does not have the correct lock tokenRepositoryException
Node.unlock()
public boolean holdsLock(NodeImpl node) throws RepositoryException
true
if the node given holds a lock;
otherwise returns false
.holdsLock
in interface LockManager
node
- nodetrue
if the node given holds a lock;
otherwise returns false
RepositoryException
- If an exception occurs.Node.holdsLock()
public boolean isLocked(NodeImpl node) throws RepositoryException
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
isLocked
in interface LockManager
node
- nodetrue
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
RepositoryException
- If an exception occurs.Node.isLocked()
public void checkLock(NodeImpl node) throws LockException, RepositoryException
checkLock
in interface LockManager
node
- node to checkLockException
- if write access to the specified node is not allowedRepositoryException
- if some other error occurspublic void checkLock(Path path, Session session) throws LockException, RepositoryException
checkLock
in interface LockManager
path
- path to checksession
- sessionLockException
- if write access to the specified path is not allowedRepositoryException
- if some other error occursprotected void checkLock(LockInfo info, Session session) throws LockException, RepositoryException
Default implementation allows access to the lock holder only.
info
- info to checksession
- sessionLockException
- if write access to the specified path is not allowedRepositoryException
- if some other error occurspublic void checkUnlock(Session session, NodeImpl node) throws LockException, RepositoryException
checkUnlock
in interface LockManager
LockException
- if unlocking is deniedRepositoryException
- if some other error occursprotected void checkUnlock(LockInfo info, Session session) throws LockException, RepositoryException
Default implementation allows unlocking to the lock holder only.
info
- info to checksession
- sessionLockException
- if unlocking is deniedRepositoryException
- if some other error occurspublic void addLockToken(SessionImpl session, String lt) throws LockException, RepositoryException
addLockToken
in interface LockManager
session
- session that has a added lock tokenlt
- added lock tokenLockException
RepositoryException
public void removeLockToken(SessionImpl session, String lt) throws LockException, RepositoryException
removeLockToken
in interface LockManager
session
- session that has a removed lock tokenlt
- removed lock tokenLockException
RepositoryException
public void beginUpdate()
public void endUpdate()
public void cancelUpdate()
protected void writeLockProperties(NodeImpl node, String lockOwner, boolean isDeep) throws RepositoryException
node
- lockOwner
- isDeep
- RepositoryException
protected void removeLockProperties(NodeImpl node) throws RepositoryException
node
- RepositoryException
public void onEvent(EventIterator events)
onEvent
in interface EventListener
public void setEventChannel(LockEventChannel eventChannel)
eventChannel
- lock event channelpublic void externalLock(NodeId nodeId, boolean isDeep, String lockOwner) throws RepositoryException
externalLock
in interface LockEventListener
nodeId
- node idisDeep
- true
if the lock is deep;
false
otherwiselockOwner
- lock ownerRepositoryException
- if the lock cannot be processedpublic void externalUnlock(NodeId nodeId) throws RepositoryException
externalUnlock
in interface LockEventListener
nodeId
- node idRepositoryException
- if the unlock cannot be processedCopyright © 2004–2022 The Apache Software Foundation. All rights reserved.