v2/blob: _upload_chunk parse range header

This commit is contained in:
Jimmy Zelinskie 2016-08-09 16:02:49 -04:00
parent 9f743fd6cd
commit c77a7bc0b9

View file

@ -140,7 +140,7 @@ def start_blob_upload(namespace_name, repo_name):
# Upload the chunk to storage while calculating some metadata and updating # Upload the chunk to storage while calculating some metadata and updating
# the upload state. # the upload state.
updated_blob_upload = _upload_chunk(blob_upload, *_start_offset_and_length(request.headers)) updated_blob_upload = _upload_chunk(blob_upload, request.headers.get('range'))
if updated_blob_upload is None: if updated_blob_upload is None:
_abort_range_not_satisfiable(updated_blob_upload.byte_count, new_upload_uuid) _abort_range_not_satisfiable(updated_blob_upload.byte_count, new_upload_uuid)
@ -193,7 +193,7 @@ def upload_chunk(namespace_name, repo_name, upload_uuid):
# Upload the chunk to storage while calculating some metadata and updating # Upload the chunk to storage while calculating some metadata and updating
# the upload state. # the upload state.
updated_blob_upload = _upload_chunk(blob_upload, *_start_offset_and_length(request.headers)) updated_blob_upload = _upload_chunk(blob_upload, request.headers.get('range'))
if updated_blob_upload is None: if updated_blob_upload is None:
_abort_range_not_satisfiable(updated_blob_upload.byte_count, upload_uuid) _abort_range_not_satisfiable(updated_blob_upload.byte_count, upload_uuid)
@ -229,7 +229,7 @@ def monolithic_upload_or_last_chunk(namespace_name, repo_name, upload_uuid):
# Upload the chunk to storage while calculating some metadata and updating # Upload the chunk to storage while calculating some metadata and updating
# the upload state. # the upload state.
updated_blob_upload = _upload_chunk(blob_upload, *_start_offset_and_length(request.headers)) updated_blob_upload = _upload_chunk(blob_upload, request.headers.get('range'))
if updated_blob_upload is None: if updated_blob_upload is None:
_abort_range_not_satisfiable(updated_blob_upload.byte_count, upload_uuid) _abort_range_not_satisfiable(updated_blob_upload.byte_count, upload_uuid)
@ -318,14 +318,13 @@ def _parse_range_header(range_header_text):
return (start, length) return (start, length)
def _start_offset_and_length(headers): def _start_offset_and_length(range_header):
""" """
Returns a tuple of the start offset and the length. Returns a tuple of the start offset and the length.
If the range header doesn't exist, defaults to (0, -1). If the range header doesn't exist, defaults to (0, -1).
If parsing fails, returns (None, None). If parsing fails, returns (None, None).
""" """
start_offset, length = 0, -1 start_offset, length = 0, -1
range_header = headers.get('range', None)
if range_header is not None: if range_header is not None:
try: try:
start_offset, length = _parse_range_header(range_header) start_offset, length = _parse_range_header(range_header)
@ -335,15 +334,16 @@ def _start_offset_and_length(headers):
return start_offset, length return start_offset, length
def _upload_chunk(blob_upload, start_offset, length): def _upload_chunk(blob_upload, range_header):
""" """
Calculates metadata while uploading a chunk to storage. Calculates metadata while uploading a chunk to storage.
Returns a BlobUpload object or None if there was a failure. Returns a BlobUpload object or None if there was a failure.
""" """
# Check for invalidate arguments. # Get the offset and length of the current chunk.
start_offset, length = _start_offset_and_length(range_header)
if None in {blob_upload, start_offset, length}: if None in {blob_upload, start_offset, length}:
logger.error('None provided as argument to _upload_chunk') logger.error('Invalid arguments provided to _upload_chunk')
return None return None
if start_offset > 0 and start_offset > blob_upload.byte_count: if start_offset > 0 and start_offset > blob_upload.byte_count: