org.apache.jackrabbit.core
Class SessionImpl

java.lang.Object
  extended by org.apache.jackrabbit.commons.AbstractSession
      extended by org.apache.jackrabbit.core.SessionImpl
All Implemented Interfaces:
Session, JackrabbitSession, Dumpable, IdentifierResolver, NamePathResolver, NameResolver, PathResolver, NamespaceResolver
Direct Known Subclasses:
XASessionImpl

public class SessionImpl
extends AbstractSession
implements JackrabbitSession, NamespaceResolver, NamePathResolver, IdentifierResolver, Dumpable

A SessionImpl ...


Field Summary
protected  AccessManager accessMgr
          the AccessManager associated with this session
protected  boolean alive
          flag indicating whether this session is alive
protected  Map<String,Object> attributes
          the attributes of this session
static String DISABLE_CLUSTER_SYNC_ON_REFRESH
          Name of the session attribute that controls whether the refresh(boolean) method will cause the repository to synchronize itself to changes in other cluster nodes.
protected  HierarchyManager hierMgr
          the HierarchyManager associated with this session
protected  ItemManager itemMgr
          the item mgr associated with this session
protected  SessionItemStateManager itemStateMgr
          the item state mgr associated with this session
protected  Map<SessionListener,SessionListener> listeners
          Listeners (weak references)
protected  AuthContext loginContext
          the AuthContext of this session (can be null if this session was not instantiated through a login process)
protected  NamePathResolver namePathResolver
          Name and Path resolver
protected  NodeTypeInstanceHandler ntInstanceHandler
          node type instance handler
protected  NodeTypeManagerImpl ntMgr
          the node type manager
protected  RepositoryImpl rep
          the repository that issued this session
protected  Subject subject
          the Subject of this session
protected  String userId
          the user ID that was used to acquire this session
protected  ValueFactory valueFactory
          value factory
protected  InternalVersionManager versionMgr
          The version manager for this session
protected  WorkspaceImpl wsp
          the Workspace associated with this session
 
Fields inherited from interface javax.jcr.Session
ACTION_ADD_NODE, ACTION_READ, ACTION_REMOVE, ACTION_SET_PROPERTY
 
Constructor Summary
protected SessionImpl(RepositoryImpl rep, AuthContext loginContext, WorkspaceConfig wspConfig)
          Protected constructor.
protected SessionImpl(RepositoryImpl rep, Subject subject, WorkspaceConfig wspConfig)
          Protected constructor.
 
Method Summary
 void addListener(SessionListener listener)
          Add a SessionListener
 void addLockToken(String lt)
          
 void checkFormat(String identifier)
           
 void checkPermission(String absPath, String actions)
          
protected  boolean clusterSyncOnRefresh()
          Checks whether the refresh(boolean) method should cause cluster synchronization.
protected  AccessManager createAccessManager(Subject subject, HierarchyManager hierarchyManager)
          Create the access manager.
 GarbageCollector createDataStoreGarbageCollector()
          Create a data store garbage collector for this repository.
protected  ItemManager createItemManager(SessionItemStateManager itemStateMgr, HierarchyManager hierMgr)
          Create the item manager.
 Session createSession(String workspaceName)
          Creates a new session with the same subject as this sessions but to a different workspace.
protected  SessionItemStateManager createSessionItemStateManager(LocalItemStateManager manager)
          Create the session item state manager.
protected  InternalVersionManager createVersionManager(RepositoryImpl rep)
          Create the version manager.
protected  void createWorkspace(String workspaceName)
          Creates a workspace with the given name.
protected  void createWorkspace(String workspaceName, InputSource configTemplate)
          Creates a workspace with the given name and a workspace configuration template.
protected  WorkspaceImpl createWorkspaceInstance(WorkspaceConfig wspConfig, SharedItemStateManager stateMgr, RepositoryImpl rep, SessionImpl session)
          Creates the workspace instance backing this session.
 void dump(PrintStream ps)
          Dumps the state of this instance in a human readable format for diagnostic purposes.
 void finalize()
          Finalize the session.
 AccessControlManager getAccessControlManager()
           
 AccessManager getAccessManager()
          Returns the AccessManager associated with this session.
 Object getAttribute(String name)
          
 String[] getAttributeNames()
          
 HierarchyManager getHierarchyManager()
          Returns the HierarchyManager associated with this session.
 ContentHandler getImportContentHandler(String parentAbsPath, int uuidBehavior)
          
 InternalVersionManager getInternalVersionManager()
          Returns the InternalVersionManager associated with this session.
 Item getItem(String absPath)
          Returns the node or property at the given path.
 ItemManager getItemManager()
          Returns the ItemManager of this session.
protected  SessionItemStateManager getItemStateManager()
          Returns the SessionItemStateManager associated with this session.
 String getJCRName(Name name)
          Returns the qualified JCR name String for the given Name object.
 String getJCRPath(Path path)
          Returns the given JCR path string for the given path object.
 LockManager getLockManager()
          Return the lock manager for this session.
 Lock[] getLocks()
          Returns all locks owned by this session.
 String[] getLockTokens()
          
 Node getNode(String absPath)
          Returns the node with the given absolute path.
 NodeImpl getNodeById(NodeId id)
          Retrieves the Node with the given id.
 Node getNodeByIdentifier(String id)
           
 Node getNodeByUUID(String uuid)
          
 NodeTypeInstanceHandler getNodeTypeInstanceHandler()
          Returns the node type instance handler for this session
 NodeTypeManagerImpl getNodeTypeManager()
          Returns the NodeTypeManager.
 Path getPath(String identifier)
           
 String getPrefix(String uri)
          Returns the prefix which is mapped to the given URI.
 PrincipalManager getPrincipalManager()
          Returns the PrincipalManager for the current Session.
 Property getProperty(String absPath)
          Returns the property with the given absolute path.
 Name getQName(String name)
          Returns the Name for the given JCR name String.
 Path getQPath(String path)
          Returns the path object for the given JCR path string.
 Path getQPath(String path, boolean normalizeIdentifier)
          Returns the path object for the given JCR path string.
 Repository getRepository()
          
 RetentionManager getRetentionManager()
           
protected  RetentionRegistry getRetentionRegistry()
          Returns the internal retention manager used for evaluation of effective retention policies and holds.
 Node getRootNode()
          
 Subject getSubject()
          Returns the Subject associated with this session.
 String getURI(String prefix)
          Returns the URI to which the given prefix is mapped.
 String getUserID()
          
 UserManager getUserManager()
          Returns the UserManager for the current Session.
 ItemValidator getValidator()
           
 ValueFactory getValueFactory()
          
 Workspace getWorkspace()
          
protected  String[] getWorkspaceNames()
          Returns the names of all workspaces of this repository with respect of the access rights of this session.
 boolean hasCapability(String methodName, Object target, Object[] arguments)
           
 boolean hasPendingChanges()
          
 boolean hasPermission(String absPath, String actions)
           
 Session impersonate(Credentials otherCredentials)
          Logs in the same workspace with the given credentials.
 boolean isLive()
          
 boolean itemExists(String absPath)
          Calls AbstractSession.getItem(String) with the given path and returns true if the call succeeds.
 void logout()
          Clears the local namespace mappings.
 void move(String srcAbsPath, String destAbsPath)
          
 boolean nodeExists(String absPath)
          Checks whether a node with the given absolute path exists.
protected  void notifyLoggedOut()
          Notify the listeners that this session has been closed.
protected  void notifyLoggingOut()
          Notify the listeners that this session is about to be closed.
 boolean propertyExists(String absPath)
          Checks whether a property with the given absolute path exists.
 void refresh(boolean keepChanges)
          
 void removeItem(String absPath)
          Removes the identified item.
 void removeListener(SessionListener listener)
          Remove a SessionListener
 void removeLockToken(String lt)
          
protected  String retrieveUserId(Subject subject, String workspaceName)
          Retrieve the userID from the specified subject.
protected  void sanityCheck()
          Performs a sanity check on this session.
 void save()
          
protected  void setAttribute(String name, Object value)
          Sets the named attribute.
 void setNamespacePrefix(String prefix, String uri)
          Modifies the session local namespace mappings to contain the given prefix to URI mapping.
 
Methods inherited from class org.apache.jackrabbit.commons.AbstractSession
exportDocumentView, exportDocumentView, exportSystemView, exportSystemView, getNamespacePrefix, getNamespacePrefixes, getNamespaceURI, importXML
 
Methods inherited from class java.lang.Object
clone, equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 
Methods inherited from interface javax.jcr.Session
exportDocumentView, exportDocumentView, exportSystemView, exportSystemView, getNamespacePrefix, getNamespacePrefixes, getNamespaceURI, importXML
 

Field Detail

DISABLE_CLUSTER_SYNC_ON_REFRESH

public static final String DISABLE_CLUSTER_SYNC_ON_REFRESH
Name of the session attribute that controls whether the refresh(boolean) method will cause the repository to synchronize itself to changes in other cluster nodes. This cluster synchronization is enabled by default, unless an attribute with this name is set (any non-null value) for this session.

Since:
Apache Jackrabbit 1.6
See Also:
JCR-1753, Constant Field Values

alive

protected boolean alive
flag indicating whether this session is alive


rep

protected final RepositoryImpl rep
the repository that issued this session


loginContext

protected AuthContext loginContext
the AuthContext of this session (can be null if this session was not instantiated through a login process)


subject

protected final Subject subject
the Subject of this session


userId

protected final String userId
the user ID that was used to acquire this session


attributes

protected final Map<String,Object> attributes
the attributes of this session


ntMgr

protected final NodeTypeManagerImpl ntMgr
the node type manager


accessMgr

protected AccessManager accessMgr
the AccessManager associated with this session


itemStateMgr

protected final SessionItemStateManager itemStateMgr
the item state mgr associated with this session


hierMgr

protected final HierarchyManager hierMgr
the HierarchyManager associated with this session


itemMgr

protected final ItemManager itemMgr
the item mgr associated with this session


wsp

protected final WorkspaceImpl wsp
the Workspace associated with this session


namePathResolver

protected NamePathResolver namePathResolver
Name and Path resolver


versionMgr

protected final InternalVersionManager versionMgr
The version manager for this session


ntInstanceHandler

protected final NodeTypeInstanceHandler ntInstanceHandler
node type instance handler


listeners

protected final Map<SessionListener,SessionListener> listeners
Listeners (weak references)


valueFactory

protected ValueFactory valueFactory
value factory

Constructor Detail

SessionImpl

protected SessionImpl(RepositoryImpl rep,
                      AuthContext loginContext,
                      WorkspaceConfig wspConfig)
               throws AccessDeniedException,
                      RepositoryException
Protected constructor.

Parameters:
rep -
loginContext -
wspConfig -
Throws:
AccessDeniedException - if the subject of the given login context is not granted access to the specified workspace
RepositoryException - if another error occurs

SessionImpl

protected SessionImpl(RepositoryImpl rep,
                      Subject subject,
                      WorkspaceConfig wspConfig)
               throws AccessDeniedException,
                      RepositoryException
Protected constructor.

Parameters:
rep -
subject -
wspConfig -
Throws:
AccessDeniedException - if the given subject is not granted access to the specified workspace
RepositoryException - if another error occurs
Method Detail

retrieveUserId

protected String retrieveUserId(Subject subject,
                                String workspaceName)
                         throws RepositoryException
Retrieve the userID from the specified subject.

Returns:
the userID.
Throws:
RepositoryException

createSessionItemStateManager

protected SessionItemStateManager createSessionItemStateManager(LocalItemStateManager manager)
Create the session item state manager.

Returns:
session item state manager

createWorkspaceInstance

protected WorkspaceImpl createWorkspaceInstance(WorkspaceConfig wspConfig,
                                                SharedItemStateManager stateMgr,
                                                RepositoryImpl rep,
                                                SessionImpl session)
Creates the workspace instance backing this session.

Parameters:
wspConfig - The workspace configuration
stateMgr - The shared item state manager
rep - The repository
session - The session
Returns:
An instance of the WorkspaceImpl class or an extension thereof.

createItemManager

protected ItemManager createItemManager(SessionItemStateManager itemStateMgr,
                                        HierarchyManager hierMgr)
Create the item manager.

Returns:
item manager

createVersionManager

protected InternalVersionManager createVersionManager(RepositoryImpl rep)
                                               throws RepositoryException
Create the version manager. If we are not using XA, we may safely use the repository version manager.

Returns:
version manager
Throws:
RepositoryException

createAccessManager

protected AccessManager createAccessManager(Subject subject,
                                            HierarchyManager hierarchyManager)
                                     throws AccessDeniedException,
                                            RepositoryException
Create the access manager.

Parameters:
subject -
hierarchyManager -
Returns:
access manager
Throws:
AccessDeniedException - if the current subject is not granted access to the current workspace
RepositoryException - if the access manager cannot be instantiated

sanityCheck

protected void sanityCheck()
                    throws RepositoryException
Performs a sanity check on this session.

Throws:
RepositoryException - if this session has been rendered invalid for some reason (e.g. if this session has been closed explicitly or if it has expired)

getValidator

public ItemValidator getValidator()
                           throws RepositoryException
Returns:
ItemValidator instance for this session.
Throws:
RepositoryException - If an error occurs.

getSubject

public Subject getSubject()
Returns the Subject associated with this session.

Returns:
the Subject associated with this session

createSession

public Session createSession(String workspaceName)
                      throws AccessDeniedException,
                             NoSuchWorkspaceException,
                             RepositoryException
Creates a new session with the same subject as this sessions but to a different workspace. The returned session is a newly logged in session, with the same subject but a different workspace. Even if the given workspace is the same as this sessions one, the implementation must return a new session object.

Parameters:
workspaceName - name of the workspace to acquire a session for.
Returns:
A session to the requested workspace for the same authenticated subject.
Throws:
AccessDeniedException - in case the current Subject is not allowed to access the requested Workspace
NoSuchWorkspaceException - If the named workspace does not exist.
RepositoryException - in any other exceptional state

getAccessManager

public AccessManager getAccessManager()
Returns the AccessManager associated with this session.

Returns:
the AccessManager associated with this session

getNodeTypeManager

public NodeTypeManagerImpl getNodeTypeManager()
Returns the NodeTypeManager.

Returns:
the NodeTypeManager

getItemManager

public ItemManager getItemManager()
Returns the ItemManager of this session.

Returns:
the ItemManager

getItemStateManager

protected SessionItemStateManager getItemStateManager()
Returns the SessionItemStateManager associated with this session.

Returns:
the SessionItemStateManager associated with this session

getHierarchyManager

public HierarchyManager getHierarchyManager()
Returns the HierarchyManager associated with this session.

Returns:
the HierarchyManager associated with this session

getInternalVersionManager

public InternalVersionManager getInternalVersionManager()
Returns the InternalVersionManager associated with this session.

Returns:
the InternalVersionManager associated with this session

getRetentionRegistry

protected RetentionRegistry getRetentionRegistry()
                                          throws RepositoryException
Returns the internal retention manager used for evaluation of effective retention policies and holds.

Returns:
internal retention manager
Throws:
RepositoryException

getNodeTypeInstanceHandler

public NodeTypeInstanceHandler getNodeTypeInstanceHandler()
Returns the node type instance handler for this session

Returns:
the node type instance handler.

setAttribute

protected void setAttribute(String name,
                            Object value)
Sets the named attribute. If the value is null, then the named attribute is removed.

Parameters:
name - attribute name
value - attribute value
Since:
Apache Jackrabbit 1.6
See Also:
JCR-1932

getNodeById

public NodeImpl getNodeById(NodeId id)
                     throws ItemNotFoundException,
                            RepositoryException
Retrieves the Node with the given id.

Parameters:
id - id of node to be retrieved
Returns:
node with the given NodeId.
Throws:
ItemNotFoundException - if no such node exists or if this Session does not have permission to access the node.
RepositoryException - if another error occurs.

getWorkspaceNames

protected String[] getWorkspaceNames()
                              throws RepositoryException
Returns the names of all workspaces of this repository with respect of the access rights of this session.

Returns:
the names of all accessible workspaces
Throws:
RepositoryException - if an error occurs

createWorkspace

protected void createWorkspace(String workspaceName)
                        throws AccessDeniedException,
                               RepositoryException
Creates a workspace with the given name.

Parameters:
workspaceName - name of the new workspace
Throws:
AccessDeniedException - if the current session is not allowed to create the workspace
RepositoryException - if a workspace with the given name already exists or if another error occurs

createWorkspace

protected void createWorkspace(String workspaceName,
                               InputSource configTemplate)
                        throws AccessDeniedException,
                               RepositoryException
Creates a workspace with the given name and a workspace configuration template.

Parameters:
workspaceName - name of the new workspace
configTemplate - the configuration template of the new workspace
Throws:
AccessDeniedException - if the current session is not allowed to create the workspace
RepositoryException - if a workspace with the given name already exists or if another error occurs

notifyLoggingOut

protected void notifyLoggingOut()
Notify the listeners that this session is about to be closed.


notifyLoggedOut

protected void notifyLoggedOut()
Notify the listeners that this session has been closed.


addListener

public void addListener(SessionListener listener)
Add a SessionListener

Parameters:
listener - the new listener to be informed on modifications

removeListener

public void removeListener(SessionListener listener)
Remove a SessionListener

Parameters:
listener - an existing listener

createDataStoreGarbageCollector

public GarbageCollector createDataStoreGarbageCollector()
                                                 throws RepositoryException
Create a data store garbage collector for this repository.

Throws:
RepositoryException

getPrefix

public String getPrefix(String uri)
                 throws NamespaceException
Description copied from interface: NamespaceResolver
Returns the prefix which is mapped to the given URI.

Specified by:
getPrefix in interface NamespaceResolver
Parameters:
uri - namespace URI
Returns:
the prefix mapped to the given URI.
Throws:
NamespaceException - if the URI is unknown.

getURI

public String getURI(String prefix)
              throws NamespaceException
Description copied from interface: NamespaceResolver
Returns the URI to which the given prefix is mapped.

Specified by:
getURI in interface NamespaceResolver
Parameters:
prefix - namespace prefix
Returns:
the namespace URI to which the given prefix is mapped.
Throws:
NamespaceException - if the prefix is unknown.

getJCRName

public String getJCRName(Name name)
                  throws NamespaceException
Description copied from interface: NameResolver
Returns the qualified JCR name String for the given Name object.

Specified by:
getJCRName in interface NameResolver
Parameters:
name - A Name object.
Returns:
The qualified JCR name String consisting of prefix:localName or localName in case of the empty namespace.
Throws:
NamespaceException - if the namespace URI can not be resolved

getQName

public Name getQName(String name)
              throws IllegalNameException,
                     NamespaceException
Description copied from interface: NameResolver
Returns the Name for the given JCR name String.

Specified by:
getQName in interface NameResolver
Parameters:
name - A JCR name String.
Returns:
A Name object.
Throws:
IllegalNameException - if the JCR name format is invalid
NamespaceException - if the namespace prefix can not be resolved

getJCRPath

public String getJCRPath(Path path)
                  throws NamespaceException
Description copied from interface: PathResolver
Returns the given JCR path string for the given path object.

Specified by:
getJCRPath in interface PathResolver
Parameters:
path - a Path object.
Returns:
a JCR path string
Throws:
NamespaceException - if a namespace URI can not be resolved

getQPath

public Path getQPath(String path)
              throws MalformedPathException,
                     IllegalNameException,
                     NamespaceException
Description copied from interface: PathResolver
Returns the path object for the given JCR path string.

Specified by:
getQPath in interface PathResolver
Parameters:
path - prefixed JCR path
Returns:
a Path object.
Throws:
MalformedPathException - if the JCR path format is invalid.
IllegalNameException - if any of the JCR names contained in the path are invalid.
NamespaceException - if a namespace prefix can not be resolved.

getQPath

public Path getQPath(String path,
                     boolean normalizeIdentifier)
              throws MalformedPathException,
                     IllegalNameException,
                     NamespaceException
Description copied from interface: PathResolver
Returns the path object for the given JCR path string.

Specified by:
getQPath in interface PathResolver
Parameters:
path - prefixed JCR path
Returns:
a Path object.
Throws:
MalformedPathException - if the JCR path format is invalid.
IllegalNameException - if any of the JCR names contained in the path are invalid.
NamespaceException - if a namespace prefix can not be resolved.

getPath

public Path getPath(String identifier)
             throws MalformedPathException
Specified by:
getPath in interface IdentifierResolver
Throws:
MalformedPathException
See Also:
IdentifierResolver.getPath(String)

checkFormat

public void checkFormat(String identifier)
                 throws MalformedPathException
Specified by:
checkFormat in interface IdentifierResolver
Throws:
MalformedPathException
See Also:
IdentifierResolver.checkFormat(String)

getPrincipalManager

public PrincipalManager getPrincipalManager()
                                     throws RepositoryException,
                                            AccessDeniedException
Description copied from interface: JackrabbitSession
Returns the PrincipalManager for the current Session.

Specified by:
getPrincipalManager in interface JackrabbitSession
Returns:
the PrincipalManager associated with this Session.
Throws:
AccessDeniedException - If the session lacks privileges to access the principal manager or principals in general.
UnsupportedRepositoryOperationException - If principal management is not supported.
RepositoryException - If another error occors.
See Also:
JackrabbitSession.getPrincipalManager()

getUserManager

public UserManager getUserManager()
                           throws AccessDeniedException,
                                  RepositoryException
Description copied from interface: JackrabbitSession
Returns the UserManager for the current Session.

Specified by:
getUserManager in interface JackrabbitSession
Returns:
the UserManager associated with this Session.
Throws:
AccessDeniedException - If this session is not allowed to to access user data.
UnsupportedRepositoryOperationException - If user management is not supported.
RepositoryException - If another error occurs.
See Also:
JackrabbitSession.getUserManager()

checkPermission

public void checkPermission(String absPath,
                            String actions)
                     throws AccessControlException,
                            RepositoryException

Specified by:
checkPermission in interface Session
Throws:
AccessControlException
RepositoryException

getWorkspace

public Workspace getWorkspace()

Specified by:
getWorkspace in interface Session

impersonate

public Session impersonate(Credentials otherCredentials)
                    throws LoginException,
                           RepositoryException
Logs in the same workspace with the given credentials.

The default implementation:

Specified by:
impersonate in interface Session
Overrides:
impersonate in class AbstractSession
Parameters:
otherCredentials - login credentials
Returns:
logged in session
Throws:
RepositoryException - if an error occurs
LoginException

getRootNode

public Node getRootNode()
                 throws RepositoryException

Specified by:
getRootNode in interface Session
Throws:
RepositoryException

getNodeByUUID

public Node getNodeByUUID(String uuid)
                   throws ItemNotFoundException,
                          RepositoryException

Specified by:
getNodeByUUID in interface Session
Throws:
ItemNotFoundException
RepositoryException

getItem

public Item getItem(String absPath)
             throws PathNotFoundException,
                    RepositoryException
Returns the node or property at the given path.

The default implementation:

Specified by:
getItem in interface Session
Overrides:
getItem in class AbstractSession
Parameters:
absPath - absolute path
Returns:
the node or property with the given path
Throws:
PathNotFoundException - if the given path is invalid or not found
RepositoryException - if another error occurs
See Also:
Session.getItem(String)

itemExists

public boolean itemExists(String absPath)
                   throws RepositoryException
Calls AbstractSession.getItem(String) with the given path and returns true if the call succeeds. Returns false if a PathNotFoundException was thrown. Other exceptions are passed through.

Specified by:
itemExists in interface Session
Overrides:
itemExists in class AbstractSession
Parameters:
absPath - absolute path
Returns:
true if an item exists at the given path, false otherwise
Throws:
RepositoryException - if an error occurs
See Also:
Session.itemExists(String)

save

public void save()
          throws AccessDeniedException,
                 ItemExistsException,
                 ConstraintViolationException,
                 InvalidItemStateException,
                 VersionException,
                 LockException,
                 NoSuchNodeTypeException,
                 RepositoryException

Specified by:
save in interface Session
Throws:
AccessDeniedException
ItemExistsException
ConstraintViolationException
InvalidItemStateException
VersionException
LockException
NoSuchNodeTypeException
RepositoryException

refresh

public void refresh(boolean keepChanges)
             throws RepositoryException

Specified by:
refresh in interface Session
Throws:
RepositoryException

clusterSyncOnRefresh

protected boolean clusterSyncOnRefresh()
Checks whether the refresh(boolean) method should cause cluster synchronization.

Subclasses can override this method to implement alternative rules on when cluster synchronization should be done.

Returns:
true if the DISABLE_CLUSTER_SYNC_ON_REFRESH attribute is not set, false otherwise
Since:
Apache Jackrabbit 1.6
See Also:
JCR-1753

hasPendingChanges

public boolean hasPendingChanges()
                          throws RepositoryException

Specified by:
hasPendingChanges in interface Session
Throws:
RepositoryException

move

public void move(String srcAbsPath,
                 String destAbsPath)
          throws ItemExistsException,
                 PathNotFoundException,
                 VersionException,
                 ConstraintViolationException,
                 LockException,
                 RepositoryException

Specified by:
move in interface Session
Throws:
ItemExistsException
PathNotFoundException
VersionException
ConstraintViolationException
LockException
RepositoryException

getImportContentHandler

public ContentHandler getImportContentHandler(String parentAbsPath,
                                              int uuidBehavior)
                                       throws PathNotFoundException,
                                              ConstraintViolationException,
                                              VersionException,
                                              LockException,
                                              RepositoryException

Specified by:
getImportContentHandler in interface Session
Throws:
PathNotFoundException
ConstraintViolationException
VersionException
LockException
RepositoryException

isLive

public boolean isLive()

Specified by:
isLive in interface Session

logout

public void logout()
Clears the local namespace mappings. Subclasses that for example want to participate in a session pools should remember to call super.logout() when overriding this method to avoid namespace mappings to be carried over to a new session.

Specified by:
logout in interface Session
Overrides:
logout in class AbstractSession

getRepository

public Repository getRepository()

Specified by:
getRepository in interface Session

getValueFactory

public ValueFactory getValueFactory()

Specified by:
getValueFactory in interface Session

getUserID

public String getUserID()

Specified by:
getUserID in interface Session

getAttribute

public Object getAttribute(String name)

Specified by:
getAttribute in interface Session

getAttributeNames

public String[] getAttributeNames()

Specified by:
getAttributeNames in interface Session

setNamespacePrefix

public void setNamespacePrefix(String prefix,
                               String uri)
                        throws NamespaceException,
                               RepositoryException
Modifies the session local namespace mappings to contain the given prefix to URI mapping.

This behaviour is based on JSR 283 (JCR 2.0), but remains backwards compatible with JCR 1.0.

Specified by:
setNamespacePrefix in interface Session
Overrides:
setNamespacePrefix in class AbstractSession
Parameters:
prefix - namespace prefix
uri - namespace URI
Throws:
NamespaceException - if the mapping is illegal
RepositoryException - if a repository error occurs

addLockToken

public void addLockToken(String lt)

Specified by:
addLockToken in interface Session

getLockTokens

public String[] getLockTokens()

Specified by:
getLockTokens in interface Session

removeLockToken

public void removeLockToken(String lt)

Specified by:
removeLockToken in interface Session

getLockManager

public LockManager getLockManager()
                           throws RepositoryException
Return the lock manager for this session.

Returns:
lock manager for this session
Throws:
RepositoryException

getLocks

public Lock[] getLocks()
Returns all locks owned by this session.

Returns:
an array of Locks

getNodeByIdentifier

public Node getNodeByIdentifier(String id)
                         throws ItemNotFoundException,
                                RepositoryException
Specified by:
getNodeByIdentifier in interface Session
Throws:
ItemNotFoundException
RepositoryException
Since:
JCR 2.0
See Also:
Session.getNodeByIdentifier(String)

getNode

public Node getNode(String absPath)
             throws PathNotFoundException,
                    RepositoryException
Description copied from class: AbstractSession
Returns the node with the given absolute path.

Specified by:
getNode in interface Session
Overrides:
getNode in class AbstractSession
Parameters:
absPath - absolute path
Returns:
node at the given path
Throws:
RepositoryException - if the node can not be accessed
PathNotFoundException
Since:
JCR 2.0
See Also:
Session.getNode(String)

getProperty

public Property getProperty(String absPath)
                     throws PathNotFoundException,
                            RepositoryException
Description copied from class: AbstractSession
Returns the property with the given absolute path.

Specified by:
getProperty in interface Session
Overrides:
getProperty in class AbstractSession
Parameters:
absPath - absolute path
Returns:
node at the given path
Throws:
RepositoryException - if the property can not be accessed
PathNotFoundException
Since:
JCR 2.0
See Also:
Session.getProperty(String)

nodeExists

public boolean nodeExists(String absPath)
                   throws RepositoryException
Description copied from class: AbstractSession
Checks whether a node with the given absolute path exists.

Specified by:
nodeExists in interface Session
Overrides:
nodeExists in class AbstractSession
Parameters:
absPath - absolute path
Returns:
true if a node with the given path exists, false otherwise
Throws:
RepositoryException - if the path is invalid
Since:
JCR 2.0
See Also:
Session.nodeExists(String)

propertyExists

public boolean propertyExists(String absPath)
                       throws RepositoryException
Description copied from class: AbstractSession
Checks whether a property with the given absolute path exists.

Specified by:
propertyExists in interface Session
Overrides:
propertyExists in class AbstractSession
Parameters:
absPath - absolute path
Returns:
true if a property with the given path exists, false otherwise
Throws:
RepositoryException - if the path is invalid
Since:
JCR 2.0
See Also:
Session.propertyExists(String)

removeItem

public void removeItem(String absPath)
                throws VersionException,
                       LockException,
                       ConstraintViolationException,
                       RepositoryException
Description copied from class: AbstractSession
Removes the identified item. Implemented by calling Item.remove() on the item removed by AbstractSession.getItem(String).

Specified by:
removeItem in interface Session
Overrides:
removeItem in class AbstractSession
Parameters:
absPath - An absolute path of the item to be removed
Throws:
RepositoryException - if the item can not be removed
VersionException
LockException
ConstraintViolationException
Since:
JCR 2.0
See Also:
Session.removeItem(String)

hasPermission

public boolean hasPermission(String absPath,
                             String actions)
                      throws RepositoryException
Specified by:
hasPermission in interface Session
Throws:
RepositoryException
Since:
2.0
See Also:
Session.hasPermission(String, String)

hasCapability

public boolean hasCapability(String methodName,
                             Object target,
                             Object[] arguments)
                      throws RepositoryException
Specified by:
hasCapability in interface Session
Throws:
RepositoryException
Since:
JCR 2.0
See Also:
Session.hasCapability(String, Object, Object[])

getAccessControlManager

public AccessControlManager getAccessControlManager()
                                             throws UnsupportedRepositoryOperationException,
                                                    RepositoryException
Specified by:
getAccessControlManager in interface Session
Throws:
UnsupportedRepositoryOperationException
RepositoryException
Since:
JCR 2.0
See Also:
Session.getAccessControlManager()

getRetentionManager

public RetentionManager getRetentionManager()
                                     throws UnsupportedRepositoryOperationException,
                                            RepositoryException
Specified by:
getRetentionManager in interface Session
Throws:
UnsupportedRepositoryOperationException
RepositoryException
Since:
JCR 2.0
See Also:
Session.getRetentionManager()

dump

public void dump(PrintStream ps)
Dumps the state of this instance in a human readable format for diagnostic purposes.

Specified by:
dump in interface Dumpable
Parameters:
ps - stream to dump state to

finalize

public void finalize()
Finalize the session. If the application doesn't call Session.logout(), the session is closed automatically; however a warning is written to the log file, together with the stack trace of where the session was opened.

Overrides:
finalize in class Object


Copyright © 2004-2010 The Apache Software Foundation. All Rights Reserved.