1 #Copyright 2015 Open Platform for NFV Project, Inc. and its contributors
3 # Licensed under the Apache License, Version 2.0 (the "License");
4 # you may not use this file except in compliance with the License.
5 # You may obtain a copy of the License at
7 # http://www.apache.org/licenses/LICENSE-2.0
9 # Unless required by applicable law or agreed to in writing, software
10 # distributed under the License is distributed on an "AS IS" BASIS,
11 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 # See the License for the specific language governing permissions and
13 # limitations under the License.
15 class opnfv::external_net_presetup {
17 if $public_gateway == '' { fail('public_gateway is empty') }
18 if $public_dns == '' { fail('public_dns is empty') }
19 if $public_network == '' { fail('public_network is empty') }
20 if $public_subnet == '' { fail('public_subnet is empty') }
21 if $public_allocation_start == '' { fail('public_allocation_start is empty') }
22 if $public_allocation_end == '' { fail('public_allocation_end is empty') }
23 if !$controllers_hostnames_array { fail('controllers_hostnames_array is empty') }
24 $controllers_hostnames_array_str = $controllers_hostnames_array
25 $controllers_hostnames_array = split($controllers_hostnames_array, ',')
27 if ($admin_network != '') and ($admin_network != 'false') {
28 $admin_nic = get_nic_from_network("$admin_network")
29 if $admin_nic == '' { fail('admin_nic was not found') }
30 $admin_ip = get_ip_from_nic("admin_nic")
31 $admin_netmask = get_netmask_from_nic("$admin_nic")
32 #Modify ifcfg Admin network
33 augeas { "main-$admin_nic":
34 context => "/files/etc/sysconfig/network-scripts/ifcfg-$public_nic",
36 "set IPADDR $admin_ip",
37 "set NETMASK $admin_netmask",
46 "set BOOTPROTO static",
48 "set IPV6_AUTOCONF no",
52 before => Exec['systemctl restart network'],
57 if ($private_network != '') and ($private_network != 'false') {
58 $private_nic = get_nic_from_network("$private_network")
59 if $private_nic == '' { fail('private_nic was not found') }
60 $private_ip = get_ip_from_nic("private_nic")
61 $private_netmask = get_netmask_from_nic("$private_nic")
62 #Modify ifcfg private network
63 augeas { "main-$private_nic":
64 context => "/files/etc/sysconfig/network-scripts/ifcfg-$private_nic",
66 "set IPADDR $private_ip",
67 "set NETMASK $private_netmask",
76 "set BOOTPROTO static",
78 "set IPV6_AUTOCONF no",
82 before => Exec['systemctl restart network'],
88 $public_nic = get_nic_from_network("$public_network")
89 $public_nic_ip = get_ip_from_nic("$public_nic")
90 $public_nic_netmask = get_netmask_from_nic("$public_nic")
92 if ($public_nic == '') or ($public_nic_ip == '') or ($public_nic == "br-ex") or ($public_nic == "br_ex") {
93 notify {"Skipping augeas, public_nic ${public_nic}, public_nic_ip ${public_nic_ip}":}
95 exec {'ovs-vsctl -t 10 -- --may-exist add-br br-ex':
96 path => ["/usr/sbin/", "/usr/bin/"],
97 unless => 'ip addr show br-ex | grep "inet "',
98 before => Exec['restart-network-public-nic-ip'],
101 exec {'systemctl restart network':
102 path => ["/usr/sbin/", "/usr/bin/"],
103 refreshonly => 'true',
106 exec {'restart-network-public-nic-ip':
107 command => 'systemctl restart network',
108 path => ["/usr/sbin/", "/usr/bin/"],
109 onlyif => 'ip addr show | grep $(ip addr show br-ex | grep -Eo "inet [\.0-9]+" | cut -d " " -f2) | grep -v br-ex',
113 #reconfigure public interface to be ovsport
114 augeas { "main-$public_nic":
115 context => "/files/etc/sysconfig/network-scripts/ifcfg-$public_nic",
125 "rm IPV6_PEERROUTES",
128 "set BOOTPROTO static",
130 "set IPV6_AUTOCONF no",
133 "set OVS_BRIDGE br-ex",
137 before => Class["quickstack::pacemaker::params"],
138 require => Service["openvswitch"],
142 #create br-ex interface
143 file { 'external_bridge':
144 path => '/etc/sysconfig/network-scripts/ifcfg-br-ex',
148 content => template('opnfv/br_ex.erb'),
149 before => Class["quickstack::pacemaker::params"],
152 exec {'ovs-vsctl -t 10 -- --may-exist add-br br-ex':
153 path => ["/usr/sbin/", "/usr/bin/"],
156 exec {'systemctl restart network':
157 path => ["/usr/sbin/", "/usr/bin/"],
158 refreshonly => 'true',