diff --git a/src/main/java/bark/client/examples/AlertWebhook.java b/src/main/java/bark/client/examples/AlertWebhook.java new file mode 100644 index 0000000..f48f7de --- /dev/null +++ b/src/main/java/bark/client/examples/AlertWebhook.java @@ -0,0 +1,25 @@ +package bark.client.examples; + +import bark.client.constants.Global; +import bark.client.models.BarkLog; +import bark.client.models.Config; +import bark.client.models.Webhook; + +import java.io.IOException; + +import static bark.client.models.Config.BarkClient; + +public class AlertWebhook { + public static void main(String[] args) throws IOException { + Config logConf = BarkClient("http://localhost:8080/", Global.Info, "AlertWebhookSvc", "AlertWebhookSess"); + Webhook webhook = new Webhook() { + @Override + public void processWebhook(BarkLog barkLog) { + System.out.println(barkLog.toString()); + } + }; + + logConf.setAlertWebhook(webhook); + logConf.Alert("Hello Alert Webhook"); + } +} diff --git a/src/main/java/bark/client/models/BarkLog.java b/src/main/java/bark/client/models/BarkLog.java index 9f576ef..681a69c 100644 --- a/src/main/java/bark/client/models/BarkLog.java +++ b/src/main/java/bark/client/models/BarkLog.java @@ -35,5 +35,17 @@ public void setMoreData(MoreData moreData) { this.moreData = moreData; } - + @Override + public String toString() { + return "BarkLog{" + + "id=" + id + + ", logTime=" + logTime + + ", logLevel='" + logLevel + '\'' + + ", serviceName='" + serviceName + '\'' + + ", sessionName='" + sessionName + '\'' + + ", code='" + code + '\'' + + ", message='" + message + '\'' + + ", moreData=" + moreData + + '}'; + } } diff --git a/src/main/java/bark/client/models/Config.java b/src/main/java/bark/client/models/Config.java index 9d924c4..8c997dc 100644 --- a/src/main/java/bark/client/models/Config.java +++ b/src/main/java/bark/client/models/Config.java @@ -12,6 +12,11 @@ public class Config { private String errorLevel; private String serviceName; private String sessionName; + private Webhook webhook; + + public void setAlertWebhook(Webhook webhook){ + this.webhook = webhook; + } public void Panic(String message) throws IOException { System.out.println(message); @@ -21,6 +26,11 @@ public void Panic(String message) throws IOException { public void Alert(String message) throws IOException { System.out.println(message); BarkLog log = new BarkLog(Global.Alert, this.serviceName, this.sessionName, Global.DefaultLogCode,message); + + if(webhook!=null){ + webhook.processWebhook(log); + } + dispatchLogMessage(log); } public void Error(String message) throws IOException { diff --git a/src/main/java/bark/client/models/Webhook.java b/src/main/java/bark/client/models/Webhook.java new file mode 100644 index 0000000..64c4037 --- /dev/null +++ b/src/main/java/bark/client/models/Webhook.java @@ -0,0 +1,5 @@ +package bark.client.models; + +public interface Webhook { + void processWebhook(BarkLog log); +}