Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * Copyright (c) OSGi Alliance (2004, 2011). All Rights Reserved.
   * 
   * Licensed under the Apache License, Version 2.0 (the "License");
   * you may not use this file except in compliance with the License.
   * You may obtain a copy of the License at
   *
   *      http://www.apache.org/licenses/LICENSE-2.0
   *
  * Unless required by applicable law or agreed to in writing, software
  * distributed under the License is distributed on an "AS IS" BASIS,
  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  * See the License for the specific language governing permissions and
  * limitations under the License.
  */
 package org.osgi.service.dmt.spi;
 
Provides non-atomic read-write access to the part of the tree handled by the plugin that created this session.

The nodePath parameters appearing in this interface always contain an array of path segments identifying a node in the subtree of this plugin. This parameter contains an absolute path, so the first segment is always ".". Special characters appear escaped in the segments.

Error handling

When a tree manipulation command is called on the DmtAdmin service, it must perform an extensive set of checks on the parameters and the authority of the caller before delegating the call to a plugin. Therefore plugins can take certain circumstances for granted: that the path is valid and is within the subtree of the plugin and the session, the command can be applied to the given node (e.g. the target of setNodeValue is a leaf node), etc. All errors described by the error codes org.osgi.service.dmt.DmtException.INVALID_URI, org.osgi.service.dmt.DmtException.URI_TOO_LONG, org.osgi.service.dmt.DmtException.PERMISSION_DENIED, org.osgi.service.dmt.DmtException.COMMAND_NOT_ALLOWED and org.osgi.service.dmt.DmtException.TRANSACTION_ERROR are fully filtered out before control reaches the plugin.

If the plugin provides meta-data for a node, the DmtAdmin service must also check the constraints specified by it, as described in org.osgi.service.dmt.MetaNode. If the plugin does not provide meta-data, it must perform the necessary checks for itself and use the org.osgi.service.dmt.DmtException.METADATA_MISMATCH error code to indicate such discrepancies.

The DmtAdmin does not check that the targeted node exists (or that it does not exist, in case of a node creation) before calling the plugin. It is the responsibility of the plugin to perform this check and to throw a org.osgi.service.dmt.DmtException.NODE_NOT_FOUND or org.osgi.service.dmt.DmtException.NODE_ALREADY_EXISTS if needed. In this case the DmtAdmin must pass through this exception to the caller of the corresponding DmtSession method.

The plugin can use the remaining error codes as needed. If an error does not fit into any other category, the org.osgi.service.dmt.DmtException.COMMAND_FAILED code should be used.

Version:
$Id: 29681a6258518e5514d42c5aba0d3524c61d783e $
 
 public interface ReadWriteDataSession extends ReadableDataSession {

Create a copy of a node or a whole subtree. Beside the structure and values of the nodes, most properties managed by the plugin must also be copied, with the exception of the Timestamp and Version properties.

Parameters:
nodePath an absolute path specifying the node or the root of a subtree to be copied
newNodePath the absolute path of the new node or root of a subtree
recursive false if only a single node is copied, true if the whole subtree is copied
Throws:
org.osgi.service.dmt.DmtException with the following possible error codes:
  • NODE_NOT_FOUND if nodePath points to a non-existing node, or if newNodePath points to a node that cannot exist in the tree
  • NODE_ALREADY_EXISTS if newNodePath points to a node that already exists
  • METADATA_MISMATCH if the node could not be copied because of meta-data restrictions
  • FEATURE_NOT_SUPPORTED if the copy operation is not supported by the plugin
  • DATA_STORE_FAILURE if an error occurred while accessing the data store
  • COMMAND_FAILED if some unspecified error is encountered while attempting to complete the command
java.lang.SecurityException if the caller does not have the necessary permissions to execute the underlying management operation
See also:
org.osgi.service.dmt.DmtSession.copy(java.lang.String,java.lang.String,boolean)
 
 	void copy(String[] nodePathString[] newNodePathboolean recursive)
 			throws DmtException;

Create an interior node with a given type. The type of interior node, if specified, is a URI identifying a DDF document.

Parameters:
nodePath the absolute path of the node to create
type the type URI of the interior node, can be null if no node type is defined
Throws:
org.osgi.service.dmt.DmtException with the following possible error codes:
  • NODE_NOT_FOUND if nodePath points to a node that cannot exist in the tree
  • NODE_ALREADY_EXISTS if nodeUri points to a node that already exists
  • METADATA_MISMATCH if the node could not be created because of meta-data restrictions
  • DATA_STORE_FAILURE if an error occurred while accessing the data store
  • COMMAND_FAILED if some unspecified error is encountered while attempting to complete the command
java.lang.SecurityException if the caller does not have the necessary permissions to execute the underlying management operation
See also:
org.osgi.service.dmt.DmtSession.createInteriorNode(java.lang.String)
org.osgi.service.dmt.DmtSession.createInteriorNode(java.lang.String,java.lang.String)
	void createInteriorNode(String[] nodePathString typethrows DmtException;

Create a leaf node with a given value and MIME type. If the specified value or MIME type is null, their default values must be taken.

Parameters:
nodePath the absolute path of the node to create
value the value to be given to the new node, can be null
mimeType the MIME type to be given to the new node, can be null
Throws:
org.osgi.service.dmt.DmtException with the following possible error codes:
  • NODE_NOT_FOUND if nodePath points to a node that cannot exist in the tree
  • NODE_ALREADY_EXISTS if nodePath points to a node that already exists
  • METADATA_MISMATCH if the node could not be created because of meta-data restrictions
  • DATA_STORE_FAILURE if an error occurred while accessing the data store
  • COMMAND_FAILED if some unspecified error is encountered while attempting to complete the command
java.lang.SecurityException if the caller does not have the necessary permissions to execute the underlying management operation
See also:
org.osgi.service.dmt.DmtSession.createLeafNode(java.lang.String)
org.osgi.service.dmt.DmtSession.createLeafNode(java.lang.String,org.osgi.service.dmt.DmtData)
org.osgi.service.dmt.DmtSession.createLeafNode(java.lang.String,org.osgi.service.dmt.DmtData,java.lang.String)
	void createLeafNode(String[] nodePathDmtData valueString mimeType)
			throws DmtException;

Delete the given node. Deleting interior nodes is recursive, the whole subtree under the given node is deleted.

Parameters:
nodePath the absolute path of the node to delete
Throws:
org.osgi.service.dmt.DmtException with the following possible error codes:
  • NODE_NOT_FOUND if nodePath points to a non-existing node
  • METADATA_MISMATCH if the node could not be deleted because of meta-data restrictions
  • DATA_STORE_FAILURE if an error occurred while accessing the data store
  • COMMAND_FAILED if some unspecified error is encountered while attempting to complete the command
java.lang.SecurityException if the caller does not have the necessary permissions to execute the underlying management operation
See also:
org.osgi.service.dmt.DmtSession.deleteNode(java.lang.String)
	void deleteNode(String[] nodePaththrows DmtException;

Rename a node. This operation only changes the name of the node (updating the timestamp and version properties if they are supported), the value and the other properties are not changed. The new name of the node must be provided, the new path is constructed from the base of the old path and the given name.

Parameters:
nodePath the absolute path of the node to rename
newName the new name property of the node
Throws:
org.osgi.service.dmt.DmtException with the following possible error codes:
  • NODE_NOT_FOUND if nodePath points to a non-existing node, or if the new node is not defined in the tree
  • NODE_ALREADY_EXISTS if there already exists a sibling of nodePath with the name newName
  • METADATA_MISMATCH if the node could not be renamed because of meta-data restrictions
  • DATA_STORE_FAILURE if an error occurred while accessing the data store
  • COMMAND_FAILED if some unspecified error is encountered while attempting to complete the command
java.lang.SecurityException if the caller does not have the necessary permissions to execute the underlying management operation
See also:
org.osgi.service.dmt.DmtSession.renameNode(java.lang.String,java.lang.String)
	void renameNode(String[] nodePathString newNamethrows DmtException;

Set the title property of a node. The length of the title is guaranteed not to exceed the limit of 255 bytes in UTF-8 encoding.

Parameters:
nodePath the absolute path of the node
title the title text of the node, can be null
Throws:
org.osgi.service.dmt.DmtException with the following possible error codes:
  • NODE_NOT_FOUND if nodePath points to a non-existing node
  • METADATA_MISMATCH if the title could not be set because of meta-data restrictions
  • FEATURE_NOT_SUPPORTED if the Title property is not supported by the plugin
  • DATA_STORE_FAILURE if an error occurred while accessing the data store
  • COMMAND_FAILED if some unspecified error is encountered while attempting to complete the command
java.lang.SecurityException if the caller does not have the necessary permissions to execute the underlying management operation
See also:
org.osgi.service.dmt.DmtSession.setNodeTitle(java.lang.String,java.lang.String)
	void setNodeTitle(String[] nodePathString titlethrows DmtException;

Set the type of a node. The type of leaf node is the MIME type of the data it contains. The type of an interior node is a URI identifying a DDF document.

For interior nodes, the null type should remove the reference (if any) to a DDF document overriding the tree structure defined by the ancestors. For leaf nodes, it requests that the default MIME type is used for the given node.

Parameters:
nodePath the absolute path of the node
type the type of the node, can be null
Throws:
org.osgi.service.dmt.DmtException with the following possible error codes:
  • NODE_NOT_FOUND if nodePath points to a non-existing node
  • METADATA_MISMATCH if the type could not be set because of meta-data restrictions
  • DATA_STORE_FAILURE if an error occurred while accessing the data store
  • COMMAND_FAILED if some unspecified error is encountered while attempting to complete the command
java.lang.SecurityException if the caller does not have the necessary permissions to execute the underlying management operation
See also:
org.osgi.service.dmt.DmtSession.setNodeType(java.lang.String,java.lang.String)
	void setNodeType(String[] nodePathString typethrows DmtException;

Set the value of a leaf or interior node. The format of the node is contained in the DmtData object. For interior nodes, the format is FORMAT_NODE, while for leaf nodes this format is never used.

If the specified value is null, the default value must be taken; if there is no default value, a DmtException with error code METADATA_MISMATCH must be thrown.

Parameters:
nodePath the absolute path of the node
data the data to be set, can be null
Throws:
org.osgi.service.dmt.DmtException with the following possible error codes:
  • NODE_NOT_FOUND if nodePath points to a non-existing node
  • METADATA_MISMATCH if the value could not be set because of meta-data restrictions
  • FEATURE_NOT_SUPPORTED if the specified node is an interior node and does not support Java object values
  • DATA_STORE_FAILURE if an error occurred while accessing the data store
  • COMMAND_FAILED if some unspecified error is encountered while attempting to complete the command
java.lang.SecurityException if the caller does not have the necessary permissions to execute the underlying management operation
See also:
org.osgi.service.dmt.DmtSession.setNodeValue(java.lang.String,org.osgi.service.dmt.DmtData)
	void setNodeValue(String[] nodePathDmtData datathrows DmtException;
New to GrepCode? Check out our FAQ X