Skip to content

Akiro-IO/akiro-clients

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Akiro Logo

Akiro - MQTT Java Client

Akiro is a High Performance Messaging and Connectivity platform. Akiro's MQTT Broker is proven to handle millions of concurrent connections at production scale.
For more information on the product and solutions visit our website : https://www.akiroio.com/

This project is intended to offer simple and easy to use MQTT Client for applications which run on JVM based platforms.
The current implementation of the Java client is a wrapper around Eclipse Paho Java Client and provides.

For information on Javascript based MQTT client please refer to Akiro MQTT Javascript Client

Note on Eclipse Paho

Eclipse Paho is an open source project which provides a number of clients using which one can connect to the server over MQTT messaging protocol.
For complete information on the project : https://www.eclipse.org/paho/index.php?page=clients/js/index.php#

Installation

Prerequisites

  • Java : 1.8
  • Maven : 3.x

Clone the repo into a directory of choice.
Perform a simple maven build using the command

mvn clean install

This will install the Akiro MQTT Client library to your local M2 Repo.

Plugin the library to your application by adding it as a Maven dependency.

<dependency>
	<groupId>com.akiro</groupId>
	<artifactId>akiro-mqtt-client</artifactId>
	<version>1.0</version>
</dependency>

Create MQTTClient

Create a Client Instance by providing the required connection configuration parameters.

Connection Parameters

Following connection parameters are supported

{	
	host : "akiro.broker.ip",
	port : "akiro.broker.port",
	userName : “<string>”,
	password  : ”<string>”,
	connectionTimeOut (in seconds) : <number>,
	keepAliveInterval (in seconds) : <boolean>,
	cleanSession : <boolean>,
	autoReconnect : <boolean>,
	willMessage : <topic,payload,qos,retain>
}
// Create the connection config
MQTTMessage willmessage = new MQTTMessage("topic", "My Last Will Message", 0, true);

	MQTTConnectionConfig config = new MQTTConnectionConfigBuilder(host, username, password)
            .cleanSession(false)
            .port(port)
            .willMessage(willmessage)
            .keepAliveInterval(keepAliveInterval)
            .autoReconnect(isAutoReconnect)
            .connectionTimeOut(connectionTimeOut)
            .build();

CallBackHandler

Implement the interface CallBackHandler, to configure callbacks in order to take control on the actions and perform certain business logic.
Following callback functions are available

void messageReceived(MQTTMessage message);
void messageDelivered(MQTTMessage message);
void subscriptionComplete(String topic);
void connectionEstablished();
void connectionLost();
void connectionFailure();
new CallBackHandler() {

            @Override
            public void messageReceived(MQTTMessage message) {
              System.out.println("Message received succesfully :: " + message.getPayload());
            }

            @Override
            public void messageDelivered(MQTTMessage message) {
              System.out.println("Message delivered successfully :: " + message.getPayload());
            }

            @Override
            public void connectionLost() {
              System.out.println("Connection lost");
            }

            @Override
            public void connectionEstablished() {
              System.out.println("Connection established successfully");
            }

            @Override
            public void subscriptionComplete(String topic) {
              System.out.println("Subscribed to :: " + topic);
            }

            @Override
            public void connectionFailure() {
              System.out.println("Connection Failed.");
            }
          }

Create the Client instance

MQTTClient client = MQTTClientFactory.createMqttClientInstance(,, );

Connect to the Broker

Once the client is initialized, connect to the MQTTBroker with a simple call.

client.connect();

Publish Message to a Topic

Once the connection is successfully established with the Broker, we can now create an MQTT message and publish to the required topic.

MQTTMessage message = new MQTTMessage();
message.setQos(0);
message.setPayload("this is your message payload");
message.setRetained(false);

String topic = "your topic of interest";
client.publish(message, topic);

Subscribe to one or more topics

Subscribe to a topic

client.subscribe("topic");

Subscribe to multiple topics

Set topics = new HashSet();
topics.add("topic1");
topics.add("topic2");
client.subscribe(topics);

Upon subscribing to a topic, you will start receiving the messages at the callback method configured.

Unsubscribe from one or more topics

Unsubscribe from a Topic.

Unsubscribing from a topic is very similar and simple to subscribe.

client.unsubscribe(“topic name”);

Unsubscribe from multiple topics.

Set topics = new HashSet();
topics.add("topic1");
topics.add("topic2");
client.unsubscribe(topics);

Disconnect

Disconnect the client from the broker using a simple call.

client.disconnect();

Complete Example Application

The example application to demonstrate the important operations

package com.akiro.client.mqtt.examples;

import java.util.HashSet;
import java.util.Set;
import com.akiro.client.mqtt.MQTTClient;
import com.akiro.client.mqtt.CallBackHandler;
import com.akiro.client.mqtt.MQTTClientFactory;
import com.akiro.client.mqtt.exception.MQTTException;
import com.akiro.client.mqtt.model.MQTTConnectionConfig;
import com.akiro.client.mqtt.model.MQTTMessage;
import com.akiro.client.mqtt.model.MQTTConnectionConfig.MQTTConnectionConfigBuilder;

public class MQTTClientExample {

  public static void main(String args[]) {

	String host = "akiro.broker.ip";
	String username = "deviceUserName";
	String password = "devicePassword";
	String deviceId = "mySampleDeviceId";
	int port = 1883;
	int keepAliveInterval = 2;
	boolean isAutoReconnect = true;
	int connectionTimeOut = 10;

	MQTTMessage willmessage = new MQTTMessage("topic", "My Last Will Message", 0, true);

	MQTTConnectionConfig config = new MQTTConnectionConfigBuilder(host, username, password)
			.cleanSession(false)
			.port(port)
			.willMessage(willmessage)
			.keepAliveInterval(keepAliveInterval)
			.autoReconnect(isAutoReconnect)
			.connectionTimeOut(connectionTimeOut)
			.build();

	try {

	  MQTTClient client =
		  MQTTClientFactory.createMqttClientInstance(deviceId, new CallBackHandler() {

			@Override
			public void messageReceived(MQTTMessage message) {
			  System.out.println("Message received succesfully :: " + message.getPayload());

			}

			@Override
			public void messageDelivered(MQTTMessage message) {
			  System.out.println("Message delivered successfully :: " + message.getPayload());
			}

			@Override
			public void connectionLost() {
			  System.out.println("Connection lost");
			}

			@Override
			public void connectionEstablished() {
			  System.out.println("Connection established successfully");
			}

			@Override
			public void subscriptionComplete(String topic) {
			  System.out.println("subscribed to :: " + topic);

			}

			@Override
			public void connectionFailure() {
			  System.out.println("Connection Failed.");

			}
		  }, config);
	  client.connect();

	  // Subscribe to topic1 and topic2

	  Set<String> topics = new HashSet<String>();
	  topics.add("topic1");
	  topics.add("topic3");
	  client.subscribe(topics);


	  // Publish message to topic1
	  MQTTMessage message = new MQTTMessage();
	  message.setQos(0);
	  message.setPayload("Your message payload");
	  message.setRetained(false);
	  client.publish(message, "topic1");

	  // Unsubscribe from topic1
	  client.unsubscribe("topic1");

	  // Disconnect the client
	  client.disconnect();

	} catch (MQTTException e) {
	  System.out.println("Exception occured " + e.getMessage());
	  e.printStackTrace();
	}
  }
}

About

Akiro Clients to connect to the Akiro IoT

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published