rabbitChat¶
A Chat-Server/Chat-System based on AMQP protocol(RabbitMQ Message Broker)
Home Page : https://pypi.python.org/pypi/rabbitChat
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¶
rabbitChat is a very 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 AMQP protocol to implement the real time message passing system. AMQP is implemented in many languages and in many softwares, once of such is RabbitMQ , which is a message broker implementing the AMQP 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 rabbitMQ via AMQP protocol using the AMQP Python Client Library, Pika.
Thus the connection is web-browser to tornado to rabbitMQ 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 |
| AMQP: | Advance Message Queuing Protocol used in Message Oriented Middleware |
| pika: | AMQP Python Client Library |
| RabbitMQ: | A Message Broker implementing AMQP |
Features¶
- Public chat
- Shows who joined and who left
- Shows number of people online
- Shows who is typing and who is not
- Join/Leave chat room features
Installation¶
Prerequisites¶
- python 2.7+
- tornado
- sockjs-tornado
- sockjs-client
- pika
- rabbitMQ
Install¶
$ pip install rabbitChat
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.
- Method 1 - https://pip.pypa.io/en/stable/installing/
- Method 2 - http://ask.xmodulo.com/install-pip-linux.html
- Method 3 - If you installed python on MAC OS X via
brew install python, then pip is already installed along with python.Step 2 - Install tornado
$ pip install tornadoStep 3 - Install sockjs-tornado
$ pip install sockjs-tornadoStep 4 - Install pika
$ pip install pikaStep 5 - Install RabbitMQ
For
MacUsers1. Brew Install RabbitMQ
$ brew install rabbitmqFor
Ubuntu/LinuxUsers1. Enable RabbitMQ application repository
$ echo "deb http://www.rabbitmq.com/debian/ testing main" >> /etc/apt/sources.list2. Add the verification key for the package
$ wget -o http://www.rabbitmq.com/rabbitmq-signing-key-public.asc | sudo apt-key add -3. Update the sources with our new addition from above
$ apt-get update4. And finally, download and install RabbitMQ
$ sudo apt-get install rabbitmq-server
Usage¶
After having installed rabbitChat, just the run the following commands to use it:
RabbitMQ Server
1. For
MacUsers# start normally $ rabbitmq-server # If you want to run in background $ rabbitmq-server --detached # start using brew rervices (doesn't work with tmux) $ brew services rabbitmq start
2. For
Ubuntu/LInuxUsers# start normally $ rabbitmq-server # If you want to run in background $ rabbitmq-server --detached # To start using service $ service rabbitmq-server start # To stop using service $ service rabbitmq-server stop # To restart using service $ service rabbitmq-server restart # To check the status $ service rabbitmq-server status
Start rabbitChat Server
$ rabbitChat [options]
Options
–port: Port number where the chat server will start Example
$ rabbitChat --port=9191
Stop rabbitChat Server
Click
Ctrl+Cto stop the server.
Todo¶
- Add Private Chat functionality.
- Manage Presence Management, sent, delivered acknowledgements.
- Message Persistence and delivery of messages to offline clinets.
- Add Blog post regarding this topic.