All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.yestech.lib.camel.TerracottaProducer Maven / Gradle / Ivy

Go to download

A collection of classes that can be used across yestech artifacts/components, but must not be dependant on any yestech component. Most of the code is utility type code. When more than a few classes are found to be in a package or the package start to handle more that a few reposibilities then a new independant component is created and the existing code in yeslib is ported to the new component.

There is a newer version: 1.2.0
Show newest version
/*
 * Copyright LGPL3
 * YES Technology Association
 * http://yestech.org
 *
 * http://www.opensource.org/licenses/lgpl-3.0.html
 */
package org.yestech.lib.camel;

import org.apache.camel.Exchange;
import org.apache.camel.impl.DefaultProducer;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.terracotta.message.pipe.Pipe;

/**
 * 
 * A {@link org.apache.camel.Producer} which uses a Terracotta {@link Pipe} to pass the {@link org.apache.camel.Exchange}.
 *
 */
public class TerracottaProducer extends DefaultProducer {
    final private static Logger logger = LoggerFactory.getLogger(TerracottaProducer.class);
    private final Pipe queue;
    private TerracottaEndpoint endpoint;

    public TerracottaProducer(TerracottaEndpoint endpoint, Pipe queue) {
        super(endpoint);
        this.endpoint = endpoint;
        this.queue = queue;
    }

    @Override
    public void process(Exchange exchange) throws Exception {
        queue.put(exchange.copy());
    }

    @Override
    protected void doStart() throws Exception {
        super.doStart();
        endpoint.onStarted(this);
    }

    @Override
    protected void doStop() throws Exception {
        endpoint.onStopped(this);
        super.doStop();
    }
}