|
OSGi™ Service Platform Release 4 Version 4.1 |
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
The MonitorAdmin
service is a singleton service that handles
StatusVariable
query requests and measurement job control
requests.
Note that an alternative but not recommended way of obtaining
StatusVariable
s is that applications having the required
ServicePermissions
can query the list of
Monitorable
services from the service registry and then query
the list of StatusVariable
names from the
Monitorable
services. This way all services which publish
StatusVariable
s will be returned regardless of whether they
do or do not hold the necessary MonitorPermission
for
publishing StatusVariable
s. By using the
MonitorAdmin
to obtain the StatusVariable
s it
is guaranteed that only those Monitorable
services will be
accessed who are authorized to publish StatusVariable
s. It is
the responsibility of the MonitorAdmin
implementation to check
the required permissions and show only those variables which pass this check.
The events posted by MonitorAdmin
contain the following
properties:
mon.monitorable.pid
: The identifier of the
Monitorable
mon.statusvariable.name
: The identifier of the
StatusVariable
within the given Monitorable
mon.statusvariable.value
: The value of the
StatusVariable
, represented as a String
mon.listener.id
: The identifier of the initiator of the
monitoring job (only present if the event was generated due to a monitoring
job)
Most of the methods require either a Monitorable ID or a Status Variable path
parameter, the latter in [Monitorable_ID]/[StatusVariable_ID] format. These
parameters must not be null
, and the IDs they contain must
conform to their respective definitions in Monitorable
and
StatusVariable
. If any of the restrictions are violated, the method
must throw an IllegalArgumentException
.
Method Summary | |
java.lang.String |
getDescription(java.lang.String path)
Returns a human readable description of the given StatusVariable . |
java.lang.String[] |
getMonitorableNames()
Returns the names of the Monitorable services that are
currently registered. |
MonitoringJob[] |
getRunningJobs()
Returns the list of currently running MonitoringJob s. |
StatusVariable |
getStatusVariable(java.lang.String path)
Returns a StatusVariable addressed by its full path. |
java.lang.String[] |
getStatusVariableNames(java.lang.String monitorableId)
Returns the list of StatusVariable names published by a
Monitorable instance. |
StatusVariable[] |
getStatusVariables(java.lang.String monitorableId)
Returns the StatusVariable objects published by a
Monitorable instance. |
boolean |
resetStatusVariable(java.lang.String path)
Issues a request to reset a given StatusVariable . |
MonitoringJob |
startJob(java.lang.String initiator,
java.lang.String[] statusVariables,
int count)
Starts a change based MonitoringJob with the parameters
provided. |
MonitoringJob |
startScheduledJob(java.lang.String initiator,
java.lang.String[] statusVariables,
int schedule,
int count)
Starts a time based MonitoringJob with the parameters
provided. |
void |
switchEvents(java.lang.String path,
boolean on)
Switches event sending on or off for the specified StatusVariable s. |
Method Detail |
public StatusVariable getStatusVariable(java.lang.String path) throws java.lang.IllegalArgumentException, java.lang.SecurityException
StatusVariable
addressed by its full path.
The entity which queries a StatusVariable
needs to hold
MonitorPermission
for the given target with the
read
action present.
path
- the full path of the StatusVariable
in
[Monitorable_ID]/[StatusVariable_ID] format
StatusVariable
object
java.lang.IllegalArgumentException
- if path
is
null
or otherwise invalid, or points to a
non-existing StatusVariable
java.lang.SecurityException
- if the caller does not hold a
MonitorPermission
for the
StatusVariable
specified by path
with the read
action presentpublic java.lang.String[] getMonitorableNames()
Monitorable
services that are
currently registered. The Monitorable
instances are not
accessible through the MonitorAdmin
, so that requests to
individual status variables can be filtered with respect to the
publishing rights of the Monitorable
and the reading
rights of the caller.
The returned array contains the names in alphabetical order. It cannot be
null
, an empty array is returned if no
Monitorable
services are registered.
Monitorable
namespublic StatusVariable[] getStatusVariables(java.lang.String monitorableId) throws java.lang.IllegalArgumentException
StatusVariable
objects published by a
Monitorable
instance. The StatusVariables
will hold the values taken at the time of this method call. Only those
status variables are returned where the following two conditions are met:
Monitorable
holds a
MonitorPermission
for the status variable with the
publish
action present
MonitorPermission
for the status
variable with the read
action present
The elements in the returned array are in no particular order. The return
value cannot be null
, an empty array is returned if no
(authorized and readable) Status Variables are provided by the given
Monitorable
.
monitorableId
- the identifier of a Monitorable
instance
StatusVariable
objects published
by the specified Monitorable
java.lang.IllegalArgumentException
- if monitorableId
is null
or otherwise invalid, or points to a
non-existing Monitorable
public java.lang.String[] getStatusVariableNames(java.lang.String monitorableId) throws java.lang.IllegalArgumentException
StatusVariable
names published by a
Monitorable
instance. Only those status variables are
listed where the following two conditions are met:
Monitorable
holds a
MonitorPermission
for the status variable with the
publish
action present
MonitorPermission
for
the status variable with the read
action present
The returned array does not contain duplicates, and the elements are in
alphabetical order. It cannot be null
, an empty array is
returned if no (authorized and readable) Status Variables are provided
by the given Monitorable
.
monitorableId
- the identifier of a Monitorable
instance
StatusVariable
objects names
published by the specified Monitorable
java.lang.IllegalArgumentException
- if monitorableId
is null
or otherwise invalid, or points to a
non-existing Monitorable
public void switchEvents(java.lang.String path, boolean on) throws java.lang.IllegalArgumentException, java.lang.SecurityException
StatusVariable
s. When the MonitorAdmin
is
notified about a StatusVariable
being updated it sends an
event unless this feature is switched off. Note that events within a
monitoring job can not be switched off. The event sending state of the
StatusVariables
must not be persistently stored. When a
StatusVariable
is registered for the first time in a
framework session, its event sending state is set to ON by default.
Usage of the "*" wildcard is allowed in the path argument of this method
as a convenience feature. The wildcard can be used in either or both path
fragments, but only at the end of the fragments. The semantics of the
wildcard is that it stands for any matching StatusVariable
at the time of the method call, it does not affect the event sending
status of StatusVariable
s which are not yet registered. As
an example, when the switchEvents("MyMonitorable/*", false)
method is executed, event sending from all StatusVariables
of the MyMonitorable service are switched off. However, if the
MyMonitorable service starts to publish a new StatusVariable
later, it's event sending status is on by default.
path
- the identifier of the StatusVariable
(s) in
[Monitorable_id]/[StatusVariable_id] format, possibly with the
"*" wildcard at the end of either path fragmenton
- false
if event sending should be switched off,
true
if it should be switched on for the given path
java.lang.SecurityException
- if the caller does not hold
MonitorPermission
with the
switchevents
action or if there is any
StatusVariable
in the path
field for
which it is not allowed to switch event sending on or off as per
the target field of the permission
java.lang.IllegalArgumentException
- if path
is
null
or otherwise invalid, or points to a
non-existing StatusVariable
public boolean resetStatusVariable(java.lang.String path) throws java.lang.IllegalArgumentException, java.lang.SecurityException
StatusVariable
.
Depending on the semantics of the StatusVariable
this call
may or may not succeed: it makes sense to reset a counter to its starting
value, but e.g. a StatusVariable
of type String might not
have a meaningful default value. Note that for numeric
StatusVariable
s the starting value may not necessarily be
0. Resetting a StatusVariable
triggers a monitor event if
the StatusVariable
supports update notifications.
The entity that wants to reset the StatusVariable
needs to
hold MonitorPermission
with the reset
action present. The target field of the permission must match the
StatusVariable
name to be reset.
path
- the identifier of the StatusVariable
in
[Monitorable_id]/[StatusVariable_id] format
true
if the Monitorable
could
successfully reset the given StatusVariable
,
false
otherwise
java.lang.IllegalArgumentException
- if path
is
null
or otherwise invalid, or points to a
non-existing StatusVariable
java.lang.SecurityException
- if the caller does not hold
MonitorPermission
with the reset
action or if the specified StatusVariable
is not
allowed to be reset as per the target field of the permissionpublic java.lang.String getDescription(java.lang.String path) throws java.lang.IllegalArgumentException, java.lang.SecurityException
StatusVariable
. The null
value may be returned
if there is no description for the given StatusVariable
.
The entity that queries a StatusVariable
needs to hold
MonitorPermission
for the given target with the
read
action present.
path
- the full path of the StatusVariable
in
[Monitorable_ID]/[StatusVariable_ID] format
StatusVariable
or null
if it is not
set
java.lang.IllegalArgumentException
- if path
is
null
or otherwise invalid, or points to a
non-existing StatusVariable
java.lang.SecurityException
- if the caller does not hold a
MonitorPermission
for the
StatusVariable
specified by path
with the read
action presentpublic MonitoringJob startScheduledJob(java.lang.String initiator, java.lang.String[] statusVariables, int schedule, int count) throws java.lang.IllegalArgumentException, java.lang.SecurityException
MonitoringJob
with the parameters
provided. Monitoring events will be sent according to the specified
schedule. All specified StatusVariable
s must exist when the
job is started. The initiator string is used in the
mon.listener.id
field of all events triggered by the job,
to allow filtering the events based on the initiator.
The schedule
parameter specifies the time in seconds
between two measurements, it must be greater than 0. The first
measurement will be taken when the timer expires for the first time, not
when this method is called.
The count
parameter defines the number of measurements to be
taken, and must either be a positive integer, or 0 if the measurement is
to run until explicitely stopped.
The entity which initiates a MonitoringJob
needs to hold
MonitorPermission
for all the specified target
StatusVariable
s with the startjob
action
present. If the permission's action string specifies a minimal sampling
interval then the schedule
parameter should be at least as
great as the value in the action string.
initiator
- the identifier of the entity that initiated the jobstatusVariables
- the list of StatusVariable
s to be
monitored, with each StatusVariable
name given in
[Monitorable_PID]/[StatusVariable_ID] formatschedule
- the time in seconds between two measurementscount
- the number of measurements to be taken, or 0 for the
measurement to run until explicitely stopped
null
java.lang.IllegalArgumentException
- if the list of
StatusVariable
names contains an invalid or
non-existing StatusVariable
; if
initiator
is null
or empty; or if the
schedule
or count
parameters are
invalid
java.lang.SecurityException
- if the caller does not hold
MonitorPermission
for all the specified
StatusVariable
s, with the startjob
action present, or if the permission does not allow starting the
job with the given frequencypublic MonitoringJob startJob(java.lang.String initiator, java.lang.String[] statusVariables, int count) throws java.lang.IllegalArgumentException, java.lang.SecurityException
MonitoringJob
with the parameters
provided. Monitoring events will be sent when the
StatusVariable
s of this job are updated. All specified
StatusVariable
s must exist when the job is started, and
all must support update notifications. The initiator string is used in
the mon.listener.id
field of all events triggered by the
job, to allow filtering the events based on the initiator.
The count
parameter specifies the number of changes that
must happen to a StatusVariable
before a new notification is
sent, this must be a positive integer.
The entity which initiates a MonitoringJob
needs to hold
MonitorPermission
for all the specified target
StatusVariable
s with the startjob
action
present.
initiator
- the identifier of the entity that initiated the jobstatusVariables
- the list of StatusVariable
s to be
monitored, with each StatusVariable
name given in
[Monitorable_PID]/[StatusVariable_ID] formatcount
- the number of changes that must happen to a
StatusVariable
before a new notification is sent
null
java.lang.IllegalArgumentException
- if the list of
StatusVariable
names contains an invalid or
non-existing StatusVariable
, or one that does not
support notifications; if the initiator
is
null
or empty; or if count
is invalid
java.lang.SecurityException
- if the caller does not hold
MonitorPermission
for all the specified
StatusVariable
s, with the startjob
action presentpublic MonitoringJob[] getRunningJobs()
MonitoringJob
s.
Jobs are only visible to callers that have the necessary permissions: to
receive a Monitoring Job in the returned list, the caller must hold all
permissions required for starting the job. This means that if the caller
does not have MonitorPermission
with the proper
startjob
action for all the Status Variables monitored by a
job, then that job will be silently omitted from the results.
The returned array cannot be null
, an empty array is
returned if there are no running jobs visible to the caller at the time
of the call.
|
OSGi™ Service Platform Release 4 Version 4.1 |
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |