NetBox. Плагины

2024-07-22 · 3 мин. для прочтения

Плагины NetBox.

Содержание

1 Общая информация

  • Основные плагины: https://netboxlabs.com/netbox-plugins/
  • Плагины NetBox являются приложениями Django.
  • Плагины могут добавлять свои собственные модели и представления, но не могут вмешиваться в работу существующих компонентов.
  • Архитектура плагинов NetBox позволяет следующее:
    • добавлять новые модели данных;
    • добавлять новые URL-адреса и представления.
      • могут регистрировать URL-адреса /plugins для предоставления пользователям возможности просмотра;
    • добавлять контент в существующие шаблоны моделей;
    • добавлять пункты в меню навигации;
    • добавлять собственное промежуточное программное обеспечение;
    • объявлять параметры конфигурации;
      • параметры конфигурации определяются пользователем в разделе PLUGINS_CONFIG в configuration.py.

2 Установка плагинов

2.1 Установите пакет Python

  • Загрузите и установите пакет Python плагина, следуя инструкциям по установке.
  • Плагины, публикуемые через PyPI, обычно устанавливаются с помощью утилиты pip командной строки.
  • Обязательно установите плагин в виртуальной среде NetBox.
    1source /opt/netbox/venv/bin/activate
    2(venv) $ pip install <package>
    
  • Альтернативно, можно установить плагин вручную:
    1python setup.py install
    

2.2 Включите плагин

  • В configuration.py добавьте имя плагина в список PLUGINS:
    1PLUGINS = [
    2    # ...
    3    'plugin_name',
    4]
    

2.3 Настройте плагин

  • Если плагин требует какой-либо настройки, задайте её в configuration.py в параметре PLUGINS_CONFIG:
    1PLUGINS_CONFIG = {
    2    'plugin_name': {
    3        'foo': 'bar',
    4        'buzz': 'bazz'
    5    }
    6}
    

2.4 Запустите миграцию базы данных

  • Если плагин вводит новые модели базы данных, выполните миграцию схемы:
    1(venv) $ cd /opt/netbox/netbox/
    2(venv) $ python3 manage.py migrate
    

2.5 Статические файлы

  • Плагины могут упаковывать статические ресурсы, такие как изображения или скрипты, для непосредственного обслуживания HTTP-интерфейсом.
  • Убедитесь, что они скопированы в статический корневой каталог с именем collectstatic:
    1(venv) $ cd /opt/netbox/netbox/
    2(venv) $ python3 manage.py collectstatic
    

2.6 Перезапустите службу WSGI

  • Перезапустите службу WSGI:
    1systemctl restart netbox netbox-rq
    

3 Удаление плагинов

3.1 Отключите плагин

  • Отключите плагин, удалив его из списка PLUGINS список в configuration.py .

3.2 Удалите конфигурацию

  • Удалите запись о плагине в словаре PLUGINS_CONFIG в configuration.py .

3.3 Переиндексируйте записи поиска

  • Запустите команду reindex для переиндексации глобальной поисковой системы.
  • Это удалит все устаревшие записи, относящиеся к объектам, предоставляемым плагином:
    1cd /opt/netbox/netbox/
    2source /opt/netbox/venv/bin/activate
    3(venv) $ python3 manage.py reindex
    

3.4 Удалите пакет Python

  • Используйте pip, чтобы удалить установленный плагин:
    1source /opt/netbox/venv/bin/activate
    2(venv) $ pip uninstall <package>
    

3.5 Перезапустите службу WSGI

  • Перезапустите службу WSGI:
    1systemctl restart netbox
    

3.6 Удалите таблицы базы данных

  • Этот шаг необходим только для плагинов, которые создали одну или несколько таблиц базы данных.
  • Войдите в оболочку базы данных PostgreSQL (manage.py dbshell), чтобы определить, создал ли плагин какие-либо таблицы SQL.
  • Можно запустить командe \dt без шаблона для вывода списка всех таблиц.
    1netbox=> \dt pluginname_*
    
  • Удалите каждую из перечисленных таблиц:
    1netbox=> DROP TABLE pluginname_foo;
    2netbox=> DROP TABLE pluginname_bar;
    

3.7 Удалите записи миграции Django

  • После удаления таблиц, созданных плагином, миграции, создавшие эти таблицы, также необходимо удалить из истории миграции Django.
  • Это необходимо для того, чтобы иметь возможность переустановить плагин позже.
  • Если бы история миграции осталась на месте, Django пропустил бы все миграции, которые были выполнены в ходе предыдущей установки, что привело бы к сбою плагина после переустановки.
    1netbox=> SELECT * FROM django_migrations WHERE app='pluginname';
    2netbox=> DELETE FROM django_migrations WHERE app='pluginname';
    
Дмитрий Сергеевич Кулябов
Authors
Профессор кафедры теории вероятностей и кибербезопасности
Мои научные интересы включают физику, администрирование Unix и сетей.