mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-26 13:56:09 -07:00 
			
		
		
		
	This doesn't account for boto configs where e.g. RDS has one default region and EC2 another - all will default to `ec2_region_name`. However, this is just handy to allow an easy site wide default region if existing configuration already relies on it. Modules can be improved to mention this in the documentation and turn off required=True where needed. But it works with `ec2` and `ec2_vol` without change.
		
			
				
	
	
		
			84 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| AWS_REGIONS = ['ap-northeast-1',
 | |
|                'ap-southeast-1',
 | |
|                'ap-southeast-2',
 | |
|                'eu-west-1',
 | |
|                'sa-east-1',
 | |
|                'us-east-1',
 | |
|                'us-west-1',
 | |
|                'us-west-2']
 | |
| 
 | |
| 
 | |
| def ec2_argument_spec():
 | |
|     return dict(
 | |
|         region=dict(aliases=['aws_region', 'ec2_region'], choices=AWS_REGIONS),
 | |
|         ec2_url=dict(),
 | |
|         ec2_secret_key=dict(aliases=['aws_secret_key', 'secret_key'], no_log=True),
 | |
|         ec2_access_key=dict(aliases=['aws_access_key', 'access_key']),
 | |
|     )
 | |
| 
 | |
| 
 | |
| def get_ec2_creds(module):
 | |
| 
 | |
|     # Check module args for credentials, then check environment vars
 | |
| 
 | |
|     ec2_url = module.params.get('ec2_url')
 | |
|     ec2_secret_key = module.params.get('ec2_secret_key')
 | |
|     ec2_access_key = module.params.get('ec2_access_key')
 | |
|     region = module.params.get('region')
 | |
| 
 | |
|     if not ec2_url:
 | |
|         if 'EC2_URL' in os.environ:
 | |
|             ec2_url = os.environ['EC2_URL']
 | |
|         elif 'AWS_URL' in os.environ:
 | |
|             ec2_url = os.environ['AWS_URL']
 | |
| 
 | |
|     if not ec2_access_key:
 | |
|         if 'EC2_ACCESS_KEY' in os.environ:
 | |
|             ec2_access_key = os.environ['EC2_ACCESS_KEY']
 | |
|         elif 'AWS_ACCESS_KEY_ID' in os.environ:
 | |
|             ec2_access_key = os.environ['AWS_ACCESS_KEY_ID']
 | |
|         elif 'AWS_ACCESS_KEY' in os.environ:
 | |
|             ec2_access_key = os.environ['AWS_ACCESS_KEY']
 | |
| 
 | |
|     if not ec2_secret_key:
 | |
|         if 'EC2_SECRET_KEY' in os.environ:
 | |
|             ec2_secret_key = os.environ['EC2_SECRET_KEY']
 | |
|         elif 'AWS_SECRET_ACCESS_KEY' in os.environ:
 | |
|             ec2_secret_key = os.environ['AWS_SECRET_ACCESS_KEY']
 | |
|         elif 'AWS_SECRET_KEY' in os.environ:
 | |
|             ec2_secret_key = os.environ['AWS_SECRET_KEY']
 | |
| 
 | |
|     if not region:
 | |
|         if 'EC2_REGION' in os.environ:
 | |
|             region = os.environ['EC2_REGION']
 | |
|         elif 'AWS_REGION' in os.environ:
 | |
|             region = os.environ['AWS_REGION']
 | |
|         else:
 | |
|             # boto.config.get returns None if config not found
 | |
|             region = boto.config.get('Boto', 'ec2_region_name')
 | |
| 
 | |
|     return ec2_url, ec2_access_key, ec2_secret_key, region
 | |
| 
 | |
| 
 | |
| def ec2_connect(module):
 | |
| 
 | |
|     """ Return an ec2 connection"""
 | |
| 
 | |
|     ec2_url, aws_access_key, aws_secret_key, region = get_ec2_creds(module)
 | |
| 
 | |
|     # If we have a region specified, connect to its endpoint.
 | |
|     if region:
 | |
|         try:
 | |
|             ec2 = boto.ec2.connect_to_region(region, aws_access_key_id=aws_access_key, aws_secret_access_key=aws_secret_key)
 | |
|         except boto.exception.NoAuthHandlerFound, e:
 | |
|             module.fail_json(msg = str(e))
 | |
|     # Otherwise, no region so we fallback to the old connection method
 | |
|     elif ec2_url:
 | |
|         try:
 | |
|             ec2 = boto.connect_ec2_endpoint(ec2_url, aws_access_key, aws_secret_key)
 | |
|         except boto.exception.NoAuthHandlerFound, e:
 | |
|             module.fail_json(msg = str(e))
 | |
|     else:
 | |
|         module.fail_json(msg="Either region or ec2_url must be specified")
 | |
|     return ec2
 | |
| 
 |