Interface Subsystem
-
@ProviderType public interface SubsystemA subsystem is a collection of resources constituting a logical, possibly isolated, unit of functionality.A subsystem may be scoped or unscoped. Scoped subsystems are isolated by implicit or explicit sharing policies. Unscoped subsystems are not isolated and, therefore, have no sharing policy. There are three standard
typesof subsystems.Application- An implicitly scoped subsystem. Nothing is exported, and imports are computed based on any unsatisfied content requirements.Composite- An explicitly scoped subsystem. The sharing policy is defined by metadata within the subsystem archive.Feature- An unscoped subsystem.
retrievedfrom any subsystem within that region. This context may be used to monitor activity occurring within the region.A subsystem may have
childrenand, unless it's the root subsystem, must have at least oneparent. Subsystems become children of the subsystem in which they are installed. Unscoped subsystems have more than one parent if they are installed in more than one subsystem within the same region. The subsystem graph may be thought of as an acyclic digraph with one and only one source vertex, which is the root subsystem. The edges have the child as the head and parent as the tail.A subsystem has several identifiers.
Location- An identifier specified by the client as part of installation. It is guaranteed to be unique within the same framework.ID- An identifier generated by the implementation as part of installation. It is guaranteed to be unique within the same framework.Symbolic Name/Version- The combination of symbolic name and version is guaranteed to be unique within the same region. Althoughtypeis not formally part of the identity, two subsystems with the same symbolic names and versions but different types are not considered to be equal.
life cycle. Which stage a subsystem is in may be obtained from the subsystem'sstateand is dependent on which life cycle operation is currently active or was last invoked.A subsystem archive is a ZIP file having an
.esaextension and containing metadata describing the subsystem. The form of the metadata may be a subsystem or deployment manifest, as well as any content resource files. The manifests are optional and will be computed if not present. The subsystem manifest headers may beretrievedin raw or localized forms. There are five standardtypesof resources that may be included in a subsystem.Bundle- A bundle that is not a fragment.Fragment- A fragment bundle.Application Subsystem- An application subsystem.Composite Subsystem- A composite subsystem.Feature Subsystem- A feature subsystem.
constituents. There are several ways a resource may become a constituent of a subsystem:- A resource is listed as part of the subsystem's content.
- A subsystem resource is a child of the subsystem.
- The subsystem has a provision policy of accept dependencies.
- A bundle resource is installed using the region bundle context.
- A bundle resource is installed using the bundle context of another resource contained by the subsystem.
In addition to invoking one of the install methods, a subsystem instance may be obtained through the service registry. Each installed subsystem has a corresponding service registration. A subsystem service has the following properties.
ID- The ID of the subsystem.Symbolic Name- The symbolic name of the subsystem.Version- The version of the subsystem.Type- The type of the subsystem.State- The state of the subsystem.
Because a subsystem must be used to install other subsystems, a root subsystem is provided as a starting point. The root subsystem may only be obtained as a service and has the following characteristics.
- The ID is
0. - The symbolic name is
org.osgi.service.subsystem.root. - The version matches this specification's version.
- It has no parents.
- All existing bundles, including the system and subsystem implementation bundles, are constituents.
- The type is
osgi.subsystem.applicationwith no imports. - The provision policy is
acceptDependencies.
-
-
Nested Class Summary
Nested Classes Modifier and Type Interface Description static classSubsystem.StateAn enumeration of the possible states of a subsystem.
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description org.osgi.framework.BundleContextgetBundleContext()Returns the bundle context of the region within which this subsystem resides.java.util.Collection<Subsystem>getChildren()Returns the child subsystems of this subsystem.java.util.Collection<org.osgi.resource.Resource>getConstituents()Returns the constituent resources of this subsystem.java.util.Map<java.lang.String,java.lang.String>getDeploymentHeaders()Returns the headers for this subsystem's deployment manifest.java.lang.StringgetLocation()Returns the location identifier of this subsystem.java.util.Collection<Subsystem>getParents()Returns the parent subsystems of this subsystem.Subsystem.StategetState()Returns the current state of this subsystem.java.util.Map<java.lang.String,java.lang.String>getSubsystemHeaders(java.util.Locale locale)Returns the headers for this subsystem's subsystem manifest.longgetSubsystemId()Returns the identifier of this subsystem.java.lang.StringgetSymbolicName()Returns the symbolic name of this subsystem.java.lang.StringgetType()Returns thetypeof this subsystem.org.osgi.framework.VersiongetVersion()Returns theversionof this subsystem.Subsysteminstall(java.lang.String location)Installs a subsystem from the specified location identifier.Subsysteminstall(java.lang.String location, java.io.InputStream content)Installs a subsystem from the specified content.Subsysteminstall(java.lang.String location, java.io.InputStream content, java.io.InputStream deploymentManifest)Installs a subsystem from the specified content according to the specified deployment manifest.voidstart()Starts this subsystem.voidstop()Stops this subsystem.voiduninstall()Uninstalls this subsystem.
-
-
-
Method Detail
-
getBundleContext
org.osgi.framework.BundleContext getBundleContext()
Returns the bundle context of the region within which this subsystem resides.The bundle context offers the same perspective of any resource contained by a subsystem within the region. It may be used, for example, to monitor events internal to the region as well as external events visible to the region. All subsystems within the same region have the same bundle context. If this subsystem is in a state where the bundle context would be invalid,
nullis returned.- Returns:
- The bundle context of the region within which this subsystem
resides or
nullif this subsystem's state is inINSTALL_FAILED,UNINSTALLED. - Throws:
java.lang.SecurityException- If the caller does not have the appropriateSubsystemPermission[this,CONTEXT], and the runtime supports permissions.
-
getChildren
java.util.Collection<Subsystem> getChildren()
Returns the child subsystems of this subsystem.- Returns:
- The child subsystems of this subsystem. The returned collection is an unmodifiable snapshot of all subsystems that are installed in this subsystem. The collection will be empty if no subsystems are installed in this subsystem.
- Throws:
java.lang.IllegalStateException- If this subsystem's state is inINSTALL_FAILED,UNINSTALLED.
-
getSubsystemHeaders
java.util.Map<java.lang.String,java.lang.String> getSubsystemHeaders(java.util.Locale locale)
Returns the headers for this subsystem's subsystem manifest.Each key in the map is a header name and the value of the key is the corresponding header value. Because header names are case-insensitive, the methods of the map must treat the keys in a case-insensitive manner. If the header name is not found,
nullis returned. Both original and derived headers will be included in the map.This method must continue to return the headers while this subsystem is in the
INSTALL_FAILEDorUNINSTALLEDstates.- Parameters:
locale- The locale for which translations are desired. The header values are translated according to the specified locale. If the specified locale isnullor not supported, the raw values are returned. If the translation for a particular header is not found, the raw value is returned.- Returns:
- The headers for this subsystem's subsystem manifest. The returned map is unmodifiable.
- Throws:
java.lang.SecurityException- If the caller does not have the appropriateSubsystemPermission[this,METADATA], and the runtime supports permissions.
-
getLocation
java.lang.String getLocation()
Returns the location identifier of this subsystem.The location identifier is the
locationthat was passed to theinstallmethod of theparentsubsystem. It is unique within the framework.This method must continue to return this subsystem's headers while this subsystem is in the
INSTALL_FAILEDorUNINSTALLEDstates.- Returns:
- The location identifier of this subsystem.
- Throws:
java.lang.SecurityException- If the caller does not have the appropriateSubsystemPermission[this,METADATA], and the runtime supports permissions.
-
getParents
java.util.Collection<Subsystem> getParents()
Returns the parent subsystems of this subsystem.- Returns:
- The parent subsystems of this subsystem. The returned collection is an unmodifiable snapshot of all subsystems in which this subsystem is installed. The collection will be empty for the root subsystem; otherwise, it must contain at least one parent. Scoped subsystems always have only one parent. Unscoped subsystems may have multiple parents.
- Throws:
java.lang.IllegalStateException- If this subsystem's state is inINSTALL_FAILED,UNINSTALLED.
-
getConstituents
java.util.Collection<org.osgi.resource.Resource> getConstituents()
Returns the constituent resources of this subsystem.- Returns:
- The constituent resources of this subsystem. The returned collection is an unmodifiable snapshot of the constituent resources of this subsystem. If this subsystem has no constituents, the collection will be empty.
- Throws:
java.lang.IllegalStateException- If this subsystem's state is inINSTALL_FAILED,UNINSTALLED.
-
getDeploymentHeaders
java.util.Map<java.lang.String,java.lang.String> getDeploymentHeaders()
Returns the headers for this subsystem's deployment manifest.Each key in the map is a header name and the value of the key is the corresponding header value. Because header names are case-insensitive, the methods of the map must treat the keys in a case-insensitive manner. If the header name is not found,
nullis returned. Both original and derived headers will be included in the map.This method must continue to return the headers while this subsystem is in the
INSTALL_FAILEDorUNINSTALLEDstates.- Returns:
- The headers for this subsystem's deployment manifest. The returned map is unmodifiable.
- Throws:
java.lang.SecurityException- If the caller does not have the appropriateSubsystemPermission[this,METADATA], and the runtime supports permissions.- Since:
- 1.1
-
getState
Subsystem.State getState()
Returns the current state of this subsystem.This method must continue to return this subsystem's state while this subsystem is in the
INSTALL_FAILEDorUNINSTALLEDstates.- Returns:
- The current state of this subsystem.
-
getSubsystemId
long getSubsystemId()
Returns the identifier of this subsystem.The identifier is a monotonically increasing, non-negative integer automatically generated at installation time and guaranteed to be unique within the framework. The identifier of the root subsystem is zero.
This method must continue to return this subsystem's identifier while this subsystem is in the
INSTALL_FAILEDorUNINSTALLEDstates.- Returns:
- The identifier of this subsystem.
-
getSymbolicName
java.lang.String getSymbolicName()
Returns the symbolic name of this subsystem.The subsystem symbolic name conforms to the same grammar rules as the bundle symbolic name and is derived from one of the following, in order.
- The value of the
Subsystem-SymbolicNameheader, if specified. - The subsystem URI if passed as the
locationalong with thecontentto theinstallmethod. - Optionally generated in an implementation specific way.
versionis unique within a region. The symbolic name of the root subsystem isorg.osgi.service.subsystem.root.This method must continue to return this subsystem's symbolic name while this subsystem is in the
INSTALL_FAILEDorUNINSTALLEDstates.- Returns:
- The symbolic name of this subsystem.
- The value of the
-
getType
java.lang.String getType()
Returns thetypeof this subsystem.This method must continue to return this subsystem's type while this subsystem is in the
INSTALL_FAILEDorUNINSTALLEDstates.- Returns:
- The type of this subsystem.
-
getVersion
org.osgi.framework.Version getVersion()
Returns theversionof this subsystem.The subsystem version conforms to the same grammar rules as the bundle version and is derived from one of the following, in order.
- The value of the
Subsystem-Versionheader, if specified. - The subsystem URI if passed as the
locationalong with thecontentto theinstallmethod. - Defaults to
0.0.0.
symbolic nameand version is unique within a region. The version of the root subsystem matches this specification's version.This method must continue to return this subsystem's version while this subsystem is in the
INSTALL_FAILEDorUNINSTALLEDstates.- Returns:
- The version of this subsystem.
- The value of the
-
install
Subsystem install(java.lang.String location)
Installs a subsystem from the specified location identifier.This method performs the same function as calling
install(String, InputStream)with the specified location identifier andnullas the content.- Parameters:
location- The location identifier of the subsystem to install.- Returns:
- The installed subsystem.
- Throws:
java.lang.IllegalStateException- If this subsystem's state is inINSTALLING,INSTALL_FAILED,UNINSTALLING,UNINSTALLED.SubsystemException- If the installation failed.java.lang.SecurityException- If the caller does not have the appropriateSubsystemPermission[installed subsystem,LIFECYCLE], and the runtime supports permissions.- See Also:
install(String, InputStream)
-
install
Subsystem install(java.lang.String location, java.io.InputStream content)
Installs a subsystem from the specified content.The specified location will be used as an identifier of the subsystem. Every installed subsystem is uniquely identified by its location, which is typically in the form of a URI. If the specified location conforms to the
subsystem-urigrammar, the required symbolic name and optional version information will be used as default values.If the specified content is
null, a new input stream must be created from which to read the subsystem by interpreting, in an implementation dependent manner, the specified location.A subsystem installation must be persistent. That is, an installed subsystem must remain installed across Framework and VM restarts.
All references to changing the state of this subsystem include both changing the state of the subsystem object as well as the state property of the subsystem service registration.
The following steps are required to install a subsystem.
- If an installed subsystem with the specified location identifier already exists, return the installed subsystem.
- Read the specified content in order to determine the symbolic name, version, and type of the installing subsystem. If an error occurs while reading the content, an installation failure results.
- If an installed subsystem with the same symbolic name and version
already exists within this subsystem's region, complete the installation
with one of the following.
- If the installing and installed subsystems' types are not equal, an installation failure results.
- If the installing and installed subsystems' types are equal, and the installed subsystem is already a child of this subsystem, return the installed subsystem.
- If the installing and installed subsystems' types are equal, and the installed subsystem is not already a child of this subsystem, add the installed subsystem as a child of this subsystem, increment the installed subsystem's reference count by one, and return the installed subsystem.
- Create a new subsystem based on the specified location and content.
- If the subsystem is scoped, install and start a new region context bundle.
- Change the state to
INSTALLINGand register a new subsystem service. - Discover the subsystem's content resources. If any mandatory resource is missing, an installation failure results.
- Discover the dependencies required by the content resources. If any mandatory dependency is missing, an installation failure results.
- Using a framework
ResolverHook, disable runtime resolution for the resources. - For each resource, increment the reference count by one. If the reference count is one, install the resource. If an error occurs while installing a resource, an install failure results with that error as the cause.
- If the subsystem is scoped, enable the import sharing policy.
- Enable runtime resolution for the resources.
- Change the state of the subsystem to
INSTALLED. - Return the new subsystem.
Implementations should be sensitive to the potential for long running operations and periodically check the current thread for interruption. An interrupted thread should result in a
SubsystemExceptionwith an InterruptedException as the cause and be treated as an installation failure.All installation failure flows include the following, in order.
- Change the state to
INSTALL_FAILED. - Change the state to
UNINSTALLING. - All content and dependencies which may have been installed by the installing process must be uninstalled.
- Change the state to
UNINSTALLED. - Unregister the subsystem service.
- If the subsystem is a scoped subsystem then, uninstall the region context bundle.
- Throw a
SubsystemExceptionwith the cause of the installation failure.
- Parameters:
location- The location identifier of the subsystem to be installed.content- The input stream from which this subsystem will be read ornullto indicate the input stream must be created from the specified location identifier. The input stream will always be closed when this method completes, even if an exception is thrown.- Returns:
- The installed subsystem.
- Throws:
java.lang.IllegalStateException- If this subsystem's state is inINSTALLING,INSTALL_FAILED,UNINSTALLING,UNINSTALLED.SubsystemException- If the installation failed.java.lang.SecurityException- If the caller does not have the appropriateSubsystemPermission[installed subsystem,LIFECYCLE], and the runtime supports permissions.
-
install
Subsystem install(java.lang.String location, java.io.InputStream content, java.io.InputStream deploymentManifest)
Installs a subsystem from the specified content according to the specified deployment manifest.This method installs a subsystem using the provided deployment manifest instead of the one in the archive, if any, or a computed one. If the deployment manifest is
null, the behavior is exactly the same as in theinstall(String, InputStream)method. Implementations must support deployment manifest input streams in the format described by section 134.2 of the Subsystem Service Specification. If the deployment manifest does not conform to the subsystem manifest (see 134.15.2), the installation fails.- Parameters:
location- The location identifier of the subsystem to be installed.content- The input stream from which this subsystem will be read ornullto indicate the input stream must be created from the specified location identifier. The input stream will always be closed when this method completes, even if an exception is thrown.deploymentManifest- The deployment manifest to use in lieu of the one in the archive, if any, or a computed one.- Returns:
- The installed subsystem.
- Throws:
java.lang.IllegalStateException- If this subsystem's state is inINSTALLING,INSTALL_FAILED,UNINSTALLING,UNINSTALLED.SubsystemException- If the installation failed.java.lang.SecurityException- If the caller does not have the appropriateSubsystemPermission[installed subsystem,LIFECYCLE], and the runtime supports permissions.- Since:
- 1.1
-
start
void start()
Starts this subsystem.The following table shows which actions are associated with each state. An action of
Waitmeans this method will block until a state transition occurs, upon which the new state will be evaluated in order to determine how to proceed. If a state transition does not occur in a reasonable time while waiting then no action is taken and a SubsystemException is thrown to indicate the subsystem was unable to be started. An action ofReturnmeans this method returns immediately without taking any other action.State Action INSTALLINGWaitINSTALLEDResolve,StartINSTALL_FAILEDIllegalStateExceptionRESOLVINGWaitRESOLVEDStartSTARTINGWaitACTIVEReturnSTOPPINGWaitUNINSTALLINGIllegalStateExceptionUNINSTALLEDIllegalStateExceptionAll references to changing the state of this subsystem include both changing the state of the subsystem object as well as the state property of the subsystem service registration.
A subsystem must be persistently started. That is, a started subsystem must be restarted across Framework and VM restarts, even if a start failure occurs.
The following steps are required to start this subsystem.
- Set the subsystem autostart setting to started.
- If this subsystem is in the
RESOLVEDstate, proceed to step 7. - Change the state to
RESOLVING. - Resolve the content resources. A resolution failure results in a
start failure with a state of
INSTALLED. - Change the state to
RESOLVED. - If this subsystem is scoped, enable the export sharing policy.
- Change the state to
STARTING. - For each eligible resource, increment the active use count by one. If
the active use count is one, start the resource. All dependencies must be
started before any content resource, and content resources must be
started according to the specified
start order. If an error occurs while starting a resource, a start failure results with that error as the cause. - Change the state to
ACTIVE.
Implementations should be sensitive to the potential for long running operations and periodically check the current thread for interruption. An interrupted thread should be treated as a start failure with an
InterruptedExceptionas the cause.All start failure flows include the following, in order.
- Throws:
SubsystemException- If this subsystem fails to start.java.lang.IllegalStateException- If this subsystem's state is inINSTALL_FAILED,UNINSTALLING, orUNINSTALLED, or if the state of at least one of this subsystem's parents is not inSTARTING,ACTIVE.java.lang.SecurityException- If the caller does not have the appropriateSubsystemPermission[this,EXECUTE], and the runtime supports permissions.
-
stop
void stop()
Stops this subsystem.The following table shows which actions are associated with each state. An action of
Waitmeans this method will block until a state transition occurs, upon which the new state will be evaluated in order to determine how to proceed. If a state transition does not occur in a reasonable time while waiting then no action is taken and a SubsystemException is thrown to indicate the subsystem was unable to be stopped. An action ofReturnmeans this method returns immediately without taking any other action.State Action INSTALLINGWaitINSTALLEDReturnINSTALL_FAILEDIllegalStateExceptionRESOLVINGWaitRESOLVEDReturnSTARTINGWaitACTIVEStopSTOPPINGWaitUNINSTALLINGIllegalStateExceptionUNINSTALLEDIllegalStateExceptionA subsystem must be persistently stopped. That is, a stopped subsystem must remain stopped across Framework and VM restarts.
All references to changing the state of this subsystem include both changing the state of the subsystem object as well as the state property of the subsystem service registration.
The following steps are required to stop this subsystem.
- Set the subsystem autostart setting to stopped.
- Change the state to
STOPPING. - For each eligible resource, decrement the active use count by one. If
the active use count is zero, stop the resource. All content resources
must be stopped before any dependencies, and content resources must be
stopped in reverse
start order. - Change the state to
RESOLVED.
STOPPINGstate, every part of each step above must be attempted. Errors subsequent to the first should be logged. Once the stop process has completed, a SubsystemException must be thrown with the initial error as the specified cause.Implementations should be sensitive to the potential for long running operations and periodically check the current thread for interruption, in which case a SubsystemException with an InterruptedException as the cause should be thrown. If an interruption occurs while waiting, this method should terminate immediately. Once the transition to the
STOPPINGstate has occurred, however, this method must not terminate due to an interruption until the stop process has completed.- Throws:
SubsystemException- If this subsystem fails to stop cleanly.java.lang.IllegalStateException- If this subsystem's state is inINSTALL_FAILED,UNINSTALLING, orUNINSTALLED.java.lang.SecurityException- If the caller does not have the appropriateSubsystemPermission[this,EXECUTE], and the runtime supports permissions.
-
uninstall
void uninstall()
Uninstalls this subsystem.The following table shows which actions are associated with each state. An action of
Waitmeans this method will block until a state transition occurs, upon which the new state will be evaluated in order to determine how to proceed. If a state transition does not occur in a reasonable time while waiting then no action is taken and a SubsystemException is thrown to indicate the subsystem was unable to be uninstalled. An action ofReturnmeans this method returns immediately without taking any other action.State Action INSTALLINGWaitINSTALLEDUninstallINSTALL_FAILEDWaitRESOLVINGWaitRESOLVEDUninstallSTARTINGWaitACTIVEStop,UninstallSTOPPINGWaitUNINSTALLINGWaitUNINSTALLEDReturnAll references to changing the state of this subsystem include both changing the state of the subsystem object as well as the state property of the subsystem service registration.
The following steps are required to uninstall this subsystem after being stopped if necessary.
- Change the state to
INSTALLED. - Change the state to
UNINSTALLING. - For each referenced resource, decrement the reference count by one. If the reference count is zero, uninstall the resource. All content resources must be uninstalled before any dependencies.
- Change the state to
UNINSTALLED. - Unregister the subsystem service.
- If the subsystem is scoped, uninstall the region context bundle.
UNINSTALLINGstate, every part of each step above must be attempted. Errors subsequent to the first should be logged. Once the uninstall process has completed, aSubsystemExceptionmust be thrown with the specified cause.Implementations should be sensitive to the potential for long running operations and periodically check the current thread for interruption, in which case a
SubsystemExceptionwith anInterruptedExceptionas the cause should be thrown. If an interruption occurs while waiting, this method should terminate immediately. Once the transition to theUNINSTALLINGstate has occurred, however, this method must not terminate due to an interruption until the uninstall process has completed.- Throws:
SubsystemException- If this subsystem fails to uninstall cleanly.java.lang.SecurityException- If the caller does not have the appropriateSubsystemPermission[this,LIFECYCLE], and the runtime supports permissions.
- Change the state to
-
-