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

com.automationrockstars.gunter.rabbit.RabbitEventBroker Maven / Gradle / Ivy

The newest version!
/*******************************************************************************
 * Copyright (c) 2015, 2016 Automation RockStars Ltd.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Apache License v2.0
 * which accompanies this distribution, and is available at
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Contributors:
 *     Automation RockStars - initial API and implementation
 *******************************************************************************/
package com.automationrockstars.gunter.rabbit;

import com.automationrockstars.gunter.events.EventBroker;
import com.automationrockstars.gunter.events.EventBus;
import com.google.common.base.Preconditions;
import com.google.common.collect.Maps;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.IOException;
import java.util.concurrent.ConcurrentMap;
import java.util.concurrent.TimeoutException;

import static com.automationrockstars.base.ConfigLoader.config;

public class RabbitEventBroker implements EventBroker {

    public static final String HOST_PROP = "rabbitmq.host";
    public static final String PORT_PROP = "rabbitmq.port";
    public static final String USER_PROP = "rabbitmq.user";
    public static final String PASS_PROP = "rabbitmq.pass";

    private static final ConnectionFactory factory = new ConnectionFactory();
    private static final Logger LOG = LoggerFactory.getLogger(RabbitEventBroker.class);
    private static final ConcurrentMap publishers = Maps.newConcurrentMap();
    private static final ConcurrentMap consumers = Maps.newConcurrentMap();
    private static final String DEFAULT_EXCHANGE = "testing-events";
    private static final String DEFAULT_KEY = "";
    private static Connection connection;
    private static Channel channel;
    private static RabbitEventBroker instance;
    private static Publisher defaultPublisher;
    private static Consumer defaultConsumer;

    private RabbitEventBroker() {
        EventBus.registerBroker(this);
    }

    private static RabbitEventBroker getInstance() {
        if (instance == null) {
            instance = new RabbitEventBroker();
        }
        return instance;
    }

    private static Channel reconnect() throws IOException, TimeoutException {
        getInstance().close();
        connection = factory.newConnection();
        channel = connection.createChannel();
        return channel;
    }

    static Channel getChannel() {
        try {
            if (channel == null || !connection.isOpen() || !channel.isOpen()) {
                Preconditions.checkNotNull(config().getString(HOST_PROP), "RabbitMQ host cannot be undefined");
                factory.setHost(config().getString(HOST_PROP));
                factory.setPort(config().getInt(PORT_PROP));
                factory.setUsername(config().getString(USER_PROP));
                factory.setPassword(config().getString(PASS_PROP));
                reconnect();
            }
        } catch (IOException | TimeoutException e) {
            LOG.error("Connection  {}:{}@{}:{} failed",
                    factory.getUsername(), factory.getPassword(), factory.getHost(), factory.getPort(), e);
        }
        Preconditions.checkState(connection.isOpen(), "Cannot establish connection to RabbitMQ server");
        return channel;
    }

    public static boolean declareExchange(String exchange) {
        try {
            getChannel().exchangeDeclare(exchange, "fanout", true);
            return true;
        } catch (IOException e) {
            LOG.error("Creating exchange {} failed", exchange, e);
            return false;
        }
    }

    public static Publisher publisher(String exchange, String routingKey) {
        Publisher result = publishers.get(exchange + "::" + routingKey);
        if (result == null) {
            result = new Publisher(exchange, routingKey);
            publishers.put(exchange + "::" + routingKey, result);
        }
        return result;
    }

    public static Consumer consumer(String exchange, String routingKey) {
        Consumer result = consumers.get(exchange + "::" + routingKey);
        if (result == null) {
            result = new Consumer(exchange, routingKey);
            consumers.put(exchange + "::" + routingKey, result);
        }
        return result;

    }

    public static final Publisher defaultPublisher() {
        if (defaultPublisher == null) {
            defaultPublisher = publisher(DEFAULT_EXCHANGE, DEFAULT_KEY);
        }
        return defaultPublisher;

    }

    public static final Consumer defaultConsumer() {
        if (defaultConsumer == null) {
            defaultConsumer = consumer(DEFAULT_EXCHANGE, DEFAULT_KEY);
        }
        return defaultConsumer;
    }

    public static void closeAll() {
        getInstance().close();
    }

    public static final void init() {
        getInstance();
        getChannel();
    }

    public void fireEvent(String event) {
        defaultPublisher().fireEvent(event);
    }

    public void close() {
        if (channel != null) {
            try {
                channel.close();
            } catch (Exception e) {
            }
        }
        if (connection != null) {
            try {
                connection.close();

            } catch (IOException e) {
            }
        }
        channel = null;
        connection = null;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy