Package org.apache.camel.component.mqtt

Source Code of org.apache.camel.component.mqtt.MQTTEndpoint

/**
* 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.camel.component.mqtt;

import java.util.List;
import java.util.concurrent.CopyOnWriteArrayList;
import java.util.concurrent.TimeUnit;

import org.apache.camel.Consumer;
import org.apache.camel.Exchange;
import org.apache.camel.Processor;
import org.apache.camel.Producer;
import org.apache.camel.impl.DefaultEndpoint;
import org.fusesource.hawtbuf.Buffer;
import org.fusesource.hawtbuf.UTF8Buffer;
import org.fusesource.mqtt.client.Callback;
import org.fusesource.mqtt.client.CallbackConnection;
import org.fusesource.mqtt.client.Listener;
import org.fusesource.mqtt.client.Promise;
import org.fusesource.mqtt.client.QoS;
import org.fusesource.mqtt.client.Topic;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
* MQTT endpoint
*/
public class MQTTEndpoint extends DefaultEndpoint {
    private static final transient Logger LOG = LoggerFactory.getLogger(MQTTEndpoint.class);

    private CallbackConnection connection;
    private final MQTTConfiguration configuration;
    private final List<MQTTConsumer> consumers = new CopyOnWriteArrayList<MQTTConsumer>();

    public MQTTEndpoint(String uri, org.apache.camel.component.mqtt.MQTTComponent component, MQTTConfiguration properties) {
        super(uri, component);
        this.configuration = properties;
    }

    @Override
    public Consumer createConsumer(Processor processor) throws Exception {
        MQTTConsumer consumer = new MQTTConsumer(this, processor);
        return consumer;
    }

    @Override
    public Producer createProducer() throws Exception {
        MQTTProducer producer = new MQTTProducer(this);
        return producer;
    }

    public MQTTConfiguration getConfiguration() {
        return configuration;
    }


    @Override
    protected void doStart() throws Exception {
        super.doStart();
        connection = configuration.callbackConnection();

        connection.listener(new Listener() {
            public void onConnected() {
                LOG.info("MQTT Endpoint Connected to " + configuration.getHost());
            }

            public void onDisconnected() {
                LOG.debug("MQTT Connection disconnected");
            }

            public void onPublish(UTF8Buffer topic, Buffer body, Runnable ack) {

                if (!consumers.isEmpty()) {
                    Exchange exchange = createExchange();
                    exchange.getIn().setBody(body.getData());
                    exchange.setProperty(configuration.getMqttTopicPropertyName(), topic.toString());
                    for (MQTTConsumer consumer : consumers) {
                        try {
                            consumer.processExchange(exchange);
                        } catch (Exception e) {
                            LOG.error("Failed to process exchange ", exchange);
                        }
                    }
                }
                if (ack != null) {
                    ack.run();
                }

            }

            public void onFailure(Throwable value) {
                connection.disconnect(new Callback<Void>() {
                    public void onSuccess(Void value) {
                    }

                    public void onFailure(Throwable value) {
                        LOG.debug("Failed to disconnect from " + configuration.getHost());
                    }
                });
            }
        });
        final Promise promise = new Promise();
        connection.connect(new Callback<Void>() {
            public void onSuccess(Void value) {
                String subscribeTopicName = configuration.getSubscribeTopicName();
                subscribeTopicName = subscribeTopicName != null ? subscribeTopicName.trim() : null;

                if (subscribeTopicName != null && !subscribeTopicName.isEmpty()) {
                    Topic[] topics = {new Topic(subscribeTopicName, configuration.getQoS())};
                    connection.subscribe(topics, new Callback<byte[]>() {
                        public void onSuccess(byte[] value) {
                            promise.onSuccess(value);
                        }

                        public void onFailure(Throwable value) {
                            promise.onFailure(value);
                            connection.disconnect(null);
                        }
                    });
                } else {
                    promise.onSuccess(value);
                }

            }

            public void onFailure(Throwable value) {
                promise.onFailure(value);
                connection.disconnect(null);
            }
        });
        promise.await(configuration.getConnectWaitInSeconds(), TimeUnit.SECONDS);
    }

    protected void doStop() throws Exception {
        if (connection != null) {
            final Promise promise = new Promise();
            connection.disconnect(new Callback<Void>() {
                public void onSuccess(Void value) {
                    promise.onSuccess(value);
                }

                public void onFailure(Throwable value) {
                    promise.onFailure(value);
                }
            });
            promise.await(configuration.getDisconnectWaitInSeconds(), TimeUnit.SECONDS);
        }
        super.doStop();
    }

    void publish(String topic, byte[] payload, QoS qoS, boolean retain) throws Exception {
        connection.publish(topic, payload, qoS, retain, null);
        /*
        connection.publish(topic, payload, qoS, retain, new Callback<Void>() {
            public void onSuccess(Void value) {
                promise.onSuccess(value);
            }

            public void onFailure(Throwable value) {
                promise.onFailure(value);
            }

        });
        promise.await(configuration.getSendWaitInSeconds(), TimeUnit.SECONDS);
        */
    }


    void addConsumer(MQTTConsumer consumer) {
        consumers.add(consumer);
    }

    void removeConsumer(MQTTConsumer consumer) {
        consumers.remove(consumer);
    }

    public boolean isSingleton() {
        return false;
    }
}
TOP

Related Classes of org.apache.camel.component.mqtt.MQTTEndpoint

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.