Skip to main content

A Bind provisioning plugin that uses netbox_dns for its data source

Project description

Netbox Bind Provisioner

The Netbox Bind Provisioner plugin implements a lightweight DNS server inside Netbox and builds a bridge for BIND and other DNS Servers implementing RFC9432 to retrieve DNS Zones directly from Netbox using DNS native mechanisms.

PyPi Stars Badge Forks Badge Issues Badge Pull Requests Badge GitHub contributors License Badge Code Style Black Downloads Downloads/Week Downloads/Month

Plugin configuration

While providing Zone transfers via AXFR, the Server also exposes specialized catalog zones that BIND and other RFC9432 compliant DNS Servers use to automatically discover newly created zones and remove deleted ones. The plugin supports views and basic DNS security via TSIG.

The plugin exposes one catalog zone per view. Each catalog zone is made available under the special zone name "catz" and addtionally under "[viewname].catz" and may be queried through the built-in DNS server just like any other dns zone.

For proper operation, each view requires an installed TSIG key, and the dns-transfer-endpoint must be running as a separate background service using the manage.py command. Note that DNSSEC support will be added once BIND9 provides a mechanism to configure it through the Catalog Zones system.

To start the service in the foreground:

manage.py dns-transfer-endpoint --port 5354

This process needs to be scheduled as a background service for the built-in DNS Server to work correctly. For Linux users with Systemd (Ubuntu, etc), Matt Kollross provides a startup unit and instructions here.

Service parameters

Parameter Description
--port Port to listen on for requests (defaults to 5354)
--address IP of interface to bind to (defaults to 0.0.0.0)

Plugin settings

Setting Description
tsig_keys Maps a TSIG Key to be used for each view.

Installation guide

This setup provisions a BIND9 server directly with DNS data from NetBox. BIND9 can optionally run on a separate server. If so, any reference to 127.0.0.1 in step 6 must be replaced with the IP address of the NetBox host. TCP and UDP traffic from the BIND9 server to the NetBox host must be allowed on port 5354 (or the port you have configured).

This guide assumes:

  • Netbox has been installed under /opt/netbox
  • Bind9 is installed on the same host as Netbox
  • The Netbox DNS Plugin netbox-plugin-dns is installed
  • The following dns views exist in Netbox DNS:
    • public (the default)
    • private
  1. Preliminaries

    • Install Bind9 on the same host that netbox is on.
    • Generate a TSIG Key for the public and private dns views respectively.
  2. Adding required package

    cd netbox
    echo netbox-plugin-bind-provisioner >> local_requirements.txt
    . venv/bin/activate
    pip install -r local_requirements.txt
    
  3. Updating netbox plugin configuration (configuration.py) Change following line from

    PLUGINS = ['netbox_dns']
    

    to

    PLUGINS = ['netbox_dns', 'netbox_plugin_bind_provisioner']
    

    Configure the Bind Exporter Plugin using the PLUGINS_CONFIG dictionary. Change

    PLUGINS_CONFIG = {}
    

    to

    PLUGINS_CONFIG = {
        "netbox_plugin_bind_provisioner": {
            "tsig_keys": {
                "public": {
                    "keyname":   "public_view_key",
                    "algorithm": "hmac-sha256",
                    "secret":    "base64-encoded-secret"
                },
                "private": {
                    "keyname":   "private_view_key",
                    "algorithm": "hmac-sha256",
                    "secret":    "base64-encoded-secret"
                }
            }
        }
    }
    

    Note that the tsig-key attributes keyname, algorithm and secret form a dictionary in following python structure path:

    PLUGINS_CONFIG.netbox_plugin_bind_provisioner.tsig_keys.<dns_view_name>
    

    This allows the plugin to map requests to the right dns view using the tsig signature from each request.

  4. Run migrations

    python3 netbox/manage.py migrate
    
  5. Start listener

    This step runs the DNS endpoint used by bind to configure itself. You may want to write a service wrapper that runs this in the background. A guide for setting up a systemd service on Ubuntu is provided by Matt Kollross here. Dont forget to activate the venv if you do decide to run this service in the background.

    Note that --port 5354 is optional. The listener will bind this port by default.

    python3 netbox/manage.py dns-transfer-endpoint --port 5354
    
  6. Configuring a Bind9 to interact with Netbox via the dns-transfer-endpoint endpoint. Note that its not possible to give all the correct details of the options block as it is heavily dependent on the Operating System used. Please dont forget to adjust as required.

    ########## OPTIONS ##########
    
    options {
        allow-update      { none; };
        allow-query       { any; };
        allow-recursion   { none; };
        notify            yes;
        min-refresh-time  60;
    };
    
    ########## ACLs ##########
    
    acl public {
        !10.0.0.0/8;
        !172.16.0.0/12;
        !192.168.0.0/16;
        any;
    };
    
    acl private {
        10.0.0.0/8;
        172.16.0.0/12;
        192.168.0.0/16;
    };
    
    ########## ZONES ##########
    
    view "public" {
        key "public_view_key" {
            algorithm hmac-sha256;
            secret "base64-encoded-secret";
        };
    
        match-clients { public; };
    
        catalog-zones {
            zone "catz"
                default-masters { 127.0.0.1 port 5354 key "public_view_key"; }
                zone-directory "/var/lib/bind/zones"
                min-update-interval 1;
        };
    
        zone "catz" {
            type slave;
            file "/var/lib/bind/zones/catz_public";
            masters { 127.0.0.1 port 5354 key "public_view_key"; };
            notify no;
        };
    };
    
    view "private" {
        key "private_view_key" {
            algorithm hmac-sha256;
            secret "base64-encoded-secret";
        };
    
        match-clients { private; };
    
        catalog-zones {
            zone "catz"
                default-masters { 127.0.0.1 port 5354 key "private_view_key"; }
                zone-directory "/var/lib/bind/zones"
                min-update-interval 1;
        };
    
        zone "catz" {
            type slave;
            file "/var/lib/bind/zones/catz_private";
            masters { 127.0.0.1 port 5354 key "private_view_key"; };
            notify no;
        };
    };
    
  7. Restart bind - Done

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

netbox_plugin_bind_provisioner-1.0.7.tar.gz (25.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

netbox_plugin_bind_provisioner-1.0.7-py3-none-any.whl (28.8 kB view details)

Uploaded Python 3

File details

Details for the file netbox_plugin_bind_provisioner-1.0.7.tar.gz.

File metadata

File hashes

Hashes for netbox_plugin_bind_provisioner-1.0.7.tar.gz
Algorithm Hash digest
SHA256 56c447ba9b2766e2b5dc3ef0b638093cd23c331b70e483477264dfea9bcbdee2
MD5 9fca520e5ce2f0e789d41fc53af22c1b
BLAKE2b-256 10becb1a24feda20eec96fecca718256dd91ca34a0682bb553d8c92f598f55c7

See more details on using hashes here.

Provenance

The following attestation bundles were made for netbox_plugin_bind_provisioner-1.0.7.tar.gz:

Publisher: python-publish.yml on Suraxius/netbox-plugin-bind-provisioner

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file netbox_plugin_bind_provisioner-1.0.7-py3-none-any.whl.

File metadata

File hashes

Hashes for netbox_plugin_bind_provisioner-1.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 2232e7925f248ebda1eb199a183460564810612dd50f7cdffb7d352c91766715
MD5 6b39e8313a9b85ef88064231a2fe2938
BLAKE2b-256 72ba5855e9440673bea80878e17d093bca3bf99d6a3f1f65797c189c91780455

See more details on using hashes here.

Provenance

The following attestation bundles were made for netbox_plugin_bind_provisioner-1.0.7-py3-none-any.whl:

Publisher: python-publish.yml on Suraxius/netbox-plugin-bind-provisioner

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page