Encrypted Chat Application Design and Workflow
System Architecture
- Client
- Generates and manages RSA key pairs for encryption and decryption.
- Handles user authentication and session tokens.
- Encrypts messages using the recipient’s public key before sending them.
- Server
- Acts as a relay for encrypted messages.
- Stores and retrieves public/private keys and encrypted messages from the database.
- Facilitates secure key exchange between users.
- Database
- Stores encrypted private keys for retrieval, allowing multi-device access.
- Stores encrypted messages to ensure privacy.
- Uses encryption at rest and access control mechanisms.
data:image/s3,"s3://crabby-images/fcd23/fcd23831949c733cdf8385d967a88983d2063a1a" alt="System Architecture Diagram"
data:image/s3,"s3://crabby-images/fe43e/fe43e8f37a8df2b78db81c7532b3b2cab767a6e2" alt="System Architecture Design"
Workflows
User Registration
- The user generates an RSA key pair locally.
- The public key is sent to the server.
- The private key is encrypted with the master password and uploaded to the server for recovery.
data:image/s3,"s3://crabby-images/951b2/951b268a81ce2cda69fb45e9392b49ae0e7fd60f" alt="User Registration Workflow (placeholder)"
Sending a Message
- The sender requests the recipient’s public key from the server.
- The server retrieves the recipient's public key from MongoDB.
- The server returns the recipient's public key to the sender.
- The sender encrypts the message using the recipient’s public key.
- The encrypted message is sent to the server via a Socket connection.
- The server stores the encrypted message in MongoDB.
data:image/s3,"s3://crabby-images/5a0dd/5a0dd98985fd8e47d99dd754bbded402829cf583" alt="Sending a Message Workflow (placeholder)"
Receiving a Message
- The recipient requests the encrypted message from the server.
- The server fetches the encrypted message from MongoDB.
- The server sends the encrypted message to the recipient.
- The recipient decrypts the message locally using their private key.
data:image/s3,"s3://crabby-images/e8f09/e8f09233f7e837bdbe3ff111b526980b7d57be9d" alt="Receiving a Message Workflow (placeholder)"
Multi-Device Support
- The user logs in with their master password.
- The client forwards the payload to the server for verification.
- The server verifies the user’s login.
- The server retrieves the encrypted private key from MongoDB.
- The user decrypts their private key locally using the derived key.
data:image/s3,"s3://crabby-images/6dccb/6dccb5dd5bea93439785e4ca4b102c7688c65882" alt="Multi-Device Support Workflow (placeholder)"
Vulnerabilities & Security Considerations
Potential Vulnerabilities
- Replay Attacks without session expiration.
- Password Recovery risk if the master password is compromised.
Potential Improvements
- Perfect Forward Secrecy (PFS) via the Signal Protocol to protect past messages even if keys are compromised.
- Zero-Knowledge Proof Authentication to ensure passwords are never revealed to the server.
Conclusion
This project provides a secure and privacy-focused messaging solution with end-to-end encryption. Future improvements will focus on enhancing security, usability, adding a TOR relay for IP anonymity, and robust password recovery.