Class NotificationFilterSupport
- All Implemented Interfaces:
-
Serializable
,NotificationFilter
- Direct Known Subclasses:
MBeanServerNotificationFilter
public class NotificationFilterSupport extends Object implements NotificationFilter
NotificationFilter
interface. The filtering is performed on the notification type attribute. Manages a list of enabled notification types. A method allows users to enable/disable as many notification types as required.
Then, before sending a notification to a listener registered with a filter, the notification broadcaster compares this notification type with all notification types enabled by the filter. The notification will be sent to the listener only if its filter enables this notification type.
Example:
The listenerNotificationFilterSupport myFilter = new NotificationFilterSupport(); myFilter.enableType("my_example.my_type"); myBroadcaster.addListener(myListener, myFilter, null);
myListener
will only receive notifications the type of which equals/starts with "my_example.my_type".Constructor Summary
Constructor | Description |
---|---|
NotificationFilterSupport() |
Constructs a NotificationFilterSupport . |
Method Summary
Modifier and Type | Method | Description |
---|---|---|
void |
disableAllTypes() |
Disables all notification types. |
void |
disableType |
Removes the given prefix from the prefix list. |
void |
enableType |
Enables all the notifications the type of which starts with the specified prefix to be sent to the listener. |
Vector<String> |
getEnabledTypes() |
Gets all the enabled notification types for this filter. |
boolean |
isNotificationEnabled |
Invoked before sending the specified notification to the listener. |
Constructor Details
NotificationFilterSupport
public NotificationFilterSupport()
NotificationFilterSupport
.Method Details
isNotificationEnabled
public boolean isNotificationEnabled(Notification notification)
This filter compares the type of the specified notification with each enabled type. If the notification type matches one of the enabled types, the notification should be sent to the listener and this method returns
true
.- Specified by:
-
isNotificationEnabled
in interfaceNotificationFilter
- Parameters:
-
notification
- The notification to be sent. - Returns:
-
true
if the notification should be sent to the listener,false
otherwise.
enableType
public void enableType(String prefix) throws IllegalArgumentException
If the specified prefix is already in the list of enabled notification types, this method has no effect.
Example:
Note that:// Enables all notifications the type of which starts with "my_example" to be sent. myFilter.enableType("my_example"); // Enables all notifications the type of which is "my_example.my_type" to be sent. myFilter.enableType("my_example.my_type");
myFilter.enableType("my_example.*");
will no match any notification type.- Parameters:
-
prefix
- The prefix. - Throws:
-
IllegalArgumentException
- The prefix parameter is null.
disableType
public void disableType(String prefix)
If the specified prefix is not in the list of enabled notification types, this method has no effect.
- Parameters:
-
prefix
- The prefix.
disableAllTypes
public void disableAllTypes()
getEnabledTypes
public Vector<String> getEnabledTypes()
- Returns:
- The list containing all the enabled notification types.
© 1993, 2021, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/17/docs/api/java.management/javax/management/NotificationFilterSupport.html