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

org.yamcs.artemis.ArtemisEventDataLink Maven / Gradle / Ivy

package org.yamcs.artemis;

import org.apache.activemq.artemis.api.core.ActiveMQException;
import org.apache.activemq.artemis.api.core.client.ClientConsumer;
import org.apache.activemq.artemis.api.core.client.ClientSession;
import org.apache.activemq.artemis.api.core.client.ServerLocator;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.yamcs.StreamConfig;
import org.yamcs.yarch.Stream;
import org.yamcs.yarch.Tuple;
import org.yamcs.yarch.YarchDatabase;
import org.yamcs.yarch.YarchDatabaseInstance;

import com.google.common.util.concurrent.AbstractService;

/**
 * Receives event data from Artemis queues and publishes into yamcs streams
 * 
 * @author nm
 *
 */
public class ArtemisEventDataLink extends AbstractService {
    String instance;
    ServerLocator locator;
    ClientSession session;
    Logger log = LoggerFactory.getLogger(this.getClass().getName());

    public ArtemisEventDataLink(String instance) {
        this.instance = instance;
        locator = AbstractArtemisTranslatorService.getServerLocator(instance);
    }

    @Override
    protected void doStart() {
        try {
            session = locator.createSessionFactory().createSession();
            EventTupleTranslator translator = new EventTupleTranslator();
            YarchDatabaseInstance ydb = YarchDatabase.getInstance(instance);
            StreamConfig sc = StreamConfig.getInstance(instance);
            for (String streamName : sc.getStreamNames(StreamConfig.StandardStreamType.event)) {
                Stream stream = ydb.getStream(streamName);
                String address = instance + "." + streamName;
                String queue = address + "-StreamAdapter";
                session.createTemporaryQueue(address, queue);
                ClientConsumer client = session.createConsumer(queue);
                client.setMessageHandler((msg) -> {
                    try {
                        msg.acknowledge();
                        Tuple tuple = translator.buildTuple(msg);
                        stream.emitTuple(tuple);
                    } catch (Exception e) {
                        log.warn("{} for message: {}", e.getMessage(), msg);
                    }
                });
            }
            session.start();
        } catch (Exception e) {
            notifyFailed(e);
        }
        notifyStarted();
    }

    @Override
    protected void doStop() {
        try {
            session.stop();
            session.close();
            notifyStopped();
        } catch (ActiveMQException e) {
            notifyFailed(e);
        }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy