Interface ConfigurationAdmin
- 
@ProviderType public interface ConfigurationAdminService for administering configuration data.The main purpose of this interface is to store bundle configuration data persistently. This information is represented in
Configurationobjects. The actual configuration data is aDictionaryof properties inside aConfigurationobject.There are two principally different ways to manage configurations. First there is the concept of a Managed Service, where configuration data is uniquely associated with an object registered with the service registry.
Next, there is the concept of a factory where the Configuration Admin service will maintain 0 or more
Configurationobjects for a Managed Service Factory that is registered with the Framework.The first concept is intended for configuration data about "things/services" whose existence is defined externally, e.g. a specific printer. Factories are intended for "things/services" that can be created any number of times, e.g. a configuration for a DHCP server for different networks.
Bundles that require configuration should register a Managed Service or a Managed Service Factory in the service registry. A registration property named
service.pid(persistent identifier or PID) must be used to identify this Managed Service or Managed Service Factory to the Configuration Admin service.When the ConfigurationAdmin detects the registration of a Managed Service, it checks its persistent storage for a configuration object whose
service.pidproperty matches the PID service property (service.pid) of the Managed Service. If found, it callsManagedService.updated(Dictionary)method with the new properties. The implementation of a Configuration Admin service must run these call-backs asynchronously to allow proper synchronization.When the Configuration Admin service detects a Managed Service Factory registration, it checks its storage for configuration objects whose
service.factoryPidproperty matches the PID service property of the Managed Service Factory. For each suchConfigurationobjects, it calls theManagedServiceFactory.updatedmethod asynchronously with the new properties. The calls to theupdatedmethod of aManagedServiceFactorymust be executed sequentially and not overlap in time.In general, bundles having permission to use the Configuration Admin service can only access and modify their own configuration information. Accessing or modifying the configuration of other bundles requires
ConfigurationPermission[location,CONFIGURE], where location is the configuration location.Configurationobjects can be bound to a specified bundle location or to a region (configuration location starts with?). If a location is not set, it will be learned the first time a target is registered. If the location is learned this way, the Configuration Admin service must detect if the bundle corresponding to the location is uninstalled. If this occurs, theConfigurationobject must be unbound, that is its location field is set back tonull.If target's bundle location matches the configuration location it is always updated.
If the configuration location starts with
?, that is, the location is a region, then the configuration must be delivered to all targets registered with the given PID. If security is on, the target bundle must have Configuration Permission[location,TARGET], where location matches given the configuration location with wildcards as in the Filter substring match. The security must be verified using theBundle.hasPermission(Object)method on the target bundle.If a target cannot be updated because the location does not match or it has no permission and security is active then the Configuration Admin service must not do the normal callback.
The method descriptions of this class refer to a concept of "the calling bundle". This is a loose way of referring to the bundle which obtained the Configuration Admin service from the service registry. Implementations of
ConfigurationAdminmust use aServiceFactoryto support this concept. 
- 
- 
Field Summary
Fields Modifier and Type Field Description static java.lang.StringSERVICE_BUNDLELOCATIONConfiguration property naming the location of the bundle that is associated with aConfigurationobject.static java.lang.StringSERVICE_FACTORYPIDConfiguration property naming the Factory PID in the configuration dictionary. 
- 
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description ConfigurationcreateFactoryConfiguration(java.lang.String factoryPid)Create a new factoryConfigurationobject with a new PID.ConfigurationcreateFactoryConfiguration(java.lang.String factoryPid, java.lang.String location)Create a new factoryConfigurationobject with a new PID.ConfigurationgetConfiguration(java.lang.String pid)Get an existing or newConfigurationobject from the persistent store.ConfigurationgetConfiguration(java.lang.String pid, java.lang.String location)Get an existingConfigurationobject from the persistent store, or create a newConfigurationobject.ConfigurationgetFactoryConfiguration(java.lang.String factoryPid, java.lang.String name)Get an existing or newConfigurationobject from the persistent store.ConfigurationgetFactoryConfiguration(java.lang.String factoryPid, java.lang.String name, java.lang.String location)Get an existing or newConfigurationobject from the persistent store.Configuration[]listConfigurations(java.lang.String filter)List the currentConfigurationobjects which match the filter. 
 - 
 
- 
- 
Field Detail
- 
SERVICE_FACTORYPID
static final java.lang.String SERVICE_FACTORYPID
Configuration property naming the Factory PID in the configuration dictionary. The property's value is of typeString.- Since:
 - 1.1
 - See Also:
 - Constant Field Values
 
 
- 
SERVICE_BUNDLELOCATION
static final java.lang.String SERVICE_BUNDLELOCATION
Configuration property naming the location of the bundle that is associated with aConfigurationobject. This property can be searched for but must not appear in the configuration dictionary for security reason. The property's value is of typeString.- Since:
 - 1.1
 - See Also:
 - Constant Field Values
 
 
 - 
 
- 
Method Detail
- 
createFactoryConfiguration
Configuration createFactoryConfiguration(java.lang.String factoryPid) throws java.io.IOException
Create a new factoryConfigurationobject with a new PID. The properties of the newConfigurationobject arenulluntil the first time that itsConfiguration.update(Dictionary)method is called.It is not required that the
factoryPidmaps to a registered Managed Service Factory.The
Configurationobject is bound to the location of the calling bundle. It is possible that the same factoryPid has associated configurations that are bound to different bundles. Bundles should only see the factory configurations that they are bound to or have the proper permission.- Parameters:
 factoryPid- PID of factory (notnull).- Returns:
 - A new 
Configurationobject. - Throws:
 java.io.IOException- if access to persistent storage fails.
 
- 
createFactoryConfiguration
Configuration createFactoryConfiguration(java.lang.String factoryPid, java.lang.String location) throws java.io.IOException
Create a new factoryConfigurationobject with a new PID. The properties of the newConfigurationobject arenulluntil the first time that itsConfiguration.update(Dictionary)method is called.It is not required that the
factoryPidmaps to a registered Managed Service Factory.The
Configurationis bound to the location specified. If this location isnullit will be bound to the location of the first bundle that registers a Managed Service Factory with a corresponding PID. It is possible that the same factoryPid has associated configurations that are bound to different bundles. Bundles should only see the factory configurations that they are bound to or have the proper permission.If the location starts with
?then the configuration must be delivered to all targets with the corresponding PID.- Parameters:
 factoryPid- PID of factory (notnull).location- A bundle location string, ornull.- Returns:
 - a new 
Configurationobject. - Throws:
 java.io.IOException- if access to persistent storage fails.java.lang.SecurityException- when the require permissions are not available
 
- 
getConfiguration
Configuration getConfiguration(java.lang.String pid, java.lang.String location) throws java.io.IOException
Get an existingConfigurationobject from the persistent store, or create a newConfigurationobject.If a
Configurationwith this PID already exists in Configuration Admin service return it. The location parameter is ignored in this case though it is still used for a security check.Else, return a new
Configurationobject. This new object is bound to the location and the properties are set tonull. If the location parameter isnull, it will be set when a Managed Service with the corresponding PID is registered for the first time. If the location starts with?then the configuration is bound to all targets that are registered with the corresponding PID.- Parameters:
 pid- Persistent identifier.location- The bundle location string, ornull.- Returns:
 - An existing or new 
Configurationobject. - Throws:
 java.io.IOException- if access to persistent storage fails.java.lang.SecurityException- when the require permissions are not available
 
- 
getConfiguration
Configuration getConfiguration(java.lang.String pid) throws java.io.IOException
Get an existing or newConfigurationobject from the persistent store. If theConfigurationobject for this PID does not exist, create a newConfigurationobject for that PID, where properties arenull. Bind its location to the calling bundle's location.Otherwise, if the location of the existing
Configurationobject isnull, set it to the calling bundle's location.- Parameters:
 pid- persistent identifier.- Returns:
 - an existing or new 
Configurationmatching the PID. - Throws:
 java.io.IOException- if access to persistent storage fails.java.lang.SecurityException- when the required permission is not available
 
- 
getFactoryConfiguration
Configuration getFactoryConfiguration(java.lang.String factoryPid, java.lang.String name, java.lang.String location) throws java.io.IOException
Get an existing or newConfigurationobject from the persistent store. The PID for thisConfigurationobject is generated from the provided factory PID and the name by starting with the factory PID appending a tilde ('~'\u007E), and then appending the name.If a
Configurationwith this PID already exists in Configuration Admin service return it. The location parameter is ignored in this case though it is still used for a security check.Else, return a new
Configurationobject. This new object is bound to the location and the properties are set tonull. If the location parameter isnull, it will be set when a Managed Service with the corresponding PID is registered for the first time. If the location starts with?then the configuration is bound to all targets that are registered with the corresponding PID.- Parameters:
 factoryPid- PID of factory (notnull).name- A name forConfiguration(notnull).location- The bundle location string, ornull.- Returns:
 - An existing or new 
Configurationobject. - Throws:
 java.io.IOException- if access to persistent storage fails.java.lang.SecurityException- when the require permissions are not available- Since:
 - 1.6
 
 
- 
getFactoryConfiguration
Configuration getFactoryConfiguration(java.lang.String factoryPid, java.lang.String name) throws java.io.IOException
Get an existing or newConfigurationobject from the persistent store. The PID for thisConfigurationobject is generated from the provided factory PID and the name by starting with the factory PID appending a tilde ('~'\u007E), and then appending the name.If a
Configurationobject for this PID does not exist, create a newConfigurationobject for that PID, where properties arenull. Bind its location to the calling bundle's location.Otherwise, if the location of the existing
Configurationobject isnull, set it to the calling bundle's location.- Parameters:
 factoryPid- PID of factory (notnull).name- A name forConfiguration(notnull).- Returns:
 - an existing or new 
Configurationmatching the PID. - Throws:
 java.io.IOException- if access to persistent storage fails.java.lang.SecurityException- when the required permission is not available- Since:
 - 1.6
 
 
- 
listConfigurations
Configuration[] listConfigurations(java.lang.String filter) throws java.io.IOException, org.osgi.framework.InvalidSyntaxException
List the currentConfigurationobjects which match the filter.Only
Configurationobjects with non-nullproperties are considered current. That is,Configuration.getProperties()is guaranteed not to returnnullfor each of the returnedConfigurationobjects.When there is no security on then all configurations can be returned. If security is on, the caller must have ConfigurationPermission[location,CONFIGURE].
The syntax of the filter string is as defined in the
Filterclass. The filter can test any configuration properties including the following:service.pid- the persistent identityservice.factoryPid- the factory PID, if applicableservice.bundleLocation- the bundle location
null, meaning that allConfigurationobjects should be returned.- Parameters:
 filter- A filter string, ornullto retrieve allConfigurationobjects.- Returns:
 - All matching 
Configurationobjects, ornullif there aren't any. - Throws:
 java.io.IOException- if access to persistent storage failsorg.osgi.framework.InvalidSyntaxException- if the filter string is invalid
 
 - 
 
 -