# PrivyDrop - System Architecture Overview This document provides a high-level overview of the PrivyDrop project's overall architecture, helping developers understand how the various technical components work together. ## 1. Core Components The PrivyDrop system is primarily composed of the following core parts: 1. **Frontend**: A Single Page Application (SPA) built with Next.js. It's the interface users interact with, responsible for handling file selection, UI presentation, and initiating WebRTC connections. 2. **Backend**: A server built with Node.js and Express. It does not handle any file data. Its core responsibilities are: - **Signaling Service**: Implemented with Socket.IO, it relays signaling messages (like SDP and ICE Candidates) for the "handshake" process before a WebRTC connection is established. - **Room Management**: Handles the creation, joining, and status checking of rooms. - **API Service**: Provides auxiliary HTTP endpoints. 3. **Redis**: An in-memory database used by the backend to store temporary data, such as room information and lists of participants, utilizing its TTL feature for automatic cleanup of expired rooms. 4. **TURN/STUN Server (Optional)**: Used to assist WebRTC with NAT traversal, ensuring a higher success rate for P2P connections in complex network environments. STUN is used to discover public IP addresses, while TURN serves as a fallback relay server. (This feature is not enabled by default in the current setup). ## 2. Data Flow and Interaction Diagram The following diagram illustrates the main flow for users establishing a connection and transferring files: ```mermaid graph TD subgraph "User A's Browser" ClientA[Frontend UI] end subgraph "User B's Browser" ClientB[Frontend UI] end subgraph "Server Infrastructure" Nginx[Nginx Reverse Proxy] Backend[Backend API / Socket.IO] Redis[Redis Cache] TURN[TURN/STUN Server] end ClientA -- 1. Create/Join Room (HTTP/Socket) --> Nginx Nginx --> Backend Backend -- Read/Write Room Status --> Redis ClientB -- 2. Join Same Room (HTTP/Socket) --> Nginx Backend -- 3. Broadcast user join event --> ClientA Backend -- 3. Broadcast user join event --> ClientB ClientA -- 4. Send Signal (Offer/ICE) --> Backend Backend -- 5. Forward Signal --> ClientB ClientB -- 6. Send Signal (Answer/ICE) --> Backend Backend -- 7. Forward Signal --> ClientA ClientA <-.-> |8. STUN Check| TURN ClientB <-.-> |8. STUN Check| TURN ClientA <-..- |9. P2P Direct Data Transfer| ClientB ClientA <-.-> |9. TURN Relayed Data Transfer| TURN ClientB <-.-> |9. TURN Relayed Data Transfer| TURN ``` **Flow Description:** 1. **Room Creation/Joining**: User A (the sender) requests the backend to create a unique room ID via the frontend. The backend records this room in Redis. 2. **Sharing & Joining**: User A shares the room ID with User B via a link or QR code. User B uses this ID to request joining the room. 3. **Signaling Exchange**: - Once there are two or more users in a room, they begin exchanging WebRTC signaling messages through the backend's Socket.IO service. - This process includes exchanging network information (ICE candidates) and session descriptions (SDP offers/answers). The backend server acts merely as a "postman" for these messages, forwarding them without understanding their content. 4. **NAT Traversal**: The browsers use the network information obtained from the signals, along with STUN/TURN servers, to attempt and establish a direct P2P connection. 5. **P2P Connection Established**: Once the connection is successfully established, all file and text data are transferred directly between User A's and User B's browsers, without passing through any server. If a direct connection fails, data will be relayed through a TURN server. ## 3. Design Philosophy - **Privacy First**: Core file data is never uploaded to the server. The server only acts as an "introducer" or "matchmaker." - **Frontend-Backend Separation**: Responsibilities are clearly separated. The frontend handles all user interaction and the complex logic of WebRTC; the backend provides lightweight, efficient signaling and room management services. - **Horizontal Scalability**: The backend is stateless (with state managed in Redis), which theoretically allows it to be scaled horizontally by adding more Node.js instances to handle a large volume of concurrent signaling requests.