Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rohankalbag/cryptography-signal-protocol
Cryptography and Network Security - Spring Semester 2024 - Indian Institute of Technology Bombay
https://github.com/rohankalbag/cryptography-signal-protocol
cryptography end-to-end-encryption signal-protocol
Last synced: 3 months ago
JSON representation
Cryptography and Network Security - Spring Semester 2024 - Indian Institute of Technology Bombay
- Host: GitHub
- URL: https://github.com/rohankalbag/cryptography-signal-protocol
- Owner: rohankalbag
- Created: 2024-05-04T18:48:16.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-07-27T08:37:20.000Z (6 months ago)
- Last Synced: 2024-09-27T14:01:19.783Z (3 months ago)
- Topics: cryptography, end-to-end-encryption, signal-protocol
- Language: Python
- Homepage:
- Size: 438 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
README
# Pythonic Implementation of Secure End-End Encrypted Messaging using Signal Protocol
This project presents a native implementation of the Signal Protocol for secure end-to-end messaging, using the `cryptography` library in Python. The project includes the development of a secure messaging application with a simple client-side GUI created using `PySide6` and a web-socket based messaging system utilizing `socketio`. The server adheres to the Signal Protocol Specification, storing only credentials and public keys, receiving only ciphertext, and enabling multiple concurrent two-way communications. The client application allows users to select chat partners and locally persist chat messages, enabling local chat history. The cryptographic infrastructure developed can be found in `client/utils.py`
For the Signal Protocol implementation, the Extended Triple Diffie-Hellman (X3DH) key agreement protocol and the Double Ratchet Algorithm were employed. The X3DH protocol facilitates the establishment of a shared secret key between two parties using their respective public keys, ensuring forward secrecy and cryptographic deniability. The Double Ratchet Algorithm was implemented to provide secure and synchronized key exchanges for continued communication.
The server uses `tinyDB` to store client information and acts as a communication conduit between clients without retaining any messages. The client-side application features a user-friendly interface for authentication, logging in, selecting chat partners, and viewing chat history. This project demonstrates the practical application of secure messaging protocols and provides a robust foundation for further development in secure communication systems.
[Link to Video Demonstration of the Implementation](https://youtu.be/DEt4LJ9cVp0?si=kW0laSq2_8GrXgHo)
[Link to Documentation and Implementation Report](https://github.com/rohankalbag/cryptography-signal-protocol/blob/main/docs.pdf)### Dependencies
```python
pip install -r requirements.txt
```### Run Server
```python
python3 server/server.py
```### Run Chat Interface for Client
```python
python3 main.py
```