Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/victorgoubet/livechat

Simple live chat using soket.io, react and google authenticator
https://github.com/victorgoubet/livechat

chat google-authenticator livechat nodejs react socket-io webchat

Last synced: 15 days ago
JSON representation

Simple live chat using soket.io, react and google authenticator

Awesome Lists containing this project

README

        

[![Forks][forks-shield]][forks-url]
[![Stargazers][stars-shield]][stars-url]






Logo

Live Chat


Who wants to use facebook anymore..


Visit ยป




Report Bug
โ€ข
Request Feature


## About The Project

What could be easier than a web chat? We use it every day to exchange messages, photos, news or even confidential information. But do we really trust them? Do we really know what's behind it, where our data goes, how it transits and could we easily reimplement this everyday technology?

That's the goal of this project, let's do it!

[![Product Name Screen Shot][product-screenshot]](screenshot.PNG)

๐Ÿ”

## Implementation


### About API


The architecture of a web chat is pretty simple. First you will have the backend server. You will find two types of handled requests. First, the classic rest api requests. These one will be used for login, registeration, getting the number of users and so on. The second type is socket.io events. You can see it as a biderectionnal tunnel. Indeed, in the classic pattern you would have a client calling a server and getting a response. Here, the client can send but also receive a response. It's really like a human conversation, each entity speaking but also listening to the other. This type of protocol is perfect then for a web chat!

For the front part, nothing crazy: just a react app with routers for the differents pages.


### About authentication


The new trends is about MFA, and one of the used tier is google authenticator. I thought that it could be fun to take part of this technology to avoid to remember all the time its password but just to have to give its username and the time-generated token from google authenticator.

You can see here the workflow of google authenticator extracted from this nice [twit](https://twitter.com/alexxubyte/status/1549781763999744000).



Google Authenticator archi


### And for the storage ?


Users and messages are store in mongo DB. A nice improvment would be to integrate E2E encryption which is discussed for example in [this](https://www.youtube.com/watch?v=jkV1KEJGKRA&ab_channel=Computerphile) great video from computerphile.


### Conclusion


Web chat are simple! Even a baby (or chatgpt) could create a live chat nowadays. The challenge is not about the architecture and the technologies used in these applications but about the governance and the security of the data. The question is not, "is this app working?" but "is this app secured". We saw that E2E protocols can help to provide a good level of encryption, but keep in mind that even if the system can't tell what do you speak about, he knows that you, the user 07900978 sent 11 messages to the user 0909809 at 9pm. The usage metrics are often the time more precious than the last story of when you were drunk.

๐Ÿ”

## Getting Started

You can directly go on the [webapp](https://live-chat-goubs.fly.dev/), but if you want, you can execute locally the project.

### Prerequisites

You will just need a recent version of node.

```sh
> node -v
> v18.12.1
```

### Installation

You can follow the different steps inorder to get the app working on your computer

1. Clone the repo

```sh
git clone https://github.com/VictorGoubet/LiveChat.git
```

2. Install packages. (It will install required packages from front and back)

```sh
npm run build
```

3. Launch the server

```sh
npm start
```

4. Go to **localhost:5000** in a browser

5. Try it yourself!

๐Ÿ”

-----

[![LinkedIn][linkedin-shield]][linkedin-url]

Victor Goubet - [email protected]

[forks-shield]: https://img.shields.io/github/forks/VictorGoubet/LiveChat.svg?style=for-the-badge
[forks-url]: https://github.com/VictorGoubet/LiveChat/network/members
[stars-shield]: https://img.shields.io/github/stars/VictorGoubet/LiveChat.svg?style=for-the-badge
[stars-url]: https://img.shields.io/github/issues/VictorGoubet/LiveChat/stargazers
[issues-shield]: https://img.shields.io/github/issues/VictorGoubet/LiveChat.svg?style=for-the-badge
[issues-url]: https://github.com/VictorGoubet/LiveChat/issues
[linkedin-shield]: https://img.shields.io/badge/-LinkedIn-black.svg?style=for-the-badge&logo=linkedin&colorB=555
[linkedin-url]: https://www.linkedin.com/in/victorgoubet/
[product-screenshot]: screenshot.png