foreman_network
Version information
This version is compatible with:
- Puppet Enterprise 2019.8.x, 2019.7.x, 2019.5.x, 2019.4.x, 2019.3.x, 2019.2.x, 2019.1.x, 2019.0.x, 2018.1.x, 2017.3.x, 2017.2.x, 2016.4.x
- Puppet >= 4.10.0 < 7.0.0
- , , ,
Start using this module
Add this module to your Puppetfile:
mod 'andeman-foreman_network', '1.0.0'
Learn more about managing modules with a PuppetfileDocumentation
foreman_network
Table of Contents
Overview
This module configures network interfaces, network routes and resolv.conf from Foreman ENC (external node classifier) node parameters.
Basically it parses the foreman_interfaces and domainname node parameters from foreman and pass it to other puppet modules to configure the settings.
More information about foreman: https://theforeman.org/
Information about Puppet ENC (external node classifier): https://puppet.com/docs/puppet/latest/nodes_external.html
Requirements
- Puppet >= 4.10.0 < 7.0.0
- puppetlabs/stdlib
- puppet/network
- saz/resolv_conf
Beginning with foreman_network
All parameters for the module are contained within the main class, so for any function of the module, set the options you want. All configuration parameters can be assigned hiera. The default values are also lookuped up by hiera. See the common usages below for examples.
Usage
Install and enable foreman_network
include foreman_network
Declare foreman_network
To get foreman_network up and running just declare the class.
class { 'foreman_network': }
Declare the class with default values:
class { 'foreman_network':
nameservers => [],
nameservers_merge => true,
manage_resolv_conf => true,
route_overrides => {},
mange_network_interface_restart => true,
manage_if_from_facts_only => true,
resolv_conf_path => '/etc/resolv.conf',
debug => false,
searchpath_merge => true,
searchpath => [],
}
Using Hiera with default values:
foreman_network:
nameservers: []
nameservers_merge: true
manage_resolv_conf: true
route_overrides: {}
mange_network_interface_restart: true
manage_if_from_facts_only: true
resolv_conf_path: /etc/resolv.conf
debug: false
searchpath_merge: true
searchpath: []
Configure nameservers
IMPORTANT: When the boot mode of the primary interface from foreman is a DHCP, the resolv.conf will be always unmanaged even when the parameter manage_resolv_conf is true.
Additional nameservers
Foreman passes 2 nameservers via node parameters: dns_primary (eg. 1.1.1.1) and dns_secondary (eg. 2.2.2.2).
With the following configuration additional nameservers will be added via an unique merge:
class { 'foreman_network':
nameservers_merge => true,
nameservers => [
'1.1.1.1',
'8.8.8.8',
'4.4.4.4'
],
}
Using Hiera:
foreman_network:
nameservers_merge: true
nameservers:
- 8.8.8.8
- 4.4.4.4
The result in /etc/resolv.conf will be:
[...]
nameserver 1.1.1.1
nameserver 2.2.2.2
nameserver 8.8.8.8
nameserver 4.4.4.4
[...]
Custom nameservers
Use custom nameservers and ignore foreman nameservers with the following configuration
class { 'foreman_network':
nameservers_merge => false,
nameservers => [
'8.8.8.8',
'4.4.4.4'
],
}
Using Hiera:
foreman_network:
nameservers_merge: false
nameservers:
- 8.8.8.8
- 4.4.4.4
The result in /etc/resolv.conf will be:
[...]
nameserver 8.8.8.8
nameserver 4.4.4.4
[...]
Overwrite network routes
IMPORTANT: When the boot mode of the primary interface from foreman is a DHCP, all routes for this interface will be ignored IMPORTANT: When NetworkManager is enabled no static routes will be set
Add static route and overwrite the default gateway on interface eth0
class { 'foreman_network':
route_overrides => {
'0.0.0.0/0' => {
'ensure' => 'present',
'gateway' => '10.241.60.253',
'interface' => 'eth0',
'netmask' => '255.255.255.0',
'network' => '10.241.60.0',
},
'10.1.2.0/24' => {
'ensure' => 'present',
'gateway' => '10.1.2.254',
'interface' => 'eth0',
'netmask' => '255.255.255.0',
'network' => '10.1.2.0',
},
}
}
Using Hiera:
foreman_network:
route_overrides:
0.0.0.0/24:
ensure: present
gateway: 10.241.60.253
interface: eth0
netmask: 255.255.255.0
network: 10.241.60.0
10.1.2.0/24:
ensure: present
gateway: 10.1.2.254
interface: eth0
netmask: 255.255.255.0
network: 10.1.2.0
Reference
See REFERENCE.md
Limitations
For a list of supported operating systems, see metadata.json
Development
This module uses puppet_litmus for development and acceptance testing.
Setup testing and development environment (MacOSX)
Install required software with brew
brew cask install docker
brew cask install puppetlabs/puppet/pdk
brew cask install puppet-bolt
brew install rbenv
rbenv init
echo 'eval "$(rbenv init -)"' >> $HOME/.zshrc
curl -fsSL https://github.com/rbenv/rbenv-installer/raw/master/bin/rbenv-doctor | bash
rbenv install 2.6.5
Install all needed gem dependencies:
./scripts/prepare_test_env.sh
Running acceptance tests
Create test environment:
./scripts/create_test_env.sh
Run the acceptance tests:
./scripts/run_tests.sh
Remove the test environment:
./scripts/remove_test_env.sh
Running unit tests
pdk test unit
Updating documentation
Update REFERENCE.md
puppet strings generate --format markdown
Generate TOC
https://ecotrust-canada.github.io/markdown-toc/
Release Notes
See CHANGELOG.md
Reference
Table of Contents
Classes
foreman_network
: Configure network interfaces, routes and resolv.conf from foreman ENC node parametes
Defined types
foreman_network::network_restart
: Restart a network interface
Classes
foreman_network
== Class: foreman_network
Parameters
The following parameters are available in the foreman_network
class.
foreman_interfaces
Data type: Array
ENC node parameter with key foreman_interfaces injected by foreman
Default value: $::foreman_interfaces
foreman_searchpath
Data type: Array
ENC node parameter with key domainname injected by foreman
Default value: [ $::domainname ]
searchpath_merge
Data type: Boolean
If true then merge the entries the foreman_searchpath with searchpath. if false then only use searchpath from foreman
searchpath
Data type: Array
Search list in resolv.conf. if searchpath_merge is true the array will me merged with foreman_searchpath
nameservers_merge
Data type: Boolean
If true then merge the entries given in the nameservers variable with the entries from foreman
nameservers
Data type: Array
List of nameservers which will be either exclusive used or merged. Depends on nameservers_merge
nameservers_merge
If true merges the entries the foreman dns servers with nameservers. if false then only use nameserver
manage_resolv_conf
Data type: Boolean
Specify wether to manage resolve.conf or not. IMPORTANT: If DHCP is enabled on the primary interface resolv.conf will always be unmanged.
route_overrides
Data type: Hash
Overrides the default route provided by foreman and could also add additional static network routes. IMPORTANT: If DHCP enabled is enabled on the primary interface. All routes on the primary interface will be ignored.
mange_network_interface_restart
Data type: Boolean
True means the network interface will be configured (if down & up) immediately on change
manage_if_from_facts_only
Data type: Boolean
If true then only interfaces will be managed that exists in $facts['networking']['interfaces']
resolv_conf_path
Data type: Stdlib::Compat::Absolute_path
The path of the resolv.conf. For docker accaptance test this could be modified
debug
Data type: Boolean
Turn on debug mode
Defined types
foreman_network::network_restart
Apply configuration changes for a network interface
Parameters
The following parameters are available in the foreman_network::network_restart
defined type.
interface
Data type: String
The network interface identifier eg. eth0
mange_network_interface_restart
Data type: Boolean
if true the network interface will be restarted
Default value: $foreman_network::mange_network_interface_restart
Dependencies
- puppet/network (>= 0.9.0 < 1.0.0)
- saz/resolv_conf (>= 4.1.0 < 5.0.0)
- puppetlabs/stdlib (>= 4.13.1 < 7.0.0)