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

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',
        ],
    }
}
  • top_level_menu : If "Contracts" appears under the "Plugins" menu item or on its own
  • 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.4.tar.gz (288.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_contract-2.4.4-py3-none-any.whl (65.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: netbox_contract-2.4.4.tar.gz
  • Upload date:
  • Size: 288.1 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.4.tar.gz
Algorithm Hash digest
SHA256 130a03ae27fb620cac6ee1ef48e997ed7a4e9517cc127daa3e8c368d704658cf
MD5 167f84c9af4e3008737ae49d86b801c4
BLAKE2b-256 6b56dfdbe860b9b14c31424277653abd5a8722290683ea32f84118827ed8febe

See more details on using hashes here.

Provenance

The following attestation bundles were made for netbox_contract-2.4.4.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.4-py3-none-any.whl.

File metadata

File hashes

Hashes for netbox_contract-2.4.4-py3-none-any.whl
Algorithm Hash digest
SHA256 d7e9bbb809ff15a3bf833ae48be6e0b3b9cb1bc76434c237e7b4009ec24589cd
MD5 369d038b62e4399f90ec333fd9b79829
BLAKE2b-256 8bd5ea527c99dac0d5c5a3c49b91634eefb438aa5bd955ce9f0f4a269080ebb4

See more details on using hashes here.

Provenance

The following attestation bundles were made for netbox_contract-2.4.4-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