From c07f4e5f8389d07a9b8fe7c44c2dbb0a5f24ebeb Mon Sep 17 00:00:00 2001 From: Micah Lee Date: Tue, 12 Apr 2016 15:59:49 -0700 Subject: [PATCH] If "Stop sharing automatically" is selected, only allow one download at a time (fixes #248) --- onionshare/web.py | 35 ++++++++++++++++++++++++++++++++--- resources/html/denied.html | 18 ++++++++++++++++++ resources/html/index.html | 2 +- setup.py | 3 ++- 4 files changed, 53 insertions(+), 5 deletions(-) create mode 100644 resources/html/denied.html diff --git a/onionshare/web.py b/onionshare/web.py index 72b74cd8..e1f8050d 100644 --- a/onionshare/web.py +++ b/onionshare/web.py @@ -144,6 +144,11 @@ def check_slug_candidate(slug_candidate, slug_compare = None): if not helpers.constant_time_compare(slug_compare.encode('ascii'), slug_candidate.encode('ascii')): abort(404) + +# If "Stop sharing automatically" is checked (stay_open == False), only allow +# one download at a time. +download_in_progress = False + @app.route("/") def index(slug_candidate): """ @@ -152,14 +157,22 @@ def index(slug_candidate): check_slug_candidate(slug_candidate) add_request(REQUEST_LOAD, request.path) + + # Deny new downloads if "Stop sharing automatically" is checked and there is + # currently a download + global stay_open, download_in_progress + deny_download = not stay_open and download_in_progress + if deny_download: + return render_template_string(open(helpers.get_resource_path('html/denied.html')).read()) + + # If download is allowed to continue, serve download page return render_template_string( open(helpers.get_resource_path('html/index.html')).read(), slug=slug, file_info=file_info, filename=os.path.basename(zip_filename), filesize=zip_filesize, - filesize_human=helpers.human_readable_filesize(zip_filesize) - ) + filesize_human=helpers.human_readable_filesize(zip_filesize)) # If the client closes the OnionShare window while a download is in progress, # it should immediately stop serving the file. The client_cancel global is @@ -173,6 +186,13 @@ def download(slug_candidate): """ check_slug_candidate(slug_candidate) + # Deny new downloads if "Stop sharing automatically" is checked and there is + # currently a download + global stay_open, download_in_progress + deny_download = not stay_open and download_in_progress + if deny_download: + return render_template_string(open(helpers.get_resource_path('html/denied.html')).read()) + global download_count # each download has a unique id @@ -195,6 +215,11 @@ def download(slug_candidate): global client_cancel client_cancel = False + # Starting a new download + global stay_open, download_in_progress + if not stay_open: + download_in_progress = True + chunk_size = 102400 # 100kb fp = open(zip_filename, 'rb') @@ -237,7 +262,11 @@ def download(slug_candidate): if helpers.get_platform() != 'Darwin': sys.stdout.write("\n") - # download is finished, close the server + # Download is finished + if not stay_open: + download_in_progress = False + + # Close the server, if necessary if not stay_open and not canceled: print(strings._("closing_automatically")) if shutdown_func is None: diff --git a/resources/html/denied.html b/resources/html/denied.html new file mode 100644 index 00000000..ef77642e --- /dev/null +++ b/resources/html/denied.html @@ -0,0 +1,18 @@ + + + + OnionShare + + + +

OnionShare download in progress

+ + diff --git a/resources/html/index.html b/resources/html/index.html index 252c628f..9b857a6a 100644 --- a/resources/html/index.html +++ b/resources/html/index.html @@ -1,6 +1,6 @@ - + OnionShare