Custom Alerter
A Decanter Alerter is basically a special kind of appender.
It’s an OSGi EventAdmin EventHandler: it listens to decanter/alert/*
EventAdmin topics, and
receives the alerting data coming from the checker.
To enable a new Decanter Alerter, you just have to register an EventHandler OSGi service, like we do for an appender.
For instance, if you want to create a very simple SystemOutAlerter that displays the alert (coming from the checker) to System.out, you can create the following SystemOutAlerter class implementing EventHandler interface:
package org.apache.karaf.decanter.sample.alerter.systemout; import org.osgi.service.event.Event; import org.osgi.service.event.EventHandler; import java.util.HashMap; public class SystemOutAlerter implements EventHandler { @Override public void handleEvent(Event event) { for (String name : event.getPropertyNames()) { System.err.println(name + ":" + event.getProperty(name)); } } }
Now, we create a BundleActivator that register our SystemOutAppender as an EventHandler OSGi service:
package org.apache.karaf.decanter.sample.alerter.systemout; import org.osgi.framework.BundleActivator; import org.osgi.framework.BundleContext; import org.osgi.framework.Constants; import org.osgi.framework.ServiceRegistration; import org.osgi.service.event.EventConstants; import org.osgi.service.event.EventHandler; import java.util.HashMap; import java.util.Dictionary; public class Activator implements BundleActivator { private ServiceRegistration registration; public void start(BundleContext bundleContext) { SystemOutAlerter alerter = new SystemOutAlerter(); Dictionary<String, String> properties = new Hashtable<>(); properties.put(EventConstants.EVENT_TOPIC, "decanter/alert/*"); registration = bundleContext.registerService(EventHandler.class, alerter, properties); } public void stop(BundleContext bundleContext) { if (registration != null) registration.unregister(); } }
You can see that our SystemOutAlerter will listen on any decanter/alert/*
topics.
We can now package our alerter bundle using the following Maven pom.xml
:
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">) <modelVersion>4.0.0</modelVersion> <groupId>org.apache.karaf.decanter.sample.alerter</groupId> <artifactId>org.apache.karaf.decanter.sample.alerter.systemout</artifactId> <version>1.0.0-SNAPSHOT</version> <packaging>bundle</packaging> <name>Apache Karaf :: Decanter :: Sample :: Alerter :: SystemOut</name> <dependencies> <!-- OSGi --> <dependency> <groupId>org.osgi</groupId> <artifactId>org.osgi.core</artifactId> <version>4.3.1</version> </dependency> <dependency> <groupId>org.osgi</groupId> <artifactId>org.osgi.compendium</artifactId> <version>4.3.1</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.apache.felix</groupId> <artifactId>maven-bundle-plugin</artifactId> <version>2.4.0</version> <inherited>true</inherited> <extensions>true</extensions> <configuration> <instructions> <Bundle-SymbolicName>${project.artifactId}</Bundle-SymbolicName> <Bundle-Version>${project.version}</Bundle-Version> <Bundle-Activator>org.apache.karaf.decanter.sample.alerter.systemout.Activator</Bundle-Activator> <Import-Package> * </Import-Package> </instructions> </configuration> </plugin> </plugins> </build> </project>
Once built, you can enable this alerter by deploying the bundle in Karaf (using the deploy folder or the bundle:install
command).