Package org.apache.synapse.message.processors.forward

Source Code of org.apache.synapse.message.processors.forward.ScheduledMessageForwardingProcessor

/*
*  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.synapse.message.processors.forward;

import org.apache.synapse.SynapseException;
import org.apache.synapse.core.SynapseEnvironment;
import org.apache.synapse.message.processors.ScheduledMessageProcessor;
import org.quartz.JobDataMap;
import org.quartz.JobDetail;
import org.quartz.SchedulerException;

import java.util.Map;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.concurrent.atomic.AtomicInteger;

/**
* Redelivery processor is the Message processor which implements the Dead letter channel EIP
* It will Time to time Redeliver the Messages to a given target.
*/
public class ScheduledMessageForwardingProcessor extends ScheduledMessageProcessor{

    public static final String BLOCKING_SENDER = "blocking.sender";


    private BlockingMessageSender sender = null;

    private volatile AtomicBoolean active = new AtomicBoolean(true);

    private volatile AtomicInteger sendAttempts = new AtomicInteger(0);

    private MessageForwardingProcessorView view;

    @Override
    public void init(SynapseEnvironment se) {
        super.init(se);
        try {
            view = new MessageForwardingProcessorView(
                    se.getSynapseConfiguration().getMessageStore(messageStore),sender,this);
        } catch (Exception e) {
            throw new SynapseException(e);
        }

        org.apache.synapse.commons.jmx.MBeanRegistrar.getInstance().registerMBean(view,
                "Message Forwarding Processor view", getName());
    }

    @Override
    protected JobDetail getJobDetail() {
        JobDetail jobDetail = new JobDetail();
        jobDetail.setName(name + "-forward job");
        jobDetail.setJobClass(ForwardingJob.class);
        return jobDetail;
    }

    @Override
    protected JobDataMap getJobDataMap() {
        JobDataMap jdm = new JobDataMap();
        sender = initMessageSender(parameters);
        jdm.put(BLOCKING_SENDER,sender);
        jdm.put(PROCESSOR_INSTANCE,this);
        return jdm;
    }

     private BlockingMessageSender initMessageSender(Map<String ,Object> params) {

        String axis2repo = (String) params.get(ForwardingProcessorConstants.AXIS2_REPO);
        String axis2Config = (String) params.get(ForwardingProcessorConstants.AXIS2_CONFIG);

        sender = new BlockingMessageSender();

        if(axis2repo != null) {
            sender.setClientRepository(axis2repo);
        }


        if(axis2Config != null) {
            sender.setAxis2xml(axis2Config);
        }
        sender.init();

        return sender;
    }

    public BlockingMessageSender getSender() {
        return sender;
    }

    public void setSender(BlockingMessageSender sender) {
        this.sender = sender;
    }

    public boolean isActive() {
        return active.get();
    }

    public void activate() {
        active.set(true);
    }

    public void deactivate() {
        active.set(false);
    }

    public int getSendAttemptCount() {
        return sendAttempts.get();
    }

    public void incrementSendAttemptCount() {
        sendAttempts.incrementAndGet();
    }
    public void resetSentAttemptCount(){
        sendAttempts.set(0);
    }

    @Override
    public void destroy() {
         try {
            scheduler.deleteJob(name + "-forward job",
                    ScheduledMessageProcessor.SCHEDULED_MESSAGE_PROCESSOR_GROUP);
        } catch (SchedulerException e) {
            log.error("Error while destroying the task " + e);
        }
        state = State.DESTROY;
    }


    /**
     * Return the JMS view of Message Processor
     * @return
     */
    public MessageForwardingProcessorView getView() {
        return view;
    }
}
TOP

Related Classes of org.apache.synapse.message.processors.forward.ScheduledMessageForwardingProcessor

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.