This repository has been archived on 2021-07-08. You can view files and clone it, but cannot push or open issues or pull requests.
opensend/README.md

48 lines
2.3 KiB
Markdown
Raw Normal View History

2020-12-03 10:55:46 +00:00
# OpenSend
## Send files between systems quickly and securely
### Usage
#### Receiver
2020-12-03 10:58:38 +00:00
- Use `opensend -r` to start the receiver
2020-12-03 10:55:46 +00:00
#### Sender
2020-12-03 10:58:38 +00:00
- Use `opensend -s -t <type> -d <data>`
- `type` can either be `url` or `file`
2020-12-05 08:27:50 +00:00
- If `type` is `url`, `data` should be a URL
- If `type` is `file`, `data` should be a file path
- Example: `opensend -s -t url -d "https://google.com"`
2020-12-05 08:27:50 +00:00
- Example: `opensend -s -t file -d ~/file.txt`
2020-12-03 10:55:46 +00:00
### Building
2020-12-03 10:58:38 +00:00
- This project uses go modules, so building is easy
- First, go 1.14+ must be installed (use buster-backports on debian)
- Then, run `make` inside the project's directory.
2020-12-03 10:58:38 +00:00
- This will get the dependencies and compile all the files.
2020-12-03 10:55:46 +00:00
### Installing
To install, simply follow the building instructions and then run
- Linux: `sudo make install`
- macOS: `sudo make install-macos`
2020-12-03 10:55:46 +00:00
### Using on iOS
Opensend can run on iOS using the [iSH app](https://apps.apple.com/us/app/ish-shell/id1436902243).
- Install go using `apk add go`
- Clone this repository
- Run `make`
- Use opensend as normal, but skip device discovery
- Device discovery does not work properly in iSH due to Alpine Linux
- When running receiver, add `--skip-mdns`
- When running sender, add `--send-to <IP>`
- This applies bidirectionally
- Known issues
2020-12-05 08:24:23 +00:00
- Opensend takes a while to become ready on iOS
### Ports to whitelist
- TCP 9797 for key exchange
- TCP 9898 for file transfer
### How does it work?
OpenSend uses a combination of 2048-bit RSA and AES GCM encryption. This is accomplished using golang's crypto/rsa and crypto/aes libraries. First, a shared AES key is generated. Then, an RSA keypair is generated. The RSA public key is then exchanged using TCP and golang's encoding/gob library. The AES key is encrypted using the RSA public key
of the receiver. This key is then saved to a file. Next, the shared AES key is used to encrypt all the files in `~/.opensend`. To send the encrypted AES key, the sender first needs to discover the receiver. This is accomplished using zeroconf. After that, the sender starts an HTTP server with some custom functions to send the file index and key.
The receiver gets the index, files, and encrypted key from this server. Once it gets all the files, it sends a stop signal to the server and decrypts the shared key using its RSA private key. The resulting AES key is then used to decrypt all files in `~/.opensend`.