onionshare/docs/source/advanced.rst

165 lines
7.8 KiB
ReStructuredText
Raw Normal View History

2020-09-23 10:14:57 +00:00
Advanced Usage
==============
.. _save_tabs:
2020-09-23 10:14:57 +00:00
Save Tabs
---------
2022-07-05 18:38:54 +00:00
Closing OnionShare tabs you host destroys them, preventing reuse.
Persistently hosted websites are available on the same address even if the computer they are shared from is rebooted.
2022-07-05 18:38:54 +00:00
Make any tab persistent by checking the "Always open this tab when OnionShare is started" box before starting your server.
.. image:: _static/screenshots/advanced-save-tabs.png
When opening OnionShare, your saved tabs from the prior session will start opened.
Each service then can be started manually, and will be available on the same OnionShare address and be protected by the same private key.
2022-02-24 23:08:15 +01:00
If you save a tab, a copy of its onion service secret key is stored on your computer.
.. _turn_off_private_key:
Turn Off Private Key
--------------------
2021-09-09 19:04:04 -07:00
By default, all OnionShare services are protected with a private key, which Tor calls "client authentication".
2022-03-06 15:01:42 -08:00
The Tor Browser will ask you to enter your private key when you load an OnionShare service.
If you want allow the public to use your service, it's better to disable the private key altogether.
2022-02-13 12:28:16 +00: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.
2022-03-06 15:01:42 -08:00
Then the server will be public and a private key is not needed to load it in the Tor Browser.
2021-05-03 21:49:25 -07:00
.. _custom_titles:
Custom Titles
-------------
2022-03-06 15:01:42 -08:00
When people load OnionShare services in the Tor Browser they see the default title for each type of service.
For example, the default title for chat services is "OnionShare Chat".
2021-05-03 21:49:25 -07:00
If you edit the "Custom title" setting before starting a server you can change it.
2021-05-03 21:49:25 -07:00
2020-09-23 10:14:57 +00:00
Scheduled Times
---------------
2020-09-23 10:14:57 +00:00
OnionShare supports scheduling exactly when a service should start and stop.
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.
Services scheduled to start in the future display a countdown timer when when the "Start sharing" button is clicked.
Services scheduled to stop in the future display a countdown timer when started.
**Scheduling an OnionShare service to automatically start can be used as a dead man's switch**.
This means your service is made public at a given time in the future if you are not there to prevent it.
2020-09-23 10:14:57 +00:00
If nothing happens to you, you can cancel the service before it's scheduled to start.
.. image:: _static/screenshots/advanced-schedule-start-timer.png
**Scheduling an OnionShare service to automatically stop limits its exposure**.
If you want to share secret info or something that will be outdated, you can do so for selected limited time.
.. image:: _static/screenshots/advanced-schedule-stop-timer.png
.. _cli:
2020-09-23 10:14:57 +00:00
Command-line Interface
----------------------
2020-09-23 10:14:57 +00:00
In addition to its graphical interface, OnionShare has a command-line interface.
2020-11-10 20:41:50 -08:00
You can install just the command-line version of OnionShare using ``pip3``::
2020-11-10 20:41:50 -08:00
pip3 install --user onionshare-cli
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-11-10 20:41:50 -08:00
Then run it like this::
2020-11-10 20:41:50 -08:00
onionshare-cli --help
Info about installing it on different operating systems can be found in the `CLI README file <https://github.com/onionshare/onionshare/blob/develop/cli/README.md>`_ in the Git repository.
If you installed OnionShare using the Snap package, you can also just run ``onionshare.cli`` to access the command-line interface version.
Usage
^^^^^
Browse the command-line documentation by running ``onionshare --help``::
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 ...]
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
optional arguments:
-h, --help Show this help message and exit
2020-11-10 20:41:50 -08:00
--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
--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
Stop onion service at scheduled time (N seconds from now)
--no-autostop-sharing Share files: Continue sharing after files have been sent (the default is to stop sharing)
2021-09-09 19:04:04 -07:00
--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
Keyboard Shortcuts
------------------
The OnionShare desktop application contains some keyboard shortcuts, for convenience and accessibility::
Ctrl T - New Tab
Ctrl X - Closes current tab
And from the main mode chooser screen::
Ctrl S - Share mode
Ctrl R - Receive mode
Ctrl W - Website mode
Ctrl C - Chat mode
Ctrl H - Settings tab