diff --git a/changes/222.fixed b/changes/222.fixed new file mode 100644 index 0000000..34368dd --- /dev/null +++ b/changes/222.fixed @@ -0,0 +1 @@ +Fixed server error when navigating to Policy detail view. diff --git a/changes/233.fixed b/changes/233.fixed new file mode 100644 index 0000000..0785601 --- /dev/null +++ b/changes/233.fixed @@ -0,0 +1,2 @@ +Fixed name fields being optional on multiple forms. +Fixed assigned devices and assigned dynamic groups fields not marked as optional on NATPolicy and Policy. diff --git a/changes/245.fixed b/changes/245.fixed new file mode 100644 index 0000000..7357fa0 --- /dev/null +++ b/changes/245.fixed @@ -0,0 +1,2 @@ +Fixed server error when navigating to NATPolicy detail view. +Fixed server error when updating device/dynamic group weights on NATPolicy. diff --git a/changes/275.fixed b/changes/275.fixed new file mode 100644 index 0000000..720c933 --- /dev/null +++ b/changes/275.fixed @@ -0,0 +1 @@ +Fixed capirca failures with Nautobot v2.3.3 or higher. diff --git a/nautobot_firewall_models/filters.py b/nautobot_firewall_models/filters.py index 990c41f..558778d 100644 --- a/nautobot_firewall_models/filters.py +++ b/nautobot_firewall_models/filters.py @@ -163,6 +163,7 @@ def search(self, queryset, name, value): # pylint: disable=unused-argument """Construct Q filter for filterset.""" if not value.strip(): return queryset + # pylint: disable=unsupported-binary-operation return queryset.filter( Q(name__icontains=value) | Q(description__icontains=value) | Q(request_id__icontains=value) ) @@ -181,6 +182,7 @@ def search(self, queryset, name, value): # pylint: disable=unused-argument """Construct Q filter for filterset.""" if not value.strip(): return queryset + # pylint: disable=unsupported-binary-operation return queryset.filter( Q(name__icontains=value) | Q(description__icontains=value) | Q(request_id__icontains=value) ) diff --git a/nautobot_firewall_models/forms.py b/nautobot_firewall_models/forms.py index e0d9768..d5b1a71 100644 --- a/nautobot_firewall_models/forms.py +++ b/nautobot_firewall_models/forms.py @@ -538,7 +538,6 @@ class PolicyRuleFilterForm(LocalContextFilterForm, NautobotFilterForm): class PolicyRuleForm(LocalContextModelForm, NautobotModelForm): """PolicyRule creation/edit form.""" - name = forms.CharField(required=False, label="Name") tags = DynamicModelMultipleChoiceField(queryset=Tag.objects.all(), required=False) source_users = DynamicModelMultipleChoiceField( queryset=models.UserObject.objects.all(), label="Source User Objects", required=False @@ -710,7 +709,6 @@ class NATPolicyRuleForm(LocalContextModelForm, NautobotModelForm): """NATPolicyRule creation/edit form.""" # Metadata - name = forms.CharField(required=False, label="Name") tags = DynamicModelMultipleChoiceField(queryset=Tag.objects.all(), required=False) request_id = forms.CharField(required=False, label="Optional field for request ticket identifier.") diff --git a/nautobot_firewall_models/migrations/0022_fix_policy_natpolicy_m2ms.py b/nautobot_firewall_models/migrations/0022_fix_policy_natpolicy_m2ms.py new file mode 100644 index 0000000..7257f65 --- /dev/null +++ b/nautobot_firewall_models/migrations/0022_fix_policy_natpolicy_m2ms.py @@ -0,0 +1,54 @@ +# Generated by Django 4.2.16 on 2024-10-03 21:29 + +from django.db import migrations, models + + +class Migration(migrations.Migration): + dependencies = [ + ("dcim", "0014_location_status_data_migration"), + ("extras", "0047_enforce_custom_field_slug"), + ("nautobot_firewall_models", "0021_alter_addressobject_status_and_more"), + ] + + operations = [ + migrations.AlterField( + model_name="natpolicy", + name="assigned_devices", + field=models.ManyToManyField( + blank=True, + related_name="nat_policies", + through="nautobot_firewall_models.NATPolicyDeviceM2M", + to="dcim.device", + ), + ), + migrations.AlterField( + model_name="natpolicy", + name="assigned_dynamic_groups", + field=models.ManyToManyField( + blank=True, + related_name="nat_policies", + through="nautobot_firewall_models.NATPolicyDynamicGroupM2M", + to="extras.dynamicgroup", + ), + ), + migrations.AlterField( + model_name="policy", + name="assigned_devices", + field=models.ManyToManyField( + blank=True, + related_name="firewall_policies", + through="nautobot_firewall_models.PolicyDeviceM2M", + to="dcim.device", + ), + ), + migrations.AlterField( + model_name="policy", + name="assigned_dynamic_groups", + field=models.ManyToManyField( + blank=True, + related_name="firewall_policies", + through="nautobot_firewall_models.PolicyDynamicGroupM2M", + to="extras.dynamicgroup", + ), + ), + ] diff --git a/nautobot_firewall_models/models/nat_policy.py b/nautobot_firewall_models/models/nat_policy.py index da4c528..6b1c2e9 100644 --- a/nautobot_firewall_models/models/nat_policy.py +++ b/nautobot_firewall_models/models/nat_policy.py @@ -252,10 +252,16 @@ class NATPolicy(PrimaryModel): to="nautobot_firewall_models.NATPolicyRule", blank=True, related_name="nat_policies" ) assigned_devices = models.ManyToManyField( - to="dcim.Device", through="NATPolicyDeviceM2M", related_name="nat_policies" + to="dcim.Device", + through="NATPolicyDeviceM2M", + related_name="nat_policies", + blank=True, ) assigned_dynamic_groups = models.ManyToManyField( - to="extras.DynamicGroup", through="NATPolicyDynamicGroupM2M", related_name="nat_policies" + to="extras.DynamicGroup", + through="NATPolicyDynamicGroupM2M", + related_name="nat_policies", + blank=True, ) status = StatusField( on_delete=models.PROTECT, diff --git a/nautobot_firewall_models/models/security_policy.py b/nautobot_firewall_models/models/security_policy.py index 356d6a2..e5fbd71 100644 --- a/nautobot_firewall_models/models/security_policy.py +++ b/nautobot_firewall_models/models/security_policy.py @@ -183,10 +183,16 @@ class Policy(PrimaryModel): name = models.CharField(max_length=100, unique=True) policy_rules = models.ManyToManyField(to=PolicyRule, blank=True, related_name="policies") assigned_devices = models.ManyToManyField( - to="dcim.Device", through="PolicyDeviceM2M", related_name="firewall_policies" + to="dcim.Device", + through="PolicyDeviceM2M", + related_name="firewall_policies", + blank=True, ) assigned_dynamic_groups = models.ManyToManyField( - to="extras.DynamicGroup", through="PolicyDynamicGroupM2M", related_name="firewall_policies" + to="extras.DynamicGroup", + through="PolicyDynamicGroupM2M", + related_name="firewall_policies", + blank=True, ) status = StatusField( on_delete=models.PROTECT, diff --git a/nautobot_firewall_models/templates/nautobot_firewall_models/inc/nat_policy_device_weight.html b/nautobot_firewall_models/templates/nautobot_firewall_models/inc/nat_policy_device_weight.html index 9f6d2cd..a106571 100644 --- a/nautobot_firewall_models/templates/nautobot_firewall_models/inc/nat_policy_device_weight.html +++ b/nautobot_firewall_models/templates/nautobot_firewall_models/inc/nat_policy_device_weight.html @@ -6,7 +6,7 @@ Assign NAT Policy Weight to Device {% if object.natpolicydevicem2m_set.all %} -