# Class swift::objectexpirer # # == Parameters # [*enabled*] # (optional) Should the service be enabled. # Defaults to true # # [*manage_service*] # (optional) Whether the service should be managed by Puppet. # Defaults to true. # # [*package_ensure*] # (optional) Value of package resource parameter 'ensure'. # Defaults to 'present'. # # [*pipeline*] # (optional) The list of elements of the object expirer pipeline. # Defaults to ['catch_errors', 'proxy-logging', 'cache', 'proxy-server'] # # [*concurrency*] # (optional) Number of replication workers to spawn. # Defaults to $facts['os_service_default']. # # [*expiring_objects_account_name*] # (optional) Account name used for expiring objects. # Defaults to $facts['os_service_default']. # # [*interval*] # (optional) Minimum time for a pass to take, in seconds. # Defaults to $facts['os_service_default']. # # [*process*] # (optional) Which part of the work defined by $processes # will this instance take. # Defaults to $facts['os_service_default']. # # [*processes*] # (optional) How many parts to divide the work into, one part per # process. 0 means a single process will do all work. # Defaults to $facts['os_service_default']. # # [*reclaim_age*] # (optional) Time elapsed in seconds before an object can be # reclaimed. # Defaults to $facts['os_service_default']. # # [*recon_cache_path*] # (optional) Directory where stats for a few items will be stored. # Defaults to $facts['os_service_default']. # # [*report_interval*] # (optional) Report interval, in seconds. # Defaults to $facts['os_service_default']. # # [*service_provider*] # (optional) # To use the swiftinit service provider to manage swift services, set # service_provider to "swiftinit". When enable is true the provider # will populate boot files that start swift using swift-init at boot. # See README for more details. # Defaults to $::swift::params::service_provider. # # [*memcache_servers*] # (optional) # A list of the memcache servers to be used. Entries should be in the # form host:port. This value is only used if 'cache' is added to the # pipeline, e.g. ['catch_errors', 'proxy-logging', 'cache', 'proxy-server'] # Defaults to ['127.0.0.1:11211'] # # [*cache_tls_enabled*] # (Optional) Global toggle for TLS usage when communicating with # the caching servers. # Default to false # # [*cache_tls_cafile*] # (Optional) Path to a file of concatenated CA certificates in PEM # format necessary to establish the caching server's authenticity. # If tls_enabled is False, this option is ignored. # Defaults to undef # # [*cache_tls_certfile*] # (Optional) Path to a single file in PEM format containing the # client's certificate as well as any number of CA certificates # needed to establish the certificate's authenticity. This file # is only required when client side authentication is necessary. # If tls_enabled is False, this option is ignored. # Defaults to undef # # [*cache_tls_keyfile*] # (Optional) Path to a single file containing the client's private # key in. Otherwise the private key will be taken from the file # specified in tls_certfile. If tls_enabled is False, this option # is ignored. # Defaults to undef # # [*log_level*] # (optional) Log level. # Defaults to 'INFO'. # # [*log_facility*] # (optional) Log level # Defaults to 'LOG_LOCAL2'. # # DEPRECATED PARAMETERS # # [*auto_create_account_prefix*] # (optional) Prefix to use when automatically creating accounts. # Defaults to undef # class swift::objectexpirer( $manage_service = true, $enabled = true, $package_ensure = 'present', $pipeline = ['catch_errors', 'proxy-logging', 'cache', 'proxy-server'], $concurrency = $facts['os_service_default'], $expiring_objects_account_name = $facts['os_service_default'], $interval = $facts['os_service_default'], $process = $facts['os_service_default'], $processes = $facts['os_service_default'], $reclaim_age = $facts['os_service_default'], $recon_cache_path = $facts['os_service_default'], $report_interval = $facts['os_service_default'], $service_provider = $::swift::params::service_provider, $memcache_servers = ['127.0.0.1:11211'], $cache_tls_enabled = false, $cache_tls_cafile = undef, $cache_tls_certfile = undef, $cache_tls_keyfile = undef, $log_level = 'INFO', $log_facility = 'LOG_LOCAL2', # DEPRECATED PARAMETERS $auto_create_account_prefix = undef, ) inherits swift::params { include swift::deps Swift_object_expirer_config<||> ~> Service['swift-object-expirer'] if $auto_create_account_prefix != undef { warning('The auto_create_account_prefix parameter is deprecated. Use the swift::constraints class.') } # On Red Hat platforms, it may be defined already, # because it is part of openstack-swift-proxy if $::swift::params::object_expirer_package_name != $::swift::params::proxy_package_name { package { 'swift-object-expirer': ensure => $package_ensure, name => $::swift::params::object_expirer_package_name, tag => ['openstack', 'swift-package'], } } # only add memcache servers if 'cache' is included in the pipeline if !empty(grep(any2array($pipeline), 'cache')) { swift_object_expirer_config { 'filter:cache/memcache_servers': value => join(any2array($memcache_servers), ','); 'filter:cache/tls_enabled': value => $cache_tls_enabled; 'filter:cache/tls_cafile': value => $cache_tls_cafile; 'filter:cache/tls_certfile': value => $cache_tls_certfile; 'filter:cache/tls_keyfile': value => $cache_tls_keyfile; } # require the memcached class if it is on the same machine if !empty(grep(any2array($memcache_servers), '127.0.0.1')) { Class['memcached'] -> Class['swift::objectexpirer'] } } else { swift_object_expirer_config { 'filter:cache/memcache_servers': ensure => absent; 'filter:cache/tls_enabled': ensure => absent; 'filter:cache/tls_cafile': ensure => absent; 'filter:cache/tls_certfile': ensure => absent; 'filter:cache/tls_keyfile': ensure => absent; } } swift_object_expirer_config { 'filter:proxy-logging/use': value => 'egg:swift#proxy_logging' } swift_object_expirer_config { 'pipeline:main/pipeline': value => join($pipeline, ' '); 'object-expirer/auto_create_account_prefix': value => pick($auto_create_account_prefix, $facts['os_service_default']); 'object-expirer/concurrency': value => $concurrency; 'object-expirer/expiring_objects_account_name': value => $expiring_objects_account_name; 'object-expirer/interval': value => $interval; 'object-expirer/process': value => $process; 'object-expirer/processes': value => $processes; 'object-expirer/reclaim_age': value => $reclaim_age; 'object-expirer/recon_cache_path': value => $recon_cache_path; 'object-expirer/report_interval': value => $report_interval; 'object-expirer/log_facility': value => $log_facility; 'object-expirer/log_level': value => $log_level; } if $manage_service { if $enabled { $service_ensure = 'running' } else { $service_ensure = 'stopped' } swift::service { 'swift-object-expirer': os_family_service_name => $::swift::params::object_expirer_service_name, service_ensure => $service_ensure, enabled => $enabled, config_file_name => 'object-expirer.conf', service_provider => $service_provider, } } }