Merge "pxe: Support more flexible configurations of apache vhost"
This commit is contained in:
		| @@ -91,6 +91,18 @@ | ||||
| #   (optional) Set up Apache HTTP Server. | ||||
| #   Defaults to true | ||||
| # | ||||
| # [*vhost_priority*] | ||||
| #   (Optional) The priority for the vhost. | ||||
| #   Defaults to 10 | ||||
| # | ||||
| # [*vhost_options*] | ||||
| #   (Optional) Set the options for the spefieid virtual host. | ||||
| #   Defaults to ['-Indexes', '+FollowSymLinks'] | ||||
| # | ||||
| # [*vhost_config*] | ||||
| #   (Optional) Additional parameters passed to the apache::vhost defined type. | ||||
| #   Defaults to {} | ||||
| # | ||||
| class ironic::pxe ( | ||||
|   $package_ensure              = 'present', | ||||
|   Boolean $manage_service      = true, | ||||
| @@ -108,6 +120,9 @@ class ironic::pxe ( | ||||
|   Boolean $tftp_use_xinetd     = $::ironic::params::xinetd_available, | ||||
|   $dnsmasq_log_facility        = undef, | ||||
|   Boolean $manage_http_server  = true, | ||||
|   $vhost_priority              = 10, | ||||
|   Array[String] $vhost_options = ['-Indexes', '+FollowSymLinks'], | ||||
|   Hash $vhost_config           = {}, | ||||
| ) inherits ironic::params { | ||||
|  | ||||
|   include ironic::deps | ||||
| @@ -162,7 +177,7 @@ class ironic::pxe ( | ||||
|       tag    => ['openstack', 'ironic-ipxe', 'ironic-support-package'], | ||||
|     } | ||||
|  | ||||
|     $options = "--map-file ${tftp_root_real}/map-file" | ||||
|     $tftp_options = "--map-file ${tftp_root_real}/map-file" | ||||
|  | ||||
|     include xinetd | ||||
|  | ||||
| @@ -170,7 +185,7 @@ class ironic::pxe ( | ||||
|       port        => '69', | ||||
|       bind        => $tftp_bind_host, | ||||
|       protocol    => 'udp', | ||||
|       server_args => "${options} ${tftp_root_real}", | ||||
|       server_args => "${tftp_options} ${tftp_root_real}", | ||||
|       server      => '/usr/sbin/in.tftpd', | ||||
|       socket_type => 'dgram', | ||||
|       cps         => '100 2', | ||||
| @@ -347,11 +362,13 @@ class ironic::pxe ( | ||||
|  | ||||
|     include apache | ||||
|  | ||||
|     apache::vhost { 'ipxe_vhost': | ||||
|       priority => 10, | ||||
|       options  => ['-Indexes', '+FollowSymLinks'], | ||||
|       docroot  => $http_root_real, | ||||
|       port     => $http_port_real, | ||||
|     create_resources(apache::vhost, { | ||||
|       'ipxe_vhost' => { | ||||
|         'priority' => $vhost_priority, | ||||
|         'options'  => $vhost_options, | ||||
|         'docroot'  => $http_root_real, | ||||
|         'port'     => $http_port_real, | ||||
|       } | ||||
|     }, $vhost_config) | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -0,0 +1,9 @@ | ||||
| --- | ||||
| features: | ||||
|   - | | ||||
|     The following parameters have been added to the ``ironic::pxe`` class, to | ||||
|     allow more flexible configurations of the virtual host serving image files. | ||||
|  | ||||
|     - ``vhost_priority`` | ||||
|     - ``vhost_options`` | ||||
|     - ``vhost_config`` | ||||
| @@ -130,6 +130,11 @@ describe 'ironic::pxe' do | ||||
|           :http_root      => '/var/www/httpboot', | ||||
|           :http_port      => 3816, | ||||
|           :tftp_bind_host => '1.2.3.4', | ||||
|           :vhost_priority => 20, | ||||
|           :vhost_options  => ['Indexes', '+FollowSymLinks'], | ||||
|           :vhost_config   => { | ||||
|             'ssl' => true, | ||||
|           }, | ||||
|         ) | ||||
|       end | ||||
|  | ||||
| @@ -202,10 +207,11 @@ describe 'ironic::pxe' do | ||||
|       it 'should configure http server' do | ||||
|         is_expected.to contain_class('apache') | ||||
|         is_expected.to contain_apache__vhost('ipxe_vhost').with( | ||||
|           :priority => 10, | ||||
|           :options  => ['-Indexes', '+FollowSymLinks'], | ||||
|           :priority => 20, | ||||
|           :options  => ['Indexes', '+FollowSymLinks'], | ||||
|           :docroot  => '/var/www/httpboot', | ||||
|           :port     => 3816, | ||||
|           :ssl      => true, | ||||
|         ) | ||||
|       end | ||||
|     end | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Zuul
					Zuul