diff --git a/manifests/wsgi/apache.pp b/manifests/wsgi/apache.pp index db09914..3fa0fae 100644 --- a/manifests/wsgi/apache.pp +++ b/manifests/wsgi/apache.pp @@ -78,6 +78,14 @@ # The error log file name for the virtualhost. # Optional. Defaults to undef. # +# [*custom_wsgi_process_options*] +# (optional) gives you the oportunity to add custom process options or to +# overwrite the default options for the WSGI main process. +# eg. to use a virtual python environment for the WSGI process +# you could set it to: +# { python-path => '/my/python/virtualenv' } +# Defaults to {} +# # == Dependencies # # requires Class['apache'] & Class['zaqar'] @@ -89,25 +97,26 @@ # class { 'zaqar::wsgi::apache': } # class zaqar::wsgi::apache ( - $servername = $::fqdn, - $port = 8888, - $bind_host = undef, - $path = '/', - $ssl = true, - $workers = $::os_workers, - $ssl_cert = undef, - $ssl_key = undef, - $ssl_chain = undef, - $ssl_ca = undef, - $ssl_crl_path = undef, - $ssl_crl = undef, - $ssl_certs_dir = undef, - $wsgi_process_display_name = undef, - $threads = 1, - $priority = '10', - $access_log_file = false, - $access_log_format = false, - $error_log_file = undef, + $servername = $::fqdn, + $port = 8888, + $bind_host = undef, + $path = '/', + $ssl = true, + $workers = $::os_workers, + $ssl_cert = undef, + $ssl_key = undef, + $ssl_chain = undef, + $ssl_ca = undef, + $ssl_crl_path = undef, + $ssl_crl = undef, + $ssl_certs_dir = undef, + $wsgi_process_display_name = undef, + $threads = 1, + $priority = '10', + $access_log_file = false, + $access_log_format = false, + $error_log_file = undef, + $custom_wsgi_process_options = {}, ) { include ::zaqar::deps @@ -119,33 +128,34 @@ class zaqar::wsgi::apache ( } ::openstacklib::wsgi::apache { 'zaqar_wsgi': - bind_host => $bind_host, - bind_port => $port, - group => 'zaqar', - path => $path, - priority => $priority, - servername => $servername, - ssl => $ssl, - ssl_ca => $ssl_ca, - ssl_cert => $ssl_cert, - ssl_certs_dir => $ssl_certs_dir, - ssl_chain => $ssl_chain, - ssl_crl => $ssl_crl, - ssl_crl_path => $ssl_crl_path, - ssl_key => $ssl_key, - threads => $threads, - user => 'zaqar', - workers => $workers, - wsgi_daemon_process => 'zaqar-server', - wsgi_process_display_name => $wsgi_process_display_name, - wsgi_process_group => 'zaqar-server', - wsgi_script_dir => $::zaqar::params::zaqar_wsgi_script_path, - wsgi_script_file => 'zaqar-server', - wsgi_script_source => $::zaqar::params::zaqar_wsgi_script_source, - require => Anchor['zaqar::install::end'], - vhost_custom_fragment => 'WSGICallableObject app', - access_log_file => $access_log_file, - access_log_format => $access_log_format, - error_log_file => $error_log_file, + bind_host => $bind_host, + bind_port => $port, + group => 'zaqar', + path => $path, + priority => $priority, + servername => $servername, + ssl => $ssl, + ssl_ca => $ssl_ca, + ssl_cert => $ssl_cert, + ssl_certs_dir => $ssl_certs_dir, + ssl_chain => $ssl_chain, + ssl_crl => $ssl_crl, + ssl_crl_path => $ssl_crl_path, + ssl_key => $ssl_key, + threads => $threads, + user => 'zaqar', + workers => $workers, + wsgi_daemon_process => 'zaqar-server', + wsgi_process_display_name => $wsgi_process_display_name, + wsgi_process_group => 'zaqar-server', + wsgi_script_dir => $::zaqar::params::zaqar_wsgi_script_path, + wsgi_script_file => 'zaqar-server', + wsgi_script_source => $::zaqar::params::zaqar_wsgi_script_source, + require => Anchor['zaqar::install::end'], + vhost_custom_fragment => 'WSGICallableObject app', + access_log_file => $access_log_file, + access_log_format => $access_log_format, + error_log_file => $error_log_file, + custom_wsgi_process_options => $custom_wsgi_process_options, } } diff --git a/releasenotes/notes/wsgi_process_options-bba8611358c14afd.yaml b/releasenotes/notes/wsgi_process_options-bba8611358c14afd.yaml new file mode 100644 index 0000000..22d5cd1 --- /dev/null +++ b/releasenotes/notes/wsgi_process_options-bba8611358c14afd.yaml @@ -0,0 +1,4 @@ +--- +features: + - Add parameter to apache_wsgi to allow overwrite + and/or add additional wsgi process options. diff --git a/spec/classes/zaqar_wsgi_apache_spec.rb b/spec/classes/zaqar_wsgi_apache_spec.rb index b547db0..817e54a 100644 --- a/spec/classes/zaqar_wsgi_apache_spec.rb +++ b/spec/classes/zaqar_wsgi_apache_spec.rb @@ -9,36 +9,40 @@ describe 'zaqar::wsgi::apache' do it { is_expected.to contain_class('apache::mod::wsgi') } it { is_expected.to contain_class('apache::mod::ssl') } it { is_expected.to contain_openstacklib__wsgi__apache('zaqar_wsgi').with( - :bind_port => 8888, - :group => 'zaqar', - :path => '/', - :servername => facts[:fqdn], - :ssl => true, - :threads => 1, - :user => 'zaqar', - :workers => facts[:os_workers], - :wsgi_daemon_process => 'zaqar-server', - :wsgi_process_group => 'zaqar-server', - :wsgi_script_dir => platform_params[:wsgi_script_path], - :wsgi_script_file => 'zaqar-server', - :wsgi_script_source => platform_params[:wsgi_script_source], - :access_log_file => false, - :access_log_format => false, + :bind_port => 8888, + :group => 'zaqar', + :path => '/', + :servername => facts[:fqdn], + :ssl => true, + :threads => 1, + :user => 'zaqar', + :workers => facts[:os_workers], + :wsgi_daemon_process => 'zaqar-server', + :wsgi_process_group => 'zaqar-server', + :wsgi_script_dir => platform_params[:wsgi_script_path], + :wsgi_script_file => 'zaqar-server', + :wsgi_script_source => platform_params[:wsgi_script_source], + :access_log_file => false, + :access_log_format => false, + :custom_wsgi_process_options => {}, )} end context 'when overriding parameters using different ports' do let :params do { - :servername => 'dummy.host', - :bind_host => '10.42.51.1', - :port => 12345, - :ssl => false, - :wsgi_process_display_name => 'zaqar-server', - :workers => 37, - :access_log_file => '/var/log/httpd/access_log', - :access_log_format => 'some format', - :error_log_file => '/var/log/httpd/error_log' + :servername => 'dummy.host', + :bind_host => '10.42.51.1', + :port => 12345, + :ssl => false, + :wsgi_process_display_name => 'zaqar-server', + :workers => 37, + :access_log_file => '/var/log/httpd/access_log', + :access_log_format => 'some format', + :error_log_file => '/var/log/httpd/error_log', + :custom_wsgi_process_options => { + 'python_path' => '/my/python/path', + }, } end it { is_expected.to contain_class('zaqar::params') } @@ -46,24 +50,27 @@ describe 'zaqar::wsgi::apache' do it { is_expected.to contain_class('apache::mod::wsgi') } it { is_expected.to_not contain_class('apache::mod::ssl') } it { is_expected.to contain_openstacklib__wsgi__apache('zaqar_wsgi').with( - :bind_host => '10.42.51.1', - :bind_port => 12345, - :group => 'zaqar', - :path => '/', - :servername => 'dummy.host', - :ssl => false, - :threads => 1, - :user => 'zaqar', - :workers => 37, - :wsgi_daemon_process => 'zaqar-server', - :wsgi_process_display_name => 'zaqar-server', - :wsgi_process_group => 'zaqar-server', - :wsgi_script_dir => platform_params[:wsgi_script_path], - :wsgi_script_file => 'zaqar-server', - :wsgi_script_source => platform_params[:wsgi_script_source], - :access_log_file => '/var/log/httpd/access_log', - :access_log_format => 'some format', - :error_log_file => '/var/log/httpd/error_log' + :bind_host => '10.42.51.1', + :bind_port => 12345, + :group => 'zaqar', + :path => '/', + :servername => 'dummy.host', + :ssl => false, + :threads => 1, + :user => 'zaqar', + :workers => 37, + :wsgi_daemon_process => 'zaqar-server', + :wsgi_process_display_name => 'zaqar-server', + :wsgi_process_group => 'zaqar-server', + :wsgi_script_dir => platform_params[:wsgi_script_path], + :wsgi_script_file => 'zaqar-server', + :wsgi_script_source => platform_params[:wsgi_script_source], + :access_log_file => '/var/log/httpd/access_log', + :access_log_format => 'some format', + :error_log_file => '/var/log/httpd/error_log', + :custom_wsgi_process_options => { + 'python_path' => '/my/python/path', + }, )} end end