netbox/netbox/tenancy/filtersets.py

195 lines
5.5 KiB
Python
Raw Normal View History

2016-07-26 14:58:37 -04:00
import django_filters
from django.db.models import Q
from netbox.filtersets import ChangeLoggedModelFilterSet, OrganizationalModelFilterSet, NetBoxModelFilterSet
2021-10-18 16:20:31 -04:00
from utilities.filters import ContentTypeFilter, TreeNodeMultipleChoiceFilter
2021-10-18 11:45:05 -04:00
from .models import *
2016-07-26 14:58:37 -04:00
2020-01-08 17:20:31 -05:00
__all__ = (
2021-10-18 11:45:05 -04:00
'ContactAssignmentFilterSet',
'ContactFilterSet',
'ContactGroupFilterSet',
'ContactModelFilterSet',
2021-10-18 11:45:05 -04:00
'ContactRoleFilterSet',
2020-01-09 21:05:38 -05:00
'TenancyFilterSet',
2020-01-09 20:40:32 -05:00
'TenantFilterSet',
'TenantGroupFilterSet',
2020-01-08 17:20:31 -05:00
)
2021-10-18 11:45:05 -04:00
#
# Contacts
2021-10-18 11:45:05 -04:00
#
class ContactGroupFilterSet(OrganizationalModelFilterSet):
parent_id = django_filters.ModelMultipleChoiceFilter(
queryset=ContactGroup.objects.all(),
label='Contact group (ID)',
)
parent = django_filters.ModelMultipleChoiceFilter(
field_name='parent__slug',
queryset=ContactGroup.objects.all(),
to_field_name='slug',
label='Contact group (slug)',
)
class Meta:
model = ContactGroup
fields = ['id', 'name', 'slug', 'description']
class ContactRoleFilterSet(OrganizationalModelFilterSet):
class Meta:
model = ContactRole
fields = ['id', 'name', 'slug', 'description']
2022-03-18 13:17:11 -04:00
class ContactFilterSet(NetBoxModelFilterSet):
group_id = TreeNodeMultipleChoiceFilter(
queryset=ContactGroup.objects.all(),
field_name='group',
lookup_expr='in',
label='Contact group (ID)',
2016-07-26 14:58:37 -04:00
)
group = TreeNodeMultipleChoiceFilter(
queryset=ContactGroup.objects.all(),
field_name='group',
lookup_expr='in',
2016-07-26 14:58:37 -04:00
to_field_name='slug',
label='Contact group (slug)',
2016-07-26 14:58:37 -04:00
)
class Meta:
model = Contact
fields = ['id', 'name', 'title', 'phone', 'email', 'address', 'link']
2016-07-26 14:58:37 -04:00
def search(self, queryset, name, value):
if not value.strip():
return queryset
return queryset.filter(
Q(name__icontains=value) |
Q(title__icontains=value) |
Q(phone__icontains=value) |
Q(email__icontains=value) |
Q(address__icontains=value) |
Q(link__icontains=value) |
Q(comments__icontains=value)
)
2020-01-09 21:05:38 -05:00
class ContactAssignmentFilterSet(ChangeLoggedModelFilterSet):
content_type = ContentTypeFilter()
contact_id = django_filters.ModelMultipleChoiceFilter(
queryset=Contact.objects.all(),
label='Contact (ID)',
2020-01-09 21:05:38 -05:00
)
role_id = django_filters.ModelMultipleChoiceFilter(
queryset=ContactRole.objects.all(),
label='Contact role (ID)',
)
role = django_filters.ModelMultipleChoiceFilter(
field_name='role__slug',
queryset=ContactRole.objects.all(),
2020-01-09 21:05:38 -05:00
to_field_name='slug',
label='Contact role (slug)',
2020-01-09 21:05:38 -05:00
)
class Meta:
model = ContactAssignment
fields = ['id', 'content_type_id', 'object_id', 'priority']
class ContactModelFilterSet(django_filters.FilterSet):
contact = django_filters.ModelMultipleChoiceFilter(
field_name='contacts__contact',
queryset=Contact.objects.all(),
label='Contact',
2020-01-09 21:05:38 -05:00
)
contact_role = django_filters.ModelMultipleChoiceFilter(
field_name='contacts__role',
queryset=ContactRole.objects.all(),
label='Contact Role'
2020-01-09 21:05:38 -05:00
)
2021-10-18 11:45:05 -04:00
#
# Tenancy
2021-10-18 11:45:05 -04:00
#
class TenantGroupFilterSet(OrganizationalModelFilterSet):
2021-10-18 11:45:05 -04:00
parent_id = django_filters.ModelMultipleChoiceFilter(
queryset=TenantGroup.objects.all(),
label='Tenant group (ID)',
2021-10-18 11:45:05 -04:00
)
parent = django_filters.ModelMultipleChoiceFilter(
field_name='parent__slug',
queryset=TenantGroup.objects.all(),
2021-10-18 11:45:05 -04:00
to_field_name='slug',
label='Tenant group (slug)',
2021-10-18 11:45:05 -04:00
)
class Meta:
model = TenantGroup
fields = ['id', 'name', 'slug', 'description']
2021-10-18 11:45:05 -04:00
2022-03-18 13:17:11 -04:00
class TenantFilterSet(NetBoxModelFilterSet, ContactModelFilterSet):
2021-10-18 11:45:05 -04:00
group_id = TreeNodeMultipleChoiceFilter(
queryset=TenantGroup.objects.all(),
2021-10-18 11:45:05 -04:00
field_name='group',
lookup_expr='in',
label='Tenant group (ID)',
2021-10-18 11:45:05 -04:00
)
group = TreeNodeMultipleChoiceFilter(
queryset=TenantGroup.objects.all(),
2021-10-18 11:45:05 -04:00
field_name='group',
lookup_expr='in',
to_field_name='slug',
label='Tenant group (slug)',
2021-10-18 11:45:05 -04:00
)
class Meta:
model = Tenant
fields = ['id', 'name', 'slug', 'description']
2021-10-18 11:45:05 -04:00
def search(self, queryset, name, value):
if not value.strip():
return queryset
return queryset.filter(
Q(name__icontains=value) |
Q(slug__icontains=value) |
Q(description__icontains=value) |
2021-10-18 11:45:05 -04:00
Q(comments__icontains=value)
)
class TenancyFilterSet(django_filters.FilterSet):
"""
An inheritable FilterSet for models which support Tenant assignment.
"""
tenant_group_id = TreeNodeMultipleChoiceFilter(
queryset=TenantGroup.objects.all(),
field_name='tenant__group',
lookup_expr='in',
label='Tenant Group (ID)',
2021-10-18 11:45:05 -04:00
)
tenant_group = TreeNodeMultipleChoiceFilter(
queryset=TenantGroup.objects.all(),
field_name='tenant__group',
to_field_name='slug',
lookup_expr='in',
label='Tenant Group (slug)',
2021-10-18 11:45:05 -04:00
)
tenant_id = django_filters.ModelMultipleChoiceFilter(
queryset=Tenant.objects.all(),
label='Tenant (ID)',
)
tenant = django_filters.ModelMultipleChoiceFilter(
queryset=Tenant.objects.all(),
field_name='tenant__slug',
2021-10-18 11:45:05 -04:00
to_field_name='slug',
label='Tenant (slug)',
2021-10-18 11:45:05 -04:00
)