s3: better check for walrus
Check for Walrus endpoint by looking to see if the endpoint is not AWS. This fixes a bug where the user specifies an AWS endpoint via S3_URL, but the code interprets it as Walrus and then fails.
This commit is contained in:
parent
807e602228
commit
1c5bdba977
1 changed files with 11 additions and 1 deletions
|
@ -238,6 +238,16 @@ def get_download_url(module, s3, bucket, obj, expiry, changed=True):
|
||||||
except s3.provider.storage_response_error, e:
|
except s3.provider.storage_response_error, e:
|
||||||
module.fail_json(msg= str(e))
|
module.fail_json(msg= str(e))
|
||||||
|
|
||||||
|
def is_walrus(s3_url):
|
||||||
|
""" Return True if it's Walrus endpoint, not S3
|
||||||
|
|
||||||
|
We assume anything other than *.amazonaws.com is Walrus"""
|
||||||
|
if s3_url is not None:
|
||||||
|
o = urlparse.urlparse(s3_url)
|
||||||
|
return not o.hostname.endswith('amazonaws.com')
|
||||||
|
else:
|
||||||
|
return False
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec = dict(
|
argument_spec = dict(
|
||||||
|
@ -286,7 +296,7 @@ def main():
|
||||||
aws_access_key = os.environ['EC2_ACCESS_KEY']
|
aws_access_key = os.environ['EC2_ACCESS_KEY']
|
||||||
|
|
||||||
# If we have an S3_URL env var set, this is likely to be Walrus, so change connection method
|
# If we have an S3_URL env var set, this is likely to be Walrus, so change connection method
|
||||||
if 'S3_URL' in os.environ:
|
if is_walrus(s3_url):
|
||||||
try:
|
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)
|
||||||
|
|
Loading…
Add table
Reference in a new issue