Skip to main content

Contract management plugin for Netbox

Project description

Contract plugin

NetBox plugin to manage contracts.

Features

The plugin adds contracts and invoices model to NetBox.
It allows to link contract with objects.
And link invoice templates and invoices with contracts.
Invoice lines can be linked to each invoice / invoice template.
Accounting dimensions can be linked with invoice lines.

Compatibility

NetBox Version Plugin Version
4.1 2.2
4.2 2.3
4.3 2.4
4.4 2.4
4.5 2.4

Installing

Activate venv

To ensure our plugin is accessible to the NetBox installation, we first need to activate the Python virtual environment that was created when we installed NetBox. To do this, determine the virtual environment's path (this will be /opt/netbox/venv/ if you use the documentation's defaults) and activate it:

$ source /opt/netbox/venv/bin/activate

Install the package

$ python3 -m pip install netbox-contract

Configure NetBox

Finally, we need to configure NetBox to enable our new plugin. In the NetBox installation directory, open netbox/netbox/configuration.py and locate the PLUGINS parameter; it should be an empty list. (If it's not yet defined, go ahead and create it.) Add the name of our plugin to this list:

# configuration.py
PLUGINS = [
    'netbox_contract',
]

Customize the plugin

The following configuration items can be set:

# configuration.py
PLUGINS_CONFIG = {
    'netbox_contract': {
        'top_level_menu': True,
        'mandatory_contract_fields': [],
        'hidden_contract_fields': [],
        'mandatory_invoice_fields': [],
        'hidden_invoice_fields': [],
        'mandatory_dimensions': [],
        'supported_models': [
            'circuits.circuit',
            'circuits.virtualcircuit',
            'dcim.site',
            'dcim.device',
            'dcim.rack',
            'virtualization.virtualmachine',
            'virtualization.cluster',
            'ipam.ipaddress',
            'ipam.prefix',
        ],
        'contract_assignments_display': 'both',  # options: 'tab', 'inline', 'both'
    }
}
  • top_level_menu : If "Contracts" appears under the "Plugins" menu item or on its own
  • contract_assignments_display:
    • 'tab' - only the Contracts view tab is visible on the related object page.
    • 'inline' - only the inline contract assignments table is shown in object detail; the Contracts tab is hidden.
    • 'both' - both tab and inline table are shown (default behavior).
  • default_accounting_dimensions: The accounting dimensions which will appear in the field' background when empty. Note that accounting dimensions are now managed as individual objects. The use of this field is deprecated.
  • mandatory_contract_fields, mandatory_invoice_fields: Fields which are not required by default and can be set as such. The list of fields is at the bottom of the contract import form.
  • hidden_contract_fields, hidden_invoice_fields: List of fields to be hidden. Fields should not be required to be hidden.

Customize the plugin fields choices

Internal party reference the legal entity of your organization that is a party to the contract.
The first currency will also be the default currency for contracts.

# configuration.py
FIELD_CHOICES = {
    'netbox_contract.Contract.internal_party': (
        ('default', 'Default entity', 'green'),
        ('entity1', 'Entity 1', 'green'),
        ('entity2', 'Entity 2', 'yellow'),
    ),
    'netbox_contract.Contract.currency': (
        ('usd', 'USD'),  # 1st position is the default currency
        ('eur', 'EUR'),
        ('chf', 'CHF'),
        ('pln', 'PLN'),
    ),
    'netbox_contract.Contract.status': (
        ('active', 'Active', 'green'),
        ('canceled', 'Canceled', 'red'),
    )
    'netbox_contract.Invoice.status': (
        ('draft', 'Draft', 'yellow'),
        ('posted', 'Posted', 'green'),
        ('canceled', 'Canceled', 'red'),
    )
}

Run database migrations

(venv) $ cd /opt/netbox/netbox/
(venv) $ python3 manage.py migrate

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_contract-2.4.5.tar.gz (289.5 kB view details)

Uploaded Source

Built Distribution

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

netbox_contract-2.4.5-py3-none-any.whl (67.2 kB view details)

Uploaded Python 3

File details

Details for the file netbox_contract-2.4.5.tar.gz.

File metadata

  • Download URL: netbox_contract-2.4.5.tar.gz
  • Upload date:
  • Size: 289.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for netbox_contract-2.4.5.tar.gz
Algorithm Hash digest
SHA256 41f59761fe70a82f101f578f653c5c70522dbd4e19829e097636993782103aa2
MD5 8c5104a1b58c81089a03689bd6186767
BLAKE2b-256 286a182cc2d208a4044a1be4b5d89a846abf1beed95a4eebdfa09d5e04cd51ad

See more details on using hashes here.

Provenance

The following attestation bundles were made for netbox_contract-2.4.5.tar.gz:

Publisher: python-publish.yml on mlebreuil/netbox-contract

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_contract-2.4.5-py3-none-any.whl.

File metadata

File hashes

Hashes for netbox_contract-2.4.5-py3-none-any.whl
Algorithm Hash digest
SHA256 1739cf894c107ef9f367c9b3583466b8bc8798a11c4903878504d3327e53d3fb
MD5 08c04dbf246bb110b5cb858741a6fce6
BLAKE2b-256 bdd5f7b15366c7577e5b9796b68196fe47b012caf19d2ffa50186845784b7a90

See more details on using hashes here.

Provenance

The following attestation bundles were made for netbox_contract-2.4.5-py3-none-any.whl:

Publisher: python-publish.yml on mlebreuil/netbox-contract

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