Fix support for auth_uri setting in neutron provider
Neutron provider still uses auth_port and auth_host config options even though those are now deprecated and won't be set if someone chooses to use auth_uri. This commit adds support for auth_uri and keeps the provider backwards compatible. Change-Id: I4824c09e6af4a800b5ac0c22bf5daea99452bd7e
This commit is contained in:
		 Lukas Bezdicka
					Lukas Bezdicka
				
			
				
					committed by
					
						 Lukas Bezdicka
						Lukas Bezdicka
					
				
			
			
				
	
			
			
			 Lukas Bezdicka
						Lukas Bezdicka
					
				
			
						parent
						
							b29ee6f706
						
					
				
				
					commit
					6fb01efe21
				
			| @@ -26,13 +26,21 @@ class Puppet::Provider::Neutron < Puppet::Provider | |||||||
|   end |   end | ||||||
|  |  | ||||||
|   def self.get_neutron_credentials |   def self.get_neutron_credentials | ||||||
|     auth_keys = ['auth_host', 'auth_port', 'auth_protocol', |     auth_keys = ['admin_tenant_name', 'admin_user', 'admin_password'] | ||||||
|                  'admin_tenant_name', 'admin_user', 'admin_password'] |     deprecated_auth_url = ['auth_host', 'auth_port', 'auth_protocol'] | ||||||
|     conf = neutron_conf |     conf = neutron_conf | ||||||
|     if conf and conf['keystone_authtoken'] and |     if conf and conf['keystone_authtoken'] and | ||||||
|         auth_keys.all?{|k| !conf['keystone_authtoken'][k].nil?} |         auth_keys.all?{|k| !conf['keystone_authtoken'][k].nil?} and | ||||||
|  |         ( deprecated_auth_url.all?{|k| !conf['keystone_authtoken'][k].nil?} or | ||||||
|  |         !conf['keystone_authtoken']['auth_uri'].nil? ) | ||||||
|       creds = Hash[ auth_keys.map \ |       creds = Hash[ auth_keys.map \ | ||||||
|                    { |k| [k, conf['keystone_authtoken'][k].strip] } ] |                    { |k| [k, conf['keystone_authtoken'][k].strip] } ] | ||||||
|  |       if !conf['keystone_authtoken']['auth_uri'].nil? | ||||||
|  |         creds['auth_uri'] = conf['keystone_authtoken']['auth_uri'] | ||||||
|  |       else | ||||||
|  |         q = conf['keystone_authtoken'] | ||||||
|  |         creds['auth_uri'] = "#{q['auth_protocol']}://#{q['auth_host']}:#{q['auth_port']}/v2.0/" | ||||||
|  |       end | ||||||
|       if conf['DEFAULT'] and !conf['DEFAULT']['nova_region_name'].nil? |       if conf['DEFAULT'] and !conf['DEFAULT']['nova_region_name'].nil? | ||||||
|         creds['nova_region_name'] = conf['DEFAULT']['nova_region_name'] |         creds['nova_region_name'] = conf['DEFAULT']['nova_region_name'] | ||||||
|       end |       end | ||||||
| @@ -54,7 +62,11 @@ correctly configured.") | |||||||
|  |  | ||||||
|   def self.get_auth_endpoint |   def self.get_auth_endpoint | ||||||
|     q = neutron_credentials |     q = neutron_credentials | ||||||
|     "#{q['auth_protocol']}://#{q['auth_host']}:#{q['auth_port']}/v2.0/" |     if q['auth_uri'].nil? | ||||||
|  |       return "#{q['auth_protocol']}://#{q['auth_host']}:#{q['auth_port']}/v2.0/" | ||||||
|  |     else | ||||||
|  |       return "#{q['auth_uri']}".strip | ||||||
|  |     end | ||||||
|   end |   end | ||||||
|  |  | ||||||
|   def self.neutron_conf |   def self.neutron_conf | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user