Allow custom headers when using swift download (CLI)
This fixes bug #1051046 A repeatable option, --header or -H, is added so a user can specify custom headers such as Range or If-Modified-Since when downloading an object with the swift CLI. Change-Id: I1f7dcf64cf625f2e5a4488c210894cfe6e0d5974
This commit is contained in:
parent
ff6ba367fa
commit
3cabda8c48
16
bin/swift
16
bin/swift
@ -265,6 +265,11 @@ Optional arguments:
|
|||||||
Number of threads to use for deleting containers
|
Number of threads to use for deleting containers
|
||||||
--no-download Perform download(s), but don't actually write anything
|
--no-download Perform download(s), but don't actually write anything
|
||||||
to disk
|
to disk
|
||||||
|
--header <header_name:header_value>
|
||||||
|
Adds a customized request header to the query, like
|
||||||
|
"Range" or "If-Match". This argument is repeatable.
|
||||||
|
Example --header "content-type:text/plain"
|
||||||
|
|
||||||
'''.strip("\n")
|
'''.strip("\n")
|
||||||
|
|
||||||
|
|
||||||
@ -293,6 +298,13 @@ def st_download(parser, args, thread_manager):
|
|||||||
'', '--no-download', action='store_true',
|
'', '--no-download', action='store_true',
|
||||||
default=False,
|
default=False,
|
||||||
help="Perform download(s), but don't actually write anything to disk")
|
help="Perform download(s), but don't actually write anything to disk")
|
||||||
|
parser.add_option(
|
||||||
|
'-H', '--header', action='append', dest='header',
|
||||||
|
default=[],
|
||||||
|
help='Specify a request header, as --header NAME:VALUE. '
|
||||||
|
'Adds a customized request header to the query, like "Range" or '
|
||||||
|
'"If-Match". This argument is repeatable. Example'
|
||||||
|
' --header "content-type:text/plain"')
|
||||||
(options, args) = parse_args(parser, args)
|
(options, args) = parse_args(parser, args)
|
||||||
args = args[1:]
|
args = args[1:]
|
||||||
if options.out_file == '-':
|
if options.out_file == '-':
|
||||||
@ -303,6 +315,7 @@ def st_download(parser, args, thread_manager):
|
|||||||
thread_manager.error('Usage: %s download %s\n%s', basename(argv[0]),
|
thread_manager.error('Usage: %s download %s\n%s', basename(argv[0]),
|
||||||
st_download_options, st_download_help)
|
st_download_options, st_download_help)
|
||||||
return
|
return
|
||||||
|
req_headers = split_headers(options.header, '', thread_manager)
|
||||||
|
|
||||||
def _download_object(queue_arg, conn):
|
def _download_object(queue_arg, conn):
|
||||||
if len(queue_arg) == 2:
|
if len(queue_arg) == 2:
|
||||||
@ -315,7 +328,8 @@ def st_download(parser, args, thread_manager):
|
|||||||
try:
|
try:
|
||||||
start_time = time()
|
start_time = time()
|
||||||
headers, body = \
|
headers, body = \
|
||||||
conn.get_object(container, obj, resp_chunk_size=65536)
|
conn.get_object(container, obj, resp_chunk_size=65536,
|
||||||
|
headers=req_headers)
|
||||||
header_receipt = time()
|
header_receipt = time()
|
||||||
content_type = headers.get('content-type')
|
content_type = headers.get('content-type')
|
||||||
if 'content-length' in headers:
|
if 'content-length' in headers:
|
||||||
|
@ -82,6 +82,8 @@ Downloads everything in the account (with --all), or everything in a
|
|||||||
container, or a list of objects depending on the args given. For a single
|
container, or a list of objects depending on the args given. For a single
|
||||||
object download, you may use the -o [--output] <filename> option to
|
object download, you may use the -o [--output] <filename> option to
|
||||||
redirect the output to a specific file or if "-" then just redirect to stdout.
|
redirect the output to a specific file or if "-" then just redirect to stdout.
|
||||||
|
You can specify optional headers with the repeatable cURL-like option
|
||||||
|
-H [--header].
|
||||||
.RE
|
.RE
|
||||||
|
|
||||||
\fBdelete\fR [\fIcommand-options\fR] [\fIcontainer\fR] [\fIobject\fR] [\fIobject\fR] [...]
|
\fBdelete\fR [\fIcommand-options\fR] [\fIcontainer\fR] [\fIobject\fR] [\fIobject\fR] [...]
|
||||||
|
Loading…
x
Reference in New Issue
Block a user