Move connection handling failure to connect_to_aws
Make use of better error handling mechanism
This commit is contained in:
parent
c08137a3d2
commit
b0133d9c8f
1 changed files with 6 additions and 17 deletions
|
@ -165,8 +165,7 @@ class Ec2Inventory(object):
|
||||||
# as pre 2.24 boto will fall over otherwise
|
# as pre 2.24 boto will fall over otherwise
|
||||||
if self.boto_profile:
|
if self.boto_profile:
|
||||||
if not hasattr(boto.ec2.EC2Connection, 'profile_name'):
|
if not hasattr(boto.ec2.EC2Connection, 'profile_name'):
|
||||||
sys.stderr.write("boto version must be >= 2.24 to use profile\n")
|
self.fail_with_error("boto version must be >= 2.24 to use profile")
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
# Cache
|
# Cache
|
||||||
if self.args.refresh_cache:
|
if self.args.refresh_cache:
|
||||||
|
@ -386,7 +385,6 @@ class Ec2Inventory(object):
|
||||||
continue
|
continue
|
||||||
self.ec2_instance_filters[filter_key].append(filter_value)
|
self.ec2_instance_filters[filter_key].append(filter_value)
|
||||||
|
|
||||||
|
|
||||||
def parse_cli_args(self):
|
def parse_cli_args(self):
|
||||||
''' Command line argument processing '''
|
''' Command line argument processing '''
|
||||||
|
|
||||||
|
@ -425,10 +423,7 @@ class Ec2Inventory(object):
|
||||||
conn = boto.connect_euca(host=self.eucalyptus_host)
|
conn = boto.connect_euca(host=self.eucalyptus_host)
|
||||||
conn.APIVersion = '2010-08-31'
|
conn.APIVersion = '2010-08-31'
|
||||||
else:
|
else:
|
||||||
conn = ec2.connect_to_region(region)
|
conn = self.connect_to_aws(ec2, region)
|
||||||
# connect_to_region will fail "silently" by returning None if the region name is wrong or not supported
|
|
||||||
if conn is None:
|
|
||||||
self.fail_with_error("region name: %s likely not supported, or AWS is down. connection to region failed." % region)
|
|
||||||
return conn
|
return conn
|
||||||
|
|
||||||
def boto_fix_security_token_in_profile(self, connect_args):
|
def boto_fix_security_token_in_profile(self, connect_args):
|
||||||
|
@ -438,7 +433,6 @@ class Ec2Inventory(object):
|
||||||
connect_args['security_token'] = boto.config.get(profile, 'aws_security_token')
|
connect_args['security_token'] = boto.config.get(profile, 'aws_security_token')
|
||||||
return connect_args
|
return connect_args
|
||||||
|
|
||||||
|
|
||||||
def connect_to_aws(self, module, region):
|
def connect_to_aws(self, module, region):
|
||||||
connect_args = {}
|
connect_args = {}
|
||||||
|
|
||||||
|
@ -448,9 +442,11 @@ class Ec2Inventory(object):
|
||||||
self.boto_fix_security_token_in_profile(connect_args)
|
self.boto_fix_security_token_in_profile(connect_args)
|
||||||
|
|
||||||
conn = module.connect_to_region(region, **connect_args)
|
conn = module.connect_to_region(region, **connect_args)
|
||||||
|
# connect_to_region will fail "silently" by returning None if the region name is wrong or not supported
|
||||||
|
if conn is None:
|
||||||
|
self.fail_with_error("region name: %s likely not supported, or AWS is down. connection to region failed." % region)
|
||||||
return conn
|
return conn
|
||||||
|
|
||||||
|
|
||||||
def get_instances_by_region(self, region):
|
def get_instances_by_region(self, region):
|
||||||
''' Makes an AWS EC2 API call to the list of instances in a particular
|
''' Makes an AWS EC2 API call to the list of instances in a particular
|
||||||
region '''
|
region '''
|
||||||
|
@ -462,14 +458,8 @@ class Ec2Inventory(object):
|
||||||
for filter_key, filter_values in self.ec2_instance_filters.items():
|
for filter_key, filter_values in self.ec2_instance_filters.items():
|
||||||
reservations.extend(conn.get_all_instances(filters = { filter_key : filter_values }))
|
reservations.extend(conn.get_all_instances(filters = { filter_key : filter_values }))
|
||||||
else:
|
else:
|
||||||
conn = ec2.connect_to_region(region, profile_name=self.boto_profile)
|
|
||||||
|
|
||||||
# connect_to_region will fail "silently" by returning None if the region name is wrong or not supported
|
|
||||||
if conn is None:
|
|
||||||
print("region name: %s likely not supported, or AWS is down. connection to region failed." % region)
|
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
reservations = conn.get_all_instances()
|
reservations = conn.get_all_instances()
|
||||||
|
|
||||||
for reservation in reservations:
|
for reservation in reservations:
|
||||||
for instance in reservation.instances:
|
for instance in reservation.instances:
|
||||||
self.add_instance(instance, region)
|
self.add_instance(instance, region)
|
||||||
|
@ -482,7 +472,6 @@ class Ec2Inventory(object):
|
||||||
error = "Error connecting to %s backend.\n%s" % (backend, e.message)
|
error = "Error connecting to %s backend.\n%s" % (backend, e.message)
|
||||||
self.fail_with_error(error, 'getting EC2 instances')
|
self.fail_with_error(error, 'getting EC2 instances')
|
||||||
|
|
||||||
|
|
||||||
def get_rds_instances_by_region(self, region):
|
def get_rds_instances_by_region(self, region):
|
||||||
''' Makes an AWS API call to the list of RDS instances in a particular
|
''' Makes an AWS API call to the list of RDS instances in a particular
|
||||||
region '''
|
region '''
|
||||||
|
|
Loading…
Reference in a new issue