Goated E2EE TOR file sharing program.
Find a file
2016-02-12 15:12:27 -08:00
git-hooks add push hook that runs test suite 2014-07-03 15:13:39 -07:00
images moving image files into /usr/share instead of /usr/lib (fixes #126) 2014-09-03 17:50:06 -07:00
install Porting onionshare from python2 to python3 (#261). This commit only ports the CLI version, not the GUI. Has not been tested in Fedora, Windows, or OSX. Removed hack to make unicode filenames work because hack does not work in python3. Replaced constant_time_compare function with a new one that works in python3. Tweaked hidden service checking code because urllib is different in python3. 2016-02-12 14:34:19 -08:00
locale Display version string automatically in CLI, and in the status bar in GUI (#251) 2016-02-12 11:00:35 -08:00
onionshare Porting onionshare from python2 to python3 (#261). This commit only ports the CLI version, not the GUI. Has not been tested in Fedora, Windows, or OSX. Removed hack to make unicode filenames work because hack does not work in python3. Replaced constant_time_compare function with a new one that works in python3. Tweaked hidden service checking code because urllib is different in python3. 2016-02-12 14:34:19 -08:00
onionshare_gui Porting onionshare GUI from python2 to python3, and also from PyQt4 to PyQt5 (#261). This commit ports onionshare_gui. 2016-02-12 15:12:27 -08:00
screenshots Added AppData file, and made new screenshots for it (fixes #160) 2015-11-20 15:17:25 -08:00
test Updated copyright year to 2015 2015-09-07 21:48:49 -07:00
.gitignore ignoring source files that get generated in some dev environments 2015-05-14 14:40:19 -07:00
.travis.yml including pysocks with onionshare, and updated code to use pysocks instead of socksipy (#118) 2014-09-02 17:21:19 -07:00
BUILD.md Porting onionshare from python2 to python3 (#261). This commit only ports the CLI version, not the GUI. Has not been tested in Fedora, Windows, or OSX. Removed hack to make unicode filenames work because hack does not work in python3. Replaced constant_time_compare function with a new one that works in python3. Tweaked hidden service checking code because urllib is different in python3. 2016-02-12 14:34:19 -08:00
CHANGELOG.md Version bump to 0.8.1, updated changelog 2015-12-07 16:34:50 -08:00
LICENSE Updated copyright year to 2015 2015-09-07 21:48:49 -07:00
MANIFEST.in Added AppData file, and made new screenshots for it (fixes #160) 2015-11-20 15:17:25 -08:00
README.md Removed references to Tails, since it is not yet supported until #220 is resolved 2016-02-12 09:32:11 -08:00
SECURITY.md Fix typo in SECURITY.md. 2015-08-01 15:02:52 +02:00
setup.cfg Refactored onionshare 2014-05-23 12:37:10 -03:00
setup.py Porting onionshare GUI from python2 to python3, and also from PyQt4 to PyQt5 (#261). This commit ports onionshare_gui. 2016-02-12 15:12:27 -08:00
stdeb.cfg Porting onionshare from python2 to python3 (#261). This commit only ports the CLI version, not the GUI. Has not been tested in Fedora, Windows, or OSX. Removed hack to make unicode filenames work because hack does not work in python3. Replaced constant_time_compare function with a new one that works in python3. Tweaked hidden service checking code because urllib is different in python3. 2016-02-12 14:34:19 -08:00
version Version bump to 0.8.1, updated changelog 2015-12-07 16:34:50 -08:00

OnionShare

Build Status

OnionShare lets you securely and anonymously share files of any size. It works by starting a web server, making it accessible as a Tor hidden service, and generating an unguessable URL to access and download the files. It doesn't require setting up a server on the internet somewhere or using a third party filesharing service. You host the file on your own computer and use a Tor hidden service to make it temporarily accessible over the internet. The other user just needs to use Tor Browser to download the file from you.

Features include:

  • A user-friendly drag-and-drop graphical user interface that works in Windows, Mac OS X, and Linux
  • Ability to share multiple files and folders at once
  • Support for multiple people downloading files at once
  • Automatically copies the unguessable URL to your clipboard
  • Shows you the progress of file transfers
  • When file is done transferring, automatically closes OnionShare to reduce the attack surface
  • Localized into several languages, and supports international unicode filenames
  • Designed to work in Tails, for high risk users

If you're interested in exactly what OnionShare does and does not protect against, read the Security Design Document.

Client Screenshot Server Screenshot

Quick Start

You can download OnionShare to install on your computer from https://onionshare.org/.

You can set up your development environment to build OnionShare yourself by following these instructions.

How to Use

Before you can share files, you need to open Tor Browser in the background. This will provide the Tor service that OnionShare uses to start the hidden service.

Open OnionShare and drag and drop files and folders you wish to share, and start the server. It will show you a long, random-looking URL such as http://cfxipsrhcujgebmu.onion/7aoo4nnzj3qurkafvzn7kket7u and copy it to your clipboard. This is the secret URL that can be used to download the file you're sharing. If you'd like multiple people to be able to download this file, uncheck the "close automatically" checkbox.

Send this URL to the person you're trying to send the files to. If the files you're sending aren't secret, you can use normal means of sending the URL: emailing it, posting it to Facebook or Twitter, etc. If you're trying to send secret files then it's important to send this URL securely. I recommend you use Off-the-Record encrypted chat to send the URL.

The person who is receiving the files doesn't need OnionShare. All they need is to open the URL you send them in Tor Browser to be able to download the file.

Using Command Line in Mac OS X

If you'd like to use the command-line version of OnionShare in Mac OS X, after installing open a terminal and type:

ln -s /Applications/OnionShare.app/Contents/Resources/onionshare /usr/local/bin/onionshare

From that point on you can just call onionshare, like: onionshare --help