Skip to main content

Contract management plugin for Netbox

Project description

Contract pluggin

Overview

The pluggin adds contracts and invoices model to Netbox.
It allows to register contract with objects.
Add invoices to contracts.

Check the documentation for additional information

Installation

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. Over in the NetBox installation path, open netbox/netbox/configuration.py and look for the PLUGINS parameter; this 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 configurationitems can be set:

# configuration.py
PLUGINS_CONFIG = {
    'netbox_contract': {
        'top_level_menu': True,
        'default_accounting_dimensions':{
            "account": "", 
            "project": "", 
            "cost center": ""
        },
        'mandatory_contract_fields': ['accounting_dimensions'],
        'hidden_contract_fields': [],
        'mandatory_invoice_fields': ['accounting_dimensions'],
        'hidden_invoice_fields': [],
    }
}
  • 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.
  • 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 partie reference the legal entity of your organization that is a partie to the contract.

# configuration.py
FIELD_CHOICES = {
    'netbox_contract.Contract.internal_partie': (
        ('Nagravision SARL', 'Nagravision SARL', 'green'),
        ('Nagra USA', 'Nagra USA', 'green'),
        ('Nagra India', 'Nagra India', 'green'),
    ),
    'netbox_contract.Contract.currency': (
        ('usd', 'USD'),
        ('eur', 'EUR'),
        ('chf', 'CHF'),
        ('pln', 'PLN'),
    ),
    'netbox_contract.Contract.status': (
        ('Active', 'Active', 'green'),
        ('Cancled', '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.2.1.tar.gz (23.9 kB view details)

Uploaded Source

Built Distribution

netbox_contract-2.2.1-py3-none-any.whl (45.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: netbox_contract-2.2.1.tar.gz
  • Upload date:
  • Size: 23.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.0 CPython/3.12.5

File hashes

Hashes for netbox_contract-2.2.1.tar.gz
Algorithm Hash digest
SHA256 fbed27698cdd9eb3687ecc1288848803addd98b79da743cb004c5314e74b7e30
MD5 6d08d667b76d2c46eac3d8d8c0a41dd7
BLAKE2b-256 08a226617089de41d40ba16f97e82bccc1e6879bd07e678437b83c40272a005d

See more details on using hashes here.

File details

Details for the file netbox_contract-2.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for netbox_contract-2.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ea20c964d3399c196932ea6199b684735c3ee82517b9589be42b95d0006d6845
MD5 357496d91d0421b3abfb0e312609012f
BLAKE2b-256 824efbf8133e6094dc74e920a19d3587c853e25d0b4bd99319cf9f747abb04bd

See more details on using hashes here.

Supported by

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