View Javadoc
1   /*
2    * Copyright (c) MuleSoft, Inc.  All rights reserved.  http://www.mulesoft.com
3    * The software in this package is published under the terms of the CPAL v1.0
4    * license, a copy of which has been included with this distribution in the
5    * LICENSE.txt file.
6    */
7   package org.mule.transport.quartz.jobs;
8   
9   import org.mule.api.MuleContext;
10  import org.mule.api.MuleException;
11  import org.mule.api.context.MuleContextAware;
12  import org.mule.api.endpoint.InboundEndpoint;
13  import org.mule.api.lifecycle.InitialisationException;
14  import org.mule.api.lifecycle.Lifecycle;
15  import org.mule.transport.AbstractConnector;
16  import org.mule.transport.AbstractPollingMessageReceiver;
17  
18  import org.quartz.Job;
19  import org.quartz.JobExecutionContext;
20  import org.quartz.JobExecutionException;
21  
22  public class PollEndpointJob implements Job, Lifecycle, MuleContextAware
23  {
24      private String inboundPollingEndpointName;
25      private AbstractPollingMessageReceiver receiver;
26  	private MuleContext muleContext;
27      
28      public PollEndpointJob(String inboundPollingEndpointName)
29      {
30          this.inboundPollingEndpointName = inboundPollingEndpointName;
31      }
32  
33      public void execute(JobExecutionContext context) throws JobExecutionException
34      {
35          try
36          {
37              receiver.poll();
38          }
39          catch (Exception e)
40          {
41              throw new JobExecutionException(e);
42          }
43          
44      }
45  
46      public void initialise() throws InitialisationException
47      {
48          //DO NOTHING
49      }
50  
51      public void start() throws MuleException
52      {
53          InboundEndpoint endpoint = (InboundEndpoint) muleContext.getRegistry().lookupObject(this.inboundPollingEndpointName);
54          AbstractConnector connector = (AbstractConnector) endpoint.getConnector();
55          receiver = (AbstractPollingMessageReceiver) connector.getReceiver(null, endpoint);
56          receiver.disableNativeScheduling();
57      }
58  
59      public void stop() throws MuleException
60      {
61          //DO NOTHING
62      }
63  
64      public void dispose()
65      {
66          //DO NOTHING
67      }
68  
69  	public void setMuleContext(MuleContext context) {
70  		this.muleContext = context;
71  	}
72  }