@Retention(value=CLASS)
@Target(value=TYPE)
public @interface BundleAdapterService
AdapterService
,
but instead of adapting a service, they adapt a bundle with a certain set of states (STARTED|INSTALLED|...),
and provide a service on top of it. The bundle adapter will be applied to any bundle that matches the specified bundle state mask and filter conditions, which may match some of the bundle OSGi manifest headers. For each matching bundle an adapter will be created based on the adapter implementation class. The adapter will be registered with the specified interface and with service properties found from the original bundle OSGi manifest headers plus any extra properties you supply here. If you declare the original bundle as a member it will be injected.
In the following example, a "VideoPlayer" Service is registered into the OSGi registry each time an active bundle containing a "Video-Path" manifest header is detected:
@BundleAdapterService(filter = "(Video-Path=*)", stateMask = Bundle.ACTIVE, propagate=true) public class VideoPlayerImpl implements VideoPlayer { volatile Bundle bundle; // Injected by reflection void play() { URL mpegFile = bundle.getEntry(bundle.getHeaders().get("Video-Path")); // play the video provided by the bundle ... } }
Modifier and Type | Required Element and Description |
---|---|
java.lang.String |
filter
The ldap filter used to match some manifest headers of the adapted bundle.
|
Modifier and Type | Optional Element and Description |
---|---|
java.lang.String |
factoryMethod
Sets the static method used to create the BundleAdapterService implementation instance.
|
boolean |
propagate
Specifies if manifest headers from the bundle should be propagated to the service properties.
|
Property[] |
properties
Deprecated.
you can apply
Property annotation directly on the component class. |
java.lang.Class<?>[] |
provides
The interface(s) to use when registering adapters.
|
ServiceScope |
scope
The service scope for the service of this Component.
|
int |
stateMask
the bundle state mask to apply
|
public abstract java.lang.String filter
public abstract java.lang.Class<?>[] provides
public abstract int stateMask
public abstract boolean propagate
public abstract java.lang.String factoryMethod
public abstract ServiceScope scope
If not specified, the singleton
service
scope is used.