This class doesn't do anything useful, the providers are doing the work. Change-Id: I2ad76fd03650e064473d6c7d8f981b0f26afbba9
		
			
				
	
	
		
			315 lines
		
	
	
		
			9.3 KiB
		
	
	
	
		
			Puppet
		
	
	
	
	
	
			
		
		
	
	
			315 lines
		
	
	
		
			9.3 KiB
		
	
	
	
		
			Puppet
		
	
	
	
	
	
# == Class: glance::registry
 | 
						|
#
 | 
						|
# Installs and configures glance-registry
 | 
						|
#
 | 
						|
# === Parameters
 | 
						|
#
 | 
						|
#  [*keystone_password*]
 | 
						|
#    (required) The keystone password for administrative user
 | 
						|
#
 | 
						|
#  [*package_ensure*]
 | 
						|
#    (optional) Ensure state for package. Defaults to 'present'.  On RedHat
 | 
						|
#    platforms this setting is ignored and the setting from the glance class is
 | 
						|
#    used because there is only one glance package.
 | 
						|
#
 | 
						|
#  [*verbose*]
 | 
						|
#    (optional) Enable verbose logs (true|false). Defaults to undef.
 | 
						|
#
 | 
						|
#  [*debug*]
 | 
						|
#    (optional) Enable debug logs (true|false). Defaults to undef.
 | 
						|
#
 | 
						|
#  [*bind_host*]
 | 
						|
#    (optional) The address of the host to bind to. Defaults to '0.0.0.0'.
 | 
						|
#
 | 
						|
#  [*bind_port*]
 | 
						|
#    (optional) The port the server should bind to. Defaults to '9191'.
 | 
						|
#
 | 
						|
#  [*workers*]
 | 
						|
#    (optional) The number of child process workers that will be
 | 
						|
#    created to service Registry requests.
 | 
						|
#    Defaults to: $::processorcount
 | 
						|
#
 | 
						|
#  [*log_file*]
 | 
						|
#    (optional) Log file for glance-registry.
 | 
						|
#    If set to boolean false, it will not log to any file.
 | 
						|
#    Defaults to undef.
 | 
						|
#
 | 
						|
#  [*log_dir*]
 | 
						|
#    (optional) directory to which glance logs are sent.
 | 
						|
#    If set to boolean false, it will not log to any directory.
 | 
						|
#    Defaults to undef.
 | 
						|
#
 | 
						|
#  [*database_connection*]
 | 
						|
#    (optional) Connection url to connect to nova database.
 | 
						|
#    Defaults to undef
 | 
						|
#
 | 
						|
#  [*database_idle_timeout*]
 | 
						|
#    (optional) Timeout before idle db connections are reaped.
 | 
						|
#    Defaults to undef
 | 
						|
#
 | 
						|
#  [*database_max_retries*]
 | 
						|
#    (Optional) Maximum number of database connection retries during startup.
 | 
						|
#    Set to -1 to specify an infinite retry count.
 | 
						|
#    Defaults to undef.
 | 
						|
#
 | 
						|
#  [*database_retry_interval*]
 | 
						|
#    (optional) Interval between retries of opening a database connection.
 | 
						|
#    Defaults to undef.
 | 
						|
#
 | 
						|
#  [*database_min_pool_size*]
 | 
						|
#    (optional) Minimum number of SQL connections to keep open in a pool.
 | 
						|
#    Defaults to undef.
 | 
						|
#
 | 
						|
#  [*database_max_pool_size*]
 | 
						|
#    (optional) Maximum number of SQL connections to keep open in a pool.
 | 
						|
#    Defaults to undef.
 | 
						|
#
 | 
						|
#  [*database_max_overflow*]
 | 
						|
#    (optional) If set, use this value for max_overflow with sqlalchemy.
 | 
						|
#    Defaults to undef.
 | 
						|
#
 | 
						|
#  [*auth_type*]
 | 
						|
#    (optional) Authentication type. Defaults to 'keystone'.
 | 
						|
#
 | 
						|
#  [*auth_uri*]
 | 
						|
#    (optional) Complete public Identity API endpoint.
 | 
						|
#    Defaults to 'http://127.0.0.1:5000/'.
 | 
						|
#
 | 
						|
#  [*identity_uri*]
 | 
						|
#    (optional) Complete admin Identity API endpoint.
 | 
						|
#    Defaults to 'http://127.0.0.1:35357/'.
 | 
						|
#
 | 
						|
#  [*keystone_tenant*]
 | 
						|
#    (optional) administrative tenant name to connect to keystone.
 | 
						|
#    Defaults to 'services'.
 | 
						|
#
 | 
						|
#  [*keystone_user*]
 | 
						|
#    (optional) administrative user name to connect to keystone.
 | 
						|
#    Defaults to 'glance'.
 | 
						|
#
 | 
						|
#  [*pipeline*]
 | 
						|
#    (optional) Partial name of a pipeline in your paste configuration
 | 
						|
#     file with the service name removed.
 | 
						|
#     Defaults to 'keystone'.
 | 
						|
#
 | 
						|
#  [*use_syslog*]
 | 
						|
#    (optional) Use syslog for logging.
 | 
						|
#    Defaults to undef.
 | 
						|
#
 | 
						|
#  [*use_stderr*]
 | 
						|
#    (optional) Use stderr for logging
 | 
						|
#    Defaults to undef.
 | 
						|
#
 | 
						|
#  [*log_facility*]
 | 
						|
#    (optional) Syslog facility to receive log lines.
 | 
						|
#    Defaults to undef.
 | 
						|
#
 | 
						|
#  [*manage_service*]
 | 
						|
#    (optional) If Puppet should manage service startup / shutdown.
 | 
						|
#    Defaults to true.
 | 
						|
#
 | 
						|
#  [*enabled*]
 | 
						|
#    (optional) Should the service be enabled.
 | 
						|
#    Defaults to true.
 | 
						|
#
 | 
						|
#  [*purge_config*]
 | 
						|
#    (optional) Whether to create only the specified config values in
 | 
						|
#    the glance registry config file.
 | 
						|
#    Defaults to false.
 | 
						|
#
 | 
						|
# [*cert_file*]
 | 
						|
#   (optinal) Certificate file to use when starting registry server securely
 | 
						|
#   Defaults to false, not set
 | 
						|
#
 | 
						|
# [*key_file*]
 | 
						|
#   (optional) Private key file to use when starting registry server securely
 | 
						|
#   Defaults to false, not set
 | 
						|
#
 | 
						|
# [*ca_file*]
 | 
						|
#   (optional) CA certificate file to use to verify connecting clients
 | 
						|
#   Defaults to false, not set
 | 
						|
#
 | 
						|
# [*sync_db*]
 | 
						|
#   (Optional) Run db sync on the node.
 | 
						|
#   Defaults to true
 | 
						|
#
 | 
						|
#  [*os_region_name*]
 | 
						|
#    (optional) Sets the keystone region to use.
 | 
						|
#    Defaults to $::os_service_default.
 | 
						|
#
 | 
						|
#  [*signing_dir*]
 | 
						|
#    Directory used to cache files related to PKI tokens.
 | 
						|
#    Defaults to $::os_service_default.
 | 
						|
#
 | 
						|
# [*memcached_servers*]
 | 
						|
#   (optinal) a list of memcached server(s) to use for caching. If left undefined,
 | 
						|
#   tokens will instead be cached in-process.
 | 
						|
#   Defaults to $::os_service_default.
 | 
						|
#
 | 
						|
#  [*token_cache_time*]
 | 
						|
#    In order to prevent excessive effort spent validating tokens,
 | 
						|
#    the middleware caches previously-seen tokens for a configurable duration (in seconds).
 | 
						|
#    Set to -1 to disable caching completely.
 | 
						|
#    Defaults to $::os_service_default.
 | 
						|
#
 | 
						|
class glance::registry(
 | 
						|
  $keystone_password,
 | 
						|
  $package_ensure          = 'present',
 | 
						|
  $verbose                 = undef,
 | 
						|
  $debug                   = undef,
 | 
						|
  $bind_host               = '0.0.0.0',
 | 
						|
  $bind_port               = '9191',
 | 
						|
  $workers                 = $::processorcount,
 | 
						|
  $log_file                = undef,
 | 
						|
  $log_dir                 = undef,
 | 
						|
  $database_connection     = undef,
 | 
						|
  $database_idle_timeout   = undef,
 | 
						|
  $database_min_pool_size  = undef,
 | 
						|
  $database_max_pool_size  = undef,
 | 
						|
  $database_max_retries    = undef,
 | 
						|
  $database_retry_interval = undef,
 | 
						|
  $database_max_overflow   = undef,
 | 
						|
  $auth_type               = 'keystone',
 | 
						|
  $auth_uri                = 'http://127.0.0.1:5000/',
 | 
						|
  $identity_uri            = 'http://127.0.0.1:35357/',
 | 
						|
  $keystone_tenant         = 'services',
 | 
						|
  $keystone_user           = 'glance',
 | 
						|
  $pipeline                = 'keystone',
 | 
						|
  $use_syslog              = undef,
 | 
						|
  $use_stderr              = undef,
 | 
						|
  $log_facility            = undef,
 | 
						|
  $manage_service          = true,
 | 
						|
  $enabled                 = true,
 | 
						|
  $purge_config            = false,
 | 
						|
  $cert_file               = false,
 | 
						|
  $key_file                = false,
 | 
						|
  $ca_file                 = false,
 | 
						|
  $sync_db                 = true,
 | 
						|
  $os_region_name          = $::os_service_default,
 | 
						|
  $signing_dir             = $::os_service_default,
 | 
						|
  $memcached_servers       = $::os_service_default,
 | 
						|
  $token_cache_time        = $::os_service_default,
 | 
						|
) inherits glance {
 | 
						|
 | 
						|
  include ::glance::registry::logging
 | 
						|
  include ::glance::registry::db
 | 
						|
 | 
						|
  if ( $glance::params::api_package_name != $glance::params::registry_package_name ) {
 | 
						|
    ensure_packages( 'glance-registry',
 | 
						|
      {
 | 
						|
        ensure => $package_ensure,
 | 
						|
        tag    => ['openstack', 'glance-package'],
 | 
						|
      }
 | 
						|
    )
 | 
						|
  }
 | 
						|
 | 
						|
  Package[$glance::params::registry_package_name] -> File['/etc/glance/']
 | 
						|
 | 
						|
  Glance_registry_config<||> ~> Service['glance-registry']
 | 
						|
 | 
						|
  File {
 | 
						|
    ensure  => present,
 | 
						|
    owner   => 'glance',
 | 
						|
    group   => 'glance',
 | 
						|
    mode    => '0640',
 | 
						|
    notify  => Service['glance-registry'],
 | 
						|
    require => Class['glance']
 | 
						|
  }
 | 
						|
 | 
						|
  glance_registry_config {
 | 
						|
    'DEFAULT/workers':                value => $workers;
 | 
						|
    'DEFAULT/bind_host':              value => $bind_host;
 | 
						|
    'DEFAULT/bind_port':              value => $bind_port;
 | 
						|
    'glance_store/os_region_name':    value => $os_region_name;
 | 
						|
  }
 | 
						|
 | 
						|
  # Set the pipeline, it is allowed to be blank
 | 
						|
  if $pipeline != '' {
 | 
						|
    validate_re($pipeline, '^(\w+([+]\w+)*)*$')
 | 
						|
    glance_registry_config {
 | 
						|
      'paste_deploy/flavor':
 | 
						|
        ensure => present,
 | 
						|
        value  => $pipeline,
 | 
						|
    }
 | 
						|
  } else {
 | 
						|
    glance_registry_config { 'paste_deploy/flavor': ensure => absent }
 | 
						|
  }
 | 
						|
 | 
						|
  # keystone config
 | 
						|
  if $auth_type == 'keystone' {
 | 
						|
    glance_registry_config {
 | 
						|
      'keystone_authtoken/admin_tenant_name': value => $keystone_tenant;
 | 
						|
      'keystone_authtoken/admin_user':        value => $keystone_user;
 | 
						|
      'keystone_authtoken/admin_password':    value => $keystone_password, secret => true;
 | 
						|
      'keystone_authtoken/token_cache_time':  value => $token_cache_time;
 | 
						|
      'keystone_authtoken/signing_dir':       value => $signing_dir;
 | 
						|
      'keystone_authtoken/auth_uri':          value => $auth_uri;
 | 
						|
      'keystone_authtoken/identity_uri':      value => $identity_uri;
 | 
						|
      'keystone_authtoken/memcached_servers': value => join(any2array($memcached_servers), ',');
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  # SSL Options
 | 
						|
  if $cert_file {
 | 
						|
    glance_registry_config {
 | 
						|
      'DEFAULT/cert_file' : value => $cert_file;
 | 
						|
    }
 | 
						|
  } else {
 | 
						|
    glance_registry_config {
 | 
						|
      'DEFAULT/cert_file': ensure => absent;
 | 
						|
    }
 | 
						|
  }
 | 
						|
  if $key_file {
 | 
						|
    glance_registry_config {
 | 
						|
      'DEFAULT/key_file'  : value => $key_file;
 | 
						|
    }
 | 
						|
  } else {
 | 
						|
    glance_registry_config {
 | 
						|
      'DEFAULT/key_file': ensure => absent;
 | 
						|
    }
 | 
						|
  }
 | 
						|
  if $ca_file {
 | 
						|
    glance_registry_config {
 | 
						|
      'DEFAULT/ca_file'   : value => $ca_file;
 | 
						|
    }
 | 
						|
  } else {
 | 
						|
    glance_registry_config {
 | 
						|
      'DEFAULT/ca_file': ensure => absent;
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  resources { 'glance_registry_config':
 | 
						|
    purge => $purge_config
 | 
						|
  }
 | 
						|
 | 
						|
  file { ['/etc/glance/glance-registry.conf',
 | 
						|
          '/etc/glance/glance-registry-paste.ini']:
 | 
						|
  }
 | 
						|
 | 
						|
  if $sync_db {
 | 
						|
    include ::glance::db::sync
 | 
						|
  }
 | 
						|
 | 
						|
  if $manage_service {
 | 
						|
    if $enabled {
 | 
						|
      $service_ensure = 'running'
 | 
						|
    } else {
 | 
						|
      $service_ensure = 'stopped'
 | 
						|
    }
 | 
						|
  } else {
 | 
						|
    warning('Execution of db_sync does not depend on $manage_service or $enabled anymore. Please use sync_db instead.')
 | 
						|
  }
 | 
						|
 | 
						|
  service { 'glance-registry':
 | 
						|
    ensure     => $service_ensure,
 | 
						|
    name       => $::glance::params::registry_service_name,
 | 
						|
    enable     => $enabled,
 | 
						|
    hasstatus  => true,
 | 
						|
    hasrestart => true,
 | 
						|
    subscribe  => File['/etc/glance/glance-registry.conf'],
 | 
						|
    require    => Class['glance'],
 | 
						|
    tag        => 'glance-service',
 | 
						|
  }
 | 
						|
 | 
						|
}
 |