- Description
- Setup - The basics of getting started with netbox
- Usage - Configuration options and additional functionality
- Limitations - OS compatibility, etc.
- Development - Guide for contributing to the module
Puppet module for installing and configuring Netbox, an IPAM (IP Adress Management) tool initially conceived by the network engineering team at DigitalOcean. The documentation for Netbox can be found here
This module installs and configures Netbox. Netbox needs PostgreSQL and Redis to work, and this module can optionally handle that too. Netbox is a Python web applications built on the Django framework and uses the Gunicorn webserver. Usually you place a webserver (like Nginx og Apache) in front of it. This is not part of this module, but a configuration using Apache is provided. Everything in this module is made according to the Netbox documentation. As such, if something is not properly explained here, you can probably find answers to your questions there.
You need to have epel configured. The easiest way to do that is by running:
yum install -y epel-release
This module has been tested with Apache HTTPD using the puppetlabs-apache
module. There are a couple of gotchas, see example with Apache on Centos/RHEL8.
Add dependency modules to your puppet environment:
- camptocamp/systemd
- puppet/archive
- puppetlabs/inifile
- puppetlabs/stdlib
If you are going to use this module to install PostgreSQL and Redis, then you need these as well:
- puppetlabs/postgresql
- puppetlabs/concat
- puppet/redis
If you are following along the Apache example you also need to handle Selinux
:
- puppet/selinux
In its simplest configuration, the module needs only one parameter set. This is the secret_key
. This is something Netbox will not run without, and is recomended to be an at least 50 character long string of letters, symbols and numbers. This is to be treated as a secret.
By default, PostgreSQL and Redis is set up as part of the installation. If you have your own PostgreSQL or Redis installation you want to use, you simply set $handle_database
and $handle_redis
to false
. Some configuration is offered, but if you need to tweek any of those two softwares, I would recommend handling them outside of this module.
If you want to use LDAP, activate the correct parameters (which is easy to find in the REFERENCE). But you must handle the LDAP-config file yourself It is still not implemented due to some complicated template work, and it's almost as easy to handle the file yourself. The Netbox documentation is pretty clear.
The following code shows an example where you have a profile::netbox
(because of course you are using the "roles and profiles" design pattern) which takes in the secret key. This could for example be stored in Hiera eyaml.
class profile::netbox (
String $netbox_secret_key,
) {
class { 'netbox':
secret_key => $netbox_secret_key,
}
}
You also need to set up a django superuser manually after installing. This is the admin account to your Netbox application. To do this, use the virtual Python environment created by the installation and the manage.py
command:
# cd /opt/netbox
# source venv/bin/activate
(venv) # cd netbox
(venv) # python3 manage.py createsuperuser
Username: admin
Email address: admin@example.com
Password:
Password (again):
Superuser created successfully.
If you have installed Netbox in an non-default location, then you have adapt the above description accordingly.
You probably want to adjust your parameters a little more than the minimal example. Here is a more realistic one:
class { 'netbox':
secret_key => $netbox_secret_key,
allowed_hosts => [$trusted[certname], 'localhost'],
banner_top => 'TOP BANNER TEXT',
banner_login => 'WELCOME TO THE NETBOX LOGIN',
banner_bottom => 'BOTTOM BANNER TEXT',
database_password => $netbox_database_password,
email_from_email => "netbox@${trusted[domain]}",
}
The $netbox_database_password
is expected to be defined in wherever you include the Netbox module from. Should probably be stored in Hiera Eyaml.
Here is a full working example with a Netbox profile which includes Netbox module and Apache with settings as recommended in the Netbox documentation. Note that for this setup to work you need:
- The boolean
httpd_can_network_connect
set to true:- Done in the example, requires the
puppet/selinux
module
- Done in the example, requires the
- The
apache
user must be part of thenetbox
group:usermod apache -G netbox
# Netbox
#
# Profile for running Netbox through the ahs/netbox-module
#
class profile::netbox (
String $netbox_secret_key,
) {
selinux::boolean { 'httpd_can_network_connect': }
# usermod apache -G netbox
class { 'netbox':
secret_key => $netbox_secret_key,
allowed_hosts => [$trusted[certname]],
banner_top => 'TOP BANNER TEXT',
banner_bottom => 'BOTTOM BANNER TEXT',
}
class { 'apache':
default_vhost => false,
}
class { 'apache::mod::wsgi':
mod_path => '/usr/lib64/httpd/modules/mod_wsgi_python3.so',
package_name => 'python3-mod_wsgi',
}
apache::vhost { $trusted[certname]:
servername => $trusted[certname],
port => '80',
proxy_preserve_host => true,
docroot => '/opt/netbox/netbox/',
request_headers => [
'set "X-Forwarded-Proto" expr=%{REQUEST_SCHEME}',
],
proxy_pass => [
{ path => '/',
url => 'http://127.0.0.1:8001/',
reverse_url => 'http://127.0.0.1:8001/'
},
],
aliases => [
{ alias => '/static',
path => '/opt/netbox/netbox/static',
},
],
wsgi_pass_authorization => 'On',
directories => [
{ path => '/opt/netbox/netbox/static',
provider => 'directory',
custom_fragment => 'Options Indexes FollowSymLinks MultiViews'
},
{ path => '/static',
provider => 'location',
custom_fragment => 'ProxyPass !'
},
],
}
}
This module is only tested on RHEL/Centos8 at the moment, and will not work for Ubuntu family or older versions of EL just yet.
Upgrading from one version of Netbox to the next is not well tested, so you might need to do some manual steps that are explained in the Netbox documentation.
This module rests too heavily on execs that are ordered and grouped together with different notify
refreshonly
s and it's a bit fragile. So if you make a mistake by for example specifying some parameters wrong in your initial setup, and the Puppet run fails, you might have to do some manual steps. Depending on where the mistake lies, you might have to run pip install -r requirements.txt
, python manage.py migrate
or some other routine. These are explained in the Netbox documentation, and it's usually pretty clear from the error messages what you need to do.
There is only support for the tarball-way of getting Netbox as of now. This should not pose a problem as they are available through the Github repo as releases.
There are several optional integrations and configuration options found in the Netbox documentation that is not supported by this module yet. Including but not limited to:
- Remote File Storage
- Several optional settings
I would be more than happy if you wanted to improve this module. Use the Github issue tracker to submit issues og fork it and issue Pull Requests.