Files
PrivyDrop/README.md
T
david_bai 2bd09835b1 docs(docker): elevate Docker one-click to top, add LE automation + SNI443, update flags and compose v2 commands
- DEPLOYMENT_docker.md/zh-CN: Add top Quick Start (private/public/full), Let’s Encrypt auto issue/renew (webroot, zero downtime), SNI 443 default for full+domain, common flags (--with-sni443, --turn-port-range, --le-email), replace docker-compose with docker compose.
- README.md/zh-CN: Promote Docker one-click section to top and link to docs.
- DEPLOYMENT.md/zh-CN: Add audience/scope notice; point to Docker docs for recommended path.
- ROADMAP.md/zh-CN: Record recently completed (Docker, LE, SNI, TURN).
2025-10-07 22:48:26 +08:00

5.5 KiB
Raw Blame History

PrivyDrop Logo

PrivyDrop - A Privacy-Focused, WebRTC-Based File Sharing Tool

简体中文

License: MIT

PrivyDrop(formerly SecureShare) is an open-source, peer-to-peer (P2P) file and text sharing tool built on WebRTC. It requires no server-side data relay; all data is transmitted directly between browsers, ensuring end-to-end encryption for maximum privacy and security.

We believe everyone should have control over their own data. PrivyDrop was created to fulfill this vision: a simple, fast, and private sharing solution.

Try it Live » | GitHub Repository »


PrivyDrop Interface GIF

Key Features

  • 🔒 End-to-End Encryption: Leverages P2P direct connections via WebRTC. All files and text are transferred directly between browsers without passing through any central server.
  • 📂 File & Folder Transfer: Supports transferring multiple files and entire folders.
  • ⏸️ Resume Transfer: Resume file transfer from the point of interruption. Simply set the save directory to enable this feature, ensuring your large files are delivered safely even with unstable networks. If interrupted, you currently need to refresh both the sender and receiver web pages to restart the transfer.
  • Real-time & Efficient: Displays real-time transfer progress and automatically calculates transfer speed.
  • 📝 Rich Text Clipboard: Supports editing and sending formatted text, not just files.
  • 🔗 Convenient Sharing: Easily share a room and establish a connection via a link or QR code.
  • 📱 Multi-Device Support: Responsive design supports both desktop and mobile browsers.
  • 🌐 Internationalization: Supports multiple languages, including English and Chinese.

🛠️ Tech Stack

  • Frontend: Next.js 14, React 18, TypeScript, Tailwind CSS, shadcn/ui
  • Backend: Node.js, Express.js, TypeScript
  • Real-time Communication: WebRTC, Socket.IO
  • Data Storage: Redis
  • Deployment: PM2, Nginx, Docker

Deploy in minutes with zero manual configuration. Supports private/public networks and auto HTTPS (Lets Encrypt).

# Private LAN (no domain/public IP)
bash ./deploy.sh --mode private

# Public IP without domain (with TURN)
bash ./deploy.sh --mode public --with-turn

# Public domain (HTTPS + Nginx + TURN + SNI 443, auto-issue/renew)
bash ./deploy.sh --mode full --domain your-domain.com --with-nginx --with-turn --le-email you@domain.com

See Docker Deployment Guide

🚀 Quick Start (Full-Stack Local Development)

Before you begin, ensure your development environment has Node.js (v18+), npm, and a running Redis instance installed.

  1. Clone the Project & install redis

    git clone https://github.com/david-bai00/PrivyDrop.git
    cd PrivyDrop
    sudo apt-get install -y redis-server
    
  2. Configure and Start the Backend Service

    cd backend
    npm install
    
    # Copy the development environment file, then modify .env.development as needed
    cp .env_development_example .env.development
    
    npm run dev # Starts by default at http://localhost:3001
    
  3. Configure and Start the Frontend App (in a new terminal window)

    cd frontend
    pnpm install
    
    # Copy the development environment file, then modify .env.development as needed, Remove optional items
    cp .env_development_example .env.development
    
    pnpm dev # Starts by default at http://localhost:3002
    
  4. Start Sharing Open http://localhost:3002 in your browser to access the application.

🗺️ Roadmap

We have a public roadmap that outlines our vision for the future and our current priorities. It's a great place to see what we're working on or to find areas where you can contribute.

➡️ Check out the Project Roadmap

📚 Documentation

We provide detailed documentation to help you dive deeper into the project's design and deployment details:

🤝 Contributing

We warmly welcome contributions of all forms! Whether it's reporting a bug, suggesting a feature, submitting code or adding a star, your help is invaluable to PrivyDrop's growth. Please read our Contribution Guidelines to start your journey.

We have a Code of Conduct that all contributors are expected to follow. Please be sure to review it before participating.

📄 License

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