/*
* $Id: PollEndpointJob.java 21943 2011-05-18 14:23:26Z aperepel $
* --------------------------------------------------------------------------------------
* Copyright (c) MuleSource, Inc. All rights reserved. http://www.mulesource.com
*
* The software in this package is published under the terms of the CPAL v1.0
* license, a copy of which has been included with this distribution in the
* LICENSE.txt file.
*/
package org.mule.transport.quartz.jobs;
import org.mule.api.MuleContext;
import org.mule.api.MuleException;
import org.mule.api.context.MuleContextAware;
import org.mule.api.endpoint.InboundEndpoint;
import org.mule.api.lifecycle.InitialisationException;
import org.mule.api.lifecycle.Lifecycle;
import org.mule.transport.AbstractConnector;
import org.mule.transport.AbstractPollingMessageReceiver;
import org.quartz.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
public class PollEndpointJob implements Job, Lifecycle, MuleContextAware
{
private String inboundPollingEndpointName;
private AbstractPollingMessageReceiver receiver;
private MuleContext muleContext;
public PollEndpointJob(String inboundPollingEndpointName)
{
this.inboundPollingEndpointName = inboundPollingEndpointName;
}
public void execute(JobExecutionContext context) throws JobExecutionException
{
try
{
receiver.poll();
}
catch (Exception e)
{
throw new JobExecutionException(e);
}
}
public void initialise() throws InitialisationException
{
//DO NOTHING
}
public void start() throws MuleException
{
InboundEndpoint endpoint = (InboundEndpoint) muleContext.getRegistry().lookupObject(this.inboundPollingEndpointName);
AbstractConnector connector = (AbstractConnector) endpoint.getConnector();
receiver = (AbstractPollingMessageReceiver) connector.getReceiver(null, endpoint);
receiver.disableNativeScheduling();
}
public void stop() throws MuleException
{
//DO NOTHING
}
public void dispose()
{
//DO NOTHING
}
public void setMuleContext(MuleContext context) {
this.muleContext = context;
}
}