2020-09-23 10:14:57 +00:00
Advanced Usage
2020-08-23 22:52:43 -04:00
==============
2020-08-25 17:11:05 -07:00
.. _save_tabs:
2020-09-23 10:14:57 +00:00
Save Tabs
2020-08-23 22:52:43 -04:00
---------
2020-11-10 20:41:50 -08:00
Everything in OnionShare is temporary by default. If you close an OnionShare tab, its address no longer exists and it can't be used again.
2020-09-23 10:14:57 +00:00
Sometimes you might want an OnionShare service to be persistent.
2020-11-10 20:41:50 -08:00
This is useful if you want to host a website available from the same OnionShare address even if you reboot your computer.
2020-08-26 13:34:03 -07:00
2020-09-23 10:14:57 +00:00
To make any tab persistent, check the "Save this tab, and automatically open it when I open OnionShare" box before starting the server.
When a tab is saved a purple pin icon appears to the left of its server status.
2020-08-26 13:34:03 -07:00
.. image :: _static/screenshots/advanced-save-tabs.png
2020-09-23 10:14:57 +00:00
When you quit OnionShare and then open it again, your saved tabs will start opened.
2021-08-28 10:34:51 +10:00
You'll have to manually start each service, but when you do they will start with the same OnionShare address and private key.
2020-08-26 13:34:03 -07:00
If you save a tab, a copy of that tab's onion service secret key will be stored on your computer with your OnionShare settings.
2021-08-28 10:34:51 +10:00
.. _turn_off_private_key:
2020-08-25 17:11:05 -07:00
2021-08-28 10:34:51 +10:00
Turn Off Private Key
--------------------
2020-08-23 22:52:43 -04:00
2021-09-09 19:04:04 -07:00
By default, all OnionShare services are protected with a private key, which Tor calls "client authentication".
2021-08-28 10:34:51 +10:00
When browsing to an OnionShare service in Tor Browser, Tor Browser will prompt for the private key to be entered.
2020-08-26 13:34:03 -07:00
2020-11-10 20:41:50 -08:00
Sometimes you might want your OnionShare service to be accessible to the public, like if you want to set up an OnionShare receive service so the public can securely and anonymously send you files.
2021-08-28 10:34:51 +10:00
In this case, it's better to disable the private key altogether.
2020-08-26 13:34:03 -07:00
2021-08-28 10:34:51 +10:00
To turn off the private key for any tab, check the "This is a public OnionShare service (disables private key)" box before starting the server. Then the server will be public and won't need a private key to view in Tor Browser.
2020-08-26 13:34:03 -07:00
2021-05-03 21:49:25 -07:00
.. _custom_titles:
Custom Titles
-------------
By default, when people load an OnionShare service in Tor Browser they see the default title for the type of service. For example, the default title of a chat service is "OnionShare Chat".
If you want to choose a custom title, set the "Custom title" setting before starting a server.
2020-09-23 10:14:57 +00:00
Scheduled Times
2020-08-23 22:52:43 -04:00
---------------
2020-09-23 10:14:57 +00:00
OnionShare supports scheduling exactly when a service should start and stop.
2020-11-10 20:41:50 -08:00
Before starting a server, click "Show advanced settings" in its tab and then check the boxes next to either "Start onion service at scheduled time", "Stop onion service at scheduled time", or both, and set the respective desired dates and times.
2020-08-26 13:34:03 -07:00
2020-09-23 10:14:57 +00:00
If you scheduled a service to start in the future, when you click the "Start sharing" button you will see a timer counting down until it starts.
If you scheduled it to stop in the future, after it's started you will see a timer counting down to when it will stop automatically.
2020-08-26 13:34:03 -07:00
2020-09-23 10:14:57 +00:00
**Scheduling an OnionShare service to automatically start can be used as a dead man's switch** , where your service will be made public at a given time in the future if anything happens to you.
If nothing happens to you, you can cancel the service before it's scheduled to start.
2020-08-26 13:34:03 -07:00
.. image :: _static/screenshots/advanced-schedule-start-timer.png
2021-09-09 19:15:25 -07:00
**Scheduling an OnionShare service to automatically stop can be useful to limit exposure** , like if you want to share secret documents while making sure they're not available on the internet for more than a few days.
2020-08-26 13:34:03 -07:00
.. image :: _static/screenshots/advanced-schedule-stop-timer.png
2021-09-09 18:21:56 -07:00
.. _cli:
2020-09-23 10:14:57 +00:00
Command-line Interface
2020-08-27 20:30:42 -04:00
----------------------
2020-09-23 10:14:57 +00:00
In addition to its graphical interface, OnionShare has a command-line interface.
2020-08-27 20:30:42 -04:00
2020-11-10 20:41:50 -08:00
You can install just the command-line version of OnionShare using `` pip3 `` ::
2020-08-27 20:30:42 -04:00
2020-11-10 20:41:50 -08:00
pip3 install --user onionshare-cli
2020-08-27 20:30:42 -04:00
2020-11-10 20:41:50 -08:00
Note that you will also need the `` tor `` package installed. In macOS, install it with: `` brew install tor ``
2020-08-27 20:30:42 -04:00
2020-11-10 20:41:50 -08:00
Then run it like this::
2020-08-27 20:30:42 -04:00
2020-11-10 20:41:50 -08:00
onionshare-cli --help
2020-08-27 20:30:42 -04:00
2021-09-09 19:50:11 -07:00
For information about installing it on different operating systems, see the `CLI readme file <https://github.com/onionshare/onionshare/blob/develop/cli/README.md> `_ in the git repository.
2021-09-09 18:21:56 -07:00
2020-11-10 20:41:50 -08:00
If you installed OnionShare using the Linux Snapcraft package, you can also just run `` onionshare.cli `` to access the command-line interface version.
2020-08-27 20:30:42 -04:00
Usage
^^^^^
2020-09-23 10:14:57 +00:00
You can browse the command-line documentation by running `` onionshare --help `` ::
2020-08-27 20:30:42 -04:00
2020-11-10 20:41:50 -08:00
$ onionshare-cli --help
2021-05-03 21:49:25 -07:00
╭───────────────────────────────────────────╮
│ * ▄▄█████▄▄ * │
│ ▄████▀▀▀████▄ * │
│ ▀▀█▀ ▀██▄ │
│ * ▄█▄ ▀██▄ │
│ ▄█████▄ ███ -+- │
│ ███ ▀█████▀ │
│ ▀██▄ ▀█▀ │
│ * ▀██▄ ▄█▄▄ * │
│ * ▀████▄▄▄████▀ │
│ ▀▀█████▀▀ │
│ -+- * │
│ ▄▀▄ ▄▀▀ █ │
│ █ █ ▀ ▀▄ █ │
│ █ █ █▀▄ █ ▄▀▄ █▀▄ ▀▄ █▀▄ ▄▀▄ █▄▀ ▄█▄ │
│ ▀▄▀ █ █ █ ▀▄▀ █ █ ▄▄▀ █ █ ▀▄█ █ ▀▄▄ │
│ │
2021-11-23 19:33:21 -08:00
│ v2.4.1 │
2021-05-03 21:49:25 -07:00
│ │
│ https://onionshare.org/ │
╰───────────────────────────────────────────╯
2021-09-09 19:04:04 -07:00
usage: onionshare-cli [-h] [--receive] [--website] [--chat] [--local-only] [--connect-timeout SECONDS] [--config FILENAME] [--persistent FILENAME] [--title TITLE] [--public]
2021-11-23 19:33:21 -08:00
[--auto-start-timer SECONDS] [--auto-stop-timer SECONDS] [--no-autostop-sharing] [--data-dir data_dir] [--webhook-url webhook_url] [--disable-text]
[--disable-files] [--disable_csp] [--custom_csp custom_csp] [-v]
2021-09-09 19:04:04 -07:00
[filename ...]
2020-08-27 20:30:42 -04:00
positional arguments:
2020-11-10 20:41:50 -08:00
filename List of files or folders to share
2021-09-09 19:04:04 -07:00
2020-08-27 20:30:42 -04:00
optional arguments:
2020-11-10 20:41:50 -08:00
-h, --help show this help message and exit
--receive Receive files
--website Publish website
--chat Start chat server
--local-only Don't use Tor (only for development)
--connect-timeout SECONDS
2021-09-09 19:04:04 -07:00
Give up connecting to Tor after a given amount of seconds (default: 120)
2020-11-10 20:41:50 -08:00
--config FILENAME Filename of custom global settings
--persistent FILENAME Filename of persistent session
2021-05-03 21:49:25 -07:00
--title TITLE Set a title
2021-08-28 10:34:51 +10:00
--public Don't use a private key
2020-11-10 20:41:50 -08:00
--auto-start-timer SECONDS
2021-09-09 19:04:04 -07:00
Start onion service at scheduled time (N seconds from now)
2020-11-10 20:41:50 -08:00
--auto-stop-timer SECONDS
2021-09-09 19:04:04 -07:00
Stop onion service at schedule time (N seconds from now)
--no-autostop-sharing Share files: Continue sharing after files have been sent (default is to stop sharing)
--data-dir data_dir Receive files: Save files received to this directory
2021-05-03 21:49:25 -07:00
--webhook-url webhook_url
2021-09-09 19:04:04 -07:00
Receive files: URL to receive webhook notifications
2021-05-03 21:49:25 -07:00
--disable-text Receive files: Disable receiving text messages
--disable-files Receive files: Disable receiving files
2021-11-23 19:33:21 -08:00
--disable_csp Publish website: Disable the default Content Security Policy header (allows your website to use third-party resources)
--custom_csp custom_csp Publish website: Set a custom Content Security Policy header
2021-09-09 19:04:04 -07:00
-v, --verbose Log OnionShare errors to stdout, and web errors to disk