Skip to main content

A Chat Server based on MQTT protocol using Mosquitto (broker a C implementation of MQTT), websocket, sockjs javascript library on client(browser) side, sockjs-tornado, tornado, and paho-mqtt (mqtt python client library)

Project description

An MQTT protocol based Chat-Server/Chat-System using Mosquitto Broker, tornado as web server, sockjs in client(browser) side javascript library, sockjs-tornado as sockjs implementation on server side and paho-mqtt (mqtt python client).

Documentation

Link : http://mosquittochat.readthedocs.io/en/latest/

Project Home Page

Link : https://pypi.python.org/pypi/mosquittoChat

Details

Author:

Anirban Roy Das

Email:

anirban.nick@gmail.com

Copyright(C):

2016, Anirban Roy Das <anirban.nick@gmail.com>

Check rabbitChat/LICENSE file for full Copyright notice.

Overview

mosquittochat is an MQTT protocol based simple Chat Server which can be set up locally to chat in your LAN. It supports both Public Chat among all participants connected simultaneously at a particular time and also Private Chat betweent those individual participants.

It uses the MQTT protocol to implement the real time message passing system. MQTT is implemented in many languages and in many softwares, one of such is Mosquitto , which is a message broker implementing the MQTT protocol.

The connection is created using the sockjs protocol. SockJS is implemented in many languages, primarily in Javascript to talk to the servers in real time, which tries to create a duplex bi-directional connection between the Client(browser) and the Server. Ther server should also implement the sockjs protocol. Thus using the sockjs-tornado library which exposes the sockjs protocol in Tornado server.

It first tries to create a Websocket connection, and if it fails then it fallbacks to other transport mechanisms, such as Ajax, long polling, etc. After the connection is established, the tornado server**(sockjs-tornado)** connects to Mosquitto via MQTT protocol using the MQTT Python Client Library, paho-mqtt.

Thus the connection is web-browser to tornado to mosquitto and vice versa.

Technical Specs

sockjs-client:

Advanced Websocket Javascript Client

Tornado:

Async Python Web Library + Web Server

sockjs-tornado:

SockJS websocket server implementation for Tornado

MQTT:

Machine-to-Machine (M2M)/”Internet of Things” connectivity protocol

paho-mqtt:

MQTT Python Client Library

Mosquitto:

A Message Broker implementing MQTT in C

Features

  • Public chat

  • Shows who joined and who left

  • Shows list of users online/offline

  • Show last seen of offline features

  • Shows who is typing and who is not - typing indicator

  • Shows number of people online in public chat

  • Join/Leave chat room features

Installation

Prerequisites

  1. python 2.7+

  2. tornado

  3. sockjs-tornado

  4. sockjs-client

  5. paho-mqtt

  6. mosquitto

Install

$ pip install mosquittoChat

If above dependencies do not get installed by the above command, then use the below steps to install them one by one.

Step 1 - Install pip

Follow the below methods for installing pip. One of them may help you to install pip in your system.

Step 2 - Install tornado

$ pip install tornado

Step 3 - Install sockjs-tornado

$ pip install sockjs-tornado

Step 4 - Install paho-mqtt

$ pip install paho-mqtt

Step 5 - Install Mosquitto

  • For Mac Users

    1. Brew Install Mosquitto

    $ brew install mosquitto
    1. Configure mosquitto, by modifying the file at /usr/local/etc/mosquitto/mosquitto.conf.

  • For Ubuntu/Linux Users

    1. Enable mosquitto repository (optional)

      First Try directly, if it doesn’t work, then follow this step and continue after this.:

      $ sudo apt-add-repository ppa:mosquitto-dev/mosquitto-ppa

    2. Update the sources with our new addition from above

    $ apt-get update

    3. And finally, download and install Mosquitto

    $ sudo apt-get install mosquitto
    1. Configure mosquitto, by modifying the file at /usr/local/etc/mosquitto/mosquitto.conf.

Usage

After having installed mosquittoChat, just run the following commands to use it:

  • Mosquitto Server

    1. For Mac Users

    # start normally
    $ mosquitto -c /usr/local/etc/mosquitto/mosquitto.conf
    
    # If you want to run in background
    $ mosquitto -c /usr/local/etc/mosquitto/mosquitto.conf -d
    
    # start using brew services (doesn't work with tmux, athough there is a fix, mentioned in one of the pull requests and issues)
    $ brew services start mosquitto

    2. For Ubuntu/LInux Users

    # start normally
    $ mosquitto -c /usr/local/etc/mosquitto/mosquitto.conf
    
    # If you want to run in background
    $ mosquitto -c /usr/local/etc/mosquitto/mosquitto.conf -d
    
    # To start using service
    $ sudo service mosquitto start
    
    # To stop using service
    $ sudo service mosquitto stop
    
    # To restart using service
    $ sudo service mosquitto restart
    
    # To check the status
    $ service mosquitto status
  • Start mosquittochat Applcation

    $ mosquittoChat [options]
    • Options

      –port:

      Port number where the chat server will start

    • Example

      $ mosquittoChat --port=9191
  • Stop mosquittoChat Server

    Click Ctrl+C to stop the server.

Todo

  1. Add Private Chat functionality.

  2. Manage Presence Management, sent, delivered acknowledgements.

  3. Message Persistence and delivery of messages to offline clinets.

  4. Add Blog post regarding this topic.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mosquittoChat-1.0.1.tar.gz (980.6 kB view details)

Uploaded Source

Built Distribution

mosquittoChat-1.0.1-py2-none-any.whl (41.4 kB view details)

Uploaded Python 2

File details

Details for the file mosquittoChat-1.0.1.tar.gz.

File metadata

File hashes

Hashes for mosquittoChat-1.0.1.tar.gz
Algorithm Hash digest
SHA256 0d7f51c6254254a02a56f8994e11931c6e2d3d5f155ef16128fcebd16be3dd0c
MD5 54e791f0190093076ca1fa82616a86b4
BLAKE2b-256 eeaca10c94fe67edc004a5d7b845c383d95cada1ce2b2c40a2ec3d67ddd83d1d

See more details on using hashes here.

File details

Details for the file mosquittoChat-1.0.1-py2-none-any.whl.

File metadata

File hashes

Hashes for mosquittoChat-1.0.1-py2-none-any.whl
Algorithm Hash digest
SHA256 7d42f4ac2afd06ca3c7c49ec47762754383db6e7e7a5874f5310de8df590c0c3
MD5 51dc5931d4a30db33e3cb712a672b308
BLAKE2b-256 b969e868abde26b279bc6e7890480a5d1d9b933b93265d1a9a264be152947b69

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page