From 6abc2aedfa72c680a4895011f1c3eada2cd66c47 Mon Sep 17 00:00:00 2001 From: Philippe Muller Date: Fri, 27 Jan 2017 14:12:00 +0800 Subject: [PATCH] Add support for PERSISTENT_DHCLIENT --- manifests/if/dynamic.pp | 91 +++++++++++++++++---------------- manifests/init.pp | 108 +++++++++++++++++++++------------------- templates/ifcfg-eth.erb | 3 ++ tests/if-dhcp.pp | 9 ++-- 4 files changed, 111 insertions(+), 100 deletions(-) diff --git a/manifests/if/dynamic.pp b/manifests/if/dynamic.pp index de8136b8..39927063 100644 --- a/manifests/if/dynamic.pp +++ b/manifests/if/dynamic.pp @@ -4,20 +4,21 @@ # # === Parameters: # -# $ensure - required - up|down -# $macaddress - optional - defaults to macaddress_$title -# $manage_hwaddr - optional - defaults to true -# $bootproto - optional - defaults to "dhcp" -# $userctl - optional - defaults to false -# $mtu - optional -# $dhcp_hostname - optional -# $ethtool_opts - optional -# $peerdns - optional -# $linkdelay - optional -# $check_link_down - optional -# $zone - optional -# $metric - optional -# $defroute - optional +# $ensure - required - up|down +# $macaddress - optional - defaults to macaddress_$title +# $manage_hwaddr - optional - defaults to true +# $bootproto - optional - defaults to "dhcp" +# $userctl - optional - defaults to false +# $mtu - optional +# $dhcp_hostname - optional +# $persistent_dhclient - optional - defaults to false +# $ethtool_opts - optional +# $peerdns - optional +# $linkdelay - optional +# $check_link_down - optional +# $zone - optional +# $metric - optional +# $defroute - optional # # === Actions: # @@ -46,19 +47,20 @@ # define network::if::dynamic ( $ensure, - $macaddress = undef, - $manage_hwaddr = true, - $bootproto = 'dhcp', - $userctl = false, - $mtu = undef, - $dhcp_hostname = undef, - $ethtool_opts = undef, - $peerdns = false, - $linkdelay = undef, - $check_link_down = false, - $defroute = undef, - $zone = undef, - $metric = undef + $macaddress = undef, + $manage_hwaddr = true, + $bootproto = 'dhcp', + $userctl = false, + $mtu = undef, + $dhcp_hostname = undef, + $persistent_dhclient = false, + $ethtool_opts = undef, + $peerdns = false, + $linkdelay = undef, + $check_link_down = false, + $defroute = undef, + $zone = undef, + $metric = undef ) { # Validate our regular expressions $states = [ '^up$', '^down$' ] @@ -77,22 +79,23 @@ validate_bool($manage_hwaddr) network_if_base { $title: - ensure => $ensure, - ipaddress => '', - netmask => '', - gateway => '', - macaddress => $macaddy, - manage_hwaddr => $manage_hwaddr, - bootproto => $bootproto, - userctl => $userctl, - mtu => $mtu, - dhcp_hostname => $dhcp_hostname, - ethtool_opts => $ethtool_opts, - peerdns => $peerdns, - linkdelay => $linkdelay, - check_link_down => $check_link_down, - defroute => $defroute, - zone => $zone, - metric => $metric, + ensure => $ensure, + ipaddress => '', + netmask => '', + gateway => '', + macaddress => $macaddy, + manage_hwaddr => $manage_hwaddr, + bootproto => $bootproto, + userctl => $userctl, + mtu => $mtu, + dhcp_hostname => $dhcp_hostname, + persistent_dhclient => $persistent_dhclient, + ethtool_opts => $ethtool_opts, + peerdns => $peerdns, + linkdelay => $linkdelay, + check_link_down => $check_link_down, + defroute => $defroute, + zone => $zone, + metric => $metric, } } # define network::if::dynamic diff --git a/manifests/init.pp b/manifests/init.pp index 6f032f65..60ea8d06 100644 --- a/manifests/init.pp +++ b/manifests/init.pp @@ -50,31 +50,32 @@ # # === Parameters: # -# $ensure - required - up|down -# $ipaddress - required -# $netmask - required -# $macaddress - required -# $manage_hwaddr - optional - defaults to true -# $gateway - optional -# $bootproto - optional -# $userctl - optional - defaults to false -# $mtu - optional -# $dhcp_hostname - optional -# $ethtool_opts - optional -# $bonding_opts - optional -# $isalias - optional -# $peerdns - optional -# $dns1 - optional -# $dns2 - optional -# $domain - optional -# $bridge - optional -# $scope - optional -# $linkdelay - optional -# $check_link_down - optional -# $flush - optional -# $zone - optional -# $metric - optional -# $defroute - optional +# $ensure - required - up|down +# $ipaddress - required +# $netmask - required +# $macaddress - required +# $manage_hwaddr - optional - defaults to true +# $gateway - optional +# $bootproto - optional +# $userctl - optional - defaults to false +# $mtu - optional +# $dhcp_hostname - optional +# $persistent_dhclient - optional - defaults to false +# $ethtool_opts - optional +# $bonding_opts - optional +# $isalias - optional +# $peerdns - optional +# $dns1 - optional +# $dns2 - optional +# $domain - optional +# $bridge - optional +# $scope - optional +# $linkdelay - optional +# $check_link_down - optional +# $flush - optional +# $zone - optional +# $metric - optional +# $defroute - optional # # === Actions: # @@ -87,7 +88,6 @@ # SCOPE= # SRCADDR= # NOZEROCONF=yes -# PERSISTENT_DHCLIENT=yes|no|1|0 # DHCPRELEASE=yes|no|1|0 # DHCLIENT_IGNORE_GATEWAY=yes|no|1|0 # REORDER_HDR=yes|no @@ -105,32 +105,33 @@ $ipaddress, $netmask, $macaddress, - $manage_hwaddr = true, - $gateway = undef, - $ipv6address = undef, - $ipv6gateway = undef, - $ipv6init = false, - $ipv6autoconf = false, - $bootproto = 'none', - $userctl = false, - $mtu = undef, - $dhcp_hostname = undef, - $ethtool_opts = undef, - $bonding_opts = undef, - $isalias = false, - $peerdns = false, - $ipv6peerdns = false, - $dns1 = undef, - $dns2 = undef, - $domain = undef, - $bridge = undef, - $linkdelay = undef, - $scope = undef, - $check_link_down = false, - $flush = false, - $defroute = undef, - $zone = undef, - $metric = undef + $manage_hwaddr = true, + $gateway = undef, + $ipv6address = undef, + $ipv6gateway = undef, + $ipv6init = false, + $ipv6autoconf = false, + $bootproto = 'none', + $userctl = false, + $mtu = undef, + $dhcp_hostname = undef, + $persistent_dhclient = false, + $ethtool_opts = undef, + $bonding_opts = undef, + $isalias = false, + $peerdns = false, + $ipv6peerdns = false, + $dns1 = undef, + $dns2 = undef, + $domain = undef, + $bridge = undef, + $linkdelay = undef, + $scope = undef, + $check_link_down = false, + $flush = false, + $defroute = undef, + $zone = undef, + $metric = undef ) { # Validate our booleans validate_bool($userctl) @@ -150,6 +151,9 @@ $interface = $name + # Properly format $persistent_dhclient + $persistent_dhclient_real = bool2num($persistent_dhclient) + # Deal with the case where $dns2 is non-empty and $dns1 is empty. if $dns2 { if !$dns1 { diff --git a/templates/ifcfg-eth.erb b/templates/ifcfg-eth.erb index f4551e0d..65d73376 100644 --- a/templates/ifcfg-eth.erb +++ b/templates/ifcfg-eth.erb @@ -3,6 +3,9 @@ ### DEVICE=<%= @interface %> BOOTPROTO=<%= @bootproto %> +<% if @bootproto == 'dhcp' -%> +PERSISTENT_DHCLIENT=<%= @persistent_dhclient_real %> +<% end -%> <% if @manage_hwaddr and @macaddress and @macaddress != '' -%> HWADDR=<%= @macaddress %> <% end -%> diff --git a/tests/if-dhcp.pp b/tests/if-dhcp.pp index 3b17605c..67b5b3a1 100644 --- a/tests/if-dhcp.pp +++ b/tests/if-dhcp.pp @@ -2,8 +2,9 @@ # normal interface - dhcp network::if::dynamic { 'eth99': - ensure => 'up', - macaddress => 'ff:aa:ff:aa:ff:aa', - mtu => '1500', - ethtool_opts => 'speed 100 duplex full autoneg off', + ensure => 'up', + macaddress => 'ff:aa:ff:aa:ff:aa', + mtu => '1500', + ethtool_opts => 'speed 100 duplex full autoneg off', + persistent_dhclient => true, }