From b9088700f5e146ee223705bd1cc13c2e3eaa2555 Mon Sep 17 00:00:00 2001 From: Benedikt Trefzer Date: Sun, 24 Sep 2017 12:22:10 +0200 Subject: [PATCH] add parameter to overwrite/add wsgi process options Add parameter to apache_wsgi to allow overwrite and/or add additional wsgi process options. This possibility was added to openstacklib with Change-Id: I41914ce3361988d5db1695f09d21209772fdf548 Change-Id: I9f4ca58129a21a61cffbe84ee542ab7e16d2bb19 --- manifests/wsgi/apache.pp | 88 +++++++++++-------- ...wsgi_process_options-03a80f11e4fcd30b.yaml | 5 ++ spec/classes/panko_wsgi_apache_spec.rb | 6 ++ 3 files changed, 60 insertions(+), 39 deletions(-) create mode 100644 releasenotes/notes/wsgi_process_options-03a80f11e4fcd30b.yaml diff --git a/manifests/wsgi/apache.pp b/manifests/wsgi/apache.pp index d6d32a2..a75f3b3 100644 --- a/manifests/wsgi/apache.pp +++ b/manifests/wsgi/apache.pp @@ -67,6 +67,14 @@ # apache::vhost ssl parameters. # Optional. Default to apache::vhost 'ssl_*' defaults. # +# [*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['panko'] @@ -78,22 +86,23 @@ # class { 'panko::wsgi::apache': } # class panko::wsgi::apache ( - $servername = $::fqdn, - $port = 8977, - $bind_host = undef, - $path = '/', - $ssl = true, - $workers = 1, - $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 = $::os_workers, - $priority = '10', + $servername = $::fqdn, + $port = 8977, + $bind_host = undef, + $path = '/', + $ssl = true, + $workers = 1, + $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 = $::os_workers, + $priority = '10', + $custom_wsgi_process_options = {}, ) { include ::panko::deps @@ -105,28 +114,29 @@ class panko::wsgi::apache ( } ::openstacklib::wsgi::apache { 'panko_wsgi': - bind_host => $bind_host, - bind_port => $port, - group => 'panko', - 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 => 'panko', - workers => $workers, - wsgi_daemon_process => 'panko', - wsgi_process_display_name => $wsgi_process_display_name, - wsgi_process_group => 'panko', - wsgi_script_dir => $::panko::params::panko_wsgi_script_path, - wsgi_script_file => 'app', - wsgi_script_source => $::panko::params::panko_wsgi_script_source, + bind_host => $bind_host, + bind_port => $port, + group => 'panko', + 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 => 'panko', + workers => $workers, + wsgi_daemon_process => 'panko', + wsgi_process_display_name => $wsgi_process_display_name, + wsgi_process_group => 'panko', + wsgi_script_dir => $::panko::params::panko_wsgi_script_path, + wsgi_script_file => 'app', + wsgi_script_source => $::panko::params::panko_wsgi_script_source, + custom_wsgi_process_options => $custom_wsgi_process_options, } } diff --git a/releasenotes/notes/wsgi_process_options-03a80f11e4fcd30b.yaml b/releasenotes/notes/wsgi_process_options-03a80f11e4fcd30b.yaml new file mode 100644 index 0000000..aabf09f --- /dev/null +++ b/releasenotes/notes/wsgi_process_options-03a80f11e4fcd30b.yaml @@ -0,0 +1,5 @@ +--- +features: + - Add parameter to wsgi::apache to allow overwrite + and/or add additional wsgi process options. + diff --git a/spec/classes/panko_wsgi_apache_spec.rb b/spec/classes/panko_wsgi_apache_spec.rb index 9342aaa..c78973b 100644 --- a/spec/classes/panko_wsgi_apache_spec.rb +++ b/spec/classes/panko_wsgi_apache_spec.rb @@ -34,6 +34,9 @@ describe 'panko::wsgi::apache' do :ssl => false, :wsgi_process_display_name => 'panko', :workers => 8, + :custom_wsgi_process_options => { + 'python_path' => '/my/python/admin/path', + }, } end it { is_expected.to contain_class('panko::params') } @@ -56,6 +59,9 @@ describe 'panko::wsgi::apache' do :wsgi_script_dir => platform_params[:wsgi_script_path], :wsgi_script_file => 'app', :wsgi_script_source => platform_params[:wsgi_script_source], + :custom_wsgi_process_options => { + 'python_path' => '/my/python/admin/path', + }, )} end end