Easily and securely share files from the command line. A fully featured Firefox Send client.
Easily and securely share files and directories from the command line through a safe, private and encrypted link using a single simple command. Files are shared using the Send service and may be up to 2GB. Others are able to download these files with this tool, or through their web browser.
No demo visible here? View it on asciinema.
All files are always encrypted on the client, and secrets are never shared with the remote host. An optional password may be specified, and a default file lifetime of 1 (up to 20) download or 24 hours is enforced to ensure your stuff does not remain online forever. This provides a secure platform to share your files. Find out more about security here.
The public Send service that is used as default host is provided by
Mozilla.
This application is not affiliated with Mozilla, Firefox
or Firefox Send in any way.
Note: this tool is currently in the alpha phase
For a list of upcoming features and ideas, take a look at the ROADMAP file.
Easily upload and download:
```bash
$ ffsend upload my-file.txt Share link: https://send.firefox.com/#sample-share-url
$ ffsend upload --downloads 20 --password --archive --copy --open my-file.txt Password: ** Share link: https://send.firefox.com/#sample-share-url
$ ffsend u -h https://example.com/ my-file.txt Share link: https://example.com/#sample-share-url
$ ffsend download https://send.firefox.com/#sample-share-url ```
Inspect remote files:
```bash
$ ffsend exists https://send.firefox.com/#sample-share-url Exists: yes
$ ffsend info https://send.firefox.com/#sample-share-url ID: b087066715 Name: my-file.txt Size: 12 KiB MIME: text/plain Downloads: 0 of 10 Expiry: 18h2m (64928s) ```
Other commands include: ```bash
$ ffsend history
1 https://send.firefox.com/#sample-share-url 23h57m eea9f544f6d5df8a5afd 2 https://send.firefox.com/#other-sample-url 17h38m 1e9fef63fee3baaf54ce 3 https://example.com/#sample-share-url 37m30s 8eb28bc1bc85cfdab0e4
$ ffsend password https://send.firefox.com/#sample-share-url Password: **
$ ffsend delete https://send.firefox.com/#sample-share-url ```
Use the --help
flag, help
subcommand, or see the help section for
all available subcommands.
apt install openssl ca-certificates
xclip
for clipboard support (optional)apt install xclip
yum install xclip
pacman -S xclip
Because ffsend
is still in alpha, only limited installation options are
available right now.
It is recommended to build and install ffsend
yourself using these fairly
easy steps below.
ยป ffsend
on aur.archlinux.org
```bash yaourt -S ffsend
yay ffsend
```
A set of prebuilt binaries for Linux and macOS can be found as asset of the
latest release. When downloading such release, mark
the binary as executable using chmod a+x ffsend
, and move it into /usr/bin/
.
If running the binary fails (probably due to some linked library), please feel
free to open an issue.
To build and install ffsend
yourself, you meet the following requirements
before proceeding:
git
rust
v1.32
or higher (install using rustup
)apt install build-essential cmake pkg-config libssl-dev
yum install gcc gcc-c++ make cmake openssl-devel
pacman -S openssl base-devel
emerge -a dev-util/pkgconfig dev-util/cmake dev-libs/openssl
dnf install gcc gcc-c++ make cmake openssl-devel
brew
: brew install cmake pkg-config openssl
Then, walk through one of the following steps to compile and install ffsend
:
Compile and install it directly from cargo:
```bash
cargo install ffsend -f
ffsend --help ```
Or clone the repository and install it with cargo
:
```bash
git clone https://github.com/timvisee/ffsend.git cd ffsend
cargo install -f
ffsend --help
cargo run --release -- --help ```
Or clone the repository and invoke the binary directly (Linux/macOS):
```bash
git clone https://github.com/timvisee/ffsend.git cd ffsend
cargo build --release
./target/release/ffsend --help ```
Different use flags are available for ffsend
to toggle whether to include
various features.
The following features are available, some of which are enabled by default:
| Feature | Enabled | Description |
| :---------: | :-----: | :--------------------------------------------------------- |
| send2
| Default | Compile with support for Firefox Send v2 servers |
| send3
| Default | Compile with support for Firefox Send v3 servers |
| clipboard
| Default | Support for copying links to the clipboard |
| history
| Default | Support for tracking files in history |
| archive
| Default | Support for archiving and extracting uploads and downloads |
| no-color
| | Compile without color support in error and help messages |
To enable features during building or installation, specify them with
--features <features, >
when using cargo
.
You may want to disable alisl default features first using
--no-default-features
.
Here are some examples:
```bash
cargo install --features no-color cargo build --release --features no-color
cargo install --no-default-features
cargo install --no-default--features --features history,clipboard ```
The following environment variables may be used to configure the following defaults. The CLI flag is shown along with it, to better describe the relation to command line arguments:
| Variable | CLI flag | Description |
| :------------------------ | :----------------------------: | :-------------------------------- |
| FFSEND_HISTORY
| --history <FILE>
| History file path |
| FFSEND_HOST
| --host <URL>
| Upload host |
| FFSEND_TIMEOUT
| --timeout <SECONDS>
| Request timeout (0 to disable) |
| FFSEND_TRANSFER_TIMEOUT
| --transfer-timeout <SECONDS>
| Transfer timeout (0 to disable) |
| FFSEND_API
| --api <VERSION>
| Server API version, -
to lookup |
These environment variables may be used to toggle a flag, simply by making them available. The actual value of these variables is ignored, and variables may be empty.
| Variable | CLI flag | Description |
| :------------------- | :-------------: | :-------------------------------- |
| FFSEND_FORCE
| --force
| Force operations |
| FFSEND_NO_INTERACT
| --no-interact
| No interaction for prompts |
| FFSEND_YES
| --yes
| Assume yes for prompts |
| FFSEND_INCOGNITO
| --incognito
| Incognito mode, don't use history |
| FFSEND_OPEN
| --open
| Open share link of uploaded file |
| FFSEND_ARCHIVE
| --archive
| Archive files uploaded |
| FFSEND_EXTRACT
| --extract
| Extract files downloaded |
| FFSEND_COPY
| --copy
| Copy share link to clipboard |
| FFSEND_QUIET
| --quiet
| Log quiet information |
| FFSEND_VERBOSE
| --verbose
| Log verbose information |
At this time, no configuration or dotfile file support is available. This will be something added in a later release.
In short; the ffsend
tool and the Send service can be considered
secure, and may be used to share sensitive files. Note though that the
created share link for an upload will allow anyone to download the file.
Make sure you don't share this link with unauthorized people.
For more detailed information on encryption, please read the rest of the paragraphs in this security section.
Note: even though the encryption method is considered secure, this ffsend
tool does not provide any warranty in any way, shape or form for files that
somehow got decrypted without proper authorization.
ffsend
uses client side encryption, to ensure your files are securely
encrypted before they are uploaded to the remote host. This makes it impossible
for third parties to decrypt your file without having the secret (encryption
key). The file and it's metadata are encrypted using 128-bit AES-GCM
, and a
HMAC SHA-256
signing key is used for request authentication.
This is consistent with the encryption documentation provided by the
Send service, ffsend
is a tool for.
A detailed list on the encryption/decryption steps, and on what encryption is exactly used can be found here in the official service documentation.
The encryption secret, that is used to decrypt the file when downloading,
is included in the share URL behind the #
(hash). This secret is never sent
the remote server directly when using the share link in your browser.
It would be possible however for a webpage to load some malicious JavaScript
snippet that eventually steals the secret from the link once the page is loaded.
Although this scenario is extremely unlikely, there are some options to prevent
this from happening:
ffsend
tool, do not use the share link in your browser.--password
while
uploading, or using the password
subcommand afterwards.A complete overview on encryption can be found in the official service documentation here.
``` $ ffsend help
ffsend 0.2.7
Tim Visee
USAGE: ffsend [FLAGS] [OPTIONS] [SUBCOMMAND]
FLAGS: -f, --force Force the action, ignore warnings -h, --help Prints help information -i, --incognito Don't update local history for actions -I, --no-interact Not interactive, do not prompt -q, --quiet Produce output suitable for logging and automation -V, --version Prints version information -v, --verbose Enable verbose information and logging -y, --yes Assume yes for prompts
OPTIONS:
-H, --history
SUBCOMMANDS: upload Upload files [aliases: u, up] download Download files [aliases: d, down] debug View debug information [aliases: dbg] delete Delete a shared file [aliases: del] exists Check whether a remote file exists [aliases: e] help Prints this message or the help of the given subcommand(s) history View file history [aliases: h] info Fetch info about a shared file [aliases: i] parameters Change parameters of a shared file [aliases: params] password Change the password of a shared file [aliases: pass, p] version Determine the Send server version [aliases: v]
The public Send service that is used as default host is provided by Mozilla. This application is not affiliated with Mozilla, Firefox or Firefox Send. ```
This project is released under the GNU GPL-3.0 license. Check out the LICENSE file for more information.