Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions network_importer/adapters/base.py
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
"""BaseAdapter for the network importer."""
from diffsync import DiffSync
from diffsync import Adapter
from diffsync.exceptions import ObjectNotFound
from network_importer.models import Site, Device, Interface, IPAddress, Cable, Vlan, Prefix


class BaseAdapter(DiffSync):
class BaseAdapter(Adapter):
"""Base Adapter for the network importer."""

site = Site
Expand Down
4 changes: 2 additions & 2 deletions network_importer/adapters/nautobot_api/adapter.py
Original file line number Diff line number Diff line change
Expand Up @@ -201,7 +201,7 @@ def load_nautobot_vlan(self, site):
vlans = self.nautobot.ipam.vlans.filter(site=site.name)

for nb_vlan in vlans:
vlan = self.vlan.create_from_pynautobot(diffsync=self, obj=nb_vlan, site_name=site.name)
vlan = self.vlan.create_from_pynautobot(adapter=self, obj=nb_vlan, site_name=site.name)
self.add(vlan)
site.add_child(vlan)

Expand Down Expand Up @@ -326,7 +326,7 @@ def load_nautobot_ip_address(self, site, device): # pylint: disable=unused-argu

ips = self.nautobot.ipam.ip_addresses.filter(device=device.name)
for ipaddr in ips:
ip_address = self.ip_address.create_from_pynautobot(diffsync=self, obj=ipaddr, device_name=device.name)
ip_address = self.ip_address.create_from_pynautobot(adapter=self, obj=ipaddr, device_name=device.name)
ip_address, _ = self.get_or_add(ip_address)

interface = self.get(
Expand Down
162 changes: 81 additions & 81 deletions network_importer/adapters/nautobot_api/models.py

Large diffs are not rendered by default.

20 changes: 6 additions & 14 deletions network_importer/adapters/nautobot_api/settings.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
"""Settings definition for the NetboxAPIAdapter."""
from typing import List, Optional, Union
from pydantic import BaseSettings
from pydantic_settings import BaseSettings
from pydantic import Field

from diffsync import DiffSyncModelFlags

Expand All @@ -9,25 +10,16 @@ class AdapterSettings(BaseSettings):
"""Config settings for the netbox_api adapter. Not used currently."""

model_flag_tags: List[str] = list() # List of tags that defines what objects to assign the model_flag to.
model_flag: Optional[DiffSyncModelFlags] # The model flag that will be applied to objects based on tag.
model_flag: Optional[DiffSyncModelFlags] = None # The model flag that will be applied to objects based on tag.


class InventorySettings(BaseSettings):
"""Config settings for the NautobotAPI inventory."""

address: Optional[str] = "http://localhost"
token: Optional[str] = None
verify_ssl: Union[bool, str] = True
address: Optional[str] = Field(default="http://localhost", env="NAUTOBOT_ADDRESS")
token: Optional[str] = Field(default=None, env="NAUTOBOT_TOKEN")
verify_ssl: Union[bool, str] = Field(default=True, env="NAUTOBOT_VERIFY_SSL")

use_primary_ip: Optional[bool] = True
fqdn: Optional[str] = None
filter: Optional[str] = None

class Config:
"""Additional parameters to automatically map environment variable to some settings."""

fields = {
"address": {"env": "NAUTOBOT_ADDRESS"},
"token": {"env": "NAUTOBOT_TOKEN"},
"verify_ssl": {"env": "NAUTOBOT_VERIFY_SSL"},
}
4 changes: 2 additions & 2 deletions network_importer/adapters/netbox_api/adapter.py
Original file line number Diff line number Diff line change
Expand Up @@ -208,7 +208,7 @@ def load_netbox_vlan(self, site):
vlans = self.netbox.ipam.vlans.filter(site=site.name)

for nb_vlan in vlans:
vlan = self.vlan.create_from_pynetbox(diffsync=self, obj=nb_vlan, site_name=site.name)
vlan = self.vlan.create_from_pynetbox(adapter=self, obj=nb_vlan, site_name=site.name)
self.add(vlan)
site.add_child(vlan)

Expand Down Expand Up @@ -333,7 +333,7 @@ def load_netbox_ip_address(self, site, device): # pylint: disable=unused-argume

ips = self.netbox.ipam.ip_addresses.filter(device=device.name)
for ipaddr in ips:
ip_address = self.ip_address.create_from_pynetbox(diffsync=self, obj=ipaddr, device_name=device.name)
ip_address = self.ip_address.create_from_pynetbox(adapter=self, obj=ipaddr, device_name=device.name)
ip_address, _ = self.get_or_add(ip_address)

interface = self.get(
Expand Down
Loading
Loading