Try and fix closing the request for a valid upload post-timer expiry, whilst still rejecting subsequent uploads

This commit is contained in:
Miguel Jacq 2018-11-13 14:42:26 +11:00
parent 875b538347
commit db8548c35b
No known key found for this signature in database
GPG Key ID: EEA4341C6D97A0B6

View File

@ -244,39 +244,38 @@ class ReceiveModeRequest(Request):
if self.path == '/upload': if self.path == '/upload':
self.upload_request = True self.upload_request = True
# Prevent new uploads if we've said so (timer expired)
if not self.web.receive_mode.can_upload:
self.upload_request = False
if self.upload_request: if self.upload_request:
# A dictionary that maps filenames to the bytes uploaded so far # A dictionary that maps filenames to the bytes uploaded so far
self.progress = {} self.progress = {}
# Create an upload_id, attach it to the request # Prevent new uploads if we've said so (timer expired)
self.upload_id = self.web.receive_mode.upload_count if self.web.receive_mode.can_upload:
self.web.receive_mode.upload_count += 1 # Create an upload_id, attach it to the request
self.upload_id = self.web.receive_mode.upload_count
# Figure out the content length self.web.receive_mode.upload_count += 1
try:
self.content_length = int(self.headers['Content-Length'])
except:
self.content_length = 0
print("{}: {}".format( # Figure out the content length
datetime.now().strftime("%b %d, %I:%M%p"), try:
strings._("receive_mode_upload_starting").format(self.web.common.human_readable_filesize(self.content_length)) self.content_length = int(self.headers['Content-Length'])
)) except:
self.content_length = 0
# Tell the GUI print("{}: {}".format(
self.web.add_request(self.web.REQUEST_STARTED, self.path, { datetime.now().strftime("%b %d, %I:%M%p"),
'id': self.upload_id, strings._("receive_mode_upload_starting").format(self.web.common.human_readable_filesize(self.content_length))
'content_length': self.content_length ))
})
self.web.receive_mode.uploads_in_progress.append(self.upload_id) # Tell the GUI
self.web.add_request(self.web.REQUEST_STARTED, self.path, {
'id': self.upload_id,
'content_length': self.content_length
})
self.previous_file = None self.web.receive_mode.uploads_in_progress.append(self.upload_id)
self.previous_file = None
def _get_file_stream(self, total_content_length, content_type, filename=None, content_length=None): def _get_file_stream(self, total_content_length, content_type, filename=None, content_length=None):
""" """
@ -296,13 +295,16 @@ class ReceiveModeRequest(Request):
Closing the request. Closing the request.
""" """
super(ReceiveModeRequest, self).close() super(ReceiveModeRequest, self).close()
if self.upload_request: try:
upload_id = self.upload_id
self.web.common.log('ReceiveModeWeb', 'We finished our upload')
# Inform the GUI that the upload has finished # Inform the GUI that the upload has finished
self.web.add_request(self.web.REQUEST_UPLOAD_FINISHED, self.path, { self.web.add_request(self.web.REQUEST_UPLOAD_FINISHED, self.path, {
'id': self.upload_id 'id': upload_id
}) })
self.web.receive_mode.uploads_in_progress.remove(self.upload_id) self.web.receive_mode.uploads_in_progress.remove(upload_id)
except AttributeError:
pass
def file_write_func(self, filename, length): def file_write_func(self, filename, length):
""" """