2017-08-16 17:00:17 -04:00
|
|
|
import django_filters
|
2017-11-07 11:08:23 -05:00
|
|
|
from django.db.models import Q
|
2017-10-09 13:59:53 -04:00
|
|
|
|
2021-03-08 13:28:53 -05:00
|
|
|
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
|
2019-08-15 11:02:40 -04:00
|
|
|
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-08-15 11:02:40 -04:00
|
|
|
)
|
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):
|
2018-03-01 13:22:43 -05:00
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
|
model = ClusterType
|
2020-03-13 16:24:37 -04:00
|
|
|
fields = ['id', 'name', 'slug', 'description']
|
2018-03-01 13:22:43 -05:00
|
|
|
|
|
|
|
|
|
2020-02-09 17:46:21 -05:00
|
|
|
class ClusterGroupFilterSet(BaseFilterSet, NameSlugSearchFilterSet):
|
2018-03-01 13:22:43 -05:00
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
|
model = ClusterGroup
|
2020-03-13 16:24:37 -04:00
|
|
|
fields = ['id', 'name', 'slug', 'description']
|
2018-03-01 13:22:43 -05:00
|
|
|
|
|
|
|
|
|
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',
|
|
|
|
|
)
|
2020-01-03 13:52:50 -05:00
|
|
|
region_id = TreeNodeMultipleChoiceFilter(
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=Region.objects.all(),
|
2020-02-09 17:46:21 -05:00
|
|
|
field_name='site__region',
|
|
|
|
|
lookup_expr='in',
|
2020-01-03 13:52:50 -05:00
|
|
|
label='Region (ID)',
|
|
|
|
|
)
|
|
|
|
|
region = TreeNodeMultipleChoiceFilter(
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=Region.objects.all(),
|
2020-02-09 17:46:21 -05:00
|
|
|
field_name='site__region',
|
|
|
|
|
lookup_expr='in',
|
2020-01-03 13:52:50 -05:00
|
|
|
to_field_name='slug',
|
|
|
|
|
label='Region (slug)',
|
|
|
|
|
)
|
2021-03-08 13:28:53 -05:00
|
|
|
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)',
|
|
|
|
|
)
|
2020-01-03 13:52:50 -05:00
|
|
|
site_id = django_filters.ModelMultipleChoiceFilter(
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=Site.objects.all(),
|
2020-01-03 13:52:50 -05:00
|
|
|
label='Site (ID)',
|
|
|
|
|
)
|
|
|
|
|
site = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
field_name='site__slug',
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=Site.objects.all(),
|
2020-01-03 13:52:50 -05:00
|
|
|
to_field_name='slug',
|
|
|
|
|
label='Site (slug)',
|
|
|
|
|
)
|
2017-10-30 17:20:22 -04:00
|
|
|
group_id = django_filters.ModelMultipleChoiceFilter(
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=ClusterGroup.objects.all(),
|
2017-08-16 17:00:17 -04:00
|
|
|
label='Parent group (ID)',
|
|
|
|
|
)
|
2017-10-30 17:20:22 -04:00
|
|
|
group = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='group__slug',
|
2020-07-23 12:48:03 -04:00
|
|
|
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(
|
2020-07-23 12:48:03 -04:00
|
|
|
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',
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=ClusterType.objects.all(),
|
2017-08-16 17:00:17 -04:00
|
|
|
to_field_name='slug',
|
|
|
|
|
label='Cluster type (slug)',
|
|
|
|
|
)
|
2018-11-12 15:48:58 -05:00
|
|
|
tag = TagFilter()
|
2017-08-16 17:00:17 -04:00
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
|
model = Cluster
|
2020-05-06 12:33:52 -04:00
|
|
|
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)
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
2020-01-13 13:49:22 -05:00
|
|
|
class VirtualMachineFilterSet(
|
2020-02-09 17:46:21 -05:00
|
|
|
BaseFilterSet,
|
2020-01-13 13:49:22 -05:00
|
|
|
LocalConfigContextFilterSet,
|
|
|
|
|
TenancyFilterSet,
|
2020-11-23 14:47:54 -05:00
|
|
|
CustomFieldModelFilterSet,
|
2020-01-13 13:49:22 -05:00
|
|
|
CreatedUpdatedFilterSet
|
|
|
|
|
):
|
2017-08-16 17:00:17 -04:00
|
|
|
q = django_filters.CharFilter(
|
|
|
|
|
method='search',
|
|
|
|
|
label='Search',
|
|
|
|
|
)
|
2017-09-14 14:35:34 -04:00
|
|
|
status = django_filters.MultipleChoiceFilter(
|
2019-12-04 20:40:18 -05:00
|
|
|
choices=VirtualMachineStatusChoices,
|
2017-11-14 12:58:47 -05:00
|
|
|
null_value=None
|
2017-09-14 14:35:34 -04:00
|
|
|
)
|
2017-10-30 17:20:22 -04:00
|
|
|
cluster_group_id = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='cluster__group',
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=ClusterGroup.objects.all(),
|
2017-08-16 17:00:17 -04:00
|
|
|
label='Cluster group (ID)',
|
|
|
|
|
)
|
2017-10-30 17:20:22 -04:00
|
|
|
cluster_group = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='cluster__group__slug',
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=ClusterGroup.objects.all(),
|
2017-08-16 17:00:17 -04:00
|
|
|
to_field_name='slug',
|
|
|
|
|
label='Cluster group (slug)',
|
|
|
|
|
)
|
2017-12-20 14:24:12 -05:00
|
|
|
cluster_type_id = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='cluster__type',
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=ClusterType.objects.all(),
|
2017-12-20 14:24:12 -05:00
|
|
|
label='Cluster type (ID)',
|
|
|
|
|
)
|
|
|
|
|
cluster_type = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='cluster__type__slug',
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=ClusterType.objects.all(),
|
2017-12-20 14:24:12 -05:00
|
|
|
to_field_name='slug',
|
|
|
|
|
label='Cluster type (slug)',
|
|
|
|
|
)
|
2017-09-29 11:13:41 -04:00
|
|
|
cluster_id = django_filters.ModelMultipleChoiceFilter(
|
2020-07-23 12:48:03 -04:00
|
|
|
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(
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=Region.objects.all(),
|
2020-02-09 17:46:21 -05:00
|
|
|
field_name='cluster__site__region',
|
|
|
|
|
lookup_expr='in',
|
2018-11-06 10:31:56 -05:00
|
|
|
label='Region (ID)',
|
|
|
|
|
)
|
2019-03-04 14:57:35 -05:00
|
|
|
region = TreeNodeMultipleChoiceFilter(
|
2020-07-23 12:48:03 -04:00
|
|
|
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',
|
2018-11-06 10:31:56 -05:00
|
|
|
label='Region (slug)',
|
|
|
|
|
)
|
2021-03-08 13:28:53 -05:00
|
|
|
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)',
|
|
|
|
|
)
|
2017-11-27 10:59:24 -05:00
|
|
|
site_id = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='cluster__site',
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=Site.objects.all(),
|
2017-11-27 10:59:24 -05:00
|
|
|
label='Site (ID)',
|
|
|
|
|
)
|
|
|
|
|
site = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='cluster__site__slug',
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=Site.objects.all(),
|
2017-11-27 10:59:24 -05:00
|
|
|
to_field_name='slug',
|
|
|
|
|
label='Site (slug)',
|
|
|
|
|
)
|
2017-10-30 17:20:22 -04:00
|
|
|
role_id = django_filters.ModelMultipleChoiceFilter(
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=DeviceRole.objects.all(),
|
2017-09-29 11:13:41 -04:00
|
|
|
label='Role (ID)',
|
|
|
|
|
)
|
2017-10-30 17:20:22 -04:00
|
|
|
role = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='role__slug',
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=DeviceRole.objects.all(),
|
2017-09-29 11:13:41 -04:00
|
|
|
to_field_name='slug',
|
|
|
|
|
label='Role (slug)',
|
|
|
|
|
)
|
2017-10-30 17:20:22 -04:00
|
|
|
platform_id = django_filters.ModelMultipleChoiceFilter(
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=Platform.objects.all(),
|
2017-08-16 17:00:17 -04:00
|
|
|
label='Platform (ID)',
|
|
|
|
|
)
|
2017-10-30 17:20:22 -04:00
|
|
|
platform = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='platform__slug',
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=Platform.objects.all(),
|
2017-08-16 17:00:17 -04:00
|
|
|
to_field_name='slug',
|
|
|
|
|
label='Platform (slug)',
|
|
|
|
|
)
|
2019-08-15 11:02:40 -04:00
|
|
|
mac_address = MultiValueMACAddressFilter(
|
|
|
|
|
field_name='interfaces__mac_address',
|
|
|
|
|
label='MAC address',
|
|
|
|
|
)
|
2020-10-09 11:46:16 -04:00
|
|
|
has_primary_ip = django_filters.BooleanFilter(
|
|
|
|
|
method='_has_primary_ip',
|
|
|
|
|
label='Has a primary IP',
|
|
|
|
|
)
|
2018-11-12 15:48:58 -05:00
|
|
|
tag = TagFilter()
|
2017-08-16 17:00:17 -04:00
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
|
model = VirtualMachine
|
2019-05-07 13:55:48 -04:00
|
|
|
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)
|
|
|
|
|
)
|
2017-10-09 13:59:53 -04:00
|
|
|
|
2020-10-09 11:46:16 -04:00
|
|
|
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)
|
|
|
|
|
|
2017-10-09 13:59:53 -04:00
|
|
|
|
2021-03-10 13:49:10 -05:00
|
|
|
class VMInterfaceFilterSet(BaseFilterSet, CustomFieldModelFilterSet, CreatedUpdatedFilterSet):
|
2019-01-31 13:36:30 -05:00
|
|
|
q = django_filters.CharFilter(
|
|
|
|
|
method='search',
|
|
|
|
|
label='Search',
|
|
|
|
|
)
|
2020-07-13 15:43:54 -04:00
|
|
|
cluster_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
field_name='virtual_machine__cluster',
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=Cluster.objects.all(),
|
2020-07-13 15:43:54 -04:00
|
|
|
label='Cluster (ID)',
|
|
|
|
|
)
|
|
|
|
|
cluster = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
field_name='virtual_machine__cluster__name',
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=Cluster.objects.all(),
|
2020-07-13 15:43:54 -04:00
|
|
|
to_field_name='name',
|
|
|
|
|
label='Cluster',
|
|
|
|
|
)
|
2017-10-09 13:59:53 -04:00
|
|
|
virtual_machine_id = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='virtual_machine',
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=VirtualMachine.objects.all(),
|
2017-10-09 13:59:53 -04:00
|
|
|
label='Virtual machine (ID)',
|
|
|
|
|
)
|
|
|
|
|
virtual_machine = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='virtual_machine__name',
|
2020-07-23 12:48:03 -04:00
|
|
|
queryset=VirtualMachine.objects.all(),
|
2017-10-09 13:59:53 -04:00
|
|
|
to_field_name='name',
|
|
|
|
|
label='Virtual machine',
|
|
|
|
|
)
|
2020-01-07 10:31:44 -05:00
|
|
|
mac_address = MultiValueMACAddressFilter(
|
2017-10-09 13:59:53 -04:00
|
|
|
label='MAC address',
|
|
|
|
|
)
|
2020-07-21 09:41:00 -04:00
|
|
|
tag = TagFilter()
|
2017-10-09 13:59:53 -04:00
|
|
|
|
|
|
|
|
class Meta:
|
2020-06-23 13:16:21 -04:00
|
|
|
model = VMInterface
|
2019-05-07 13:55:48 -04:00
|
|
|
fields = ['id', 'name', 'enabled', 'mtu']
|
2017-10-09 13:59:53 -04:00
|
|
|
|
2019-01-31 13:36:30 -05:00
|
|
|
def search(self, queryset, name, value):
|
|
|
|
|
if not value.strip():
|
|
|
|
|
return queryset
|
|
|
|
|
return queryset.filter(
|
|
|
|
|
Q(name__icontains=value)
|
|
|
|
|
)
|