Rusty-Torrent/readme.md

115 lines
3.5 KiB
Markdown

# Rusty_Torrent BitTorrent Client
![GitHub](https://img.shields.io/github/license/ArloFilley/rusty_torrent)
![GitHub last commit](https://img.shields.io/github/last-commit/ArloFilley/rusty_torrent)
![GitHub stars](https://img.shields.io/github/stars/ArloFilley/rusty_torrent?style=social)
A BitTorrent client implemented in Rust that allows you to interact with the BitTorrent protocol and download torrents.
## Table of Contents
- [Introduction](#introduction)
- [Features](#features)
- [Getting Started](#getting-started)
- [Prerequisites](#prerequisites)
- [Installation](#installation)
- [Usage](#usage)
- [How It Works](#how-it-works)
- [Contributing](#contributing)
- [License](#license)
## Introduction
This BitTorrent client is designed to provide a simple and functional implementation of the BitTorrent protocol. It supports downloading torrents and interacting with peers to exchange pieces of files.
## Features
- Handshake and communication with peers using the BitTorrent protocol.
- Support for downloading torrents in both single-file and multi-file mode.
- Ability to request and download individual pieces from peers.
- Piece verification using SHA-1 hashes to ensure data integrity.
- Logging using the `log` crate for better debugging and tracing.
## Getting Started
### Prerequisites
- Rust programming language: [Install Rust](https://www.rust-lang.org/tools/install)
- Cargo: The Rust package manager, usually installed with Rust.
### Installation
1. Clone the repository:
```bash
git clone https://github.com/ArloFilley/rusty_torrent.git
```
2. Navigate to the project directory:
```bash
cd rusty_torrent
```
3. Build the project
```bash
cargo build --release
```
### Usage
To use the BitTorrent client, follow these steps:
1. Run the compiled binary:
```bash
cargo run --release
```
2. Provide the path to a .torrent file:
```bash
cargo run --release /path/to/your.torrent
```
3. Provide the path to download
```bash
cargo run --release /path/to/your.torrent /path/to/downloads
```
4. Clap help message
```
A BitTorrent client implemented in Rust that allows you to interact with the BitTorrent protocol and download torrents.
Usage: rusty_torrent [OPTIONS] --torrent-file-path <TORRENT_FILE_PATH> --download-path <DOWNLOAD_PATH>
Options:
-l, --log-file-path <LOG_FILE_PATH>
-t, --torrent-file-path <TORRENT_FILE_PATH>
-d, --download-path <DOWNLOAD_PATH>
-h, --help Print help
-V, --version Print version
```
The client will start downloading the torrent files and interacting with peers.
## How It Works
This BitTorrent client uses Rust's asynchronous programming features to manage connections with peers and perform file downloads. It employs the BitTorrent protocol's handshake and communication mechanisms to exchange pieces of data with other peers in the network. The client also verifies downloaded pieces using SHA-1 hashes provided by the torrent file.
## Contributing
Contributions are welcome! If you find any bugs or want to add new features, please feel free to open issues and pull requests on the GitHub repository.
## References
These resources were used to build this project
- [Bittorrent Community Wiki](https://wiki.theory.org/BitTorrentSpecification)
- [Bittorrent Udp Tracker Protocol](https://www.rasterbar.com/products/libtorrent/udp_tracker_protocol.html)
- [Bittorrent Specification](https://www.bittorrent.org/beps/bep_0003.html)
## License
This project is licensed under the MIT License.