Skip to content

Commit

Permalink
fixed acl assignment form filtering (#125)
Browse files Browse the repository at this point in the history
  • Loading branch information
abhi1693 authored Feb 3, 2023
1 parent b1999e7 commit 269354f
Showing 1 changed file with 29 additions and 20 deletions.
49 changes: 29 additions & 20 deletions netbox_acls/forms/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -65,19 +65,20 @@ class AccessListForm(NetBoxModelForm):
region = DynamicModelChoiceField(
queryset=Region.objects.all(),
required=False,
initial_params={
"sites": "$site",
},
)
site_group = DynamicModelChoiceField(
queryset=SiteGroup.objects.all(),
required=False,
label="Site Group",
initial_params={"sites": "$site"},
)
site = DynamicModelChoiceField(
queryset=Site.objects.all(),
required=False,
query_params={
"region_id": "$region",
"group_id": "$site_group",
},
query_params={"region_id": "$region", "group_id": "$site_group"},
)
device = DynamicModelChoiceField(
queryset=Device.objects.all(),
Expand All @@ -101,32 +102,24 @@ class AccessListForm(NetBoxModelForm):
queryset=ClusterType.objects.all(),
required=False,
)

cluster_group = DynamicModelChoiceField(
queryset=ClusterGroup.objects.all(),
required=False,
query_params={
"type_id": "$cluster_type",
},
query_params={"type_id": "$cluster_type"},
)

cluster = DynamicModelChoiceField(
queryset=Cluster.objects.all(),
required=False,
query_params={
"type_id": "$cluster_type",
"group_id": "$cluster_group",
},
query_params={"type_id": "$cluster_type", "group_id": "$cluster_group"},
)

virtual_machine = DynamicModelChoiceField(
queryset=VirtualMachine.objects.all(),
required=False,
label="Virtual Machine",
query_params={
"cluster_id": "$cluster",
"cluster_type_id": "$cluster_type",
"cluster_group_id": "$cluster_group",
"cluster_id": "$cluster",
},
)

Expand Down Expand Up @@ -161,14 +154,30 @@ def __init__(self, *args, **kwargs):
instance = kwargs.get("instance")
initial = kwargs.get("initial", {}).copy()
if instance:
if type(instance.assigned_object) is Device:
if isinstance(instance.assigned_object, Device):
initial["device"] = instance.assigned_object
elif type(instance.assigned_object) is VirtualChassis:
initial["virtual_chassis"] = instance.assigned_object
elif type(instance.assigned_object) is VirtualMachine:
if instance.assigned_object.site:
initial["site"] = instance.assigned_object.site
if instance.assigned_object.site.group:
initial["site_group"] = instance.assigned_object.site.group

if instance.assigned_object.site.region:
initial["region"] = instance.assigned_object.site.region
elif isinstance(instance.assigned_object, VirtualMachine):
initial["virtual_machine"] = instance.assigned_object
kwargs["initial"] = initial
if instance.assigned_object.cluster:
initial["cluster"] = instance.assigned_object.cluster
if instance.assigned_object.cluster.group:
initial[
"cluster_group"
] = instance.assigned_object.cluster.group

if instance.assigned_object.cluster.type:
initial["cluster_type"] = instance.assigned_object.cluster.type
elif isinstance(instance.assigned_object, VirtualChassis):
initial["virtual_chassis"] = instance.assigned_object

kwargs["initial"] = initial
super().__init__(*args, **kwargs)

def clean(self):
Expand Down

0 comments on commit 269354f

Please sign in to comment.