Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/privapps/share

A pure static javascript running in a browser that can chat and share files between two devices within the same network. Under the neath, it uses a public Piping server to do the handshake (signal server), and WebRTC when chatting or file transfer.
https://github.com/privapps/share

chat communication compression-with-password end-to-end-encryption file-share file-sharing javascript messenger peer-to-peer piping-server privacy web-client-compression webapp webrtc zip

Last synced: about 2 months ago
JSON representation

A pure static javascript running in a browser that can chat and share files between two devices within the same network. Under the neath, it uses a public Piping server to do the handshake (signal server), and WebRTC when chatting or file transfer.

Awesome Lists containing this project

README

        

### What
A pure static javascript running in a browser that can chat and share files between **two** devices within the **same network**.

Under the neath, it uses a public [Piping server](https://github.com/nwtgck/piping-server) to do the handshake (signal server), and WebRTC when chatting or file transfer.

Or, you can also use plain Piping as backend for chat with end to end encryption. It also has a way to zip multiple files together using the password shared for chat.

### Why
A lot of time I need to transfer files between computers or phones. However, not all devices have BlueTooth, USB cables may not be available, nor always possible to run your local web server, e.g. `python3 -m HTTP.server 8080`. While using email or instant messages that go through some third-party servers is not ideal too.

### Demo
Live Site
* [WebRTC](https://privapps.github.io/share/)
* [Plain E2E encrypted Piping](https://privapps.github.io/share/chat.html)

![Demo](./demos.gif)

### Usage
1. Use the same piping server and secret. The default secret is your public IP address but can be anything.
2. With your two devices, one as an initiator and one as a responder. In many cases, you might switch it around to get it to work. see below.
3. After connecting, those two devices can chat with each other, or transfer files. All those communications are within a local network and have nothing to do with any server (WebRTC)

### Tips
- Make sure the piping server and shared secrets are the same
- May need to swap the initiator and the responder to get it to work. It is a mystery which device should be the initiator/responder; My experience is that is related to your devices, e.g. firewall/network card, etc. rather than your browsers. According to my tests, it works for most cases.
- You can open debug tab to see how the handshake is happening.
- Due to the nature of WebRTC, if devices are in a different network, e.g. under a different router, using a virtual machine, etc. devices' information can be exchanged (using public piping server), but the WebRTC connection may not be initialized.
- You can open the debug tab to see the initial handshake.

### Features
* chat
* file transfer

### Tested
* Chrome 73+
* Firefox 85+
* Safari 14
* Chromium 91

On Android, Windows 10, Mac and Linux. But actual result may vary due to the network configure.

### WebRTC Archetecture / Diagrams
![Diagram](./diagram.jpg)

### Credit
* [piping server](https://github.com/nwtgck/piping-server)
* [serverless-webrtc](https://github.com/svarunan/serverless-webrtc)
* [WebRTC IPs](https://github.com/diafygi/webrtc-ips)
* [picnic css](https://github.com/franciscop/picnic)

### Alternative
* [ShareDrop](https://github.com/szimek/sharedrop)
* [PeerJS File Transfer](https://privapps.github.io/p2pf/)

### Contribute
Raise PR if have improvements.

### In addition
In the event that WebRTC encounters issues, an alternative chat solution has been implemented using a piping server. This method is considerably more reliable, as WebRTC connectivity can sometimes be inconsistent. The addition of symmetric encryption ensures the privacy and security of the communication, which is particularly important since it operates over a public server.

https://privapps.github.io/share/chat.html