Skip to main content

A unified communications management plugin for NetBox.

Project description

UCBox Plugin

A Unified Communications Management Plugin for NetBox.

The plugin versions 0.0.1b1-0.0.1b4 support NetBox 2.10.x versions.

Latest plugin version 0.0.1b5 supports NetBox 2.11.0+ versions

Preview

Supported Features and Models

Numbers

The plugin currently implements a Number abstraction representing a single telephone number of an arbitrary format.
A Number can consist of valid DTMF characters and leading plus sign for E.164 support:

  • leading plus ("+") sign (optional)
  • digits 0-9
  • characters A, B, C, D
  • pound sign ("#")
  • asterisk sign ("*")

Sample valid numbers: +12341234567, 1000, 123#2341234567, *100#.
Numbers are stored without delimiters. They will be implemented as an additional formatting function.
Number values can be not unique. Tenant is a mandatory option representing a number partition. Number and Tenant are globally unique.
A Number can optionally be assigned with Provider and Region relations.
A Number can contain an optional Description.
A Number can optionally be tagged with Tags.

The plugin supports Bulk Edit and Delete operations for Numbers.

SIP Trunks

A sip trunk has a name, a region, and destination

Plugin API

The plugin introduces a NetBox REST API extension /api/plugins/ucbox/.
It currently supports all create, read, update, and delete operations for Numbers via /api/plugins/ucbox/numbers/.
The API is compatible with pynetbox:

>>> nb.plugins.ucbox.numbers.get(7)
2000
>>> 

Installation

General installation steps and considerations follow the official guidelines.

Package Installation from PyPi

Assuming you use a Virtual Environment for Netbox:

$ source /opt/netbox/venv/bin/activate
(venv) $ pip3 install ucbox_plugin

Package Installation from Source Code

The source code is available on GitHub.
Download and install the package. Assuming you use a Virtual Environment for Netbox:

$ git clone https://github.com/iDebugAll/ucbox_plugin
$ cd ucbox_plugin
$ source /opt/netbox/venv/bin/activate
(venv) $ pip3 install .

To ensure NextBox UI plugin is automatically re-installed during future upgrades, create a file named local_requirements.txt (if not already existing) in the NetBox root directory (alongside requirements.txt) and list the ucbox_plugin package:

# echo ucbox_plugin >> local_requirements.txt

Enable the Plugin

In a global Netbox configuration.py configuration file, update or add PLUGINS parameter:

PLUGINS = [
    'ucbox_plugin',
]

Collect Static Files

The Plugin contains static files for topology visualization. They should be served directly by the HTTP frontend. In order to collect them from the package to the Netbox static root directory use the following command:

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

Apply Database Migrations

Apply database migrations with Django manage.py:

(venv) $ python3 manage.py migrate

Restart Netbox

Restart the WSGI service to apply changes:

sudo systemctl restart netbox

Installation with Docker

The Plugin may be installed in a Netbox Docker deployment. The package contains a Dockerfile for Netbox-Community Docker extension. Latest-LDAP version is used by default as a source.
Download the Plugin and build from source:

$ git clone https://github.com/iDebugAll/ucbox_plugin
$ cd ucbox_plugin
$ docker build -t netbox-custom .

Update a netbox image name in docker-compose.yml in a Netbox Community Docker project root:

services:
  netbox: &netbox
    image: netbox-custom:latest

Update a configuration.py. It is stored in netbox-docker/configuration/ by default. Update or add PLUGINS parameter and PLUGINS_CONFIG parameter as described above.

Rebuild the running docker containers:

$ cd netbox-docker
$ docker-compose down
$ docker-compose up -d

Netbox Community Docker setup performs static files collection on every startup. No manual actions required.

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

ucbox_plugin-0.0.12.tar.gz (17.3 kB view details)

Uploaded Source

Built Distribution

ucbox_plugin-0.0.12-py3-none-any.whl (33.6 kB view details)

Uploaded Python 3

File details

Details for the file ucbox_plugin-0.0.12.tar.gz.

File metadata

  • Download URL: ucbox_plugin-0.0.12.tar.gz
  • Upload date:
  • Size: 17.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/3.8.2

File hashes

Hashes for ucbox_plugin-0.0.12.tar.gz
Algorithm Hash digest
SHA256 8269a72fdd3bafedf8d3f96a378ec7ab03a8a4acbcd2591a4308c796a97c4b01
MD5 d22969d86cdc4df8a4565c08316558d6
BLAKE2b-256 2e93350633864b24ba1511635038c8e96e90861bb83a78657268f88ccb7e5fb5

See more details on using hashes here.

File details

Details for the file ucbox_plugin-0.0.12-py3-none-any.whl.

File metadata

  • Download URL: ucbox_plugin-0.0.12-py3-none-any.whl
  • Upload date:
  • Size: 33.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/3.8.2

File hashes

Hashes for ucbox_plugin-0.0.12-py3-none-any.whl
Algorithm Hash digest
SHA256 fca2bfefb6b409af7e37d47abd8cda9217fcf665613486469fa84c013283d70a
MD5 4a3cd4d8cd3a194f1c78e4f3d3caee7e
BLAKE2b-256 c34a731ccf996d48c278b7aff33c473b5aaeaeae1c1d807b1d9a8f4932e2b119

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