commit
0771dd12ca
1 changed files with 15 additions and 12 deletions
|
@ -320,8 +320,8 @@ def main():
|
||||||
|
|
||||||
# Look at s3_url and tweak connection settings
|
# Look at s3_url and tweak connection settings
|
||||||
# if connecting to Walrus or fakes3
|
# if connecting to Walrus or fakes3
|
||||||
if is_fakes3(s3_url):
|
try:
|
||||||
try:
|
if is_fakes3(s3_url):
|
||||||
fakes3 = urlparse.urlparse(s3_url)
|
fakes3 = urlparse.urlparse(s3_url)
|
||||||
s3 = boto.connect_s3(
|
s3 = boto.connect_s3(
|
||||||
aws_access_key,
|
aws_access_key,
|
||||||
|
@ -330,19 +330,22 @@ def main():
|
||||||
host=fakes3.hostname,
|
host=fakes3.hostname,
|
||||||
port=fakes3.port,
|
port=fakes3.port,
|
||||||
calling_format=OrdinaryCallingFormat())
|
calling_format=OrdinaryCallingFormat())
|
||||||
except boto.exception.NoAuthHandlerFound, e:
|
elif is_walrus(s3_url):
|
||||||
module.fail_json(msg = str(e))
|
|
||||||
elif is_walrus(s3_url):
|
|
||||||
try:
|
|
||||||
walrus = urlparse.urlparse(s3_url).hostname
|
walrus = urlparse.urlparse(s3_url).hostname
|
||||||
s3 = boto.connect_walrus(walrus, aws_access_key, aws_secret_key)
|
s3 = boto.connect_walrus(walrus, aws_access_key, aws_secret_key)
|
||||||
except boto.exception.NoAuthHandlerFound, e:
|
else:
|
||||||
module.fail_json(msg = str(e))
|
|
||||||
else:
|
|
||||||
try:
|
|
||||||
s3 = boto.s3.connect_to_region(location, aws_access_key_id=aws_access_key, aws_secret_access_key=aws_secret_key, is_secure=True, calling_format=OrdinaryCallingFormat())
|
s3 = boto.s3.connect_to_region(location, aws_access_key_id=aws_access_key, aws_secret_access_key=aws_secret_key, is_secure=True, calling_format=OrdinaryCallingFormat())
|
||||||
except boto.exception.NoAuthHandlerFound, e:
|
# use this as fallback because connect_to_region seems to fail in boto + non 'classic' aws accounts in some cases
|
||||||
module.fail_json(msg = str(e))
|
if s3 is None:
|
||||||
|
s3 = boto.connect_s3(aws_access_key, aws_secret_key)
|
||||||
|
|
||||||
|
except boto.exception.NoAuthHandlerFound, e:
|
||||||
|
module.fail_json(msg='No Authentication Handler found: %s ' % str(e))
|
||||||
|
except Exception, e:
|
||||||
|
module.fail_json(msg='Failed to connect to S3: %s' % str(e))
|
||||||
|
|
||||||
|
if s3 is None: # this should never happen
|
||||||
|
module.fail_json(msg ='Unknown error, failed to create s3 connection, no information from boto.')
|
||||||
|
|
||||||
# If our mode is a GET operation (download), go through the procedure as appropriate ...
|
# If our mode is a GET operation (download), go through the procedure as appropriate ...
|
||||||
if mode == 'get':
|
if mode == 'get':
|
||||||
|
|
Loading…
Reference in a new issue