How develop realtime chat application in 2019? — part II

Burak Eray KAYIŞ
Jan 27, 2019 · 2 min read

In this part of the series, I will mention how manage realtime communication between a client to another clients. This is the most important thing in a realtime based application.

Events Logic is utterly event-based library. Communication Logic

Communication Basics

  • A client cannot emit anything to another client.
  • A client can only emit event to a server.
  • A client can listen events which emitted by a server.

Data Transfer Basics

  • You can pass data during emitting, on client and server side.
  • You can retrieve acknowledgement to be ensure to emitting is successful.


In my projects, I had nine events on server-side. I will mention two of these.

  • User Connection event
  • Message event

Connection Event

When a user enters the app, we need update user’s online status.

Then, client must inform server about this event. This event’s identifier is a constant string and defined client and server side: “CONNECTION_EVENT

Client also transfer own’s UserModel during emitting to server.

Server handles UserModel, and invoke setConnectionStatus() method to send request API to set user online and also set user’s unique socket id.

server’s user connection handling

Message Event

The another important event was messaging event, I think we can analyze this event’s handling client and server-side.

When a user sends a message to another user, client emits a MessageModel to server. You can see model below:

Server handles this emitting and pass event to only receiver user. Also, socket server decides a message’s date.

server’s messaging handling

On client side, receiver handles event like below. addMessageToList() method, adds message to chat screen.

Thank you for using your precious time to reading this article. If you liked it clap your 👏 to say “thanks!” and help others find this article.

Welcome to a place where words matter. On Medium, smart voices and original ideas take center stage - with no ads in sight. Watch
Follow all the topics you care about, and we’ll deliver the best stories for you to your homepage and inbox. Explore
Get unlimited access to the best stories on Medium — and support writers while you’re at it. Just $5/month. Upgrade

Get the Medium app

A button that says 'Download on the App Store', and if clicked it will lead you to the iOS App store
A button that says 'Get it on, Google Play', and if clicked it will lead you to the Google Play store