Class: Puppet::Provider::Cinder

Inherits:
Openstack
  • Object
show all
Extended by:
Openstack::Auth
Defined in:
lib/puppet/provider/cinder.rb

Class Method Summary collapse

Instance Method Summary collapse

Class Method Details

.auth_endpointObject



92
93
94
# File 'lib/puppet/provider/cinder.rb', line 92

def self.auth_endpoint
  @auth_endpoint ||= get_auth_endpoint
end

.cinder_confObject



16
17
18
19
20
21
# File 'lib/puppet/provider/cinder.rb', line 16

def self.cinder_conf
  return @cinder_conf if @cinder_conf
  @cinder_conf = Puppet::Util::IniConfig::File.new
  @cinder_conf.read(conf_filename)
  @cinder_conf
end

.cinder_credentialsObject



47
48
49
# File 'lib/puppet/provider/cinder.rb', line 47

def self.cinder_credentials
  @cinder_credentials ||= get_cinder_credentials
end

.cinder_request(service, action, error, properties = nil) ⇒ Object



31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
# File 'lib/puppet/provider/cinder.rb', line 31

def self.cinder_request(service, action, error, properties=nil)
  warning('Usage of keystone_authtoken parameters is deprecated.')
  properties ||= []
  @credentials.username = cinder_credentials['username']
  @credentials.password = cinder_credentials['password']
  @credentials.project_name = cinder_credentials['project_name']
  @credentials.auth_url = auth_endpoint
  @credentials.user_domain_name = cinder_credentials['user_domain_name']
  @credentials.project_domain_name = cinder_credentials['project_domain_name']
  if cinder_credentials['region_name']
    @credentials.region_name = cinder_credentials['region_name']
  end
  raise error unless @credentials.set?
  Puppet::Provider::Openstack.request(service, action, properties, @credentials)
end

.conf_filenameObject



12
13
14
# File 'lib/puppet/provider/cinder.rb', line 12

def self.conf_filename
  '/etc/cinder/cinder.conf'
end

.get_auth_endpointObject



87
88
89
90
# File 'lib/puppet/provider/cinder.rb', line 87

def self.get_auth_endpoint
  q = cinder_credentials
  "#{q['auth_url']}"
end

.get_cinder_credentialsObject



55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
# File 'lib/puppet/provider/cinder.rb', line 55

def self.get_cinder_credentials
  auth_keys = ['auth_url', 'project_name', 'username',
               'password']
  conf = cinder_conf
  if conf and conf['keystone_authtoken'] and
      auth_keys.all?{|k| !conf['keystone_authtoken'][k].nil?}
    creds = Hash[ auth_keys.map \
                 { |k| [k, conf['keystone_authtoken'][k].strip] } ]
    if conf['keystone_authtoken']['project_domain_name']
      creds['project_domain_name'] = conf['keystone_authtoken']['project_domain_name']
    else
      creds['project_domain_name'] = 'Default'
    end

    if conf['keystone_authtoken']['user_domain_name']
      creds['user_domain_name'] = conf['keystone_authtoken']['user_domain_name']
    else
      creds['user_domain_name'] = 'Default'
    end

    if conf['keystone_authtoken']['region_name']
      creds['region_name'] = conf['keystone_authtoken']['region_name']
    end

    return creds
  else
    raise(Puppet::Error, "File: #{conf_filename} does not contain all " +
          "required sections. Cinder types will not work if cinder is not " +
          "correctly configured.")
  end
end

.request(service, action, properties = nil) ⇒ Object



23
24
25
26
27
28
29
# File 'lib/puppet/provider/cinder.rb', line 23

def self.request(service, action, properties=nil)
  begin
    super
  rescue Puppet::Error::OpenstackAuthInputError, Puppet::Error::OpenstackUnauthorizedError => error
    cinder_request(service, action, error, properties)
  end
end

.resetObject



96
97
98
99
100
# File 'lib/puppet/provider/cinder.rb', line 96

def self.reset
  @cinder_conf = nil
  @cinder_credentials = nil
  @auth_endpoint = nil
end

Instance Method Details

#cinder_credentialsObject



51
52
53
# File 'lib/puppet/provider/cinder.rb', line 51

def cinder_credentials
  self.class.cinder_credentials
end