# TFTP Server Daemon Pure [Rust](https://www.rust-lang.org/) implementation of a Trivial File Transfer Protocol server daemon. This server implements [RFC 1350](https://www.rfc-editor.org/rfc/rfc1350), The TFTP Protocol (Revision 2). It also supports the following [RFC 2347](https://www.rfc-editor.org/rfc/rfc2347) TFTP Option Extensions: - [RFC 2348](https://www.rfc-editor.org/rfc/rfc2348) Blocksize Option - [RFC 2349](https://www.rfc-editor.org/rfc/rfc2349) Timeout Interval Option - [RFC 2349](https://www.rfc-editor.org/rfc/rfc2349) Transfer Size Option - [RFC 7440](https://www.rfc-editor.org/rfc/rfc7440) Windowsize Option ## Security Since TFTP servers do not offer any type of login or access control mechanisms, this server only allows transfer and receiving inside a chosen folder, and disallows external file access. ## Documentation Documentation for the project can be found in [docs.rs](https://docs.rs/tftpd/latest/tftpd/). ## Usage (Server) To install the server using Cargo: ```bash cargo install tftpd tftpd --help ``` To run the server on the IP address `0.0.0.0`, read-only, on port `1234` in the `/home/user/tftp` directory: ```bash tftpd -i 0.0.0.0 -p 1234 -d "/home/user/tftp" -r ``` ## Usage (Client) Client code is protected by a feature flag names `client`. To install the client and server using Cargo: ```bash cargo install --features client tftpd tftpc --help ``` To connect the client to a tftp server running on IP address `127.0.0.1`, read-only, on port `1234` and download a file named `example.file` ```bash tftpc example.file -i 0.0.0.0 -p 1234 -d ``` To connect the client to a tftp server running on IP address `127.0.0.1`, read-only, on port `1234` and upload a file named `example.file` ```bash tftpc example.file -i 0.0.0.0 -p 1234 -u ``` ## License This project is licensed under the [MIT License](https://opensource.org/license/mit/).