2017-04-17 23:28:51 -03:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
"""
|
|
|
|
OnionShare | https://onionshare.org/
|
|
|
|
|
2022-01-16 21:15:49 -03:00
|
|
|
Copyright (C) 2014-2022 Micah Lee, et al. <micah@micahflee.com>
|
2017-04-17 23:28:51 -03:00
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
"""
|
|
|
|
|
2021-04-29 20:13:05 -04:00
|
|
|
import os
|
2019-10-13 01:01:25 -03:00
|
|
|
from .common import AutoStopTimer
|
|
|
|
|
2017-04-17 23:28:51 -03:00
|
|
|
|
|
|
|
class OnionShare(object):
|
|
|
|
"""
|
|
|
|
OnionShare is the main application class. Pass in options and run
|
|
|
|
start_onion_service and it will do the magic.
|
|
|
|
"""
|
2019-10-13 01:01:25 -03:00
|
|
|
|
2019-03-25 01:05:54 -03:00
|
|
|
def __init__(self, common, onion, local_only=False, autostop_timer=0):
|
2018-03-08 15:18:31 -03:00
|
|
|
self.common = common
|
|
|
|
|
2019-10-13 01:01:25 -03:00
|
|
|
self.common.log("OnionShare", "__init__")
|
2017-05-16 14:23:18 -04:00
|
|
|
|
2017-04-17 23:28:51 -03:00
|
|
|
# The Onion object
|
|
|
|
self.onion = onion
|
|
|
|
|
|
|
|
self.hidserv_dir = None
|
|
|
|
self.onion_host = None
|
2018-04-28 19:00:23 -03:00
|
|
|
self.port = None
|
2017-04-17 23:28:51 -03:00
|
|
|
|
|
|
|
# do not use tor -- for development
|
|
|
|
self.local_only = local_only
|
|
|
|
|
2017-11-08 06:25:59 -03:00
|
|
|
# optionally shut down after N hours
|
2019-03-25 01:05:54 -03:00
|
|
|
self.autostop_timer = autostop_timer
|
|
|
|
# init auto-stop timer thread
|
|
|
|
self.autostop_timer_thread = None
|
2017-11-08 06:25:59 -03:00
|
|
|
|
2018-04-28 19:00:23 -03:00
|
|
|
def choose_port(self):
|
|
|
|
"""
|
|
|
|
Choose a random port.
|
|
|
|
"""
|
|
|
|
try:
|
|
|
|
self.port = self.common.get_available_port(17600, 17650)
|
2021-04-29 20:13:05 -04:00
|
|
|
except Exception:
|
2020-10-13 02:40:55 -03:00
|
|
|
raise OSError("Cannot find an available OnionShare port")
|
2017-04-17 23:28:51 -03:00
|
|
|
|
2020-11-27 16:22:29 -03:00
|
|
|
def start_onion_service(self, mode, mode_settings, await_publication=True):
|
2017-04-17 23:28:51 -03:00
|
|
|
"""
|
|
|
|
Start the onionshare onion service.
|
|
|
|
"""
|
2019-10-13 01:01:25 -03:00
|
|
|
self.common.log("OnionShare", "start_onion_service")
|
2017-05-16 14:23:18 -04:00
|
|
|
|
2018-04-28 19:00:23 -03:00
|
|
|
if not self.port:
|
|
|
|
self.choose_port()
|
2017-04-17 23:28:51 -03:00
|
|
|
|
2019-03-25 01:05:54 -03:00
|
|
|
if self.autostop_timer > 0:
|
|
|
|
self.autostop_timer_thread = AutoStopTimer(self.common, self.autostop_timer)
|
2018-05-04 20:43:30 -03:00
|
|
|
|
2017-04-17 23:28:51 -03:00
|
|
|
if self.local_only:
|
2019-10-20 14:15:16 -03:00
|
|
|
self.onion_host = f"127.0.0.1:{self.port}"
|
2021-08-27 01:52:29 -04:00
|
|
|
if not mode_settings.get("general", "public"):
|
2021-12-02 01:34:54 -03:00
|
|
|
self.auth_string = (
|
|
|
|
"E2GOT5LTUTP3OAMRCRXO4GSH6VKJEUOXZQUC336SRKAHTTT5OVSA"
|
|
|
|
)
|
2017-04-17 23:28:51 -03:00
|
|
|
return
|
|
|
|
|
2019-10-13 01:01:25 -03:00
|
|
|
self.onion_host = self.onion.start_onion_service(
|
2020-11-27 16:22:29 -03:00
|
|
|
mode, mode_settings, self.port, await_publication
|
2019-10-13 01:01:25 -03:00
|
|
|
)
|
2017-04-17 23:28:51 -03:00
|
|
|
|
2021-08-27 01:52:29 -04:00
|
|
|
if not mode_settings.get("general", "public"):
|
2017-04-17 23:28:51 -03:00
|
|
|
self.auth_string = self.onion.auth_string
|
|
|
|
|
2019-11-10 22:32:34 -03:00
|
|
|
def stop_onion_service(self, mode_settings):
|
|
|
|
"""
|
|
|
|
Stop the onion service
|
|
|
|
"""
|
|
|
|
self.onion.stop_onion_service(mode_settings)
|