⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 endpointpollingjob.java

📁 提供ESB 应用mule源代码 提供ESB 应用mule源代码
💻 JAVA
字号:
/* * $Id: EndpointPollingJob.java 11967 2008-06-05 20:32:19Z dfeist $ * -------------------------------------------------------------------------------------- * 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.MuleException;import org.mule.api.MuleMessage;import org.mule.api.ThreadSafeAccess;import org.mule.api.transport.PropertyScope;import org.mule.module.client.MuleClient;import org.mule.transport.quartz.QuartzConnector;import org.mule.transport.quartz.QuartzMessageReceiver;import org.mule.transport.quartz.i18n.QuartzMessages;import org.mule.transport.AbstractConnector;import org.mule.transport.AbstractMessageReceiver;import org.mule.RegistryContext;import org.apache.commons.logging.Log;import org.apache.commons.logging.LogFactory;import org.quartz.Job;import org.quartz.JobDataMap;import org.quartz.JobExecutionContext;import org.quartz.JobExecutionException;/** * Will receive on an endpoint and dispatch it to the component set via the Receiver information. */public class EndpointPollingJob implements Job{    /**     * The logger used for this class     */    protected transient Log logger = LogFactory.getLog(getClass());    public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException    {        JobDataMap jobDataMap = jobExecutionContext.getJobDetail().getJobDataMap();        String receiverKey = (String) jobDataMap.get(QuartzMessageReceiver.QUARTZ_RECEIVER_PROPERTY);        if (receiverKey == null)        {            throw new JobExecutionException(QuartzMessages.receiverNotInJobDataMap().getMessage());        }        String connectorName = (String) jobDataMap.get(QuartzMessageReceiver.QUARTZ_CONNECTOR_PROPERTY);        if (connectorName == null)        {            throw new JobExecutionException(QuartzMessages.connectorNotInJobDataMap().getMessage());        }        AbstractConnector connector = (AbstractConnector) RegistryContext.getRegistry().lookupConnector(connectorName);        if (connector == null)        {            throw new JobExecutionException(QuartzMessages.noConnectorFound(connectorName).getMessage());        }        AbstractMessageReceiver receiver = (AbstractMessageReceiver) connector.lookupReceiver(receiverKey);        if (receiver == null)        {            throw new JobExecutionException(                    QuartzMessages.noReceiverInConnector(receiverKey, connectorName).getMessage());        }        EndpointPollingJobConfig jobConfig = (EndpointPollingJobConfig) jobDataMap.get(QuartzConnector.PROPERTY_JOB_CONFIG);        if (jobConfig == null)        {            throw new JobExecutionException(                    QuartzMessages.missingJobDetail(QuartzConnector.PROPERTY_JOB_CONFIG).getMessage());        }        try        {            MuleClient client = new MuleClient();            logger.debug("Attempting to receive event on: " + jobConfig.getEndpointRef());            MuleMessage result = client.request(jobConfig.getEndpointRef(), jobConfig.getTimeout());            if (result != null)            {                if (logger.isDebugEnabled())                {                    logger.debug("Received event on: " + jobConfig.getEndpointRef());                }                //we need to do this because                result = (MuleMessage)((ThreadSafeAccess)result).newThreadCopy();                //Add the context properties to the message.                result.addProperties(jobDataMap, PropertyScope.INVOCATION);                receiver.routeMessage(result);            }        }        catch (MuleException e)        {            throw new JobExecutionException(e);        }    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -