Interface DmtAdmin
-
public interface DmtAdminAn interface providing methods to open sessions and register listeners. The implementation ofDmtAdminshould register itself in the OSGi service registry as a service.DmtAdminis the entry point for applications to use the DMT API.The
getSessionmethods are used to open a session on a specified subtree of the DMT. A typical way of usage:serviceRef = context.getServiceReference(DmtAdmin.class.getName()); DmtAdmin admin = (DmtAdmin) context.getService(serviceRef); DmtSession session = admin.getSession("./OSGi/Configuration"); session.createInteriorNode("./OSGi/Configuration/my.table");The methods for opening a session take a node URI (the session root) as a parameter. All segments of the given URI must be within the segment length limit of the implementation, and the special characters '/' and '\' must be escaped (preceded by a '\').
See the
Uri.encode(String)method for support on escaping invalid characters in a URI.It is possible to specify a lock mode when opening the session (see lock type constants in
DmtSession). This determines whether the session can run in parallel with other sessions, and the kinds of operations that can be performed in the session. All Management Objects constituting the device management tree must support read operations on their nodes, while support for write operations depends on the Management Object. Management Objects supporting write access may support transactional write, non-transactional write or both. Users ofDmtAdminshould consult the Management Object specification and implementation for the supported update modes. If Management Object definition permits, implementations are encouraged to support both update modes.
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description DmtSessiongetSession(java.lang.String subtreeUri)Opens aDmtSessionfor local usage on a given subtree of the DMT with non transactional write lock.DmtSessiongetSession(java.lang.String subtreeUri, int lockMode)Opens aDmtSessionfor local usage on a specific DMT subtree with a given lock mode.DmtSessiongetSession(java.lang.String principal, java.lang.String subtreeUri, int lockMode)Opens aDmtSessionon a specific DMT subtree using a specific lock mode on behalf of a remote principal.
-
-
-
Method Detail
-
getSession
DmtSession getSession(java.lang.String subtreeUri) throws DmtException
Opens aDmtSessionfor local usage on a given subtree of the DMT with non transactional write lock. This call is equivalent to the following:getSession(null, subtreeUri, DmtSession.LOCK_TYPE_EXCLUSIVE)The
subtreeUriparameter must contain an absolute URI. It can also benull, in this case the session is opened with the default session root, ".", that gives access to the whole tree.To perform this operation the caller must have
DmtPermissionfor thesubtreeUrinode with the Get action present.- Parameters:
subtreeUri- the subtree on which DMT manipulations can be performed within the returned session- Returns:
- a
DmtSessionobject for the requested subtree - Throws:
DmtException- with the following possible error codes:INVALID_URIifsubtreeUriis syntactically invalidURI_TOO_LONGifsubtreeUriis longer than accepted by theDmtAdminimplementation (especially on systems with limited resources)-
NODE_NOT_FOUNDifsubtreeUrispecifies a non-existing node -
SESSION_CREATION_TIMEOUTif the operation timed out because of another ongoing session COMMAND_FAILEDifsubtreeUrispecifies a relative URI, or some unspecified error is encountered while attempting to complete the command
java.lang.SecurityException- if the caller does not haveDmtPermissionfor the given root node with the Get action present
-
getSession
DmtSession getSession(java.lang.String subtreeUri, int lockMode) throws DmtException
Opens aDmtSessionfor local usage on a specific DMT subtree with a given lock mode. This call is equivalent to the following:getSession(null, subtreeUri, lockMode)The
subtreeUriparameter must contain an absolute URI. It can also benull, in this case the session is opened with the default session root, ".", that gives access to the whole tree.To perform this operation the caller must have
DmtPermissionfor thesubtreeUrinode with the Get action present.- Parameters:
subtreeUri- the subtree on which DMT manipulations can be performed within the returned sessionlockMode- one of the lock modes specified inDmtSession- Returns:
- a
DmtSessionobject for the requested subtree - Throws:
DmtException- with the following possible error codes:INVALID_URIifsubtreeUriis syntactically invalidURI_TOO_LONGifsubtreeUriis longer than accepted by theDmtAdminimplementation (especially on systems with limited resources)-
NODE_NOT_FOUNDifsubtreeUrispecifies a non-existing node -
FEATURE_NOT_SUPPORTEDif atomic sessions are not supported by the implementation andlockModerequests an atomic session -
SESSION_CREATION_TIMEOUTif the operation timed out because of another ongoing session -
COMMAND_FAILEDifsubtreeUrispecifies a relative URI, iflockModeis unknown, or some unspecified error is encountered while attempting to complete the command
java.lang.SecurityException- if the caller does not haveDmtPermissionfor the given root node with the Get action present
-
getSession
DmtSession getSession(java.lang.String principal, java.lang.String subtreeUri, int lockMode) throws DmtException
Opens aDmtSessionon a specific DMT subtree using a specific lock mode on behalf of a remote principal. If local management applications are using this method then they should providenullas the first parameter. Alternatively they can use other forms of this method without providing a principal string.The
subtreeUriparameter must contain an absolute URI. It can also benull, in this case the session is opened with the default session root, ".", that gives access to the whole tree.This method is guarded by
DmtPrincipalPermissionin case of remote sessions. In addition, the caller must have Get access rights (ACL in case of remote sessions,DmtPermissionin case of local sessions) on thesubtreeUrinode to perform this operation.- Parameters:
principal- the identifier of the remote server on whose behalf the data manipulation is performed, ornullfor local sessionssubtreeUri- the subtree on which DMT manipulations can be performed within the returned sessionlockMode- one of the lock modes specified inDmtSession- Returns:
- a
DmtSessionobject for the requested subtree - Throws:
DmtException- with the following possible error codes:INVALID_URIifsubtreeUriis syntactically invalidURI_TOO_LONGifsubtreeUriis longer than accepted by theDmtAdminimplementation (especially on systems with limited resources)-
NODE_NOT_FOUNDifsubtreeUrispecifies a non-existing node -
PERMISSION_DENIEDifprincipalis notnulland the ACL of the node does not allow theGetoperation for the principal on the given root node FEATURE_NOT_SUPPORTEDif atomic sessions are not supported by the implementation andlockModerequests an atomic session-
SESSION_CREATION_TIMEOUTif the operation timed out because of another ongoing session -
COMMAND_FAILEDifsubtreeUrispecifies a relative URI, iflockModeis unknown, or some unspecified error is encountered while attempting to complete the command
java.lang.SecurityException- in case of remote sessions, if the caller does not have the requiredDmtPrincipalPermissionwith a target matching theprincipalparameter, or in case of local sessions, if the caller does not haveDmtPermissionfor the given root node with the Get action present
-
-