From 4cf32d51e0fbd28e82a35fc4983c8083d01f9a24 Mon Sep 17 00:00:00 2001 From: Jeremy Stretch Date: Tue, 24 Sep 2024 15:47:25 -0400 Subject: [PATCH] Replicate dcim_cablepath table for branch --- netbox_branching/constants.py | 6 ++++++ netbox_branching/database.py | 5 ----- netbox_branching/utilities.py | 5 +++-- 3 files changed, 9 insertions(+), 7 deletions(-) diff --git a/netbox_branching/constants.py b/netbox_branching/constants.py index ea9e7fa..938963d 100644 --- a/netbox_branching/constants.py +++ b/netbox_branching/constants.py @@ -10,6 +10,12 @@ # URL query parameter name QUERY_PARAM = '_branch' +# Tables which must be replicated within a branch even though their +# models don't directly support branching. +REPLICATE_TABLES = ( + 'dcim_cablepath', +) + # Models for which branching support is explicitly disabled EXEMPT_MODELS = ( # Exempt applicable core NetBox models diff --git a/netbox_branching/database.py b/netbox_branching/database.py index 842f881..3c749fc 100644 --- a/netbox_branching/database.py +++ b/netbox_branching/database.py @@ -21,11 +21,6 @@ def _get_db(self, model, **hints): warnings.warn(f"Routing database query for {model} before branching support is initialized.") return - # Bail if the model does not support branching - app_label, model_name = model._meta.label.lower().split('.') - if model_name not in registry['model_features']['branching'].get(app_label, []): - return - # Return the schema for the active branch (if any) if branch := active_branch.get(): return f'schema_{branch.schema_name}' diff --git a/netbox_branching/utilities.py b/netbox_branching/utilities.py index 4beb534..ea38cea 100644 --- a/netbox_branching/utilities.py +++ b/netbox_branching/utilities.py @@ -6,6 +6,7 @@ from django.db.models import ForeignKey, ManyToManyField from django.urls import reverse +from .constants import REPLICATE_TABLES from .contextvars import active_branch __all__ = ( @@ -81,9 +82,9 @@ def get_branchable_object_types(): def get_tables_to_replicate(): """ - Returned an ordered list of database tables to replicate when provisioning a new schema. + Return an ordered list of database tables to replicate when provisioning a new schema. """ - tables = set() + tables = set(REPLICATE_TABLES) branch_aware_models = [ ot.model_class() for ot in get_branchable_object_types()