public class NodeImpl extends ItemImpl implements Node, org.apache.jackrabbit.api.JackrabbitNode
NodeImpl implements the Node interface.| Modifier and Type | Field and Description |
|---|---|
protected static short |
CREATED |
id, itemMgr, sessionContext, stateMgr, STATUS_DESTROYED, STATUS_INVALIDATED, STATUS_MODIFIED, STATUS_NORMALJCR_CHILD_NODE_DEFINITION, JCR_CONTENT, JCR_FROZEN_NODE, JCR_PROPERTY_DEFINITION, JCR_ROOT_VERSION, JCR_VERSION_LABELS| Modifier | Constructor and Description |
|---|---|
protected |
NodeImpl(ItemManager itemMgr,
SessionContext sessionContext,
AbstractNodeData data)
Protected constructor.
|
| Modifier and Type | Method and Description |
|---|---|
void |
accept(ItemVisitor visitor) |
void |
addMixin(Name mixinName)
|
void |
addMixin(String mixinName)
Wrapper around
addMixin(Name). |
NodeImpl |
addNode(Name nodeName,
Name nodeTypeName,
NodeId id)
Same as
except that
this method takes Name arguments instead of
Strings and has an additional uuid argument. |
Node |
addNode(String relPath) |
Node |
addNode(String relPath,
String nodeTypeName) |
Node |
addNodeWithUuid(String relPath,
String uuid)
Adds a node with the given UUID.
|
Node |
addNodeWithUuid(String relPath,
String nodeTypeName,
String uuid)
Adds a node with the given node type and UUID.
|
void |
assignLifecyclePolicy(Node policy,
String state)
Assigns the given lifecycle policy to this node and sets the
current state to the one given.
|
boolean |
canAddMixin(String mixinName) |
void |
cancelMerge(Version version)
Deprecated.
|
Version |
checkin()
Deprecated.
|
Version |
checkin(Calendar created)
Deprecated.
|
protected void |
checkLock()
Deprecated.
|
void |
checkout()
Deprecated.
|
protected void |
checkSetProperty()
Checks various pre-conditions that are common to all
setProperty() methods. |
NodeImpl |
clone(NodeImpl src,
Name name)
Create a child node that is a clone of a shareable node.
|
protected NodeImpl |
createChildNode(Name name,
NodeTypeImpl nodeType,
NodeId id) |
protected PropertyImpl |
createChildProperty(Name name,
int type,
PropertyDefinitionImpl def)
Creates a new property with the given name and
type hint and
property definition. |
void |
doneMerge(Version version)
Deprecated.
|
void |
followLifecycleTransition(String transition)
Transitions this node through its lifecycle to the given target state.
|
String[] |
getAllowedLifecycleTransistions()
Returns all allowed transitions from the current lifecycle state of
this node.
|
protected NodeDefinitionImpl |
getApplicableChildNodeDefinition(Name nodeName,
Name nodeTypeName)
Returns the applicable child node definition for a child node with the
specified name and node type.
|
protected PropertyDefinitionImpl |
getApplicablePropertyDefinition(Name propertyName,
int type,
boolean multiValued,
boolean exactTypeMatch)
Returns the applicable property definition for a property with the
specified name and type.
|
Version |
getBaseVersion()
Deprecated.
|
String |
getCorrespondingNodePath(String workspaceName) |
NodeDefinition |
getDefinition() |
EffectiveNodeType |
getEffectiveNodeType()
Returns the effective (i.e.
|
String |
getIdentifier() |
int |
getIndex() |
Lock |
getLock() |
NodeType[] |
getMixinNodeTypes() |
Set<Name> |
getMixinTypeNames()
Returns the
Names of this node's mixin types. |
String |
getName() |
NodeImpl |
getNode(Name name)
Returns the child node of
this node with the specified
name. |
NodeImpl |
getNode(Name name,
int index)
Returns the child node of
this node with the specified
name. |
Node |
getNode(String relPath) |
NodeId |
getNodeId()
Returns the identifier of this
Node. |
NodeIterator |
getNodes() |
NodeIterator |
getNodes(String namePattern) |
NodeIterator |
getNodes(String[] nameGlobs) |
protected PropertyImpl |
getOrCreateProperty(Name name,
int type,
boolean multiValued,
boolean exactTypeMatch,
BitSet status) |
protected PropertyImpl |
getOrCreateProperty(String name,
int type,
boolean multiValued,
boolean exactTypeMatch,
BitSet status) |
protected ItemState |
getOrCreateTransientItemState() |
Node |
getParent() |
NodeId |
getParentId()
Helper method, returning the parent id this node is attached to.
|
Item |
getPrimaryItem() |
NodeType |
getPrimaryNodeType() |
Name |
getPrimaryNodeTypeName()
Returns the name of the primary node type as exposed on the node state
without retrieving the node type.
|
Path |
getPrimaryPath()
Returns the primary path to this
Item. |
PropertyIterator |
getProperties() |
PropertyIterator |
getProperties(String namePattern) |
PropertyIterator |
getProperties(String[] nameGlobs) |
PropertyImpl |
getProperty(Name name)
Returns the property of
this node with the specified
name. |
Property |
getProperty(String relPath) |
Name |
getQName()
|
PropertyIterator |
getReferences() |
PropertyIterator |
getReferences(String name) |
NodeIterator |
getSharedSet()
Returns an iterator over all nodes that are in the shared set of this
node.
|
String |
getUUID() |
VersionHistory |
getVersionHistory()
Deprecated.
|
PropertyIterator |
getWeakReferences() |
PropertyIterator |
getWeakReferences(String name) |
boolean |
hasNode(Name name)
Indicates whether a child node with the specified
name exists. |
boolean |
hasNode(Name name,
int index)
Indicates whether a child node with the specified
name exists. |
boolean |
hasNode(String relPath) |
boolean |
hasNodes() |
protected boolean |
hasPendingChanges()
Determines if there are pending unsaved changes either on this
node or on any node or property in the subtree below it.
|
boolean |
hasProperties() |
boolean |
hasProperty(Name name)
Indicates whether a property with the specified
name exists. |
boolean |
hasProperty(String relPath) |
boolean |
holdsLock() |
protected Property |
internalSetProperty(Name name,
InternalValue value)
Sets the internal value of a property without checking any constraints.
|
protected Property |
internalSetProperty(Name name,
InternalValue[] values)
Sets the internal value of a property without checking any constraints.
|
protected Property |
internalSetProperty(Name name,
InternalValue[] values,
int type)
Sets the internal value of a property without checking any constraints.
|
boolean |
isAccessControllable()
Test if this node is access controlled.
|
boolean |
isCheckedOut() |
boolean |
isLocked() |
boolean |
isNode() |
boolean |
isNodeType(Name ntName)
|
boolean |
isNodeType(String nodeTypeName) |
Lock |
lock(boolean isDeep,
boolean isSessionScoped) |
protected void |
makePersistent() |
NodeIterator |
merge(String srcWorkspace,
boolean bestEffort)
Deprecated.
|
protected void |
onRedefine(QNodeDefinition def) |
protected void |
onRemove(NodeId parentId) |
void |
orderBefore(Path.Element srcName,
Path.Element dstName)
Same as
except that
this method takes a Path.Element arguments instead of
Strings. |
void |
orderBefore(String srcName,
String destName) |
protected void |
removeChildNode(NodeId childId) |
protected void |
removeChildProperty(Name propName) |
void |
removeMixin(Name mixinName)
|
void |
removeMixin(String mixinName)
Wrapper around
removeMixin(Name). |
void |
removeShare()
A special kind of
remove() that removes this node, but does
not remove any other node in the shared set of this node. |
void |
removeSharedSet()
A special kind of
remove() that removes this node and every
other node in the shared set of this node. |
void |
rename(String newName) |
protected void |
renameChildNode(Name oldName,
int index,
NodeId id,
Name newName)
Deprecated.
use #renameChildNode(NodeId, Name, boolean)
|
protected void |
renameChildNode(NodeId id,
Name newName,
boolean replace) |
NodeImpl |
replaceChildNode(NodeId id,
Name nodeName,
Name nodeTypeName,
Name[] mixinNames)
Replaces the child node with the specified
id
by a new child node with the same id and specified nodeName,
nodeTypeName and mixinNames. |
protected NodeId |
resolveRelativeNodePath(String relPath)
Returns the id of the node at
relPath or null
if no node exists at relPath. |
protected PropertyId |
resolveRelativePropertyPath(String relPath)
Returns the id of the property at
relPath or null
if no property exists at relPath. |
void |
restore(String versionName,
boolean removeExisting)
Deprecated.
|
void |
restore(Version version,
boolean removeExisting)
Deprecated.
|
void |
restore(Version version,
String relPath,
boolean removeExisting)
Deprecated.
|
void |
restoreByLabel(String versionLabel,
boolean removeExisting)
Deprecated.
|
protected void |
restoreTransient(NodeState transientState) |
void |
setMixins(String[] mixinNames) |
void |
setPrimaryType(String nodeTypeName) |
PropertyImpl |
setProperty(Name name,
Value value)
Same as
except that
this method takes a Name name argument instead of a
String. |
PropertyImpl |
setProperty(Name name,
Value[] values,
int type)
Same as
except
that this method takes a Name name argument instead of a
String. |
protected PropertyImpl |
setProperty(Name name,
Value[] values,
int type,
boolean enforceType)
Implementation for
setProperty() using a Value
array. |
Property |
setProperty(String name,
BigDecimal value) |
Property |
setProperty(String name,
Binary value) |
Property |
setProperty(String name,
boolean value)
Wrapper around
setProperty(String, Value) |
Property |
setProperty(String name,
Calendar value)
Wrapper around
setProperty(String, Value) |
Property |
setProperty(String name,
double value)
Wrapper around
setProperty(String, Value) |
Property |
setProperty(String name,
InputStream value)
Wrapper around
setProperty(String, Value) |
Property |
setProperty(String name,
long value)
Wrapper around
setProperty(String, Value) |
Property |
setProperty(String name,
Node value)
Wrapper around
setProperty(String, Value) |
Property |
setProperty(String name,
String value)
Wrapper around
setProperty(String, Value) |
Property |
setProperty(String name,
String[] strings)
Wrapper around
setProperty(Name, Value[], int, boolean) |
Property |
setProperty(String name,
String[] values,
int type)
Wrapper around
setProperty(Name, Value[], int, boolean) |
Property |
setProperty(String name,
String value,
int type)
Wrapper around
setProperty(String, Value, int) |
Property |
setProperty(String name,
Value value)
Wrapper around
SetPropertyOperation |
Property |
setProperty(String name,
Value[] values)
Wrapper around
setProperty(Name, Value[], int, boolean) |
Property |
setProperty(String name,
Value[] values,
int type)
Wrapper around
setProperty(Name, Value[], int, boolean) |
Property |
setProperty(String name,
Value value,
int type)
Wrapper around
SetPropertyOperation |
String |
toString()
Return a string representation of this node for diagnostic purposes.
|
void |
unlock() |
void |
update(String srcWorkspaceName) |
getAncestor, getDepth, getId, getPath, getQName, getSession, getType, getValueFactory, getValues, isModified, isNew, isSame, isTransactionalNew, isTransient, itemSanityCheck, perform, refresh, remove, safeGetJCRPath, sanityCheck, save, setRemovedclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitgetNodeOrNull, getPropertyOrNullgetAncestor, getDepth, getPath, getSession, isModified, isNew, isSame, refresh, remove, saveprotected static final short CREATED
protected NodeImpl(ItemManager itemMgr, SessionContext sessionContext, AbstractNodeData data)
itemMgr - the ItemManager that created this Node instancesessionContext - the component context of the associated sessiondata - the node dataprotected PropertyId resolveRelativePropertyPath(String relPath) throws RepositoryException
relPath or null
if no property exists at relPath.
Note that access rights are not checked.
relPath - relative path of a (possible) propertyrelPath or
null if no property exists at relPathRepositoryException - if relPath is not a valid
relative pathprotected NodeId resolveRelativeNodePath(String relPath) throws RepositoryException
relPath or null
if no node exists at relPath.
Note that access rights are not checked.
relPath - relative path of a (possible) noderelPath or
null if no node exists at relPathRepositoryException - if relPath is not a valid
relative pathprotected boolean hasPendingChanges()
throws RepositoryException
true if there are pending unsaved changes,
false otherwise.RepositoryException - if an error occurredprotected ItemState getOrCreateTransientItemState() throws RepositoryException
getOrCreateTransientItemState in class ItemImplRepositoryExceptionprotected PropertyImpl getOrCreateProperty(String name, int type, boolean multiValued, boolean exactTypeMatch, BitSet status) throws ConstraintViolationException, RepositoryException
name - type - multiValued - exactTypeMatch - status - ConstraintViolationException - if no applicable property definition
could be foundRepositoryException - if another error occursprotected PropertyImpl getOrCreateProperty(Name name, int type, boolean multiValued, boolean exactTypeMatch, BitSet status) throws ConstraintViolationException, RepositoryException
name - type - multiValued - exactTypeMatch - status - ConstraintViolationException - if no applicable property definition
could be foundRepositoryException - if another error occursprotected PropertyImpl createChildProperty(Name name, int type, PropertyDefinitionImpl def) throws RepositoryException
type hint and
property definition. If the given property definition is not of type
UNDEFINED, then it takes precedence over the
type hint.name - the name of the property to create.type - the type hint.def - the associated property definition.RepositoryException - if the property cannot be created.protected NodeImpl createChildNode(Name name, NodeTypeImpl nodeType, NodeId id) throws RepositoryException
RepositoryExceptionprotected void renameChildNode(Name oldName, int index, NodeId id, Name newName) throws RepositoryException
oldName - index - id - newName - RepositoryExceptionprotected void renameChildNode(NodeId id, Name newName, boolean replace) throws RepositoryException
id - newName - replace - RepositoryExceptionprotected void removeChildProperty(Name propName) throws RepositoryException
RepositoryExceptionprotected void removeChildNode(NodeId childId) throws RepositoryException
RepositoryExceptionprotected void onRedefine(QNodeDefinition def) throws RepositoryException
RepositoryExceptionprotected void onRemove(NodeId parentId) throws RepositoryException
RepositoryExceptionpublic Set<Name> getMixinTypeNames()
Names of this node's mixin types.Names of this node's mixin types.public EffectiveNodeType getEffectiveNodeType() throws RepositoryException
RepositoryException - if an error occursprotected NodeDefinitionImpl getApplicableChildNodeDefinition(Name nodeName, Name nodeTypeName) throws ConstraintViolationException, RepositoryException
nodeName - nodeTypeName - ConstraintViolationException - if no applicable child node definition
could be foundRepositoryException - if another error occursprotected PropertyDefinitionImpl getApplicablePropertyDefinition(Name propertyName, int type, boolean multiValued, boolean exactTypeMatch) throws ConstraintViolationException, RepositoryException
propertyName - type - multiValued - exactTypeMatch - ConstraintViolationException - if no applicable property definition
could be foundRepositoryException - if another error occursprotected void makePersistent()
throws RepositoryException
makePersistent in class ItemImplRepositoryExceptionprotected void restoreTransient(NodeState transientState) throws RepositoryException
RepositoryExceptionpublic void addMixin(Name mixinName) throws RepositoryException
RepositoryExceptionNode.addMixin(String)public void removeMixin(Name mixinName) throws RepositoryException
RepositoryExceptionNode.removeMixin(String)public boolean isNodeType(Name ntName) throws RepositoryException
ntName - name of node typetrue if this node is of the specified node type;
otherwise falseRepositoryExceptionprotected void checkSetProperty()
throws VersionException,
LockException,
RepositoryException
setProperty() methods. The checks performed are:
Property.setValue() methods.VersionException - if this node is not checked-outLockException - if this node is locked by somebody elseRepositoryException - if another error occursNode.setProperty(java.lang.String, javax.jcr.Value)protected Property internalSetProperty(Name name, InternalValue value) throws ValueFormatException, RepositoryException
Note that no type conversion is being performed, i.e. it's the caller's responsibility to make sure that the type of the given value is compatible with the specified property's definition.
name - value - ValueFormatExceptionRepositoryExceptionprotected Property internalSetProperty(Name name, InternalValue[] values) throws ValueFormatException, RepositoryException
Note that no type conversion is being performed, i.e. it's the caller's responsibility to make sure that the type of the given values is compatible with the specified property's definition.
name - values - ValueFormatExceptionRepositoryExceptionprotected Property internalSetProperty(Name name, InternalValue[] values, int type) throws ValueFormatException, RepositoryException
Note that no type conversion is being performed, i.e. it's the caller's responsibility to make sure that the type of the given values is compatible with the specified property's definition.
name - values - type - ValueFormatExceptionRepositoryExceptionpublic NodeImpl getNode(Name name) throws ItemNotFoundException, RepositoryException
this node with the specified
name.name - The name of the child node to retrieve.name.ItemNotFoundException - If no child node exists with the
specified name.RepositoryException - If another error occurs.public NodeImpl getNode(Name name, int index) throws ItemNotFoundException, RepositoryException
this node with the specified
name.name - The name of the child node to retrieve.index - The index of the child node to retrieve (in the case of same-name siblings).name.ItemNotFoundException - If no child node exists with the
specified name.RepositoryException - If another error occurs.public boolean hasNode(Name name) throws RepositoryException
name exists.
Returns true if the child node exists and false
otherwise.name - The name of the child node.true if the child node exists; false otherwise.RepositoryException - If an unspecified error occurs.public boolean hasNode(Name name, int index) throws RepositoryException
name exists.
Returns true if the child node exists and false
otherwise.name - The name of the child node.index - The index of the child node (in the case of same-name siblings).true if the child node exists; false otherwise.RepositoryException - If an unspecified error occurs.public PropertyImpl getProperty(Name name) throws ItemNotFoundException, RepositoryException
this node with the specified
name.name - The name of the property to retrieve.name.ItemNotFoundException - If no property exists with the
specified name.RepositoryException - If another error occurs.public boolean hasProperty(Name name) throws RepositoryException
name exists.
Returns true if the property exists and false
otherwise.name - The name of the property.true if the property exists; false otherwise.RepositoryException - If an unspecified error occurs.public NodeImpl addNode(Name nodeName, Name nodeTypeName, NodeId id) throws RepositoryException
Node.addNode(String, String) except that
this method takes Name arguments instead of
Strings and has an additional uuid argument.
Important Notice: This method is for internal use only! Passing already assigned uuid's might lead to unexpected results and data corruption in the worst case.
nodeName - name of the new nodenodeTypeName - name of the new node's node type or null
if it should be determined automaticallyid - id of the new node or null if a new
id should be assignedRepositoryException - if the node can not addedpublic PropertyImpl setProperty(Name name, Value[] values, int type) throws ValueFormatException, VersionException, LockException, ConstraintViolationException, RepositoryException
Node.setProperty(String, Value[], int) except
that this method takes a Name name argument instead of a
String.name - values - type - ValueFormatExceptionVersionExceptionLockExceptionConstraintViolationExceptionRepositoryExceptionpublic PropertyImpl setProperty(Name name, Value value) throws RepositoryException
Node.setProperty(String, Value) except that
this method takes a Name name argument instead of a
String.RepositoryExceptionpublic Name getQName() throws RepositoryException
ItemImplgetQName in class ItemImplNameRepositoryException - if an error occurs.ItemImpl.getQName()public NodeId getNodeId()
Node.Nodepublic Name getPrimaryNodeTypeName()
public boolean isAccessControllable()
throws RepositoryException
"rep:AccessControllable"
and if it has a child node named
AccessControlConstants.N_POLICY.true if this node is access controlled and has a
rep:policy child; false otherwise.RepositoryException - if an error occurspublic void orderBefore(Path.Element srcName, Path.Element dstName) throws UnsupportedRepositoryOperationException, VersionException, ConstraintViolationException, ItemNotFoundException, LockException, RepositoryException
Node.orderBefore(String, String) except that
this method takes a Path.Element arguments instead of
Strings.srcName - dstName - UnsupportedRepositoryOperationExceptionVersionExceptionConstraintViolationExceptionItemNotFoundExceptionLockExceptionRepositoryExceptionpublic NodeImpl replaceChildNode(NodeId id, Name nodeName, Name nodeTypeName, Name[] mixinNames) throws ItemNotFoundException, NoSuchNodeTypeException, VersionException, ConstraintViolationException, LockException, RepositoryException
id
by a new child node with the same id and specified nodeName,
nodeTypeName and mixinNames.id - id of the child node to be replacednodeName - name of the new nodenodeTypeName - name of the new node's node typemixinNames - name of the new node's mixin typesItemNotFoundExceptionNoSuchNodeTypeExceptionVersionExceptionConstraintViolationExceptionLockExceptionRepositoryExceptionpublic NodeImpl clone(NodeImpl src, Name name) throws ItemExistsException, VersionException, ConstraintViolationException, LockException, RepositoryException
src - shareable source nodename - name of new nodeItemExistsException - if there already is a child node with the
name given and the definition does not allow creating another oneVersionException - if this node is not checked outConstraintViolationException - if no definition is found in this
node that would allow creating the child nodeLockException - if this node is lockedRepositoryException - if some other error occurspublic boolean isNode()
public String getName() throws RepositoryException
getName in interface ItemgetName in class ItemImplRepositoryExceptionpublic void accept(ItemVisitor visitor) throws RepositoryException
accept in interface Itemaccept in class ItemImplRepositoryExceptionpublic Node getParent() throws RepositoryException
getParent in interface ItemgetParent in class ItemImplRepositoryExceptionpublic Node addNode(String relPath) throws RepositoryException
addNode in interface NodeRepositoryExceptionpublic Node addNode(String relPath, String nodeTypeName) throws RepositoryException
addNode in interface NodeRepositoryExceptionpublic Node addNodeWithUuid(String relPath, String uuid) throws RepositoryException
relPath - path of the new nodeuuid - UUID of the new node,
or null for a random new UUIDRepositoryException - if the node can not be addedNode.addNode(String)public Node addNodeWithUuid(String relPath, String nodeTypeName, String uuid) throws RepositoryException
relPath - path of the new nodenodeTypeName - name of the new node's node type,
or null for automatic type assignmentuuid - UUID of the new node,
or null for a random new UUIDRepositoryException - if the node can not be addedNode.addNode(String, String)public void orderBefore(String srcName, String destName) throws UnsupportedRepositoryOperationException, VersionException, ConstraintViolationException, ItemNotFoundException, LockException, RepositoryException
orderBefore in interface NodeUnsupportedRepositoryOperationExceptionVersionExceptionConstraintViolationExceptionItemNotFoundExceptionLockExceptionRepositoryExceptionpublic Property setProperty(String name, Value[] values) throws RepositoryException
setProperty(Name, Value[], int, boolean)setProperty in interface NodeRepositoryExceptionpublic Property setProperty(String name, Value[] values, int type) throws RepositoryException
setProperty(Name, Value[], int, boolean)setProperty in interface NodeRepositoryExceptionpublic Property setProperty(String name, String[] strings) throws RepositoryException
setProperty(Name, Value[], int, boolean)setProperty in interface NodeRepositoryExceptionpublic Property setProperty(String name, String[] values, int type) throws RepositoryException
setProperty(Name, Value[], int, boolean)setProperty in interface NodeRepositoryExceptionpublic Property setProperty(String name, String value) throws RepositoryException
setProperty(String, Value)setProperty in interface NodeRepositoryExceptionpublic Property setProperty(String name, String value, int type) throws RepositoryException
setProperty(String, Value, int)setProperty in interface NodeRepositoryExceptionpublic Property setProperty(String name, Value value, int type) throws RepositoryException
SetPropertyOperationsetProperty in interface NodeRepositoryExceptionpublic Property setProperty(String name, Value value) throws RepositoryException
SetPropertyOperationsetProperty in interface NodeRepositoryExceptionpublic Property setProperty(String name, InputStream value) throws RepositoryException
setProperty(String, Value)setProperty in interface NodeRepositoryExceptionpublic Property setProperty(String name, boolean value) throws RepositoryException
setProperty(String, Value)setProperty in interface NodeRepositoryExceptionpublic Property setProperty(String name, double value) throws RepositoryException
setProperty(String, Value)setProperty in interface NodeRepositoryExceptionpublic Property setProperty(String name, long value) throws RepositoryException
setProperty(String, Value)setProperty in interface NodeRepositoryExceptionpublic Property setProperty(String name, Calendar value) throws RepositoryException
setProperty(String, Value)setProperty in interface NodeRepositoryExceptionpublic Property setProperty(String name, Node value) throws RepositoryException
setProperty(String, Value)setProperty in interface NodeRepositoryExceptionprotected PropertyImpl setProperty(Name name, Value[] values, int type, boolean enforceType) throws RepositoryException
setProperty() using a Value
array. The type of the returned property is enforced based on the
enforceType flag. If set to true, the returned
property is of the passed type if it didn't exist before. If set to
false, then the returned property may be of some other type,
but still must be based on an existing property definition for the given
name and multi-valued flag. The resulting type is taken from that
definition and the implementation tries to convert the passed values to
that type. If that fails, then a ValueFormatException is thrown.name - the name of the property to set.values - the values to set. If null the property
is removed.type - the target type of the values to set.enforceType - if the target type is enforced.Property object set, or null if
this method was used to remove a property (by setting its value
to null).ValueFormatException - if a value cannot be converted to
the specified type or if the
property already exists and is not
multi-valued.VersionException - if this node is read-only due to a
checked-in node and this implementation
performs this validation immediately.LockException - if a lock prevents the setting of
the property and this implementation
performs this validation immediately.ConstraintViolationException - if the change would violate a
node-type or other constraint and
this implementation performs this
validation immediately.RepositoryException - if another error occurs.public Node getNode(String relPath) throws RepositoryException
getNode in interface NodeRepositoryExceptionpublic NodeIterator getNodes() throws RepositoryException
getNodes in interface NodeRepositoryExceptionpublic PropertyIterator getProperties() throws RepositoryException
getProperties in interface NodeRepositoryExceptionpublic Property getProperty(String relPath) throws PathNotFoundException, RepositoryException
getProperty in interface NodePathNotFoundExceptionRepositoryExceptionpublic boolean hasNode(String relPath) throws RepositoryException
hasNode in interface NodeRepositoryExceptionpublic boolean hasNodes()
throws RepositoryException
hasNodes in interface NodeRepositoryExceptionpublic boolean hasProperties()
throws RepositoryException
hasProperties in interface NodeRepositoryExceptionpublic boolean isNodeType(String nodeTypeName) throws RepositoryException
isNodeType in interface NodeRepositoryExceptionpublic NodeType getPrimaryNodeType() throws RepositoryException
getPrimaryNodeType in interface NodeRepositoryExceptionpublic NodeType[] getMixinNodeTypes() throws RepositoryException
getMixinNodeTypes in interface NodeRepositoryExceptionpublic void addMixin(String mixinName) throws RepositoryException
addMixin(Name).addMixin in interface NodeRepositoryExceptionpublic void removeMixin(String mixinName) throws RepositoryException
removeMixin(Name).removeMixin in interface NodeRepositoryExceptionpublic boolean canAddMixin(String mixinName) throws NoSuchNodeTypeException, RepositoryException
canAddMixin in interface NodeNoSuchNodeTypeExceptionRepositoryExceptionpublic boolean hasProperty(String relPath) throws RepositoryException
hasProperty in interface NodeRepositoryExceptionpublic PropertyIterator getReferences() throws RepositoryException
getReferences in interface NodeRepositoryExceptionpublic NodeDefinition getDefinition() throws RepositoryException
getDefinition in interface NodeRepositoryExceptionpublic NodeIterator getNodes(String namePattern) throws RepositoryException
getNodes in interface NodeRepositoryExceptionpublic PropertyIterator getProperties(String namePattern) throws RepositoryException
getProperties in interface NodeRepositoryExceptionpublic Item getPrimaryItem() throws ItemNotFoundException, RepositoryException
getPrimaryItem in interface NodeItemNotFoundExceptionRepositoryExceptionpublic String getUUID() throws UnsupportedRepositoryOperationException, RepositoryException
getUUID in interface NodeUnsupportedRepositoryOperationExceptionRepositoryExceptionpublic String getCorrespondingNodePath(String workspaceName) throws ItemNotFoundException, NoSuchWorkspaceException, AccessDeniedException, RepositoryException
getCorrespondingNodePath in interface NodeItemNotFoundExceptionNoSuchWorkspaceExceptionAccessDeniedExceptionRepositoryExceptionpublic int getIndex()
throws RepositoryException
getIndex in interface NodeRepositoryExceptionpublic NodeIterator getSharedSet() throws RepositoryException
getSharedSet in interface NodeNodeIteratorRepositoryException - if an error occurs.public void removeSharedSet()
throws VersionException,
LockException,
ConstraintViolationException,
RepositoryException
remove() that removes this node and every
other node in the shared set of this node.
This removal must be done atomically, i.e., if one of the nodes cannot be
removed, the function throws the exception remove() would
have thrown in that case, and none of the nodes are removed.
If this node is not shared this method removes only this node.
removeSharedSet in interface NodeVersionExceptionLockExceptionConstraintViolationExceptionRepositoryExceptionremoveShare(),
Item.remove()public void removeShare()
throws VersionException,
LockException,
ConstraintViolationException,
RepositoryException
remove() that removes this node, but does
not remove any other node in the shared set of this node.
All of the exceptions defined for remove() apply to this
function. In addition, a RepositoryException is thrown if
this node cannot be removed without removing another node in the shared
set of this node.
If this node is not shared this method removes only this node.
removeShare in interface NodeVersionExceptionLockExceptionConstraintViolationExceptionRepositoryExceptionremoveSharedSet(),
Item.remove()public NodeId getParentId()
public Path getPrimaryPath() throws RepositoryException
Item.
Overridden to return a different path for shareable nodes.
TODO SN: copies functionality in that is already available in
HierarchyManagerImpl, namely composing a path by
concatenating the parent path + this node's name and index:
rather use hierarchy manager to do thisgetPrimaryPath in class ItemImplItemRepositoryExceptionpublic boolean isCheckedOut()
throws RepositoryException
isCheckedOut in interface NodeRepositoryExceptionpublic void update(String srcWorkspaceName) throws RepositoryException
update in interface NodeRepositoryException@Deprecated public Version checkin() throws RepositoryException
VersionManager.checkin(String) insteadcheckin in interface NodeRepositoryException@Deprecated public Version checkin(Calendar created) throws RepositoryException
VersionManagerImpl.checkin(String, Calendar) insteadRepositoryException@Deprecated public void checkout() throws RepositoryException
VersionManager.checkout(String) insteadcheckout in interface NodeRepositoryException@Deprecated public NodeIterator merge(String srcWorkspace, boolean bestEffort) throws RepositoryException
VersionManager.merge(String, String, boolean) insteadmerge in interface NodeRepositoryException@Deprecated public void cancelMerge(Version version) throws RepositoryException
VersionManager.cancelMerge(String, Version) insteadcancelMerge in interface NodeRepositoryException@Deprecated public void doneMerge(Version version) throws RepositoryException
VersionManager.doneMerge(String, Version) insteaddoneMerge in interface NodeRepositoryException@Deprecated public void restore(String versionName, boolean removeExisting) throws RepositoryException
VersionManager.restore(String, String, boolean) insteadrestore in interface NodeRepositoryException@Deprecated public void restore(Version version, boolean removeExisting) throws RepositoryException
VersionManager.restore(String, Version, boolean) insteadrestore in interface NodeRepositoryException@Deprecated public void restore(Version version, String relPath, boolean removeExisting) throws RepositoryException
VersionManager.restore(String, Version, boolean) insteadrestore in interface NodeRepositoryException@Deprecated public void restoreByLabel(String versionLabel, boolean removeExisting) throws RepositoryException
restoreByLabel in interface NodeRepositoryException@Deprecated public VersionHistory getVersionHistory() throws RepositoryException
VersionManager.getVersionHistory(String) insteadgetVersionHistory in interface NodeRepositoryException@Deprecated public Version getBaseVersion() throws RepositoryException
VersionManager.getBaseVersion(String) insteadgetBaseVersion in interface NodeRepositoryExceptionpublic Lock lock(boolean isDeep, boolean isSessionScoped) throws UnsupportedRepositoryOperationException, LockException, AccessDeniedException, InvalidItemStateException, RepositoryException
lock in interface NodeUnsupportedRepositoryOperationExceptionLockExceptionAccessDeniedExceptionInvalidItemStateExceptionRepositoryExceptionpublic Lock getLock() throws UnsupportedRepositoryOperationException, LockException, AccessDeniedException, RepositoryException
getLock in interface NodeUnsupportedRepositoryOperationExceptionLockExceptionAccessDeniedExceptionRepositoryExceptionpublic void unlock()
throws UnsupportedRepositoryOperationException,
LockException,
AccessDeniedException,
InvalidItemStateException,
RepositoryException
unlock in interface NodeUnsupportedRepositoryOperationExceptionLockExceptionAccessDeniedExceptionInvalidItemStateExceptionRepositoryExceptionpublic boolean holdsLock()
throws RepositoryException
holdsLock in interface NodeRepositoryExceptionpublic boolean isLocked()
throws RepositoryException
isLocked in interface NodeRepositoryExceptionprotected void checkLock()
throws LockException,
RepositoryException
LockException - if this node is locked by somebody elseRepositoryException - if some other error occurspublic String getIdentifier() throws RepositoryException
getIdentifier in interface NodeRepositoryExceptionpublic PropertyIterator getReferences(String name) throws RepositoryException
getReferences in interface NodeRepositoryExceptionpublic PropertyIterator getWeakReferences() throws RepositoryException
getWeakReferences in interface NodeRepositoryExceptionpublic PropertyIterator getWeakReferences(String name) throws RepositoryException
getWeakReferences in interface NodeRepositoryExceptionpublic NodeIterator getNodes(String[] nameGlobs) throws RepositoryException
getNodes in interface NodeRepositoryExceptionpublic PropertyIterator getProperties(String[] nameGlobs) throws RepositoryException
getProperties in interface NodeRepositoryExceptionpublic void setPrimaryType(String nodeTypeName) throws NoSuchNodeTypeException, VersionException, ConstraintViolationException, LockException, RepositoryException
setPrimaryType in interface NodeNoSuchNodeTypeExceptionVersionExceptionConstraintViolationExceptionLockExceptionRepositoryExceptionpublic Property setProperty(String name, BigDecimal value) throws ValueFormatException, VersionException, LockException, ConstraintViolationException, RepositoryException
setProperty in interface NodeValueFormatExceptionVersionExceptionLockExceptionConstraintViolationExceptionRepositoryExceptionpublic Property setProperty(String name, Binary value) throws ValueFormatException, VersionException, LockException, ConstraintViolationException, RepositoryException
setProperty in interface NodeValueFormatExceptionVersionExceptionLockExceptionConstraintViolationExceptionRepositoryExceptionpublic String[] getAllowedLifecycleTransistions() throws UnsupportedRepositoryOperationException, RepositoryException
The lifecycle policy node referenced by the "jcr:lifecyclePolicy" property is expected to contain a "transitions" node with a list of child nodes, one for each transition. These transition nodes must have single-valued string "from" and "to" properties that identify the allowed source and target states of each transition.
Note that future versions of Apache Jackrabbit may well use different lifecycle policy implementations.
getAllowedLifecycleTransistions in interface NodeUnsupportedRepositoryOperationException - if this node does not have the mix:lifecycle mixin node typeRepositoryException - if a repository error occurspublic void followLifecycleTransition(String transition) throws UnsupportedRepositoryOperationException, InvalidLifecycleTransitionException, RepositoryException
followLifecycleTransition in interface Nodetransition - target lifecycle stateUnsupportedRepositoryOperationException - if this node does not have the mix:lifecycle mixin node typeInvalidLifecycleTransitionException - if the given target state is not among the allowed
transitions from the current lifecycle state of this nodeRepositoryException - if a repository error occursgetAllowedLifecycleTransistions()public void assignLifecyclePolicy(Node policy, String state) throws RepositoryException
Note that currently no special checks are made against the given arguments, and that you will need to explicitly persist these changes by calling save().
Note that future versions of Apache Jackrabbit may well use different lifecycle policy implementations.
policy - lifecycle policy nodestate - current lifecycle stateRepositoryException - if a repository error occurspublic void rename(String newName) throws RepositoryException
rename in interface org.apache.jackrabbit.api.JackrabbitNodeRepositoryExceptionpublic void setMixins(String[] mixinNames) throws NoSuchNodeTypeException, VersionException, ConstraintViolationException, LockException, RepositoryException
setMixins in interface org.apache.jackrabbit.api.JackrabbitNodeNoSuchNodeTypeExceptionVersionExceptionConstraintViolationExceptionLockExceptionRepositoryExceptionCopyright © 2004–2024 The Apache Software Foundation. All rights reserved.