Author: davsclaus
Date: Thu Jan 21 08:57:08 2010
New Revision: 901603

URL: http://svn.apache.org/viewvc?rev=901603&view=rev
Log:
CAMEL-2347: Added nagios component

Added:
    
camel/trunk/components/camel-nagios/src/test/java/org/apache/camel/component/nagios/NagiosAsyncSendTest.java
   (with props)
Modified:
    
camel/trunk/components/camel-nagios/src/main/java/org/apache/camel/component/nagios/NagiosComponent.java
    
camel/trunk/components/camel-nagios/src/main/java/org/apache/camel/component/nagios/NagiosEndpoint.java
    
camel/trunk/components/camel-nagios/src/main/java/org/apache/camel/component/nagios/NagiosProducer.java
    
camel/trunk/components/camel-nagios/src/test/java/org/apache/camel/component/nagios/NagiosTest.java

Modified: 
camel/trunk/components/camel-nagios/src/main/java/org/apache/camel/component/nagios/NagiosComponent.java
URL: 
http://svn.apache.org/viewvc/camel/trunk/components/camel-nagios/src/main/java/org/apache/camel/component/nagios/NagiosComponent.java?rev=901603&r1=901602&r2=901603&view=diff
==============================================================================
--- 
camel/trunk/components/camel-nagios/src/main/java/org/apache/camel/component/nagios/NagiosComponent.java
 (original)
+++ 
camel/trunk/components/camel-nagios/src/main/java/org/apache/camel/component/nagios/NagiosComponent.java
 Thu Jan 21 08:57:08 2010
@@ -19,7 +19,6 @@
 import java.net.URI;
 import java.util.Map;
 
-import com.googlecode.jsendnsca.core.NagiosSettings;
 import org.apache.camel.CamelContext;
 import org.apache.camel.Endpoint;
 import org.apache.camel.impl.DefaultComponent;
@@ -30,7 +29,6 @@
  */
 public class NagiosComponent extends DefaultComponent {
 
-    private NagiosSettings nagiosSettings;
     private NagiosConfiguration configuration;
 
     public NagiosComponent() {
@@ -59,14 +57,6 @@
         return endpoint;
     }
 
-    public NagiosSettings getNagiosSettings() {
-        return nagiosSettings;
-    }
-
-    public void setNagiosSettings(NagiosSettings nagiosSettings) {
-        this.nagiosSettings = nagiosSettings;
-    }
-
     public NagiosConfiguration getConfiguration() {
         return configuration;
     }

Modified: 
camel/trunk/components/camel-nagios/src/main/java/org/apache/camel/component/nagios/NagiosEndpoint.java
URL: 
http://svn.apache.org/viewvc/camel/trunk/components/camel-nagios/src/main/java/org/apache/camel/component/nagios/NagiosEndpoint.java?rev=901603&r1=901602&r2=901603&view=diff
==============================================================================
--- 
camel/trunk/components/camel-nagios/src/main/java/org/apache/camel/component/nagios/NagiosEndpoint.java
 (original)
+++ 
camel/trunk/components/camel-nagios/src/main/java/org/apache/camel/component/nagios/NagiosEndpoint.java
 Thu Jan 21 08:57:08 2010
@@ -16,7 +16,9 @@
  */
 package org.apache.camel.component.nagios;
 
+import com.googlecode.jsendnsca.core.INagiosPassiveCheckSender;
 import com.googlecode.jsendnsca.core.NagiosPassiveCheckSender;
+import com.googlecode.jsendnsca.core.NonBlockingNagiosPassiveCheckSender;
 import org.apache.camel.Component;
 import org.apache.camel.Consumer;
 import org.apache.camel.Processor;
@@ -29,8 +31,9 @@
  */
 public class NagiosEndpoint extends DefaultEndpoint {
 
+    private INagiosPassiveCheckSender sender;
     private NagiosConfiguration configuration;
-    private NagiosPassiveCheckSender sender;
+    private boolean sendSync = true;
 
     public NagiosEndpoint() {
     }
@@ -60,14 +63,27 @@
         this.configuration = configuration;
     }
 
-    public NagiosPassiveCheckSender getSender() {
+    public boolean isSendSync() {
+        return sendSync;
+    }
+
+    public void setSendSync(boolean sendSync) {
+        this.sendSync = sendSync;
+    }
+
+    public synchronized INagiosPassiveCheckSender getSender() {
         if (sender == null) {
-            sender = new 
NagiosPassiveCheckSender(getConfiguration().getNagiosSettings());
+            if (isSendSync()) {
+                sender = new 
NagiosPassiveCheckSender(getConfiguration().getNagiosSettings());
+            } else {
+                // use a non blocking sender
+                sender = new 
NonBlockingNagiosPassiveCheckSender(getConfiguration().getNagiosSettings());
+            }
         }
         return sender;
     }
 
-    public void setSender(NagiosPassiveCheckSender sender) {
+    public void setSender(INagiosPassiveCheckSender sender) {
         this.sender = sender;
     }
 }

Modified: 
camel/trunk/components/camel-nagios/src/main/java/org/apache/camel/component/nagios/NagiosProducer.java
URL: 
http://svn.apache.org/viewvc/camel/trunk/components/camel-nagios/src/main/java/org/apache/camel/component/nagios/NagiosProducer.java?rev=901603&r1=901602&r2=901603&view=diff
==============================================================================
--- 
camel/trunk/components/camel-nagios/src/main/java/org/apache/camel/component/nagios/NagiosProducer.java
 (original)
+++ 
camel/trunk/components/camel-nagios/src/main/java/org/apache/camel/component/nagios/NagiosProducer.java
 Thu Jan 21 08:57:08 2010
@@ -16,11 +16,13 @@
  */
 package org.apache.camel.component.nagios;
 
+import com.googlecode.jsendnsca.core.INagiosPassiveCheckSender;
 import com.googlecode.jsendnsca.core.Level;
 import com.googlecode.jsendnsca.core.MessagePayload;
-import com.googlecode.jsendnsca.core.NagiosPassiveCheckSender;
+import com.googlecode.jsendnsca.core.NonBlockingNagiosPassiveCheckSender;
 import org.apache.camel.Exchange;
 import org.apache.camel.impl.DefaultProducer;
+import org.apache.camel.util.concurrent.ExecutorServiceHelper;
 
 import static org.apache.camel.component.nagios.NagiosConstants.HOST_NAME;
 import static org.apache.camel.component.nagios.NagiosConstants.LEVEL;
@@ -31,9 +33,9 @@
  */
 public class NagiosProducer extends DefaultProducer {
 
-    private final NagiosPassiveCheckSender sender;
+    private final INagiosPassiveCheckSender sender;
 
-    public NagiosProducer(NagiosEndpoint endpoint, NagiosPassiveCheckSender 
sender) {
+    public NagiosProducer(NagiosEndpoint endpoint, INagiosPassiveCheckSender 
sender) {
         super(endpoint);
         this.sender = sender;
     }
@@ -59,5 +61,23 @@
             log.trace("Sending notification done");
         }
     }
-    
+
+    @Override
+    protected void doStart() throws Exception {
+        // if non blocking then set a executor service on it
+        if (sender instanceof NonBlockingNagiosPassiveCheckSender) {
+            NonBlockingNagiosPassiveCheckSender nonBlocking = 
(NonBlockingNagiosPassiveCheckSender) sender;
+            
nonBlocking.setExecutor(ExecutorServiceHelper.newSingleThreadExecutor(getEndpoint().getEndpointUri(),
 true));
+        }
+        super.doStart();
+    }
+
+    @Override
+    protected void doStop() throws Exception {
+        super.doStop();
+        // if non blocking then shutdown executor
+        if (sender instanceof NonBlockingNagiosPassiveCheckSender) {
+            ((NonBlockingNagiosPassiveCheckSender) sender).shutdown();
+        }
+    }
 }

Added: 
camel/trunk/components/camel-nagios/src/test/java/org/apache/camel/component/nagios/NagiosAsyncSendTest.java
URL: 
http://svn.apache.org/viewvc/camel/trunk/components/camel-nagios/src/test/java/org/apache/camel/component/nagios/NagiosAsyncSendTest.java?rev=901603&view=auto
==============================================================================
--- 
camel/trunk/components/camel-nagios/src/test/java/org/apache/camel/component/nagios/NagiosAsyncSendTest.java
 (added)
+++ 
camel/trunk/components/camel-nagios/src/test/java/org/apache/camel/component/nagios/NagiosAsyncSendTest.java
 Thu Jan 21 08:57:08 2010
@@ -0,0 +1,38 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.nagios;
+
+import org.apache.camel.builder.RouteBuilder;
+
+/**
+ * @version $Revision$
+ */
+public class NagiosAsyncSendTest extends NagiosTest {
+
+    @Override
+    protected RouteBuilder createRouteBuilder() throws Exception {
+        return new RouteBuilder() {
+            @Override
+            public void configure() throws Exception {
+                // START SNIPPET: e1
+                
from("direct:start").to("nagios:127.0.0.1:5667?password=secret&sendSync=false").to("mock:result");
+                // END SNIPPET: e1
+            }
+        };
+    }
+
+}
\ No newline at end of file

Propchange: 
camel/trunk/components/camel-nagios/src/test/java/org/apache/camel/component/nagios/NagiosAsyncSendTest.java
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: 
camel/trunk/components/camel-nagios/src/test/java/org/apache/camel/component/nagios/NagiosAsyncSendTest.java
------------------------------------------------------------------------------
    svn:keywords = Rev Date

Modified: 
camel/trunk/components/camel-nagios/src/test/java/org/apache/camel/component/nagios/NagiosTest.java
URL: 
http://svn.apache.org/viewvc/camel/trunk/components/camel-nagios/src/test/java/org/apache/camel/component/nagios/NagiosTest.java?rev=901603&r1=901602&r2=901603&view=diff
==============================================================================
--- 
camel/trunk/components/camel-nagios/src/test/java/org/apache/camel/component/nagios/NagiosTest.java
 (original)
+++ 
camel/trunk/components/camel-nagios/src/test/java/org/apache/camel/component/nagios/NagiosTest.java
 Thu Jan 21 08:57:08 2010
@@ -62,6 +62,9 @@
 
         assertMockEndpointsSatisfied();
 
+        // sleep a little to let nagios stub process the payloads
+        Thread.sleep(1000);
+
         assertEquals(1, nagios.getMessagePayloadList().size());
 
         MessagePayload payload = nagios.getMessagePayloadList().get(0);
@@ -109,6 +112,9 @@
 
         assertMockEndpointsSatisfied();
 
+        // sleep a little to let nagios stub process the payloads
+        Thread.sleep(1000);
+
         assertEquals(1, nagios.getMessagePayloadList().size());
 
         MessagePayload payload = nagios.getMessagePayloadList().get(0);
@@ -127,6 +133,9 @@
 
         assertMockEndpointsSatisfied();
 
+        // sleep a little to let nagios stub process the payloads
+        Thread.sleep(1000);
+
         assertEquals(1, nagios.getMessagePayloadList().size());
 
         MessagePayload payload = nagios.getMessagePayloadList().get(0);
@@ -149,6 +158,9 @@
 
         assertMockEndpointsSatisfied();
 
+        // sleep a little to let nagios stub process the payloads
+        Thread.sleep(1000);
+
         assertEquals(1, nagios.getMessagePayloadList().size());
 
         MessagePayload payload = nagios.getMessagePayloadList().get(0);


Reply via email to