# # Copyright 2016 Red Hat, Inc. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # if ($::os_package_type == 'debian') { $wsgi_mod_package = 'libapache2-mod-wsgi-py3' $wsgi_mod_lib = 'mod_wsgi.so' } elsif ($::os['name'] == 'Fedora') or ($::os['family'] == 'RedHat' and Integer.new($::os['release']['major']) > 7) { $wsgi_mod_package = 'python3-mod_wsgi' $wsgi_mod_lib = 'mod_wsgi_python3.so' } if ($::os_package_type == 'debian') or ($::os['name'] == 'Fedora') or ($::os['family'] == 'RedHat' and Integer.new($::os['release']['major']) > 7) { include ::apache::params class { '::apache': mod_packages => merge($::apache::params::mod_packages, { 'wsgi' => $wsgi_mod_package, }), mod_libs => merge($::apache::params::mod_libs, { 'wsgi' => $wsgi_mod_lib, }) } } if ($::os['name'] == 'Fedora') or ($::os['family'] == 'RedHat' and Integer.new($::os['release']['major']) > 7) { # FIXME(ykarel) Disable SSL until services are ready to work with SSL + Python3 $ssl = false } else { $ssl = true } if $::operatingsystem == 'Ubuntu' { $ipv6 = false # Watcher packages are not available in Ubuntu repository. $watcher_enabled = false # TODO(tobasco): No service plugin 'BGPVPN' $bgpvpn_enabled = false # TODO(tobasco): Plugin 'networking_l2gw.services.l2gateway.plugin.L2GatewayPlugin' not found. $l2gw_enabled = false # FIXME(ykarel) Disable bgp_dragent until Ubuntu python3 stein(with stein packages) jobs are ready $bgp_dragent_enabled = false } else { $ipv6 = true $watcher_enabled = true $bgpvpn_enabled = true $l2gw_enabled = true $bgp_dragent_enabled = true } include ::openstack_integration class { '::openstack_integration::config': ssl => $ssl, ipv6 => $ipv6, } if $ssl { include ::openstack_integration::cacert } include ::openstack_integration::memcached include ::openstack_integration::rabbitmq include ::openstack_integration::mysql include ::openstack_integration::keystone class { '::openstack_integration::glance': backend => 'swift', } class { '::openstack_integration::neutron': bgpvpn_enabled => $bgpvpn_enabled, l2gw_enabled => $l2gw_enabled, bgp_dragent_enabled => $bgp_dragent_enabled, } class { '::openstack_integration::nova': libvirt_rbd => true, } class { '::openstack_integration::ceph': deploy_rgw => true, swift_dropin => true, } if $watcher_enabled { include ::openstack_integration::watcher } include ::openstack_integration::provision # Don't test swift, radosgw won't pass the current tests # Glance, nova, neutron are true by default. class { '::openstack_integration::tempest': watcher => $watcher_enabled, bgpvpn => $bgpvpn_enabled, l2gw => $l2gw_enabled, l2gw_switch => 'cell08-5930-01::FortyGigE1/0/1|100', dr => $bgp_dragent_enabled, }