Hey! This is my BitTorrent client built during the Codecrafters challenge.
- β¨ Parse
.torrent
files and extract metadata - π€ Connect to peers using the BitTorrent protocol
- π‘ Communicate with trackers to discover peers
- π¦ Download pieces from multiple peers simultaneously
- β Verify downloaded pieces using SHA1 hashing
- π Basic download progress tracking
This client implements core BitTorrent protocol features including:
- Bencode Parser: Custom implementation for encoding/decoding bencode format
- Peer Wire Protocol: Handles peer communication and piece exchange
- Tracker Communication: Manages tracker requests and peer discovery
- Piece Management: Downloads and verifies file pieces
- TCP Connections: Handles concurrent peer connections
- π Multi-threaded downloading for improved performance
- π Real-time download progress visualization
- π Resume interrupted downloads
- π― Selective file downloading from multi-file torrents
- π Support for encrypted peer connections
- π± Web UI for remote management
- πΎ Configurable download queue management
- π‘οΈ Bandwidth throttling and scheduling
- π DHT (Distributed Hash Table) support for trackerless torrents
- The awesome folks at Codecrafters
- The BitTorrent Protocol Spec
- Kristen Widman's super helpful guide