public interface TransactionalDataSession extends ReadWriteDataSession
Modifier and Type | Method and Description |
---|---|
void |
commit()
Commits a series of DMT operations issued in the current atomic session
since the last transaction boundary.
|
void |
rollback()
Rolls back a series of DMT operations issued in the current atomic
session since the last transaction boundary.
|
copy, createInteriorNode, createLeafNode, deleteNode, renameNode, setNodeTitle, setNodeType, setNodeValue
close, getChildNodeNames, getMetaNode, getNodeSize, getNodeTimestamp, getNodeTitle, getNodeType, getNodeValue, getNodeVersion, isLeafNode, isNodeUri, nodeChanged
void commit() throws DmtException
commit()
and rollback()
calls.
This method can fail even if all operations were successful. This can
happen due to some multi-node semantic constraints defined by a specific
implementation. For example, node A can be required to always have
children A/B, A/C and A/D. If this condition is broken when
commit()
is executed, the method will fail, and throw a
METADATA_MISMATCH
exception.
In many cases the tree is not the only way to manage a given part of the
system. It may happen that while modifying some nodes in an atomic
session, the underlying settings are modified in parallel outside the
scope of the DMT. If this is detected during commit, an exception with
the code CONCURRENT_ACCESS
is thrown.
DmtException
- with the following possible error codes
METADATA_MISMATCH
if the operation failed because of
meta-data restrictionsCONCURRENT_ACCESS
if it is
detected that some modification has been made outside the scope
of the DMT to the nodes affected in the session's operationsDATA_STORE_FAILURE
if an error occurred while
accessing the data storeCOMMAND_FAILED
if some
unspecified error is encountered while attempting to complete the
commandSecurityException
- if the caller does not have the necessary
permissions to execute the underlying management operationvoid rollback() throws DmtException
commit()
and rollback()
calls.DmtException
- with the error code ROLLBACK_FAILED
in case
the rollback did not succeedSecurityException
- if the caller does not have the necessary
permissions to execute the underlying management operationCopyright © OSGi Alliance (2000, 2015). All Rights Reserved. Licensed under the OSGi Specification License, Version 2.0