282 lines
8.6 KiB
Python
Raw Normal View History

2017-08-16 17:00:17 -04:00
import django_filters
from django.db.models import Q
from dcim.models import DeviceRole, Platform, Region, Site, SiteGroup
2020-11-23 14:47:54 -05:00
from extras.filters import CustomFieldModelFilterSet, CreatedUpdatedFilterSet, LocalConfigContextFilterSet
2020-01-09 21:05:38 -05:00
from tenancy.filters import TenancyFilterSet
from utilities.filters import (
2020-03-06 12:05:53 -05:00
BaseFilterSet, MultiValueMACAddressFilter, NameSlugSearchFilterSet, TagFilter,
2020-02-09 17:46:21 -05:00
TreeNodeMultipleChoiceFilter,
)
2019-12-04 20:40:18 -05:00
from .choices import *
2020-06-23 13:16:21 -04:00
from .models import Cluster, ClusterGroup, ClusterType, VirtualMachine, VMInterface
2017-08-16 17:00:17 -04:00
2020-01-08 17:20:31 -05:00
__all__ = (
2020-01-09 20:42:32 -05:00
'ClusterFilterSet',
'ClusterGroupFilterSet',
'ClusterTypeFilterSet',
'VirtualMachineFilterSet',
2020-06-23 16:39:43 -04:00
'VMInterfaceFilterSet',
2020-01-08 17:20:31 -05:00
)
2020-02-09 17:46:21 -05:00
class ClusterTypeFilterSet(BaseFilterSet, NameSlugSearchFilterSet):
class Meta:
model = ClusterType
fields = ['id', 'name', 'slug', 'description']
2020-02-09 17:46:21 -05:00
class ClusterGroupFilterSet(BaseFilterSet, NameSlugSearchFilterSet):
class Meta:
model = ClusterGroup
fields = ['id', 'name', 'slug', 'description']
2020-11-23 14:47:54 -05:00
class ClusterFilterSet(BaseFilterSet, TenancyFilterSet, CustomFieldModelFilterSet, CreatedUpdatedFilterSet):
2017-08-16 17:00:17 -04:00
q = django_filters.CharFilter(
method='search',
label='Search',
)
region_id = TreeNodeMultipleChoiceFilter(
queryset=Region.objects.all(),
2020-02-09 17:46:21 -05:00
field_name='site__region',
lookup_expr='in',
label='Region (ID)',
)
region = TreeNodeMultipleChoiceFilter(
queryset=Region.objects.all(),
2020-02-09 17:46:21 -05:00
field_name='site__region',
lookup_expr='in',
to_field_name='slug',
label='Region (slug)',
)
site_group_id = TreeNodeMultipleChoiceFilter(
queryset=SiteGroup.objects.all(),
field_name='site__group',
lookup_expr='in',
label='Site group (ID)',
)
site_group = TreeNodeMultipleChoiceFilter(
queryset=SiteGroup.objects.all(),
field_name='site__group',
lookup_expr='in',
to_field_name='slug',
label='Site group (slug)',
)
site_id = django_filters.ModelMultipleChoiceFilter(
queryset=Site.objects.all(),
label='Site (ID)',
)
site = django_filters.ModelMultipleChoiceFilter(
field_name='site__slug',
queryset=Site.objects.all(),
to_field_name='slug',
label='Site (slug)',
)
group_id = django_filters.ModelMultipleChoiceFilter(
queryset=ClusterGroup.objects.all(),
2017-08-16 17:00:17 -04:00
label='Parent group (ID)',
)
group = django_filters.ModelMultipleChoiceFilter(
2018-11-02 13:46:28 -04:00
field_name='group__slug',
queryset=ClusterGroup.objects.all(),
2017-08-16 17:00:17 -04:00
to_field_name='slug',
label='Parent group (slug)',
)
type_id = django_filters.ModelMultipleChoiceFilter(
queryset=ClusterType.objects.all(),
2017-08-16 17:00:17 -04:00
label='Cluster type (ID)',
)
type = django_filters.ModelMultipleChoiceFilter(
2018-11-02 13:46:28 -04:00
field_name='type__slug',
queryset=ClusterType.objects.all(),
2017-08-16 17:00:17 -04:00
to_field_name='slug',
label='Cluster type (slug)',
)
tag = TagFilter()
2017-08-16 17:00:17 -04:00
class Meta:
model = Cluster
fields = ['id', 'name']
2017-08-16 17:00:17 -04:00
def search(self, queryset, name, value):
if not value.strip():
return queryset
return queryset.filter(
Q(name__icontains=value) |
Q(comments__icontains=value)
)
class VirtualMachineFilterSet(
2020-02-09 17:46:21 -05:00
BaseFilterSet,
LocalConfigContextFilterSet,
TenancyFilterSet,
2020-11-23 14:47:54 -05:00
CustomFieldModelFilterSet,
CreatedUpdatedFilterSet
):
2017-08-16 17:00:17 -04:00
q = django_filters.CharFilter(
method='search',
label='Search',
)
status = django_filters.MultipleChoiceFilter(
2019-12-04 20:40:18 -05:00
choices=VirtualMachineStatusChoices,
null_value=None
)
cluster_group_id = django_filters.ModelMultipleChoiceFilter(
2018-11-02 13:46:28 -04:00
field_name='cluster__group',
queryset=ClusterGroup.objects.all(),
2017-08-16 17:00:17 -04:00
label='Cluster group (ID)',
)
cluster_group = django_filters.ModelMultipleChoiceFilter(
2018-11-02 13:46:28 -04:00
field_name='cluster__group__slug',
queryset=ClusterGroup.objects.all(),
2017-08-16 17:00:17 -04:00
to_field_name='slug',
label='Cluster group (slug)',
)
cluster_type_id = django_filters.ModelMultipleChoiceFilter(
2018-11-02 13:46:28 -04:00
field_name='cluster__type',
queryset=ClusterType.objects.all(),
label='Cluster type (ID)',
)
cluster_type = django_filters.ModelMultipleChoiceFilter(
2018-11-02 13:46:28 -04:00
field_name='cluster__type__slug',
queryset=ClusterType.objects.all(),
to_field_name='slug',
label='Cluster type (slug)',
)
cluster_id = django_filters.ModelMultipleChoiceFilter(
queryset=Cluster.objects.all(),
2017-09-15 11:36:06 -04:00
label='Cluster (ID)',
)
2019-03-04 14:57:35 -05:00
region_id = TreeNodeMultipleChoiceFilter(
queryset=Region.objects.all(),
2020-02-09 17:46:21 -05:00
field_name='cluster__site__region',
lookup_expr='in',
label='Region (ID)',
)
2019-03-04 14:57:35 -05:00
region = TreeNodeMultipleChoiceFilter(
queryset=Region.objects.all(),
2020-02-09 17:46:21 -05:00
field_name='cluster__site__region',
lookup_expr='in',
2019-03-04 14:57:35 -05:00
to_field_name='slug',
label='Region (slug)',
)
site_group_id = TreeNodeMultipleChoiceFilter(
queryset=SiteGroup.objects.all(),
field_name='cluster__site__group',
lookup_expr='in',
label='Site group (ID)',
)
site_group = TreeNodeMultipleChoiceFilter(
queryset=SiteGroup.objects.all(),
field_name='cluster__site__group',
lookup_expr='in',
to_field_name='slug',
label='Site group (slug)',
)
site_id = django_filters.ModelMultipleChoiceFilter(
2018-11-02 13:46:28 -04:00
field_name='cluster__site',
queryset=Site.objects.all(),
label='Site (ID)',
)
site = django_filters.ModelMultipleChoiceFilter(
2018-11-02 13:46:28 -04:00
field_name='cluster__site__slug',
queryset=Site.objects.all(),
to_field_name='slug',
label='Site (slug)',
)
role_id = django_filters.ModelMultipleChoiceFilter(
queryset=DeviceRole.objects.all(),
label='Role (ID)',
)
role = django_filters.ModelMultipleChoiceFilter(
2018-11-02 13:46:28 -04:00
field_name='role__slug',
queryset=DeviceRole.objects.all(),
to_field_name='slug',
label='Role (slug)',
)
platform_id = django_filters.ModelMultipleChoiceFilter(
queryset=Platform.objects.all(),
2017-08-16 17:00:17 -04:00
label='Platform (ID)',
)
platform = django_filters.ModelMultipleChoiceFilter(
2018-11-02 13:46:28 -04:00
field_name='platform__slug',
queryset=Platform.objects.all(),
2017-08-16 17:00:17 -04:00
to_field_name='slug',
label='Platform (slug)',
)
mac_address = MultiValueMACAddressFilter(
field_name='interfaces__mac_address',
label='MAC address',
)
has_primary_ip = django_filters.BooleanFilter(
method='_has_primary_ip',
label='Has a primary IP',
)
tag = TagFilter()
2017-08-16 17:00:17 -04:00
class Meta:
model = VirtualMachine
fields = ['id', 'name', 'cluster', 'vcpus', 'memory', 'disk']
2017-08-16 17:00:17 -04:00
def search(self, queryset, name, value):
if not value.strip():
return queryset
return queryset.filter(
Q(name__icontains=value) |
Q(comments__icontains=value)
)
def _has_primary_ip(self, queryset, name, value):
params = Q(primary_ip4__isnull=False) | Q(primary_ip6__isnull=False)
if value:
return queryset.filter(params)
return queryset.exclude(params)
class VMInterfaceFilterSet(BaseFilterSet, CustomFieldModelFilterSet, CreatedUpdatedFilterSet):
q = django_filters.CharFilter(
method='search',
label='Search',
)
cluster_id = django_filters.ModelMultipleChoiceFilter(
field_name='virtual_machine__cluster',
queryset=Cluster.objects.all(),
label='Cluster (ID)',
)
cluster = django_filters.ModelMultipleChoiceFilter(
field_name='virtual_machine__cluster__name',
queryset=Cluster.objects.all(),
to_field_name='name',
label='Cluster',
)
virtual_machine_id = django_filters.ModelMultipleChoiceFilter(
2018-11-02 13:46:28 -04:00
field_name='virtual_machine',
queryset=VirtualMachine.objects.all(),
label='Virtual machine (ID)',
)
virtual_machine = django_filters.ModelMultipleChoiceFilter(
2018-11-02 13:46:28 -04:00
field_name='virtual_machine__name',
queryset=VirtualMachine.objects.all(),
to_field_name='name',
label='Virtual machine',
)
mac_address = MultiValueMACAddressFilter(
label='MAC address',
)
tag = TagFilter()
class Meta:
2020-06-23 13:16:21 -04:00
model = VMInterface
fields = ['id', 'name', 'enabled', 'mtu']
def search(self, queryset, name, value):
if not value.strip():
return queryset
return queryset.filter(
Q(name__icontains=value)
)