Secure Chat 0.1.1
Communication Application system secured with end-to-end encryption and distributed on server and database level.
Secure Chat

C/C++ CI Docker image CodeQL scan Doxygen Pages GitHub tags GitHub release GitHub issues GitHub license

Secure Chat is my attempt at creating a C program allowing you host decentralized system and chat securely with your friends. It implements HTTPS connection (✔️) and AES algorithm is used for message end-to-end (EE2E) encryption (❌). Messages are stored in SQLite3 database and can be read by the recipient only. Sending messages in optimized for maximum performance and resource usage.

[!IMPORTANT] This project was not completed successfully and awaits second iteration.

Table of Contents

Security Measures

The application uses the OpenSSL library for HTTPS connection, encryption, and decryption. The server acts as a buffer and router for clients. The following algorithms are used:

  • AES algorithm: Used to encrypt and decrypt messages between clients.

Getting Started

These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.

Prerequisites

For a Debian-based system, you can install the following packages:

sudo apt install git gcc make sqlite3 libz-dev xorg-dev libc6-dev libxi-dev libssl-dev libuv1-dev libx11-dev libxrandr-dev libsqlite3-dev netcat-openbsd libasound2-dev libwayland-dev build-essential mesa-common-dev libgl1-mesa-dev libglu1-mesa-dev libcurl4-openssl-dev libxkbcommon-x11-dev libxkbcommon-dev

This should also work with Ubuntu and Linux Mint.

Build

git clone https://github.com/milosz275/secure-chat
cd secure-chat
make

Run the server and client executables in separate terminals.

server/build/bin/server
client/build/bin/client

Releases

You can download server and client from the releases page.

Docker

You can also run the server using Docker.

docker pull mlsh/secure-chat
docker run -d -p 12345:12345 mlsh/secure-chat

Components

Server

Server is responsible for handling client connections, retrieving messages from the database and sending messages to the recipients. It also manages user registration and authentication according to the protocol. Multithreading is used to allow many concurrent requests and connections. Client connections are stored in a thread-safe hash map and only one logged instance of a client is allowed. Messages before handling are stored in thread-safe queue. Server facilitates CLI for system administration. Server logs all requests, client connections and errors.

Client

Client connects to the server, sends messages and receives messages from the server. GUI is implemented using Raylib library and dark-mode is added. Dynamic signal resolution is used to allow for the best performance and resource usage. States are used to manage the client's connection and message sending. Client logs all requests, server connections and errors.

Common

Common generates static library that is used by both server and client, i.e. communication protocol, encryption and decryption functions. It also defines the message structure, signal codes, data structures and functions that are shared between server and client.

Database

SQLite3 database is utilized at the moment. There is planned usage of distributed database system Cassandra or MongoDB in the further project iterations.

Database Schema

Navigate to database for detailed database schema documentation.

Current work

  • [x] Graphical user interface
  • [ ] Direct message E2EE encryption
  • [ ] Group chat support
  • [x] Broadcast message support
  • [ ] Database message save and synchronization
  • [ ] Message history loading
  • [ ] Server instances connection and synchronization
  • [x] User activity tracking and polling (kick afk, statistics)
  • [x] Server command line interface for system administration (!exit, !ban, !kick, !mute, !shutdown)
  • [x] Protocol signal codes ("User is typing...", "User has read the message", "User has joined the chat")
  • [x] Server logging (requests, client connections, errors)
  • [ ] IP banning and rate limiting
  • [ ] Server start arguments using argv[], argc and/or configuration file (port, database, log level)
  • [ ] Interpreter for server automation

License

This project is licensed under the MIT License - see the LICENSE file for details.

Authors

Contributing

Please refer to CONTRIBUTING.md. We appreciate your help!

Acknowledgments