fuel-plugin-neutron-fwaas/deployment_scripts/puppet/modules/fwaas/manifests/init.pp

117 lines
3.5 KiB
Puppet

# Copyright 2015 Mirantis, 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.
#This class contains common changes for deployment FWaaS functionality in Neutron.
#It enables Firewall tab in Horizon and restart Neutron L3 agent.
class fwaas::enable_in_neutron_config {
ini_subsetting {'add_fwaas_service_plugin':
ensure => present,
section => 'DEFAULT',
key_val_separator => '=',
path => '/etc/neutron/neutron.conf',
setting => 'service_plugins',
subsetting => 'neutron_fwaas.services.firewall.',
subsetting_separator => ',',
value => 'fwaas_plugin.FirewallPlugin',
}
neutron_config {
'fwaas/enabled': value => 'True';
'fwaas/driver' : value => 'neutron_fwaas.services.firewall.drivers.linux.iptables_fwaas.IptablesFwaasDriver';
}
service { $fwaas::params::server_service:
ensure => running,
enable => true,
}
Neutron_config<||> ~> Service[$fwaas::params::server_service]
Ini_subsetting['add_fwaas_service_plugin'] ~> Service[$fwaas::params::server_service]
}
class fwaas::enable_in_dashboard {
service { $fwaas::params::dashboard_service:
ensure => running,
enable => true,
}
exec { 'enable_fwaas_dashboard':
command => "/bin/sed -i \"s/'enable_firewall': False/'enable_firewall': True/\" ${fwaas::params::dashboard_settings}",
unless => "/bin/egrep \"'enable_firewall': True\" ${fwaas::params::dashboard_settings}",
}
Exec['enable_fwaas_dashboard'] ~> Service[$fwaas::params::dashboard_service]
}
class fwaas {
include fwaas::params
include fwaas::enable_in_neutron_config
include fwaas::enable_in_dashboard
$primary_controller = hiera('primary_controller')
if $::fwaas::params::fwaas_package {
Package['neutron-fwaas'] -> Class[fwaas::enable_in_neutron_config]
package { 'neutron-fwaas':
ensure => present,
name => $::fwaas::params::fwaas_package,
}
}
if $primary_controller {
Package<| title == 'neutron-fwaas' |> -> Exec['neutron-db-sync']
exec { 'neutron-db-sync':
command => 'neutron-db-manage --config-file /etc/neutron/neutron.conf --config-file /etc/neutron/plugin.ini --subproject neutron-fwaas upgrade head',
path => '/usr/bin',
refreshonly => true,
tries => 10,
try_sleep => 10,
}
Neutron_config<||> ~> Exec['neutron-db-sync']
Ini_subsetting['add_fwaas_service_plugin'] ~> Exec['neutron-db-sync']
Exec['neutron-db-sync'] ~> Service[$fwaas::params::server_service]
}
if $fwaas::params::ha {
service {$fwaas::params::p_l3_agent:
ensure => running,
enable => true,
provider => 'pacemaker',
subscribe => Class[fwaas::enable_in_neutron_config],
}
} else {
service {$fwaas::params::l3_agent_service:
ensure => running,
enable => true,
subscribe => Class[fwaas::enable_in_neutron_config],
}
}
}