23 releases (breaking)

0.21.0 Dec 17, 2024
0.19.0 Nov 5, 2024
0.12.0 Jul 22, 2024
0.2.2 Dec 21, 2023

#107 in Network programming

Download history 195/week @ 2024-09-02 16/week @ 2024-09-09 244/week @ 2024-09-16 28/week @ 2024-09-23 260/week @ 2024-09-30 14/week @ 2024-10-07 14/week @ 2024-10-14 195/week @ 2024-10-21 14/week @ 2024-10-28 163/week @ 2024-11-04 12/week @ 2024-11-11 15/week @ 2024-11-18 183/week @ 2024-12-02 27/week @ 2024-12-09 174/week @ 2024-12-16

386 downloads per month

Apache-2.0 OR MIT

47KB
730 lines

Sendme

This is an example to use iroh-bytes and iroh-net to send files and directories over the internet.

It is also useful as a standalone tool for quick copy jobs.

Iroh-net will take case of hole punching and NAT traversal whenever possible, and fall back to a relay if hole punching does not succeed.

Iroh-bytes will take care of blake3 verified streaming, including resuming interrupted downloads.

Sendme works with 256 bit node ids and therefore location transparent. A ticket will remain valid if the IP address changes. Connections are encrypted using TLS.

Installation

cargo install sendme

Usage

Send side

sendme send <file or directory>

This will create a temporary iroh node that serves the content in the given file or directory. It will output a ticket that can be used to get the data.

The provider will run until it is terminated using Control-C. On termination it will delete the temporary directory.

This currently will create a temporary directory in the current directory. In the future this won't be needed anymore.

Receive side

sendme receive <ticket>

This will download the data and create a file or directory named like the source in the current directory.

It will create a temporary directory in the current directory, download the data (single file or directory), and only then move these files to the target directory.

On completion it will delete the temp directory.

All temp directories start with .sendme-.

Dependencies

~53–87MB
~1.5M SLoC